mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2024-12-23 12:09:43 +00:00
verify working for solana!
This commit is contained in:
parent
2e9f688775
commit
5eee920289
2 changed files with 36 additions and 7 deletions
|
@ -27,8 +27,11 @@ import 'package:hex/hex.dart';
|
||||||
import 'package:hive/hive.dart';
|
import 'package:hive/hive.dart';
|
||||||
import 'package:mobx/mobx.dart';
|
import 'package:mobx/mobx.dart';
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
|
import 'package:solana/base58.dart';
|
||||||
import 'package:solana/metaplex.dart' as metaplex;
|
import 'package:solana/metaplex.dart' as metaplex;
|
||||||
import 'package:solana/solana.dart';
|
import 'package:solana/solana.dart';
|
||||||
|
import 'package:solana/src/crypto/ed25519_hd_keypair.dart';
|
||||||
|
import 'package:cryptography/cryptography.dart';
|
||||||
|
|
||||||
part 'solana_wallet.g.dart';
|
part 'solana_wallet.g.dart';
|
||||||
|
|
||||||
|
@ -521,21 +524,46 @@ abstract class SolanaWalletBase
|
||||||
|
|
||||||
// Sign the message bytes with the wallet's private key
|
// Sign the message bytes with the wallet's private key
|
||||||
final signature = await _walletKeyPair!.sign(messageBytes);
|
final signature = await _walletKeyPair!.sign(messageBytes);
|
||||||
|
return signature.toString();
|
||||||
// Convert the signature to a hexadecimal string
|
|
||||||
final hex = HEX.encode(signature.bytes);
|
|
||||||
|
|
||||||
return hex;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<String> signMessage(String message, {String? address}) async {
|
Future<String> signMessage(String message, {String? address}) async {
|
||||||
return signSolanaMessage(message);
|
return HEX.encode(utf8.encode(await signSolanaMessage(message))).toUpperCase();
|
||||||
|
}
|
||||||
|
|
||||||
|
List<List<int>> bytesFromSigString(String signatureString) {
|
||||||
|
final regex = RegExp(r'Signature\(\[(.+)\], publicKey: (.+)\)');
|
||||||
|
final match = regex.firstMatch(signatureString);
|
||||||
|
|
||||||
|
if (match != null) {
|
||||||
|
final bytesString = match.group(1)!;
|
||||||
|
final base58EncodedPublicKeyString = match.group(2)!;
|
||||||
|
final sigBytes = bytesString.split(', ').map(int.parse).toList();
|
||||||
|
|
||||||
|
List<int> pubKeyBytes = base58decode(base58EncodedPublicKeyString);
|
||||||
|
|
||||||
|
return [sigBytes, pubKeyBytes];
|
||||||
|
} else {
|
||||||
|
throw const FormatException('Invalid Signature string format');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<bool> verifyMessage(String message, String signature, {String? address}) async {
|
Future<bool> verifyMessage(String message, String signature, {String? address}) async {
|
||||||
throw UnimplementedError();
|
String signatureString = utf8.decode(HEX.decode(signature));
|
||||||
|
|
||||||
|
List<List<int>> bytes = bytesFromSigString(signatureString);
|
||||||
|
|
||||||
|
final messageBytes = utf8.encode(message);
|
||||||
|
final sigBytes = bytes[0];
|
||||||
|
final pubKeyBytes = bytes[1];
|
||||||
|
|
||||||
|
return await verifySignature(
|
||||||
|
message: messageBytes,
|
||||||
|
signature: sigBytes,
|
||||||
|
publicKey: Ed25519HDPublicKey(pubKeyBytes),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
SolanaClient? get solanaClient => _client.getSolanaClient;
|
SolanaClient? get solanaClient => _client.getSolanaClient;
|
||||||
|
|
|
@ -378,6 +378,7 @@ abstract class DashboardViewModelBase with Store {
|
||||||
WalletType.bitcoin,
|
WalletType.bitcoin,
|
||||||
WalletType.bitcoinCash,
|
WalletType.bitcoinCash,
|
||||||
WalletType.ethereum,
|
WalletType.ethereum,
|
||||||
|
WalletType.solana,
|
||||||
].contains(wallet.type);
|
].contains(wallet.type);
|
||||||
|
|
||||||
bool get showRepWarning {
|
bool get showRepWarning {
|
||||||
|
|
Loading…
Reference in a new issue