mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-03 09:29:48 +00:00
d1870ba8b8
* chore: Initial setup for Tron Wallet * feat: Create Tron Wallet base flow implemented, keys, address, receive, restore and proxy classes all setup * feat: Display seed and key within the app * feat: Activate restore from key and seed for Tron wallet * feat: Add icon for tron wallet in wallet listing page * feat: Activate display of receive address for tron * feat: Fetch and display tron balance, sending transaction flow setup, fee limit calculation setup * feat: Implement sending of native tron, setup sending of trc20 tokens * chore: Rename function * Delete lib/tron/tron.dart * feat: Activate exchange for tron and its tokens, implement balance display for trc20 tokens and setup secrets configuration for tron * feat: Implement tron token management, add, remove, delete, and get tokens in home settings view, also minor cleanup * feat: Activate buy and sell for tron * feat: Implement restore from QR, transactions history listing for both native transactions and trc20 transactions * feat: Activate send all and do some minor cleanups * chore: Fix some lint infos and warnings * chore: Adjust configurations * ci: Modify CI to create and add secrets for node * fix: Fixes made while self reviewing the PR for this feature * feat: Add guide for adding new wallet types, and add fixes to requested changes * fix: Handle exceptions gracefully * fix: Alternative for trc20 estimated fee * fix: Fixes to display of amount and fee, removing clashes * fix: Fee calculation WIP * fix: Fix issue with handling of send all flow and display of amount and fee values before broadcasting transaction * fix: PR review fixes and fix merge conflicts * fix: Modify fetching assetOfTransaction [skip ci] * fix: Move tron settings migration to 33
97 lines
2.3 KiB
Dart
97 lines
2.3 KiB
Dart
import 'dart:convert';
|
|
import 'dart:io';
|
|
import 'utils/secret_key.dart';
|
|
import 'utils/utils.dart';
|
|
|
|
const configPath = 'tool/.secrets-config.json';
|
|
const evmChainsConfigPath = 'tool/.evm-secrets-config.json';
|
|
const solanaConfigPath = 'tool/.solana-secrets-config.json';
|
|
const tronConfigPath = 'tool/.tron-secrets-config.json';
|
|
|
|
Future<void> main(List<String> args) async => generateSecretsConfig(args);
|
|
|
|
Future<void> generateSecretsConfig(List<String> args) async {
|
|
final extraInfo = args.fold(<String, dynamic>{}, (Map<String, dynamic> acc, String arg) {
|
|
final parts = arg.split('=');
|
|
final key = normalizeKeyName(parts[0]);
|
|
acc[key] = acc[key] = parts.length > 1 ? parts[1] : 1;
|
|
return acc;
|
|
});
|
|
|
|
final configFile = File(configPath);
|
|
final evmChainsConfigFile = File(evmChainsConfigPath);
|
|
final solanaConfigFile = File(solanaConfigPath);
|
|
final tronConfigFile = File(tronConfigPath);
|
|
|
|
final secrets = <String, dynamic>{};
|
|
|
|
secrets.addAll(extraInfo);
|
|
secrets.removeWhere((key, dynamic value) {
|
|
if (key.contains('--')) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
});
|
|
|
|
if (configFile.existsSync()) {
|
|
if (extraInfo['--force'] == 1) {
|
|
await configFile.delete();
|
|
} else {
|
|
return;
|
|
}
|
|
}
|
|
|
|
SecretKey.base.forEach((sec) {
|
|
if (secrets[sec.name] != null) {
|
|
return;
|
|
}
|
|
|
|
secrets[sec.name] = sec.generate();
|
|
});
|
|
|
|
var secretsJson = JsonEncoder.withIndent(' ').convert(secrets);
|
|
await configFile.writeAsString(secretsJson);
|
|
|
|
secrets.clear();
|
|
|
|
SecretKey.evmChainsSecrets.forEach((sec) {
|
|
if (secrets[sec.name] != null) {
|
|
return;
|
|
}
|
|
|
|
secrets[sec.name] = sec.generate();
|
|
});
|
|
|
|
secretsJson = JsonEncoder.withIndent(' ').convert(secrets);
|
|
|
|
await evmChainsConfigFile.writeAsString(secretsJson);
|
|
|
|
secrets.clear();
|
|
|
|
SecretKey.solanaSecrets.forEach((sec) {
|
|
if (secrets[sec.name] != null) {
|
|
return;
|
|
}
|
|
|
|
secrets[sec.name] = sec.generate();
|
|
});
|
|
|
|
secretsJson = JsonEncoder.withIndent(' ').convert(secrets);
|
|
|
|
await solanaConfigFile.writeAsString(secretsJson);
|
|
|
|
secrets.clear();
|
|
|
|
SecretKey.tronSecrets.forEach((sec) {
|
|
if (secrets[sec.name] != null) {
|
|
return;
|
|
}
|
|
|
|
secrets[sec.name] = sec.generate();
|
|
});
|
|
|
|
secretsJson = JsonEncoder.withIndent(' ').convert(secrets);
|
|
|
|
await tronConfigFile.writeAsString(secretsJson);
|
|
}
|