mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-25 12:06:05 +00:00
Add primary receive address extracted from private key
This commit is contained in:
parent
713ea83229
commit
73680a96e2
4 changed files with 42 additions and 9 deletions
|
@ -40,6 +40,7 @@ abstract class EthereumWalletBase
|
||||||
super(walletInfo) {
|
super(walletInfo) {
|
||||||
this.walletInfo = walletInfo;
|
this.walletInfo = walletInfo;
|
||||||
transactionHistory = EthereumTransactionHistory();
|
transactionHistory = EthereumTransactionHistory();
|
||||||
|
walletAddresses.address = EthPrivateKey.fromHex(privateKey).address.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
final String mnemonic;
|
final String mnemonic;
|
||||||
|
|
|
@ -11,6 +11,9 @@ class CWEthereum extends Ethereum {
|
||||||
WalletCredentials createEthereumNewWalletCredentials({
|
WalletCredentials createEthereumNewWalletCredentials({
|
||||||
required String name,
|
required String name,
|
||||||
WalletInfo? walletInfo,
|
WalletInfo? walletInfo,
|
||||||
}) =>
|
}) {
|
||||||
EthereumNewWalletCredentials(name: name, walletInfo: walletInfo);
|
return EthereumNewWalletCredentials(name: name, walletInfo: walletInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
String getAddress(WalletBase wallet) => (wallet as EthereumWallet).walletAddresses.address;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
|
import 'package:cake_wallet/ethereum/ethereum.dart';
|
||||||
import 'package:cake_wallet/store/yat/yat_store.dart';
|
import 'package:cake_wallet/store/yat/yat_store.dart';
|
||||||
import 'package:flutter/foundation.dart';
|
|
||||||
import 'package:mobx/mobx.dart';
|
import 'package:mobx/mobx.dart';
|
||||||
import 'package:cw_core/wallet_base.dart';
|
import 'package:cw_core/wallet_base.dart';
|
||||||
import 'package:cake_wallet/utils/list_item.dart';
|
import 'package:cake_wallet/utils/list_item.dart';
|
||||||
|
@ -11,9 +11,7 @@ import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
||||||
import 'package:cw_core/transaction_history.dart';
|
import 'package:cw_core/transaction_history.dart';
|
||||||
import 'package:cw_core/balance.dart';
|
import 'package:cw_core/balance.dart';
|
||||||
import 'package:cw_core/transaction_info.dart';
|
import 'package:cw_core/transaction_info.dart';
|
||||||
import 'package:cw_core/wallet_type.dart';
|
|
||||||
import 'package:cake_wallet/store/app_store.dart';
|
import 'package:cake_wallet/store/app_store.dart';
|
||||||
import 'dart:async';
|
|
||||||
import 'package:cake_wallet/monero/monero.dart';
|
import 'package:cake_wallet/monero/monero.dart';
|
||||||
import 'package:cake_wallet/haven/haven.dart';
|
import 'package:cake_wallet/haven/haven.dart';
|
||||||
|
|
||||||
|
@ -41,7 +39,7 @@ class MoneroURI extends PaymentURI {
|
||||||
String toString() {
|
String toString() {
|
||||||
var base = 'monero:' + address;
|
var base = 'monero:' + address;
|
||||||
|
|
||||||
if (amount?.isNotEmpty ?? false) {
|
if (amount.isNotEmpty) {
|
||||||
base += '?tx_amount=${amount.replaceAll(',', '.')}';
|
base += '?tx_amount=${amount.replaceAll(',', '.')}';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +57,7 @@ class HavenURI extends PaymentURI {
|
||||||
String toString() {
|
String toString() {
|
||||||
var base = 'haven:' + address;
|
var base = 'haven:' + address;
|
||||||
|
|
||||||
if (amount?.isNotEmpty ?? false) {
|
if (amount.isNotEmpty) {
|
||||||
base += '?tx_amount=${amount.replaceAll(',', '.')}';
|
base += '?tx_amount=${amount.replaceAll(',', '.')}';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +75,7 @@ class BitcoinURI extends PaymentURI {
|
||||||
String toString() {
|
String toString() {
|
||||||
var base = 'bitcoin:' + address;
|
var base = 'bitcoin:' + address;
|
||||||
|
|
||||||
if (amount?.isNotEmpty ?? false) {
|
if (amount.isNotEmpty) {
|
||||||
base += '?amount=${amount.replaceAll(',', '.')}';
|
base += '?amount=${amount.replaceAll(',', '.')}';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,7 +93,25 @@ class LitecoinURI extends PaymentURI {
|
||||||
String toString() {
|
String toString() {
|
||||||
var base = 'litecoin:' + address;
|
var base = 'litecoin:' + address;
|
||||||
|
|
||||||
if (amount?.isNotEmpty ?? false) {
|
if (amount.isNotEmpty) {
|
||||||
|
base += '?amount=${amount.replaceAll(',', '.')}';
|
||||||
|
}
|
||||||
|
|
||||||
|
return base;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class EthereumURI extends PaymentURI {
|
||||||
|
EthereumURI({
|
||||||
|
required String amount,
|
||||||
|
required String address})
|
||||||
|
: super(amount: amount, address: address);
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
var base = 'ethereum:' + address;
|
||||||
|
|
||||||
|
if (amount.isNotEmpty) {
|
||||||
base += '?amount=${amount.replaceAll(',', '.')}';
|
base += '?amount=${amount.replaceAll(',', '.')}';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -152,6 +168,10 @@ abstract class WalletAddressListViewModelBase with Store {
|
||||||
return LitecoinURI(amount: amount, address: address.address);
|
return LitecoinURI(amount: amount, address: address.address);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (_wallet.type == WalletType.ethereum) {
|
||||||
|
return EthereumURI(amount: amount, address: address.address);
|
||||||
|
}
|
||||||
|
|
||||||
throw Exception('Unexpected type: ${type.toString()}');
|
throw Exception('Unexpected type: ${type.toString()}');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,6 +229,12 @@ abstract class WalletAddressListViewModelBase with Store {
|
||||||
addressList.addAll(bitcoinAddresses);
|
addressList.addAll(bitcoinAddresses);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (wallet.type == WalletType.ethereum) {
|
||||||
|
final primaryAddress = ethereum!.getAddress(wallet);
|
||||||
|
|
||||||
|
addressList.add(WalletAddressListItem(isPrimary: true, name: null, address: primaryAddress));
|
||||||
|
}
|
||||||
|
|
||||||
return addressList;
|
return addressList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -477,10 +477,12 @@ Future<void> generateEthereum(bool hasImplementation) async {
|
||||||
const ethereumCommonHeaders = """
|
const ethereumCommonHeaders = """
|
||||||
""";
|
""";
|
||||||
const ethereumCWHeaders = """
|
const ethereumCWHeaders = """
|
||||||
|
import 'package:cw_core/wallet_base.dart';
|
||||||
import 'package:cw_core/wallet_credentials.dart';
|
import 'package:cw_core/wallet_credentials.dart';
|
||||||
import 'package:cw_core/wallet_info.dart';
|
import 'package:cw_core/wallet_info.dart';
|
||||||
import 'package:cw_core/wallet_service.dart';
|
import 'package:cw_core/wallet_service.dart';
|
||||||
import 'package:cw_ethereum/ethereum_mnemonics.dart';
|
import 'package:cw_ethereum/ethereum_mnemonics.dart';
|
||||||
|
import 'package:cw_ethereum/ethereum_wallet.dart';
|
||||||
import 'package:cw_ethereum/ethereum_wallet_creation_credentials.dart';
|
import 'package:cw_ethereum/ethereum_wallet_creation_credentials.dart';
|
||||||
import 'package:cw_ethereum/ethereum_wallet_service.dart';
|
import 'package:cw_ethereum/ethereum_wallet_service.dart';
|
||||||
import 'package:hive/hive.dart';
|
import 'package:hive/hive.dart';
|
||||||
|
@ -491,6 +493,7 @@ abstract class Ethereum {
|
||||||
List<String> getEthereumWordList(String language);
|
List<String> getEthereumWordList(String language);
|
||||||
WalletService createEthereumWalletService(Box<WalletInfo> walletInfoSource);
|
WalletService createEthereumWalletService(Box<WalletInfo> walletInfoSource);
|
||||||
WalletCredentials createEthereumNewWalletCredentials({required String name, WalletInfo? walletInfo});
|
WalletCredentials createEthereumNewWalletCredentials({required String name, WalletInfo? walletInfo});
|
||||||
|
String getAddress(WalletBase wallet);
|
||||||
}
|
}
|
||||||
""";
|
""";
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue