mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-03 17:40:43 +00:00
Fixes for Linux build scripts. Fixes for load cw_monero on Linux. Catch exception for get PackageInfo in SettingsStore. Add excludeFlutterSecureStorage
to app_config.sh for Linux. Add FUNCTION_VISABILITY_ATTRIBUTE for monero_api.cpp.
This commit is contained in:
parent
9cd02b7541
commit
2e19e9d2b6
10 changed files with 82 additions and 23 deletions
|
@ -18,6 +18,10 @@ void __clear_cache(void* start, void* end) { }
|
||||||
#include "../External/android/include/wallet2_api.h"
|
#include "../External/android/include/wallet2_api.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(__GNUC__)
|
||||||
|
#define FUNCTION_VISABILITY_ATTRIBUTE __attribute__((visibility("default"))) __attribute__((used))
|
||||||
|
#endif
|
||||||
|
|
||||||
using namespace std::chrono_literals;
|
using namespace std::chrono_literals;
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C"
|
extern "C"
|
||||||
|
@ -152,7 +156,8 @@ extern "C"
|
||||||
fee = transaction->fee();
|
fee = transaction->fee();
|
||||||
blockHeight = transaction->blockHeight();
|
blockHeight = transaction->blockHeight();
|
||||||
subaddrAccount = transaction->subaddrAccount();
|
subaddrAccount = transaction->subaddrAccount();
|
||||||
std::set<uint32_t>::iterator it = transaction->subaddrIndex().begin();
|
std::set<uint32_t> subIndex = transaction->subaddrIndex();
|
||||||
|
std::set<uint32_t>::iterator it = subIndex.begin();
|
||||||
subaddrIndex = *it;
|
subaddrIndex = *it;
|
||||||
confirmations = transaction->confirmations();
|
confirmations = transaction->confirmations();
|
||||||
datetime = static_cast<int64_t>(transaction->timestamp());
|
datetime = static_cast<int64_t>(transaction->timestamp());
|
||||||
|
@ -194,6 +199,7 @@ extern "C"
|
||||||
std::mutex store_lock;
|
std::mutex store_lock;
|
||||||
bool is_storing = false;
|
bool is_storing = false;
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void change_current_wallet(Monero::Wallet *wallet)
|
void change_current_wallet(Monero::Wallet *wallet)
|
||||||
{
|
{
|
||||||
m_wallet = wallet;
|
m_wallet = wallet;
|
||||||
|
@ -233,6 +239,7 @@ extern "C"
|
||||||
return m_wallet;
|
return m_wallet;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool create_wallet(char *path, char *password, char *language, int32_t networkType, char *error)
|
bool create_wallet(char *path, char *password, char *language, int32_t networkType, char *error)
|
||||||
{
|
{
|
||||||
Monero::NetworkType _networkType = static_cast<Monero::NetworkType>(networkType);
|
Monero::NetworkType _networkType = static_cast<Monero::NetworkType>(networkType);
|
||||||
|
@ -255,6 +262,7 @@ extern "C"
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool restore_wallet_from_seed(char *path, char *password, char *seed, int32_t networkType, uint64_t restoreHeight, char *error)
|
bool restore_wallet_from_seed(char *path, char *password, char *seed, int32_t networkType, uint64_t restoreHeight, char *error)
|
||||||
{
|
{
|
||||||
Monero::NetworkType _networkType = static_cast<Monero::NetworkType>(networkType);
|
Monero::NetworkType _networkType = static_cast<Monero::NetworkType>(networkType);
|
||||||
|
@ -280,6 +288,7 @@ extern "C"
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool restore_wallet_from_keys(char *path, char *password, char *language, char *address, char *viewKey, char *spendKey, int32_t networkType, uint64_t restoreHeight, char *error)
|
bool restore_wallet_from_keys(char *path, char *password, char *language, char *address, char *viewKey, char *spendKey, int32_t networkType, uint64_t restoreHeight, char *error)
|
||||||
{
|
{
|
||||||
Monero::NetworkType _networkType = static_cast<Monero::NetworkType>(networkType);
|
Monero::NetworkType _networkType = static_cast<Monero::NetworkType>(networkType);
|
||||||
|
@ -308,6 +317,7 @@ extern "C"
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool load_wallet(char *path, char *password, int32_t nettype)
|
bool load_wallet(char *path, char *password, int32_t nettype)
|
||||||
{
|
{
|
||||||
nice(19);
|
nice(19);
|
||||||
|
@ -323,78 +333,91 @@ extern "C"
|
||||||
return !(status != Monero::Wallet::Status_Ok || !errorString.empty());
|
return !(status != Monero::Wallet::Status_Ok || !errorString.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *error_string() {
|
char *error_string() {
|
||||||
return strdup(get_current_wallet()->errorString().c_str());
|
return strdup(get_current_wallet()->errorString().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool is_wallet_exist(char *path)
|
bool is_wallet_exist(char *path)
|
||||||
{
|
{
|
||||||
return Monero::WalletManagerFactory::getWalletManager()->walletExists(std::string(path));
|
return Monero::WalletManagerFactory::getWalletManager()->walletExists(std::string(path));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void close_current_wallet()
|
void close_current_wallet()
|
||||||
{
|
{
|
||||||
Monero::WalletManagerFactory::getWalletManager()->closeWallet(get_current_wallet());
|
Monero::WalletManagerFactory::getWalletManager()->closeWallet(get_current_wallet());
|
||||||
change_current_wallet(nullptr);
|
change_current_wallet(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *get_filename()
|
char *get_filename()
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->filename().c_str());
|
return strdup(get_current_wallet()->filename().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *secret_view_key()
|
char *secret_view_key()
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->secretViewKey().c_str());
|
return strdup(get_current_wallet()->secretViewKey().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *public_view_key()
|
char *public_view_key()
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->publicViewKey().c_str());
|
return strdup(get_current_wallet()->publicViewKey().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *secret_spend_key()
|
char *secret_spend_key()
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->secretSpendKey().c_str());
|
return strdup(get_current_wallet()->secretSpendKey().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *public_spend_key()
|
char *public_spend_key()
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->publicSpendKey().c_str());
|
return strdup(get_current_wallet()->publicSpendKey().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *get_address(uint32_t account_index, uint32_t address_index)
|
char *get_address(uint32_t account_index, uint32_t address_index)
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->address(account_index, address_index).c_str());
|
return strdup(get_current_wallet()->address(account_index, address_index).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
const char *seed()
|
const char *seed()
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->seed().c_str());
|
return strdup(get_current_wallet()->seed().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t get_full_balance(uint32_t account_index)
|
uint64_t get_full_balance(uint32_t account_index)
|
||||||
{
|
{
|
||||||
return get_current_wallet()->balance(account_index);
|
return get_current_wallet()->balance(account_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t get_unlocked_balance(uint32_t account_index)
|
uint64_t get_unlocked_balance(uint32_t account_index)
|
||||||
{
|
{
|
||||||
return get_current_wallet()->unlockedBalance(account_index);
|
return get_current_wallet()->unlockedBalance(account_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t get_current_height()
|
uint64_t get_current_height()
|
||||||
{
|
{
|
||||||
return get_current_wallet()->blockChainHeight();
|
return get_current_wallet()->blockChainHeight();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t get_node_height()
|
uint64_t get_node_height()
|
||||||
{
|
{
|
||||||
return get_current_wallet()->daemonBlockChainHeight();
|
return get_current_wallet()->daemonBlockChainHeight();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool connect_to_node(char *error)
|
bool connect_to_node(char *error)
|
||||||
{
|
{
|
||||||
nice(19);
|
nice(19);
|
||||||
|
@ -408,6 +431,7 @@ extern "C"
|
||||||
return is_connected;
|
return is_connected;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool setup_node(char *address, char *login, char *password, bool use_ssl, bool is_light_wallet, char *error)
|
bool setup_node(char *address, char *login, char *password, bool use_ssl, bool is_light_wallet, char *error)
|
||||||
{
|
{
|
||||||
nice(19);
|
nice(19);
|
||||||
|
@ -438,27 +462,32 @@ extern "C"
|
||||||
return inited;
|
return inited;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool is_connected()
|
bool is_connected()
|
||||||
{
|
{
|
||||||
return get_current_wallet()->connected();
|
return get_current_wallet()->connected();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void start_refresh()
|
void start_refresh()
|
||||||
{
|
{
|
||||||
get_current_wallet()->refreshAsync();
|
get_current_wallet()->refreshAsync();
|
||||||
get_current_wallet()->startRefresh();
|
get_current_wallet()->startRefresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void set_refresh_from_block_height(uint64_t height)
|
void set_refresh_from_block_height(uint64_t height)
|
||||||
{
|
{
|
||||||
get_current_wallet()->setRefreshFromBlockHeight(height);
|
get_current_wallet()->setRefreshFromBlockHeight(height);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void set_recovering_from_seed(bool is_recovery)
|
void set_recovering_from_seed(bool is_recovery)
|
||||||
{
|
{
|
||||||
get_current_wallet()->setRecoveringFromSeed(is_recovery);
|
get_current_wallet()->setRecoveringFromSeed(is_recovery);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void store(char *path)
|
void store(char *path)
|
||||||
{
|
{
|
||||||
store_lock.lock();
|
store_lock.lock();
|
||||||
|
@ -472,6 +501,7 @@ extern "C"
|
||||||
store_lock.unlock();
|
store_lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool set_password(char *password, Utf8Box &error) {
|
bool set_password(char *password, Utf8Box &error) {
|
||||||
bool is_changed = get_current_wallet()->setPassword(std::string(password));
|
bool is_changed = get_current_wallet()->setPassword(std::string(password));
|
||||||
|
|
||||||
|
@ -482,6 +512,7 @@ extern "C"
|
||||||
return is_changed;
|
return is_changed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool transaction_create(char *address, char *payment_id, char *amount,
|
bool transaction_create(char *address, char *payment_id, char *amount,
|
||||||
uint8_t priority_raw, uint32_t subaddr_account, Utf8Box &error, PendingTransactionRaw &pendingTransaction)
|
uint8_t priority_raw, uint32_t subaddr_account, Utf8Box &error, PendingTransactionRaw &pendingTransaction)
|
||||||
{
|
{
|
||||||
|
@ -522,6 +553,7 @@ extern "C"
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool transaction_create_mult_dest(char **addresses, char *payment_id, char **amounts, uint32_t size,
|
bool transaction_create_mult_dest(char **addresses, char *payment_id, char **amounts, uint32_t size,
|
||||||
uint8_t priority_raw, uint32_t subaddr_account, Utf8Box &error, PendingTransactionRaw &pendingTransaction)
|
uint8_t priority_raw, uint32_t subaddr_account, Utf8Box &error, PendingTransactionRaw &pendingTransaction)
|
||||||
{
|
{
|
||||||
|
@ -564,6 +596,7 @@ extern "C"
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool transaction_commit(PendingTransactionRaw *transaction, Utf8Box &error)
|
bool transaction_commit(PendingTransactionRaw *transaction, Utf8Box &error)
|
||||||
{
|
{
|
||||||
bool committed = transaction->transaction->commit();
|
bool committed = transaction->transaction->commit();
|
||||||
|
@ -578,6 +611,7 @@ extern "C"
|
||||||
return committed;
|
return committed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t get_node_height_or_update(uint64_t base_eight)
|
uint64_t get_node_height_or_update(uint64_t base_eight)
|
||||||
{
|
{
|
||||||
if (m_cached_syncing_blockchain_height < base_eight) {
|
if (m_cached_syncing_blockchain_height < base_eight) {
|
||||||
|
@ -587,6 +621,7 @@ extern "C"
|
||||||
return m_cached_syncing_blockchain_height;
|
return m_cached_syncing_blockchain_height;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t get_syncing_height()
|
uint64_t get_syncing_height()
|
||||||
{
|
{
|
||||||
if (m_listener == nullptr) {
|
if (m_listener == nullptr) {
|
||||||
|
@ -607,6 +642,7 @@ extern "C"
|
||||||
return height;
|
return height;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint64_t is_needed_to_refresh()
|
uint64_t is_needed_to_refresh()
|
||||||
{
|
{
|
||||||
if (m_listener == nullptr) {
|
if (m_listener == nullptr) {
|
||||||
|
@ -622,6 +658,7 @@ extern "C"
|
||||||
return should_refresh;
|
return should_refresh;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
uint8_t is_new_transaction_exist()
|
uint8_t is_new_transaction_exist()
|
||||||
{
|
{
|
||||||
if (m_listener == nullptr) {
|
if (m_listener == nullptr) {
|
||||||
|
@ -638,6 +675,7 @@ extern "C"
|
||||||
return is_new_transaction_exist;
|
return is_new_transaction_exist;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void set_listener()
|
void set_listener()
|
||||||
{
|
{
|
||||||
m_last_known_wallet_height = 0;
|
m_last_known_wallet_height = 0;
|
||||||
|
@ -651,6 +689,7 @@ extern "C"
|
||||||
get_current_wallet()->setListener(m_listener);
|
get_current_wallet()->setListener(m_listener);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int64_t *subaddrress_get_all()
|
int64_t *subaddrress_get_all()
|
||||||
{
|
{
|
||||||
std::vector<Monero::SubaddressRow *> _subaddresses = m_subaddress->getAll();
|
std::vector<Monero::SubaddressRow *> _subaddresses = m_subaddress->getAll();
|
||||||
|
@ -667,33 +706,39 @@ extern "C"
|
||||||
return subaddresses;
|
return subaddresses;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int32_t subaddrress_size()
|
int32_t subaddrress_size()
|
||||||
{
|
{
|
||||||
std::vector<Monero::SubaddressRow *> _subaddresses = m_subaddress->getAll();
|
std::vector<Monero::SubaddressRow *> _subaddresses = m_subaddress->getAll();
|
||||||
return _subaddresses.size();
|
return _subaddresses.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void subaddress_add_row(uint32_t accountIndex, char *label)
|
void subaddress_add_row(uint32_t accountIndex, char *label)
|
||||||
{
|
{
|
||||||
m_subaddress->addRow(accountIndex, std::string(label));
|
m_subaddress->addRow(accountIndex, std::string(label));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void subaddress_set_label(uint32_t accountIndex, uint32_t addressIndex, char *label)
|
void subaddress_set_label(uint32_t accountIndex, uint32_t addressIndex, char *label)
|
||||||
{
|
{
|
||||||
m_subaddress->setLabel(accountIndex, addressIndex, std::string(label));
|
m_subaddress->setLabel(accountIndex, addressIndex, std::string(label));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void subaddress_refresh(uint32_t accountIndex)
|
void subaddress_refresh(uint32_t accountIndex)
|
||||||
{
|
{
|
||||||
m_subaddress->refresh(accountIndex);
|
m_subaddress->refresh(accountIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int32_t account_size()
|
int32_t account_size()
|
||||||
{
|
{
|
||||||
std::vector<Monero::SubaddressAccountRow *> _accocunts = m_account->getAll();
|
std::vector<Monero::SubaddressAccountRow *> _accocunts = m_account->getAll();
|
||||||
return _accocunts.size();
|
return _accocunts.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int64_t *account_get_all()
|
int64_t *account_get_all()
|
||||||
{
|
{
|
||||||
std::vector<Monero::SubaddressAccountRow *> _accocunts = m_account->getAll();
|
std::vector<Monero::SubaddressAccountRow *> _accocunts = m_account->getAll();
|
||||||
|
@ -710,21 +755,25 @@ extern "C"
|
||||||
return accocunts;
|
return accocunts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void account_add_row(char *label)
|
void account_add_row(char *label)
|
||||||
{
|
{
|
||||||
m_account->addRow(std::string(label));
|
m_account->addRow(std::string(label));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void account_set_label_row(uint32_t account_index, char *label)
|
void account_set_label_row(uint32_t account_index, char *label)
|
||||||
{
|
{
|
||||||
m_account->setLabel(account_index, label);
|
m_account->setLabel(account_index, label);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void account_refresh()
|
void account_refresh()
|
||||||
{
|
{
|
||||||
m_account->refresh();
|
m_account->refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int64_t *transactions_get_all()
|
int64_t *transactions_get_all()
|
||||||
{
|
{
|
||||||
std::vector<Monero::TransactionInfo *> transactions = m_transaction_history->getAll();
|
std::vector<Monero::TransactionInfo *> transactions = m_transaction_history->getAll();
|
||||||
|
@ -741,16 +790,19 @@ extern "C"
|
||||||
return transactionAddresses;
|
return transactionAddresses;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void transactions_refresh()
|
void transactions_refresh()
|
||||||
{
|
{
|
||||||
m_transaction_history->refresh();
|
m_transaction_history->refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int64_t transactions_count()
|
int64_t transactions_count()
|
||||||
{
|
{
|
||||||
return m_transaction_history->count();
|
return m_transaction_history->count();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int LedgerExchange(
|
int LedgerExchange(
|
||||||
unsigned char *command,
|
unsigned char *command,
|
||||||
unsigned int cmd_len,
|
unsigned int cmd_len,
|
||||||
|
@ -760,37 +812,44 @@ extern "C"
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
int LedgerFind(char *buffer, size_t len)
|
int LedgerFind(char *buffer, size_t len)
|
||||||
{
|
{
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void on_startup()
|
void on_startup()
|
||||||
{
|
{
|
||||||
Monero::Utils::onStartup();
|
Monero::Utils::onStartup();
|
||||||
Monero::WalletManagerFactory::setLogLevel(0);
|
Monero::WalletManagerFactory::setLogLevel(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void rescan_blockchain()
|
void rescan_blockchain()
|
||||||
{
|
{
|
||||||
m_wallet->rescanBlockchainAsync();
|
m_wallet->rescanBlockchainAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char * get_tx_key(char * txId)
|
char * get_tx_key(char * txId)
|
||||||
{
|
{
|
||||||
return strdup(m_wallet->getTxKey(std::string(txId)).c_str());
|
return strdup(m_wallet->getTxKey(std::string(txId)).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
char *get_subaddress_label(uint32_t accountIndex, uint32_t addressIndex)
|
char *get_subaddress_label(uint32_t accountIndex, uint32_t addressIndex)
|
||||||
{
|
{
|
||||||
return strdup(get_current_wallet()->getSubaddressLabel(accountIndex, addressIndex).c_str());
|
return strdup(get_current_wallet()->getSubaddressLabel(accountIndex, addressIndex).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
void set_trusted_daemon(bool arg)
|
void set_trusted_daemon(bool arg)
|
||||||
{
|
{
|
||||||
m_wallet->setTrustedDaemon(arg);
|
m_wallet->setTrustedDaemon(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FUNCTION_VISABILITY_ATTRIBUTE
|
||||||
bool trusted_daemon()
|
bool trusted_daemon()
|
||||||
{
|
{
|
||||||
return m_wallet->trustedDaemon();
|
return m_wallet->trustedDaemon();
|
||||||
|
|
|
@ -3,4 +3,4 @@ import 'dart:io';
|
||||||
|
|
||||||
final DynamicLibrary moneroApi = Platform.isAndroid
|
final DynamicLibrary moneroApi = Platform.isAndroid
|
||||||
? DynamicLibrary.open("libcw_monero.so")
|
? DynamicLibrary.open("libcw_monero.so")
|
||||||
: DynamicLibrary.open("cw_monero.framework/cw_monero");
|
: DynamicLibrary.process();
|
||||||
|
|
|
@ -17,6 +17,7 @@ set(PLUGIN_NAME "cw_monero_plugin")
|
||||||
# Any new source files that you add to the plugin should be added here.
|
# Any new source files that you add to the plugin should be added here.
|
||||||
add_library(${PLUGIN_NAME} SHARED
|
add_library(${PLUGIN_NAME} SHARED
|
||||||
"cw_monero_plugin.cc"
|
"cw_monero_plugin.cc"
|
||||||
|
"../ios/Classes/monero_api.cpp"
|
||||||
)
|
)
|
||||||
|
|
||||||
# Apply a standard set of build settings that are configured in the
|
# Apply a standard set of build settings that are configured in the
|
||||||
|
@ -37,7 +38,7 @@ target_include_directories(${PLUGIN_NAME} INTERFACE
|
||||||
"${CMAKE_CURRENT_SOURCE_DIR}/include")
|
"${CMAKE_CURRENT_SOURCE_DIR}/include")
|
||||||
target_link_libraries(${PLUGIN_NAME} PRIVATE flutter)
|
target_link_libraries(${PLUGIN_NAME} PRIVATE flutter)
|
||||||
target_link_libraries(${PLUGIN_NAME} PRIVATE PkgConfig::GTK)
|
target_link_libraries(${PLUGIN_NAME} PRIVATE PkgConfig::GTK)
|
||||||
|
target_link_libraries(${PLUGIN_NAME} PUBLIC cw_monero)
|
||||||
# List of absolute paths to libraries that should be bundled with the plugin.
|
# List of absolute paths to libraries that should be bundled with the plugin.
|
||||||
# This list could contain prebuilt libraries, or libraries created by an
|
# This list could contain prebuilt libraries, or libraries created by an
|
||||||
# external build triggered from this build file.
|
# external build triggered from this build file.
|
||||||
|
@ -50,8 +51,6 @@ add_library( cw_monero
|
||||||
STATIC
|
STATIC
|
||||||
../ios/Classes/monero_api.cpp)
|
../ios/Classes/monero_api.cpp)
|
||||||
|
|
||||||
#find_library( log-lib log )
|
|
||||||
|
|
||||||
set(EXTERNAL_LIBS_DIR ${CMAKE_SOURCE_DIR}/../cw_shared_external/ios/External/linux)
|
set(EXTERNAL_LIBS_DIR ${CMAKE_SOURCE_DIR}/../cw_shared_external/ios/External/linux)
|
||||||
|
|
||||||
############
|
############
|
||||||
|
@ -268,6 +267,4 @@ target_link_libraries( cw_monero
|
||||||
crypto
|
crypto
|
||||||
|
|
||||||
sodium
|
sodium
|
||||||
|
)
|
||||||
#${log-lib}
|
|
||||||
)
|
|
||||||
|
|
|
@ -324,7 +324,13 @@ abstract class SettingsStoreBase with Store {
|
||||||
final bitcoinElectrumServer = nodeSource.get(bitcoinElectrumServerId);
|
final bitcoinElectrumServer = nodeSource.get(bitcoinElectrumServerId);
|
||||||
final litecoinElectrumServer = nodeSource.get(litecoinElectrumServerId);
|
final litecoinElectrumServer = nodeSource.get(litecoinElectrumServerId);
|
||||||
final havenNode = nodeSource.get(havenNodeId);
|
final havenNode = nodeSource.get(havenNodeId);
|
||||||
final packageInfo = await PackageInfo.fromPlatform();
|
var appVersion = '';
|
||||||
|
|
||||||
|
try {
|
||||||
|
final packageInfo = await PackageInfo.fromPlatform();
|
||||||
|
appVersion = packageInfo.version;
|
||||||
|
} catch(_) {}
|
||||||
|
|
||||||
final shouldShowYatPopup =
|
final shouldShowYatPopup =
|
||||||
sharedPreferences.getBool(PreferencesKey.shouldShowYatPopup) ?? true;
|
sharedPreferences.getBool(PreferencesKey.shouldShowYatPopup) ?? true;
|
||||||
|
|
||||||
|
@ -349,7 +355,7 @@ abstract class SettingsStoreBase with Store {
|
||||||
return SettingsStore(
|
return SettingsStore(
|
||||||
sharedPreferences: sharedPreferences,
|
sharedPreferences: sharedPreferences,
|
||||||
nodes: nodes,
|
nodes: nodes,
|
||||||
appVersion: packageInfo.version,
|
appVersion: appVersion,
|
||||||
isBitcoinBuyEnabled: isBitcoinBuyEnabled,
|
isBitcoinBuyEnabled: isBitcoinBuyEnabled,
|
||||||
initialFiatCurrency: currentFiatCurrency,
|
initialFiatCurrency: currentFiatCurrency,
|
||||||
initialBalanceDisplayMode: currentBalanceDisplayMode,
|
initialBalanceDisplayMode: currentBalanceDisplayMode,
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
|
|
||||||
#include <cw_monero/cw_monero_plugin.h>
|
#include <cw_monero/cw_monero_plugin.h>
|
||||||
#include <devicelocale/devicelocale_plugin.h>
|
#include <devicelocale/devicelocale_plugin.h>
|
||||||
#include <flutter_secure_storage_linux/flutter_secure_storage_linux_plugin.h>
|
|
||||||
#include <platform_device_id_linux/platform_device_id_linux_plugin.h>
|
#include <platform_device_id_linux/platform_device_id_linux_plugin.h>
|
||||||
#include <url_launcher_linux/url_launcher_plugin.h>
|
#include <url_launcher_linux/url_launcher_plugin.h>
|
||||||
|
|
||||||
|
@ -19,9 +18,6 @@ void fl_register_plugins(FlPluginRegistry* registry) {
|
||||||
g_autoptr(FlPluginRegistrar) devicelocale_registrar =
|
g_autoptr(FlPluginRegistrar) devicelocale_registrar =
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "DevicelocalePlugin");
|
fl_plugin_registry_get_registrar_for_plugin(registry, "DevicelocalePlugin");
|
||||||
devicelocale_plugin_register_with_registrar(devicelocale_registrar);
|
devicelocale_plugin_register_with_registrar(devicelocale_registrar);
|
||||||
g_autoptr(FlPluginRegistrar) flutter_secure_storage_linux_registrar =
|
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "FlutterSecureStorageLinuxPlugin");
|
|
||||||
flutter_secure_storage_linux_plugin_register_with_registrar(flutter_secure_storage_linux_registrar);
|
|
||||||
g_autoptr(FlPluginRegistrar) platform_device_id_linux_registrar =
|
g_autoptr(FlPluginRegistrar) platform_device_id_linux_registrar =
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "PlatformDeviceIdLinuxPlugin");
|
fl_plugin_registry_get_registrar_for_plugin(registry, "PlatformDeviceIdLinuxPlugin");
|
||||||
platform_device_id_linux_plugin_register_with_registrar(platform_device_id_linux_registrar);
|
platform_device_id_linux_plugin_register_with_registrar(platform_device_id_linux_registrar);
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
list(APPEND FLUTTER_PLUGIN_LIST
|
list(APPEND FLUTTER_PLUGIN_LIST
|
||||||
cw_monero
|
cw_monero
|
||||||
devicelocale
|
devicelocale
|
||||||
flutter_secure_storage_linux
|
|
||||||
platform_device_id_linux
|
platform_device_id_linux
|
||||||
url_launcher_linux
|
url_launcher_linux
|
||||||
)
|
)
|
||||||
|
|
|
@ -13,7 +13,7 @@ CONFIG_ARGS=""
|
||||||
|
|
||||||
case $APP_LINUX_TYPE in
|
case $APP_LINUX_TYPE in
|
||||||
$CAKEWALLET)
|
$CAKEWALLET)
|
||||||
CONFIG_ARGS="--monero --bitcoin";; #--haven
|
CONFIG_ARGS="--monero --bitcoin --excludeFlutterSecureStorage";; #--haven
|
||||||
esac
|
esac
|
||||||
|
|
||||||
cp -rf pubspec_description.yaml pubspec.yaml
|
cp -rf pubspec_description.yaml pubspec.yaml
|
||||||
|
|
|
@ -21,7 +21,8 @@ rm -rf $BOOST_SRC_DIR
|
||||||
tar -xvf $BOOST_FILE_PATH -C $EXTERNAL_LINUX_SOURCE_DIR
|
tar -xvf $BOOST_FILE_PATH -C $EXTERNAL_LINUX_SOURCE_DIR
|
||||||
cd $BOOST_SRC_DIR
|
cd $BOOST_SRC_DIR
|
||||||
./bootstrap.sh --prefix=${EXTERNAL_LINUX_DIR}
|
./bootstrap.sh --prefix=${EXTERNAL_LINUX_DIR}
|
||||||
./b2 --with-chrono \
|
./b2 cxxflags=-fPIC cflags=-fPIC \
|
||||||
|
--with-chrono \
|
||||||
--with-date_time \
|
--with-date_time \
|
||||||
--with-filesystem \
|
--with-filesystem \
|
||||||
--with-program_options \
|
--with-program_options \
|
||||||
|
|
|
@ -14,6 +14,6 @@ curl https://www.openssl.org/source/${OPENSSL_FILENAME} -o ${OPENSSL_FILE_PATH}
|
||||||
rm -rf $OPENSSL_SRC_DIR
|
rm -rf $OPENSSL_SRC_DIR
|
||||||
tar -xzf $OPENSSL_FILE_PATH -C $EXTERNAL_LINUX_SOURCE_DIR
|
tar -xzf $OPENSSL_FILE_PATH -C $EXTERNAL_LINUX_SOURCE_DIR
|
||||||
cd $OPENSSL_SRC_DIR
|
cd $OPENSSL_SRC_DIR
|
||||||
|
export CFLAGS=-fPIC
|
||||||
./config -static --prefix=${EXTERNAL_LINUX_DIR}
|
./config -fPIC shared --prefix=${EXTERNAL_LINUX_DIR}
|
||||||
make install
|
make install
|
||||||
|
|
|
@ -14,11 +14,12 @@ git clone https://github.com/NLnetLabs/unbound.git -b ${UNBOUND_VERSION} ${UNBOU
|
||||||
cd $UNBOUND_DIR_PATH
|
cd $UNBOUND_DIR_PATH
|
||||||
test `git rev-parse HEAD` = ${UNBOUND_HASH} || exit 1
|
test `git rev-parse HEAD` = ${UNBOUND_HASH} || exit 1
|
||||||
|
|
||||||
./configure --prefix="${EXTERNAL_LINUX_DIR}" \
|
export CFLAGS=-fPIC
|
||||||
|
./configure cxxflags=-fPIC cflags=-fPIC \
|
||||||
|
--prefix="${EXTERNAL_LINUX_DIR}" \
|
||||||
--with-ssl="${EXTERNAL_LINUX_DIR}" \
|
--with-ssl="${EXTERNAL_LINUX_DIR}" \
|
||||||
--with-libexpat="${EXTERNAL_LINUX_DIR}" \
|
--with-libexpat="${EXTERNAL_LINUX_DIR}" \
|
||||||
--enable-static \
|
--enable-static \
|
||||||
--disable-shared \
|
|
||||||
--disable-flto
|
--disable-flto
|
||||||
make
|
make
|
||||||
make install
|
make install
|
||||||
|
|
Loading…
Reference in a new issue