I reply to all queries on the forums and via email, once per day, Monday to Friday (not weekends).

If you are new here, please see some information on how to ask for support. Thank you!

Hot wallet remains empty when new deposits are made.

dashed-slug.net Forums Monero Wallet Adapter extension support Hot wallet remains empty when new deposits are made.

Viewing 10 posts - 1 through 10 (of 10 total)
  • Author
    Posts
  • #8057
    d3vnu77
    Participant

    Everything seems to be fine with my BTC and LTC Adapters.

    However, I slightly hacked up the monero adapter to make it work with a different cryptonight coin and the new deposits don’t recognize that they belong in the hot wallet.

    Everything worked in v4, deposits, withdrawals, transfers, etc, however I notice that the hot/cold wallet stuff did not display correct.

    However on v5 I cannot withdrawal anything because it thinks there is 0 coins in the hot wallet.

    I’ve attached some images to explain the point. Not sure where to start looking. Does this on the production server and a brand new development box running the same code.

    Any help would be appreciated.

    Attachments:
    You must be logged in to view attached files.
    #8060
    d3vnu77
    Participant

    The problems seems to be with the get_balance method in the cryptonote adapter…

    It seems to do a “network active” check which fails and then returns a balance of false.

    public function get_balance() {
    			static $balance = false;
    
    			if ( false === $balance ) {
    				var_dump($this); die('check network');
    				if ( $this->network_active ) {
    				//if(1==1){
    						$result = $this->do_rpc_command('getBalance');
    
    					var_dump($result); die('got the balance');
    
    						$balance += round( $result->availableBalance * 1e-8, 8 );
    				}
    			}
    			return $balance;
    		}

    If I don’t check that the network is active everything works.

    #8064
    d3vnu77
    Participant

    This is the var_dump of the $this object inside of the adapter, when executing the above code, mind you I have cron turned off while I attempt to manually isolate the issue.

    object(Dashed_Slug_Wallets_Coin_Adapter_Cryptonote_2ACoin)#2159 (4) { [“network_active”:”Dashed_Slug_Wallets_Coin_Adapter_Cryptonote”:private]=> bool(false) [“menu_slug”:protected]=> string(40) “wallets-menu-2acoin-cryptonote-full-node” [“option_slug”:protected]=> string(44) “wallets-2acoin-cryptonote-full-node-settings” [“_notices”:protected]=> object(Dashed_Slug_Wallets_Admin_Notices)#1033 (1) { [“admin_notices”:”Dashed_Slug_Wallets_Admin_Notices”:private]=> object(stdClass)#1032 (4) { [“error”]=> array(1) { [0]=> object(stdClass)#993 (2) { [“message”]=> string(149) “The wp_cron tasks have not run in the past 4 hours.You must either enable auto-triggering or trigger cron manually via curl/system-cron.” [“dismiss_option”]=> string(24) “wallets-cron-not-running” } } [“warning”]=> array(0) { } [“info”]=> array(0) { } [“success”]=> array(0) { } } } } check network

    notice how the network_active property is false.Trying to understand the dynamic of this.

    #8069
    alexg
    Keymaster

    Hello,

    I’ve moved your posts to the support forum for the Monero adapter.

    If you’ve put the code under some kind of version control before making changes, you can easily diff your changes with the original code. The get_balance() method has an if..then…else construct. In the code you posted above you seem to have deleted the else branch.

    The adapter maintains an association of WordPress blog_urls to wallet accounts. If your installation is single-site, there will be only one blog url. If you are on multisite, there will be many. But if you are on a multisite installation AND the plugin is network-activated, this means that user balances are shared across all sites, and therefore the coin adapter must sum over all the sites. Hence the if/else construct.

    When the plugin is network-activated, users may potentially be holding balances on various sub-sites, therefore there is a need to store balances on different wallet accounts. But if the plugin is not network activated (which is the usual for most installations), then the else branch is executed.

    I would recommend that you restore the code and try your changes again. What you’re interested in is probably the else branch, which calls RPC get_balance once for the account corresponding to the one blog that your site has.

    Additionally, if you are encountering issues with a cryptonote wallet, you can open a new thread on this support forum, and I can investigate to see what’s going on.

    with regards

    #8083
    d3vnu77
    Participant

    I think the main reason I had to start hacking up the monero plugin is that the cryptonote coin I am making work with your plugin is a coin called 2ACoin.

    This coin which is based off TurtleCoin does not seem to have a get_accounts RPC Call. Therefore I removed most of the accounts functionality from the plugin inorder to make it work. Also had to change all of your calls to camel case as the 2ACoin Wallet RPC API is formated in camelcase: as seen here:

    https://api-docs.2acoin.org/#wallet-rpc-api

    #8085
    alexg
    Keymaster

    Thank you. It does look like this wallet has a completely different API.

    I could possibly create an adapter, but I don’t know when I can look at this, as it will require some analysis. Too many people at this time stay at home and play with the plugin due to the current situation. There is a high demand for a grin-like adapter, so this might need to take precedence.

    If you are going to attempt creating a turtlecoin/2acoin adapter, focus on providing an implementation of Dashed_Slug_Wallets_Coin_Adapter that implements all methods. A somewhat dated article on this: https://www.dashed-slug.net/developers-coin-adapters-api/

    Also, when a new deposit is discovered, the adapter should trigger the wallets_transaction action. More on this here: https://www.dashed-slug.net/howto-create-update-transactions-from-php/

    I’ll try to give you more info as soon as I perform an initial analysis on the API spec you gave me.

    with regards

    #8119
    alexg
    Keymaster

    Hello,

    I have done some preliminary work yesterday on TurtleCoin.

    I was not aware of this family of coins and I am pleasantly surprised by how easy they are to setup compared to Cryptonote, and the wallet API doc is very helpful.

    I believe that I should be able to create a TurtleCoin adapter soon (perhaps in a few weeks time, if all goes well). It would be a nice addition to the collection of available coin adapters.

    My goal is to provide support for TurtleCoin and all its forks. I will let you know again here, once I have any more news.

    with regards

    #8283
    alexg
    Keymaster

    Hello,

    Just keeping you updated, I have been developing a solution for turtlecoin and clones. Dev is about 60% done and I hope to finish the remaining dev and testing over the next week if no issues crop up during the weekend.

    with regards

    #8289
    Anonymous
    Inactive

    Glad to hear it!! Working on a site with a turtlecoin fork as well. Looking forward to your solution!!

    #8406
    alexg
    Keymaster

    Hello,

    TurtleCoin adapter is now released: https://www.dashed-slug.net/turtlecoin-on-wordpress/

    with regards

Viewing 10 posts - 1 through 10 (of 10 total)
  • You must be logged in to reply to this topic.