2023-02-01 15:37:18 +00:00
|
|
|
import 'dart:io';
|
|
|
|
|
2024-12-10 12:06:56 +00:00
|
|
|
import 'package:cake_wallet/di.dart';
|
2023-02-07 14:53:57 +00:00
|
|
|
import 'package:cake_wallet/entities/preferences_key.dart';
|
2023-02-01 15:37:18 +00:00
|
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
|
|
import 'package:cake_wallet/main.dart';
|
|
|
|
import 'package:cake_wallet/src/widgets/alert_with_two_actions.dart';
|
2024-12-10 12:06:56 +00:00
|
|
|
import 'package:cake_wallet/store/app_store.dart';
|
2024-08-06 14:59:44 +00:00
|
|
|
import 'package:cake_wallet/utils/show_bar.dart';
|
2023-02-01 15:37:18 +00:00
|
|
|
import 'package:cake_wallet/utils/show_pop_up.dart';
|
Wownero (#1485)
* fix: scanning issues
* fix: sync, storing silent unspents
* chore: deps
* fix: label issues, clear spent utxo
* chore: deps
* fix: build
* fix: missing types
* feat: new electrs API & changes, fixes for last block scanning
* feat: Scan Silent Payments homepage toggle
* chore: build configure
* feat: generic fixes, testnet UI improvements, useSSL on bitcoin nodes
* fix: invalid Object in sendData
* feat: improve addresses page & address book displays
* feat: silent payments labeled addresses disclaimer
* fix: missing i18n
* chore: print
* feat: single block scan, rescan by date working for btc mainnet
* feat: new cake features page replace market page, move sp scan toggle, auto switch node pop up alert
* feat: delete silent addresses
* fix: red dot in non ssl nodes
* fix: inconsistent connection states, fix tx history
* fix: tx & balance displays, cpfp sending
* feat: new rust lib
* chore: node path
* fix: check node based on network
* fix: missing txcount from addresses
* style: padding in feature page cards
* fix: restore not getting all wallet addresses by type
* fix: auto switch node broken
* fix: silent payment txs not being restored
* feat: change scanning to subscription model, sync improvements
* fix: scan re-subscription
* fix: default nodes
* fix: improve scanning by date, fix single block scan
* refactor: common function for input tx selection
* various fixes for build issues
* initial monero.dart implementation
* ...
* multiple wallets
new lib
minor fixes
* other fixes from monero.dart and monero_c
* fix: nodes & build
* update build scripts
fix polyseed
* remove unnecessary code
* Add windows app, build scripts and build guide for it.
* Minor fix in generated monero configs
* fix: send all with multiple outs
* add missing monero_c command
* add android build script
* Merge and fix main
* undo android ndk removal
* Fix modified exception_handler.dart
* Temporarily remove haven
* fix build issues
* fix pr script
* Fixes for build monero.dart (monero_c) for windows.
* monero build script
* wip: ios build script
* refactor: unchanged file
* Added build guides for iOS and macOS. Replaced nproc call on macOS. Added macOS configuration for configure_cake_wallet.sh script.
* Update monero.dart and monero_c versions.
* Add missed windows build scripts
* Update the application configuration for windows build script.
* Update cw_monero pubspec lock file for monero.dart
* Update pr_test_build.yml
* chore: upgrade
* chore: merge changes
* refactor: unchanged files [skip ci]
* Fix conflicts with main
* fix for multiple wallets
* Add tron to windows application configuration.
* Add macOS option for description message in configure_cake_wallet.sh
* Include missed monero dll for windows.
* fix conflicts with main
* Disable haven configuration for iOS as default. Add ability to configure cakewallet for iOS with for configuration script. Remove cw_shared configuration for cw_monero.
* fix: scan fixes, add date, allow sending while scanning
* add missing nano secrets file [skip ci]
* ios library
* don't pull prebuilds android
* Add auto generation of manifest file for android project even for iOS, macOS, Windows.
* feat: sync fixes, sp settings
* feat: fix resyncing
* store crash fix
* make init async so it won't lag
disable print starts
* fix monero_c build issues
* libstdc++
* Fix MacOS saving wallet file issue
Fix Secure Storage issue (somehow)
* update pubspec.lock
* fix build script
* Use dylib as iOS framework. Use custom path for loading of iOS framework for monero.dart. Add script for generate iOS framework for monero wallet.
* fix: date from height logic, status disconnected & chain tip get
* fix: params
* feat: electrum migration if using cake electrum
* fix nodes
update versions
* re-enable tron
* update sp_scanner to work on iOS [skip ci]
* bump monero_c hash
* bump monero_c commit
* bump moneroc version
* bump monero_c commit
* Add ability to build monero wallet lib as universal lib. Update macOS build guide. Change default arch for macOS project to .
* fix: wrong socket for old electrum nodes
* Fix unchecked wallet type call
* get App Dir correctly in default_settings_migration.dart
* handle previous issue with fetching linux documents directory [skip ci]
* backup fix
* fix NTFS issues
* Close the wallet when the wallet gets changed
* fix: double balance
* feat: node domain
* fix: menu name
* bump monero_c commit
* fix: update tip on set scanning
* fix: connection switching back and forth
* feat: check if node is electrs, and supports sp
* chore: fix build
* minor enhancements
* fixes and enhancements
* solve conflicts with main
* Only stop wallet on rename and delete
* fix: status toggle
* minor enhancement
* Monero.com fixes
* bump monero_c commit
* update sp_scanner to include windows and linux
* Update macOS build guide. Change brew dependencies for build unbound locally.
* fix conflicts and update macos build guide
* remove build cache when on gh actions
* update secure storage
* free up even more storage
* free up more storage
* Add initial wownero
* fix conflicts
* fix workflow issue
* build wownero
* ios and windows changes
* macos
* complete wownero flow (app side)
* add keychain group entitlement and update script for RunnerBase on macos
* update secure_storage version to 8.1.0 in configure.dart
* add wownero framework
* update ios builds
* proper path for wownero and monero
* finalizing wownero
* finalizing wownero
* free up even more storage
* revert commenting of build gradle configs
* revert commenting of secrets [skip ci]
* free more storage
* minor fixes
* link android wownero libraries
* bump monero_c commit
* wownero fixes
* rename target
* build_single.sh using clean env
* bump monero_c commit
* minor fix
* Add wownero polyseed
* fix conflicts with main
* fix: wallet seed display
fix: wownero not refreshing
* fix: wallet seed display
fix: wownero not refreshing
* bump monero_c commit
* minor fixes
* fix: incorrectly displaying XMR instead of WOW
* fix: incorrect restore height in wownero
* bump monero_c commit
* Add Inno Setup Script for windows exe installer
* drop libc++_shared.so
* fixes from comments
* Fix CMake for windows
* Merge latest monero dart changes [skip ci]
* bump monero_c commit
* add wownero to build scripts for macos [skip ci]
* add 14 word seed support to wownero
* UI fixes for wownero seed restore
* minor fixes
* reformat code to pass lints
* wownero: fixes
haven: removal popup
* minor iOS fix [skip ci]
* fix: wownero confirmation count (it is spendable after 3 confirms)
fix: transaction history not displaying in WOW and XMR
when tx has 0 confirms,
This is more of a workaround, because I have no idea
why would the cpp code not return pending transaction.
* Update preferences_key.dart [skip ci]
* minor fixes
---------
Co-authored-by: Rafael Saes <git@rafael.saes.dev>
Co-authored-by: Czarek Nakamoto <cyjan@mrcyjanek.net>
Co-authored-by: M <m@cakewallet.com>
Co-authored-by: Konstantin Ullrich <konstantinullrich12@gmail.com>
Co-authored-by: Matthew Fosse <matt@fosse.co>
2024-07-04 19:43:17 +00:00
|
|
|
import 'package:cw_core/root_dir.dart';
|
2024-12-09 18:23:59 +00:00
|
|
|
import 'package:cw_core/utils/print_verbose.dart';
|
2023-02-20 20:17:41 +00:00
|
|
|
import 'package:device_info_plus/device_info_plus.dart';
|
2023-02-06 16:33:12 +00:00
|
|
|
import 'package:flutter/foundation.dart';
|
2023-02-01 15:37:18 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2024-08-06 14:59:44 +00:00
|
|
|
import 'package:flutter/services.dart';
|
2023-02-01 15:37:18 +00:00
|
|
|
import 'package:flutter_mailer/flutter_mailer.dart';
|
Wownero (#1485)
* fix: scanning issues
* fix: sync, storing silent unspents
* chore: deps
* fix: label issues, clear spent utxo
* chore: deps
* fix: build
* fix: missing types
* feat: new electrs API & changes, fixes for last block scanning
* feat: Scan Silent Payments homepage toggle
* chore: build configure
* feat: generic fixes, testnet UI improvements, useSSL on bitcoin nodes
* fix: invalid Object in sendData
* feat: improve addresses page & address book displays
* feat: silent payments labeled addresses disclaimer
* fix: missing i18n
* chore: print
* feat: single block scan, rescan by date working for btc mainnet
* feat: new cake features page replace market page, move sp scan toggle, auto switch node pop up alert
* feat: delete silent addresses
* fix: red dot in non ssl nodes
* fix: inconsistent connection states, fix tx history
* fix: tx & balance displays, cpfp sending
* feat: new rust lib
* chore: node path
* fix: check node based on network
* fix: missing txcount from addresses
* style: padding in feature page cards
* fix: restore not getting all wallet addresses by type
* fix: auto switch node broken
* fix: silent payment txs not being restored
* feat: change scanning to subscription model, sync improvements
* fix: scan re-subscription
* fix: default nodes
* fix: improve scanning by date, fix single block scan
* refactor: common function for input tx selection
* various fixes for build issues
* initial monero.dart implementation
* ...
* multiple wallets
new lib
minor fixes
* other fixes from monero.dart and monero_c
* fix: nodes & build
* update build scripts
fix polyseed
* remove unnecessary code
* Add windows app, build scripts and build guide for it.
* Minor fix in generated monero configs
* fix: send all with multiple outs
* add missing monero_c command
* add android build script
* Merge and fix main
* undo android ndk removal
* Fix modified exception_handler.dart
* Temporarily remove haven
* fix build issues
* fix pr script
* Fixes for build monero.dart (monero_c) for windows.
* monero build script
* wip: ios build script
* refactor: unchanged file
* Added build guides for iOS and macOS. Replaced nproc call on macOS. Added macOS configuration for configure_cake_wallet.sh script.
* Update monero.dart and monero_c versions.
* Add missed windows build scripts
* Update the application configuration for windows build script.
* Update cw_monero pubspec lock file for monero.dart
* Update pr_test_build.yml
* chore: upgrade
* chore: merge changes
* refactor: unchanged files [skip ci]
* Fix conflicts with main
* fix for multiple wallets
* Add tron to windows application configuration.
* Add macOS option for description message in configure_cake_wallet.sh
* Include missed monero dll for windows.
* fix conflicts with main
* Disable haven configuration for iOS as default. Add ability to configure cakewallet for iOS with for configuration script. Remove cw_shared configuration for cw_monero.
* fix: scan fixes, add date, allow sending while scanning
* add missing nano secrets file [skip ci]
* ios library
* don't pull prebuilds android
* Add auto generation of manifest file for android project even for iOS, macOS, Windows.
* feat: sync fixes, sp settings
* feat: fix resyncing
* store crash fix
* make init async so it won't lag
disable print starts
* fix monero_c build issues
* libstdc++
* Fix MacOS saving wallet file issue
Fix Secure Storage issue (somehow)
* update pubspec.lock
* fix build script
* Use dylib as iOS framework. Use custom path for loading of iOS framework for monero.dart. Add script for generate iOS framework for monero wallet.
* fix: date from height logic, status disconnected & chain tip get
* fix: params
* feat: electrum migration if using cake electrum
* fix nodes
update versions
* re-enable tron
* update sp_scanner to work on iOS [skip ci]
* bump monero_c hash
* bump monero_c commit
* bump moneroc version
* bump monero_c commit
* Add ability to build monero wallet lib as universal lib. Update macOS build guide. Change default arch for macOS project to .
* fix: wrong socket for old electrum nodes
* Fix unchecked wallet type call
* get App Dir correctly in default_settings_migration.dart
* handle previous issue with fetching linux documents directory [skip ci]
* backup fix
* fix NTFS issues
* Close the wallet when the wallet gets changed
* fix: double balance
* feat: node domain
* fix: menu name
* bump monero_c commit
* fix: update tip on set scanning
* fix: connection switching back and forth
* feat: check if node is electrs, and supports sp
* chore: fix build
* minor enhancements
* fixes and enhancements
* solve conflicts with main
* Only stop wallet on rename and delete
* fix: status toggle
* minor enhancement
* Monero.com fixes
* bump monero_c commit
* update sp_scanner to include windows and linux
* Update macOS build guide. Change brew dependencies for build unbound locally.
* fix conflicts and update macos build guide
* remove build cache when on gh actions
* update secure storage
* free up even more storage
* free up more storage
* Add initial wownero
* fix conflicts
* fix workflow issue
* build wownero
* ios and windows changes
* macos
* complete wownero flow (app side)
* add keychain group entitlement and update script for RunnerBase on macos
* update secure_storage version to 8.1.0 in configure.dart
* add wownero framework
* update ios builds
* proper path for wownero and monero
* finalizing wownero
* finalizing wownero
* free up even more storage
* revert commenting of build gradle configs
* revert commenting of secrets [skip ci]
* free more storage
* minor fixes
* link android wownero libraries
* bump monero_c commit
* wownero fixes
* rename target
* build_single.sh using clean env
* bump monero_c commit
* minor fix
* Add wownero polyseed
* fix conflicts with main
* fix: wallet seed display
fix: wownero not refreshing
* fix: wallet seed display
fix: wownero not refreshing
* bump monero_c commit
* minor fixes
* fix: incorrectly displaying XMR instead of WOW
* fix: incorrect restore height in wownero
* bump monero_c commit
* Add Inno Setup Script for windows exe installer
* drop libc++_shared.so
* fixes from comments
* Fix CMake for windows
* Merge latest monero dart changes [skip ci]
* bump monero_c commit
* add wownero to build scripts for macos [skip ci]
* add 14 word seed support to wownero
* UI fixes for wownero seed restore
* minor fixes
* reformat code to pass lints
* wownero: fixes
haven: removal popup
* minor iOS fix [skip ci]
* fix: wownero confirmation count (it is spendable after 3 confirms)
fix: transaction history not displaying in WOW and XMR
when tx has 0 confirms,
This is more of a workaround, because I have no idea
why would the cpp code not return pending transaction.
* Update preferences_key.dart [skip ci]
* minor fixes
---------
Co-authored-by: Rafael Saes <git@rafael.saes.dev>
Co-authored-by: Czarek Nakamoto <cyjan@mrcyjanek.net>
Co-authored-by: M <m@cakewallet.com>
Co-authored-by: Konstantin Ullrich <konstantinullrich12@gmail.com>
Co-authored-by: Matthew Fosse <matt@fosse.co>
2024-07-04 19:43:17 +00:00
|
|
|
import 'package:cake_wallet/utils/package_info.dart';
|
2023-02-07 14:53:57 +00:00
|
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
2023-02-01 15:37:18 +00:00
|
|
|
|
|
|
|
class ExceptionHandler {
|
|
|
|
static bool _hasError = false;
|
2023-02-08 18:47:23 +00:00
|
|
|
static const _coolDownDurationInDays = 7;
|
2024-02-06 20:44:21 +00:00
|
|
|
static File? _file;
|
2023-02-01 15:37:18 +00:00
|
|
|
|
2024-12-09 12:25:36 +00:00
|
|
|
static Future<void> _saveException(String? error, StackTrace? stackTrace,
|
|
|
|
{String? library}) async {
|
2024-09-23 14:10:40 +00:00
|
|
|
final appDocDir = await getAppDir();
|
2024-02-06 20:44:21 +00:00
|
|
|
|
2024-09-23 14:10:40 +00:00
|
|
|
if (_file == null) {
|
2024-02-06 20:44:21 +00:00
|
|
|
_file = File('${appDocDir.path}/error.txt');
|
|
|
|
}
|
2023-02-01 15:37:18 +00:00
|
|
|
|
2024-12-10 12:06:56 +00:00
|
|
|
String? walletType;
|
|
|
|
CustomTrace? programInfo;
|
|
|
|
|
|
|
|
try {
|
|
|
|
walletType = getIt.get<AppStore>().wallet?.type.name;
|
|
|
|
|
|
|
|
programInfo = CustomTrace(stackTrace ?? StackTrace.current);
|
|
|
|
} catch (_) {}
|
|
|
|
|
2023-02-01 15:37:18 +00:00
|
|
|
final exception = {
|
|
|
|
"${DateTime.now()}": {
|
2023-03-17 19:15:28 +00:00
|
|
|
"Error": "$error\n\n",
|
2024-12-10 12:06:56 +00:00
|
|
|
"WalletType": "$walletType\n\n",
|
|
|
|
"VerboseLog":
|
|
|
|
"${programInfo?.fileName}#${programInfo?.lineNumber}:${programInfo?.columnNumber} ${programInfo?.callerFunctionName}\n\n",
|
2023-03-17 19:15:28 +00:00
|
|
|
"Library": "$library\n\n",
|
2023-02-01 15:37:18 +00:00
|
|
|
"StackTrace": stackTrace.toString(),
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const String separator = '''\n\n==========================================================
|
|
|
|
==========================================================\n\n''';
|
|
|
|
|
2023-09-14 19:14:16 +00:00
|
|
|
/// don't save existing errors
|
2024-02-06 20:44:21 +00:00
|
|
|
if (_file!.existsSync()) {
|
|
|
|
final String fileContent = await _file!.readAsString();
|
2023-09-14 19:14:16 +00:00
|
|
|
if (fileContent.contains("${exception.values.first}")) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-06 20:44:21 +00:00
|
|
|
_file!.writeAsStringSync(
|
2023-02-20 20:17:41 +00:00
|
|
|
"$exception $separator",
|
2023-02-01 15:37:18 +00:00
|
|
|
mode: FileMode.append,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void _sendExceptionFile() async {
|
|
|
|
try {
|
2024-02-06 20:44:21 +00:00
|
|
|
if (_file == null) {
|
Wownero (#1485)
* fix: scanning issues
* fix: sync, storing silent unspents
* chore: deps
* fix: label issues, clear spent utxo
* chore: deps
* fix: build
* fix: missing types
* feat: new electrs API & changes, fixes for last block scanning
* feat: Scan Silent Payments homepage toggle
* chore: build configure
* feat: generic fixes, testnet UI improvements, useSSL on bitcoin nodes
* fix: invalid Object in sendData
* feat: improve addresses page & address book displays
* feat: silent payments labeled addresses disclaimer
* fix: missing i18n
* chore: print
* feat: single block scan, rescan by date working for btc mainnet
* feat: new cake features page replace market page, move sp scan toggle, auto switch node pop up alert
* feat: delete silent addresses
* fix: red dot in non ssl nodes
* fix: inconsistent connection states, fix tx history
* fix: tx & balance displays, cpfp sending
* feat: new rust lib
* chore: node path
* fix: check node based on network
* fix: missing txcount from addresses
* style: padding in feature page cards
* fix: restore not getting all wallet addresses by type
* fix: auto switch node broken
* fix: silent payment txs not being restored
* feat: change scanning to subscription model, sync improvements
* fix: scan re-subscription
* fix: default nodes
* fix: improve scanning by date, fix single block scan
* refactor: common function for input tx selection
* various fixes for build issues
* initial monero.dart implementation
* ...
* multiple wallets
new lib
minor fixes
* other fixes from monero.dart and monero_c
* fix: nodes & build
* update build scripts
fix polyseed
* remove unnecessary code
* Add windows app, build scripts and build guide for it.
* Minor fix in generated monero configs
* fix: send all with multiple outs
* add missing monero_c command
* add android build script
* Merge and fix main
* undo android ndk removal
* Fix modified exception_handler.dart
* Temporarily remove haven
* fix build issues
* fix pr script
* Fixes for build monero.dart (monero_c) for windows.
* monero build script
* wip: ios build script
* refactor: unchanged file
* Added build guides for iOS and macOS. Replaced nproc call on macOS. Added macOS configuration for configure_cake_wallet.sh script.
* Update monero.dart and monero_c versions.
* Add missed windows build scripts
* Update the application configuration for windows build script.
* Update cw_monero pubspec lock file for monero.dart
* Update pr_test_build.yml
* chore: upgrade
* chore: merge changes
* refactor: unchanged files [skip ci]
* Fix conflicts with main
* fix for multiple wallets
* Add tron to windows application configuration.
* Add macOS option for description message in configure_cake_wallet.sh
* Include missed monero dll for windows.
* fix conflicts with main
* Disable haven configuration for iOS as default. Add ability to configure cakewallet for iOS with for configuration script. Remove cw_shared configuration for cw_monero.
* fix: scan fixes, add date, allow sending while scanning
* add missing nano secrets file [skip ci]
* ios library
* don't pull prebuilds android
* Add auto generation of manifest file for android project even for iOS, macOS, Windows.
* feat: sync fixes, sp settings
* feat: fix resyncing
* store crash fix
* make init async so it won't lag
disable print starts
* fix monero_c build issues
* libstdc++
* Fix MacOS saving wallet file issue
Fix Secure Storage issue (somehow)
* update pubspec.lock
* fix build script
* Use dylib as iOS framework. Use custom path for loading of iOS framework for monero.dart. Add script for generate iOS framework for monero wallet.
* fix: date from height logic, status disconnected & chain tip get
* fix: params
* feat: electrum migration if using cake electrum
* fix nodes
update versions
* re-enable tron
* update sp_scanner to work on iOS [skip ci]
* bump monero_c hash
* bump monero_c commit
* bump moneroc version
* bump monero_c commit
* Add ability to build monero wallet lib as universal lib. Update macOS build guide. Change default arch for macOS project to .
* fix: wrong socket for old electrum nodes
* Fix unchecked wallet type call
* get App Dir correctly in default_settings_migration.dart
* handle previous issue with fetching linux documents directory [skip ci]
* backup fix
* fix NTFS issues
* Close the wallet when the wallet gets changed
* fix: double balance
* feat: node domain
* fix: menu name
* bump monero_c commit
* fix: update tip on set scanning
* fix: connection switching back and forth
* feat: check if node is electrs, and supports sp
* chore: fix build
* minor enhancements
* fixes and enhancements
* solve conflicts with main
* Only stop wallet on rename and delete
* fix: status toggle
* minor enhancement
* Monero.com fixes
* bump monero_c commit
* update sp_scanner to include windows and linux
* Update macOS build guide. Change brew dependencies for build unbound locally.
* fix conflicts and update macos build guide
* remove build cache when on gh actions
* update secure storage
* free up even more storage
* free up more storage
* Add initial wownero
* fix conflicts
* fix workflow issue
* build wownero
* ios and windows changes
* macos
* complete wownero flow (app side)
* add keychain group entitlement and update script for RunnerBase on macos
* update secure_storage version to 8.1.0 in configure.dart
* add wownero framework
* update ios builds
* proper path for wownero and monero
* finalizing wownero
* finalizing wownero
* free up even more storage
* revert commenting of build gradle configs
* revert commenting of secrets [skip ci]
* free more storage
* minor fixes
* link android wownero libraries
* bump monero_c commit
* wownero fixes
* rename target
* build_single.sh using clean env
* bump monero_c commit
* minor fix
* Add wownero polyseed
* fix conflicts with main
* fix: wallet seed display
fix: wownero not refreshing
* fix: wallet seed display
fix: wownero not refreshing
* bump monero_c commit
* minor fixes
* fix: incorrectly displaying XMR instead of WOW
* fix: incorrect restore height in wownero
* bump monero_c commit
* Add Inno Setup Script for windows exe installer
* drop libc++_shared.so
* fixes from comments
* Fix CMake for windows
* Merge latest monero dart changes [skip ci]
* bump monero_c commit
* add wownero to build scripts for macos [skip ci]
* add 14 word seed support to wownero
* UI fixes for wownero seed restore
* minor fixes
* reformat code to pass lints
* wownero: fixes
haven: removal popup
* minor iOS fix [skip ci]
* fix: wownero confirmation count (it is spendable after 3 confirms)
fix: transaction history not displaying in WOW and XMR
when tx has 0 confirms,
This is more of a workaround, because I have no idea
why would the cpp code not return pending transaction.
* Update preferences_key.dart [skip ci]
* minor fixes
---------
Co-authored-by: Rafael Saes <git@rafael.saes.dev>
Co-authored-by: Czarek Nakamoto <cyjan@mrcyjanek.net>
Co-authored-by: M <m@cakewallet.com>
Co-authored-by: Konstantin Ullrich <konstantinullrich12@gmail.com>
Co-authored-by: Matthew Fosse <matt@fosse.co>
2024-07-04 19:43:17 +00:00
|
|
|
final appDocDir = await getAppDir();
|
2023-02-01 15:37:18 +00:00
|
|
|
|
2024-02-06 20:44:21 +00:00
|
|
|
_file = File('${appDocDir.path}/error.txt');
|
|
|
|
}
|
2023-02-01 15:37:18 +00:00
|
|
|
|
2024-02-06 20:44:21 +00:00
|
|
|
await _addDeviceInfo(_file!);
|
2023-02-20 20:17:41 +00:00
|
|
|
|
2024-10-31 01:10:40 +00:00
|
|
|
// Check if a mail client is available
|
|
|
|
final bool canSend = await FlutterMailer.canSendMail();
|
|
|
|
|
|
|
|
if (Platform.isIOS && !canSend) {
|
2024-12-09 18:23:59 +00:00
|
|
|
printV('Mail app is not available');
|
2024-10-31 01:10:40 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-02-01 15:37:18 +00:00
|
|
|
final MailOptions mailOptions = MailOptions(
|
|
|
|
subject: 'Mobile App Issue',
|
|
|
|
recipients: ['support@cakewallet.com'],
|
2024-02-06 20:44:21 +00:00
|
|
|
attachments: [_file!.path],
|
2023-02-01 15:37:18 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
final result = await FlutterMailer.send(mailOptions);
|
|
|
|
|
|
|
|
// Clear file content if the error was sent or saved.
|
|
|
|
// On android we can't know if it was sent or saved
|
|
|
|
if (result.name == MailerResponse.sent.name ||
|
|
|
|
result.name == MailerResponse.saved.name ||
|
|
|
|
result.name == MailerResponse.android.name) {
|
2024-02-06 20:44:21 +00:00
|
|
|
_file!.writeAsString("", mode: FileMode.write);
|
2023-02-01 15:37:18 +00:00
|
|
|
}
|
|
|
|
} catch (e, s) {
|
|
|
|
_saveException(e.toString(), s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-28 19:28:31 +00:00
|
|
|
static Future<void> resetLastPopupDate() async {
|
|
|
|
final sharedPrefs = await SharedPreferences.getInstance();
|
|
|
|
await sharedPrefs.setString(PreferencesKey.lastPopupDate, DateTime(1971).toString());
|
|
|
|
}
|
|
|
|
|
|
|
|
static Future<void> onError(FlutterErrorDetails errorDetails) async {
|
litecoin mweb support (#1455)
* Fix stub creation
* Generate MWEB addresses
* Fix mweb address derivation
* Use camel-case
* Show utxos in tx list
* A few fixes
* Add spent processing
* Update balance
* Balance fixes
* Update address records
* Get rid of debounce hack
* Get sending up to the confirmation box
* Fee estimation
* Stop the daemon if plugin is unloaded
* Normal fee for non-mweb txns
* Fix fee estimation for send all
* Don't hash mweb addresses
* More fee fixes
* Broadcast mweb
* Remove test files
* One more
* Confirm sent txns
* Couple of fixes
* Resign inputs after mweb create
* Some more fixes
* Update balance after sending
* Correctly update address records
* Update confs
* [skip ci] updates
* [skip ci] add dep overrides
* working
* small fix
* merge fixes [skip ci]
* merge fixes [skip ci]
* [skip ci] minor fixes
* silent payment fixes [skip ci]
* updates [skip ci]
* save [skip ci]
* use mwebutxos box
* [skip ci] lots of fixes, still testing
* add rescan from height feature and test workflow build
* install go
* use sudo
* correct package name
* move building mweb higher for faster testing
* install fixes
* install later version of go
* go fixes
* testing
* testing
* testing
* testing
* testing
* should workgit add .github/workflows/pr_test_build.yml
* ???
* ??? pt.2
* should work, for real this time
* fix tx history not persisting + update build_mwebd script
* updates
* fix some rescan and address gen issues
* save [skip ci]
* fix unconfirmed balance not updating when receiving
* unspent coins / coin control fixes
* coin control fixes
* address balance and txCount fixes, try/catch electrum call
* fix txCount for addresses
* save [skip ci]
* potential fixes
* minor fix
* minor fix - 2
* sync status fixes, potential fix for background state issue
* workflow and script updates
* updates
* expirimental optimization
* [skip ci] minor enhancements
* workflow and script fixes
* workflow minor cleanup [skip ci]
* minor code cleanup & friendlier error message on failed tx's
* balance when sending fix
* experimental
* more experiments
* save
* updates
* coin control edge cases
* remove neutrino.db if no litecoin wallets left after deleting
* update translations
* updates
* minor fix
* [skip ci] update translations + minor fixes
* state fixes
* configure fix
* ui updates
* translation fixes
* [skip ci] addressbook updates
* fix popup
* fix popup2
* fix litecoin address book
* fix ios mwebd build script
* fix for building monero.com
* minor fix
* uncomment fix for state issues
* potential mweb sync fix (ios)
* remove print [skip ci]
* electrum stream potential fix
* fix ios build issues [skip ci]
* connection reliability updates, update kotlin code to match swift code, minor electrum error handling
* dep fixes
* minor fix
* more merge fixes
* bitcoin_flutter removal fixes
* [skip ci] fix always scan setting, swift updates
* updates
* fixes
* small fix
* small fix
* fix
* dart:convert != package:convert
* change address fixes
* update bitcoin_base to fix mweb address program checking
* fix ios xcode project [skip ci]
* updates
* more fixes
* more fixes
* ensure we don't initialize mweb until we really have to
* fix regression
* improve mweb reliability
* [skip ci] wip adress generation
* wip
* wip
* [skip ci] wip
* updates [skip ci]
* ios fixes
* fix workflows + ios fix
* test old mweb version
* update go version and mwebd hash
* review updates pt.1
* Update cw_bitcoin/lib/litecoin_wallet.dart
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
* remove non-litecoin address types regex [skip ci]
* more minor fixes
* remove duplicate [skip ci]
* Update lib/store/settings_store.dart
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
* script updates, swap params on createLitecoinWalletService
* topup fix
* [skip ci] wip
* [skip ci] testing
* [skip ci] file didn't get saved
* more address generation reliability fixes
* [skip ci] minor
* minor code cleanup
* hopefully prevents send issue
* [skip ci] wip address changes
* [skip ci] save
* save mweb addresses, auto-restart sync process if it gets stuck [skip ci]
* address generation issues mostly resolved
* more performance fixes
* [skip ci]
* this should maybe be refactored, pt.1
* separate mweb balances, pt.2
* [skip ci] save
* add translations [skip ci]
* fix sending with mweb amounts
* works for simple mweb-mweb case, further testing needed
* found an edge case
* [skip ci] make failed broadcast error message less serious
* minor
* capture all grpc errors and much better error handling overall
* [skip ci] minor
* prevent transactions with < 6 confirmations from being used + hide mweb balances if mweb is off
* fix
* merge fixes pt.1 [skip ci]
* fix mweb tags
* fix
* [skip ci] fix tag spacing
* fix transaction history not showing up
* fix mweb crash on non-fully deleted mweb cache, sync status ETA, other connection fixes
* [skip ci] minor code cleanup
* [skip ci] minor code cleanup
* additional cleanup
* silent payments eta fixes and updates
* revert sync eta changes into separate pr
* [skip ci] minor
* [skip ci] minor
* revert sync status title
* review fixes, additional cleanup
* [skip ci] minor
* [skip ci] minor
* [skip ci] minor
* trigger build
* review fixes, pt.2
* check if still processing utxos before updating sync status [skip ci]
* [skip ci] minor
* balance fix
* minor
* minor
* [skip ci] minor
* [skip ci] fix test net btc
* don't use mwebd for non-mweb tx's
* [skip ci] minor cleanup
* don't show all 1000+ mweb addresses on receive page
* minor cleanup + additional logging
---------
Co-authored-by: Hector Chu <hectorchu@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
Co-authored-by: Czarek Nakamoto <cyjan@mrcyjanek.net>
2024-09-28 02:22:25 +00:00
|
|
|
if (kDebugMode || kProfileMode) {
|
2023-02-06 16:33:12 +00:00
|
|
|
FlutterError.presentError(errorDetails);
|
2024-12-09 18:23:59 +00:00
|
|
|
printV(errorDetails.toString());
|
2023-02-06 16:33:12 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-12-09 12:25:36 +00:00
|
|
|
if (_ignoreError(errorDetails.exception.toString()) ||
|
|
|
|
_ignoreError(errorDetails.stack.toString())) {
|
2023-02-01 15:37:18 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-03-17 19:15:28 +00:00
|
|
|
_saveException(
|
|
|
|
errorDetails.exceptionAsString(),
|
|
|
|
errorDetails.stack,
|
|
|
|
library: errorDetails.library,
|
|
|
|
);
|
2023-02-01 15:37:18 +00:00
|
|
|
|
2023-09-14 19:14:16 +00:00
|
|
|
if (errorDetails.silent) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-02-07 14:53:57 +00:00
|
|
|
final sharedPrefs = await SharedPreferences.getInstance();
|
|
|
|
|
|
|
|
final lastPopupDate =
|
|
|
|
DateTime.tryParse(sharedPrefs.getString(PreferencesKey.lastPopupDate) ?? '') ??
|
2023-02-08 18:47:23 +00:00
|
|
|
DateTime.now().subtract(Duration(days: _coolDownDurationInDays + 1));
|
2023-02-07 14:53:57 +00:00
|
|
|
|
|
|
|
final durationSinceLastReport = DateTime.now().difference(lastPopupDate).inDays;
|
|
|
|
|
2023-02-08 18:47:23 +00:00
|
|
|
if (_hasError || durationSinceLastReport < _coolDownDurationInDays) {
|
2023-02-01 15:37:18 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
_hasError = true;
|
|
|
|
|
2024-11-28 19:28:31 +00:00
|
|
|
await sharedPrefs.setString(PreferencesKey.lastPopupDate, DateTime.now().toString());
|
|
|
|
|
|
|
|
// Instead of using WidgetsBinding.instance.addPostFrameCallback we
|
|
|
|
// await Future.delayed(Duration.zero), which does essentially the same (
|
|
|
|
// but doesn't wait for actual frame to be rendered), but it allows us to
|
|
|
|
// properly await the execution - which is what we want, without awaiting
|
|
|
|
// other code may call functions like Navigator.pop(), and close the alert
|
|
|
|
// instead of the intended UI.
|
|
|
|
// WidgetsBinding.instance.addPostFrameCallback(
|
|
|
|
// (timeStamp) async {
|
|
|
|
await Future.delayed(Duration.zero);
|
|
|
|
if (navigatorKey.currentContext != null) {
|
|
|
|
await showPopUp<void>(
|
|
|
|
context: navigatorKey.currentContext!,
|
|
|
|
builder: (context) {
|
|
|
|
return AlertWithTwoActions(
|
|
|
|
isDividerExist: true,
|
|
|
|
alertTitle: S.of(context).error,
|
|
|
|
alertContent: S.of(context).error_dialog_content,
|
|
|
|
rightButtonText: S.of(context).send,
|
|
|
|
leftButtonText: S.of(context).do_not_send,
|
|
|
|
actionRightButton: () {
|
|
|
|
Navigator.of(context).pop();
|
|
|
|
_sendExceptionFile();
|
|
|
|
},
|
|
|
|
actionLeftButton: () {
|
|
|
|
Navigator.of(context).pop();
|
2024-06-10 07:30:58 +00:00
|
|
|
},
|
|
|
|
);
|
2024-11-28 19:28:31 +00:00
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
2023-02-01 15:37:18 +00:00
|
|
|
|
2024-11-28 19:28:31 +00:00
|
|
|
_hasError = false;
|
2023-02-01 15:37:18 +00:00
|
|
|
}
|
|
|
|
|
2023-02-03 12:44:13 +00:00
|
|
|
/// Ignore User related errors or system errors
|
2023-02-08 18:16:12 +00:00
|
|
|
static bool _ignoreError(String error) =>
|
|
|
|
_ignoredErrors.any((element) => error.contains(element));
|
|
|
|
|
|
|
|
static const List<String> _ignoredErrors = const [
|
2023-06-13 23:04:52 +00:00
|
|
|
"Bad file descriptor",
|
|
|
|
"No space left on device",
|
2023-07-21 14:21:37 +00:00
|
|
|
"OS Error: Broken pipe",
|
2023-06-13 23:04:52 +00:00
|
|
|
"Can't assign requested address",
|
2023-07-21 14:21:37 +00:00
|
|
|
"OS Error: Socket is not connected",
|
2023-06-13 23:04:52 +00:00
|
|
|
"Operation timed out",
|
|
|
|
"No route to host",
|
|
|
|
"Software caused connection abort",
|
|
|
|
"Connection reset by peer",
|
|
|
|
"Connection timed out",
|
2023-05-10 13:58:31 +00:00
|
|
|
"Connection reset by peer",
|
|
|
|
"Connection closed before full header was received",
|
|
|
|
"Connection terminated during handshake",
|
2023-02-08 18:16:12 +00:00
|
|
|
"PERMISSION_NOT_GRANTED",
|
2023-08-11 13:58:11 +00:00
|
|
|
"Failed host lookup:",
|
|
|
|
"CERTIFICATE_VERIFY_FAILED",
|
|
|
|
"Handshake error in client",
|
|
|
|
"Error while launching http",
|
2023-08-23 12:33:20 +00:00
|
|
|
"OS Error: Network is unreachable",
|
2023-10-13 11:49:00 +00:00
|
|
|
"ClientException: Write failed, uri=http",
|
2024-08-12 22:04:05 +00:00
|
|
|
"Corrupted wallets seeds",
|
2024-08-26 17:07:25 +00:00
|
|
|
"bad_alloc",
|
|
|
|
"does not correspond",
|
|
|
|
"basic_string",
|
|
|
|
"input_stream",
|
|
|
|
"input stream error",
|
|
|
|
"invalid signature",
|
|
|
|
"invalid password",
|
2024-12-09 12:25:36 +00:00
|
|
|
// Temporary ignored, More context: Flutter secure storage reads the values as null some times
|
|
|
|
// probably when the device was locked and then opened on Cake
|
|
|
|
// this is solved by a restart of the app
|
|
|
|
// just ignoring until we find a solution to this issue or migrate from flutter secure storage
|
2024-12-22 16:22:00 +00:00
|
|
|
"core/auth_service.dart:64",
|
2024-12-09 12:25:36 +00:00
|
|
|
"core/key_service.dart:14",
|
2024-12-19 20:48:52 +00:00
|
|
|
"core/wallet_loading_service.dart:133",
|
2023-02-08 18:16:12 +00:00
|
|
|
];
|
2023-02-20 20:17:41 +00:00
|
|
|
|
|
|
|
static Future<void> _addDeviceInfo(File file) async {
|
|
|
|
final packageInfo = await PackageInfo.fromPlatform();
|
|
|
|
final currentVersion = packageInfo.version;
|
|
|
|
|
|
|
|
final deviceInfoPlugin = DeviceInfoPlugin();
|
|
|
|
Map<String, dynamic> deviceInfo = {};
|
|
|
|
|
|
|
|
if (Platform.isAndroid) {
|
|
|
|
deviceInfo = _readAndroidBuildData(await deviceInfoPlugin.androidInfo);
|
|
|
|
deviceInfo["Platform"] = "Android";
|
|
|
|
} else if (Platform.isIOS) {
|
|
|
|
deviceInfo = _readIosDeviceInfo(await deviceInfoPlugin.iosInfo);
|
|
|
|
deviceInfo["Platform"] = "iOS";
|
|
|
|
} else if (Platform.isLinux) {
|
|
|
|
deviceInfo = _readLinuxDeviceInfo(await deviceInfoPlugin.linuxInfo);
|
|
|
|
deviceInfo["Platform"] = "Linux";
|
|
|
|
} else if (Platform.isMacOS) {
|
|
|
|
deviceInfo = _readMacOsDeviceInfo(await deviceInfoPlugin.macOsInfo);
|
|
|
|
deviceInfo["Platform"] = "MacOS";
|
|
|
|
} else if (Platform.isWindows) {
|
|
|
|
deviceInfo = _readWindowsDeviceInfo(await deviceInfoPlugin.windowsInfo);
|
|
|
|
deviceInfo["Platform"] = "Windows";
|
|
|
|
}
|
|
|
|
|
|
|
|
await file.writeAsString(
|
2023-05-10 13:58:31 +00:00
|
|
|
"App Version: $currentVersion\n\nDevice Info $deviceInfo\n\n",
|
2023-02-20 20:17:41 +00:00
|
|
|
mode: FileMode.append,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
static Map<String, dynamic> _readAndroidBuildData(AndroidDeviceInfo build) {
|
|
|
|
return <String, dynamic>{
|
|
|
|
'brand': build.brand,
|
|
|
|
'device': build.device,
|
|
|
|
'manufacturer': build.manufacturer,
|
|
|
|
'model': build.model,
|
|
|
|
'product': build.product,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
static Map<String, dynamic> _readIosDeviceInfo(IosDeviceInfo data) {
|
|
|
|
return <String, dynamic>{
|
|
|
|
'systemName': data.systemName,
|
|
|
|
'systemVersion': data.systemVersion,
|
|
|
|
'model': data.model,
|
|
|
|
'localizedModel': data.localizedModel,
|
2023-05-10 13:58:31 +00:00
|
|
|
'isPhysicalDevice': data.isPhysicalDevice,
|
2023-02-20 20:17:41 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
static Map<String, dynamic> _readLinuxDeviceInfo(LinuxDeviceInfo data) {
|
|
|
|
return <String, dynamic>{
|
|
|
|
'name': data.name,
|
|
|
|
'version': data.version,
|
|
|
|
'versionCodename': data.versionCodename,
|
|
|
|
'versionId': data.versionId,
|
|
|
|
'prettyName': data.prettyName,
|
|
|
|
'buildId': data.buildId,
|
|
|
|
'variant': data.variant,
|
|
|
|
'variantId': data.variantId,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
static Map<String, dynamic> _readMacOsDeviceInfo(MacOsDeviceInfo data) {
|
|
|
|
return <String, dynamic>{
|
|
|
|
'arch': data.arch,
|
|
|
|
'model': data.model,
|
|
|
|
'kernelVersion': data.kernelVersion,
|
|
|
|
'osRelease': data.osRelease,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
static Map<String, dynamic> _readWindowsDeviceInfo(WindowsDeviceInfo data) {
|
|
|
|
return <String, dynamic>{
|
|
|
|
'majorVersion': data.majorVersion,
|
|
|
|
'minorVersion': data.minorVersion,
|
|
|
|
'buildNumber': data.buildNumber,
|
|
|
|
'productType': data.productType,
|
|
|
|
'productName': data.productName,
|
|
|
|
};
|
|
|
|
}
|
2024-08-06 14:59:44 +00:00
|
|
|
|
2024-11-28 19:28:31 +00:00
|
|
|
static Future<void> showError(String error, {int? delayInSeconds}) async {
|
2024-08-06 14:59:44 +00:00
|
|
|
if (_hasError) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
_hasError = true;
|
|
|
|
if (delayInSeconds != null) {
|
|
|
|
Future.delayed(Duration(seconds: delayInSeconds), () => _showCopyPopup(error));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-11-28 19:28:31 +00:00
|
|
|
await Future.delayed(Duration.zero);
|
|
|
|
await _showCopyPopup(error);
|
2024-08-06 14:59:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static Future<void> _showCopyPopup(String content) async {
|
|
|
|
if (navigatorKey.currentContext != null) {
|
|
|
|
final shouldCopy = await showPopUp<bool?>(
|
|
|
|
context: navigatorKey.currentContext!,
|
|
|
|
builder: (context) {
|
|
|
|
return AlertWithTwoActions(
|
|
|
|
isDividerExist: true,
|
|
|
|
alertTitle: S.of(context).error,
|
|
|
|
alertContent: content,
|
|
|
|
rightButtonText: S.of(context).copy,
|
|
|
|
leftButtonText: S.of(context).close,
|
|
|
|
actionRightButton: () {
|
|
|
|
Navigator.of(context).pop(true);
|
|
|
|
},
|
|
|
|
actionLeftButton: () {
|
|
|
|
Navigator.of(context).pop();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
if (shouldCopy == true) {
|
|
|
|
await Clipboard.setData(ClipboardData(text: content));
|
|
|
|
await showBar<void>(
|
|
|
|
navigatorKey.currentContext!,
|
|
|
|
S.of(navigatorKey.currentContext!).copied_to_clipboard,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_hasError = false;
|
|
|
|
}
|
2023-02-01 15:37:18 +00:00
|
|
|
}
|