From 09d9db17cc09d81bfe381a8fb96be59867542ead Mon Sep 17 00:00:00 2001 From: Jack Tanner Date: Wed, 4 Sep 2024 16:07:42 +0200 Subject: [PATCH 1/4] fix: fixed config setting, and buying and selling ram algorithm --- contracts/tonomy/src/tonomy.cpp | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/contracts/tonomy/src/tonomy.cpp b/contracts/tonomy/src/tonomy.cpp index 1bb64e8..432d6ad 100644 --- a/contracts/tonomy/src/tonomy.cpp +++ b/contracts/tonomy/src/tonomy.cpp @@ -381,7 +381,7 @@ namespace tonomysystem else { // Singleton does not exist, set the values and also set other values to 0 - config = resource_config{ram_price, ram_fee, total_ram_available, 0, 0, 0}; + config = resource_config{ram_fee, ram_price, total_ram_available, 0, 0, 0}; } // Save the modified or new config back to the singleton @@ -428,8 +428,8 @@ namespace tonomysystem // Read values from the table double ram_price = config.ram_price; double ram_fee = (1.0 + config.ram_fee); - uint64_t ram_purchase = (ram_price / ram_fee) * quant.amount; - + double amount = static_cast(quant.amount) / pow(10, quant.symbol.precision()); + uint64_t ram_purchase = amount * ram_price / ram_fee; eosio::check(config.total_ram_available >= config.total_ram_used + ram_purchase, "Not enough RAM available"); // modify the values and save them back to the table, @@ -439,6 +439,7 @@ namespace tonomysystem // Allocate the RAM int64_t myRAM, myNET, myCPU; eosio::get_resource_limits(app, myRAM, myNET, myCPU); + eosio::print("RAM: ", myRAM, " --> ", myRAM + ram_purchase); eosio::set_resource_limits(app, myRAM + ram_purchase, myNET, myNET); eosio::action(permission_level{dao_owner, "active"_n}, @@ -472,17 +473,20 @@ namespace tonomysystem // Read values from the table double ram_price = config.ram_price; double ram_fee = (1.0 + config.ram_fee); - uint64_t ram_sold = ram_price * ram_fee * quant.amount; + double amount = static_cast(quant.amount) / pow(10, quant.symbol.precision()); + uint64_t ram_sold = ram_price * ram_fee * amount; - eosio::check(config.total_ram_used >= quant.amount, "Not enough RAM to sell"); // Modify the values and save them back to the table - config.total_ram_used -= quant.amount; + config.total_ram_used -= ram_sold; + eosio::check(config.total_ram_used >= 0, "Cannot have less than 0 RAM used"); resource_config_singleton.set(config, get_self()); // Deallocate the RAM int64_t myRAM, myNET, myCPU; eosio::get_resource_limits(app, myRAM, myNET, myCPU); - eosio::set_resource_limits(app, myRAM - quant.amount, myNET, myNET); + eosio::print("RAM: ", myRAM, " --> ", myRAM - ram_sold); + eosio::check(myRAM - ram_sold >= 0, "Account cannot have less than 0 RAM"); + eosio::set_resource_limits(app, myRAM - ram_sold, myNET, myNET); // Transfer token and sell RAM // TODO should buy and sell from proxy counttract, otherwise cannot autorize to sell ram From c3eddd819cfac3f1a3bec181d466cdd9c411df54 Mon Sep 17 00:00:00 2001 From: Jack Tanner Date: Wed, 9 Oct 2024 18:10:41 +0200 Subject: [PATCH 2/4] ci: using upload artifacts v4 --- .github/workflows/deploy-staging.yaml | 6 +++--- .github/workflows/deploy-testnet.yaml | 6 +++--- .github/workflows/deploy.yaml | 6 +++--- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/deploy-staging.yaml b/.github/workflows/deploy-staging.yaml index c7446b4..78ddf8d 100644 --- a/.github/workflows/deploy-staging.yaml +++ b/.github/workflows/deploy-staging.yaml @@ -24,19 +24,19 @@ jobs: run: ./contracts/tonomy/build.sh local - name: Add eosio.boot contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: eosio.boot path: ./contracts/eosio.boot - name: Add eosio.bios contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: eosio.bios path: ./contracts/eosio.bios - name: Add built contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: tonomy path: ./contracts/tonomy diff --git a/.github/workflows/deploy-testnet.yaml b/.github/workflows/deploy-testnet.yaml index df03f42..a25236d 100644 --- a/.github/workflows/deploy-testnet.yaml +++ b/.github/workflows/deploy-testnet.yaml @@ -24,19 +24,19 @@ jobs: run: ./contracts/tonomy/build.sh local - name: Add eosio.boot contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: eosio.boot path: ./contracts/eosio.boot - name: Add eosio.bios contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: eosio.bios path: ./contracts/eosio.bios - name: Add built contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: tonomy path: ./contracts/tonomy diff --git a/.github/workflows/deploy.yaml b/.github/workflows/deploy.yaml index 063afc6..db0c0b2 100644 --- a/.github/workflows/deploy.yaml +++ b/.github/workflows/deploy.yaml @@ -24,19 +24,19 @@ jobs: run: ./contracts/tonomy/build.sh local - name: Add eosio.boot contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: eosio.boot path: ./contracts/eosio.boot - name: Add eosio.bios contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: eosio.bios path: ./contracts/eosio.bios - name: Add built contracts to artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: tonomy path: ./contracts/tonomy From 3b465691b1af168a32b4f12443403cfe49c87370 Mon Sep 17 00:00:00 2001 From: Jack Tanner Date: Thu, 17 Oct 2024 13:46:36 +0200 Subject: [PATCH 3/4] chore: add testnet branch protection --- .vscode/settings.json | 1 + 1 file changed, 1 insertion(+) diff --git a/.vscode/settings.json b/.vscode/settings.json index aef25a8..f61f25a 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -6,6 +6,7 @@ "git.branchProtection": [ "master", "main", + "testnet", "development" ], } \ No newline at end of file From e142a0164a457ef6b053bc0cd5115b97dab924c8 Mon Sep 17 00:00:00 2001 From: Jack Tanner Date: Wed, 20 Nov 2024 17:30:36 +0100 Subject: [PATCH 4/4] ci: using download-artifacts@v4 --- .github/workflows/deploy-staging.yaml | 6 +++--- .github/workflows/deploy-testnet.yaml | 6 +++--- .github/workflows/deploy.yaml | 4 ++-- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/.github/workflows/deploy-staging.yaml b/.github/workflows/deploy-staging.yaml index 78ddf8d..5a12339 100644 --- a/.github/workflows/deploy-staging.yaml +++ b/.github/workflows/deploy-staging.yaml @@ -55,7 +55,7 @@ jobs: steps: - name: Get built contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: tonomy path: contracts/tonomy @@ -78,13 +78,13 @@ jobs: - uses: actions/checkout@v3 - name: Get eosio.boot contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: eosio.boot path: contracts/eosio.boot - name: Get eosio.bios contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: eosio.bios path: contracts/eosio.bios diff --git a/.github/workflows/deploy-testnet.yaml b/.github/workflows/deploy-testnet.yaml index a25236d..481d821 100644 --- a/.github/workflows/deploy-testnet.yaml +++ b/.github/workflows/deploy-testnet.yaml @@ -56,7 +56,7 @@ jobs: steps: - name: Get built contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: tonomy path: contracts/tonomy @@ -79,13 +79,13 @@ jobs: - uses: actions/checkout@v3 - name: Get eosio.boot contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: eosio.boot path: contracts/eosio.boot - name: Get eosio.bios contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: eosio.bios path: contracts/eosio.bios diff --git a/.github/workflows/deploy.yaml b/.github/workflows/deploy.yaml index db0c0b2..a7c25ef 100644 --- a/.github/workflows/deploy.yaml +++ b/.github/workflows/deploy.yaml @@ -49,13 +49,13 @@ jobs: - uses: actions/checkout@v3 - name: Get eosio.boot contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: eosio.boot path: contracts/eosio.boot - name: Get eosio.bios contracts from cache - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 with: name: eosio.bios path: contracts/eosio.bios