Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

BLOCK-2590 - Make bridge contract works with UOS, sync with main branch #2

Merged
merged 37 commits into from
Nov 15, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
c959a4d
init & setgaslimit action
taokayan May 29, 2024
65a3373
Merge pull request #44 from eosnetworkfoundation/kayan_ercinit
taokayan May 30, 2024
1c495f1
Full support for upgrade
yarkinwho Jul 30, 2024
290b3fd
Add api to call ugrade via token contract and token symbol
yarkinwho Aug 5, 2024
9778a59
After discussion, we decide that we should only keep the token
yarkinwho Aug 7, 2024
7a440c5
Merge pull request #47 from eosnetworkfoundation/yarkin/exsat_fixes
yarkinwho Aug 8, 2024
b0c548f
pass in linked eos address and evm address instead of hardcode
yarkinwho Aug 8, 2024
d342384
Merge pull request #48 from eosnetworkfoundation/yarkin/remove_hardcode
yarkinwho Aug 14, 2024
c3a0484
Bump 0.2.0 version
elmato Aug 14, 2024
0d7c963
use spring in cicd
taokayan Aug 14, 2024
eb264bf
Merge pull request #51 from eosnetworkfoundation/kayan_0.2_spring
elmato Aug 15, 2024
1db13d7
Merge pull request #50 from eosnetworkfoundation/elmato/bump_0_2_0
elmato Aug 15, 2024
5f56f41
Merge commit 'eb264bf' into elmato/merge-kayan_0.2_spring-to-main
elmato Aug 16, 2024
431eaa6
Merge commit '1db13d7' into elmato/merge-bump_0_2_0-to-main
elmato Aug 16, 2024
cf8ebb5
Merge pull request #52 from eosnetworkfoundation/elmato/merge-kayan_0…
arhag Aug 16, 2024
9abea29
Merge remote-tracking branch 'origin/main' into elmato/merge-bump_0_2…
elmato Aug 16, 2024
bc41033
Merge pull request #53 from eosnetworkfoundation/elmato/merge-bump_0_…
arhag Aug 16, 2024
529f391
Change to BSL licensing scheme
Sep 17, 2024
26a331c
Merge pull request #54 from eosnetworkfoundation/bsl-license
arhag Sep 17, 2024
7068fc8
Update silkworm submodule
arhag Sep 17, 2024
f524119
Use Spring 1.x version as Spring dependency
arhag Sep 17, 2024
b4ce79f
Merge pull request #55 from eosnetworkfoundation/update-silkworm-subm…
arhag Sep 17, 2024
95160b2
Merge branch 'release/0.2' into update-dependencies-to-main
arhag Sep 17, 2024
bbff1d4
Update silkworm submodule to head of master branch
arhag Sep 17, 2024
1cb7ba3
Return Spring dependency back to main branch
arhag Sep 17, 2024
fb85bea
Merge pull request #56 from eosnetworkfoundation/update-dependencies-…
arhag Sep 17, 2024
d5d3f2b
Also fix EVM contract dependency to use stable version
arhag Sep 18, 2024
d732449
Merge pull request #57 from eosnetworkfoundation/update-contract-depe…
arhag Sep 18, 2024
68ac4b1
Merge branch 'release/0.2' into update-contract-dependency-to-main
arhag Sep 18, 2024
c0c4977
Revert EVM Contract dependency back to main.
arhag Sep 18, 2024
6b94adf
Merge pull request #58 from eosnetworkfoundation/update-contract-depe…
arhag Sep 18, 2024
38f35fd
add erc20(usdt) test with btc as based token
taokayan Oct 7, 2024
09e9421
add verbose
taokayan Oct 7, 2024
3af2ed0
fix tests
taokayan Oct 7, 2024
35f9964
remove unnecessary param
taokayan Oct 16, 2024
dd529ec
Merge pull request #59 from eosnetworkfoundation/kayan_btc_based_test
taokayan Oct 16, 2024
98d7581
make bridge contract works with UOS
Adam-Ultra May 28, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .cicd/defaults.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"leap-dev":{
"target":"5",
"antelope-spring-dev":{
"target":"1",
"prerelease":false
},
"cdt":{
Expand Down
38 changes: 11 additions & 27 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,16 +8,6 @@ on:
pull_request:
workflow_dispatch:
inputs:
override-leap-dev:
description: Override leap-dev target
type: string
override-leap-dev-prerelease:
type: choice
description: Override leap-dev prelease
options:
- default
- true
- false
override-cdt:
description: 'Override cdt target'
type: string
Expand Down Expand Up @@ -89,8 +79,8 @@ jobs:
name: Determine Versions
runs-on: ubuntu-latest
outputs:
leap-dev-target: ${{steps.versions.outputs.leap-dev-target}}
leap-dev-prerelease: ${{steps.versions.outputs.leap-dev-prerelease}}
antelope-spring-dev-target: ${{steps.versions.outputs.antelope-spring-dev-target}}
antelope-spring-dev-prerelease: ${{steps.versions.outputs.antelope-spring-dev-prerelease}}
cdt-target: ${{steps.versions.outputs.cdt-target}}
cdt-prerelease: ${{steps.versions.outputs.cdt-prerelease}}
eos-evm-contract-target: ${{steps.versions.outputs.eos-evm-contract-target}}
Expand All @@ -102,19 +92,13 @@ jobs:
GH_TOKEN: ${{secrets.GITHUB_TOKEN}}
run: |
DEFAULTS_JSON=$(curl -sSfL $(gh api https://api.github.com/repos/${{github.repository}}/contents/.cicd/defaults.json?ref=${{github.sha}} --jq .download_url))
echo leap-dev-target=$(echo "$DEFAULTS_JSON" | jq -r '."leap-dev".target') >> $GITHUB_OUTPUT
echo leap-dev-prerelease=$(echo "$DEFAULTS_JSON" | jq -r '."leap-dev".prerelease') >> $GITHUB_OUTPUT
echo antelope-spring-dev-target=$(echo "$DEFAULTS_JSON" | jq -r '."antelope-spring-dev".target') >> $GITHUB_OUTPUT
echo antelope-spring-dev-prerelease=$(echo "$DEFAULTS_JSON" | jq -r '."antelope-spring-dev".prerelease') >> $GITHUB_OUTPUT
echo cdt-target=$(echo "$DEFAULTS_JSON" | jq -r '."cdt".target') >> $GITHUB_OUTPUT
echo cdt-prerelease=$(echo "$DEFAULTS_JSON" | jq -r '."cdt".prerelease') >> $GITHUB_OUTPUT
echo eos-evm-contract-target=$(echo "$DEFAULTS_JSON" | jq -r '."eos-evm-contract".target') >> $GITHUB_OUTPUT
echo eos-evm-contract-prerelease=$(echo "$DEFAULTS_JSON" | jq -r '."eos-evm-contract".prerelease') >> $GITHUB_OUTPUT

if [[ "${{inputs.override-leap-dev}}" != "" ]]; then
echo leap-dev-target=${{inputs.override-leap-dev}} >> $GITHUB_OUTPUT
fi
if [[ "${{inputs.override-leap-dev-prerelease}}" == +(true|false) ]]; then
echo leap-dev-prerelease=${{inputs.override-leap-dev-prerelease}} >> $GITHUB_OUTPUT
fi
if [[ "${{inputs.override-cdt}}" != "" ]]; then
echo cdt-target=${{inputs.override-cdt}} >> $GITHUB_OUTPUT
fi
Expand Down Expand Up @@ -156,16 +140,16 @@ jobs:
prereleases: ${{fromJSON(needs.versions.outputs.cdt-prerelease)}}
file: 'cdt_.*amd64.deb'

- name: Download leap-dev.deb
- name: Download antelope-spring-dev
uses: AntelopeIO/asset-artifact-download-action@v3
with:
owner: AntelopeIO
repo: leap
file: 'leap-dev.*ubuntu22.*amd64.deb'
target: ${{needs.versions.outputs.leap-dev-target}}
prereleases: ${{fromJSON(needs.versions.outputs.leap-dev-prerelease)}}
artifact-name: leap-dev-ubuntu22-amd64
container-package: experimental-binaries
repo: spring
file: 'antelope-spring-dev.*ubuntu22\.04_amd64.deb'
target: '${{needs.versions.outputs.antelope-spring-dev-target}}'
prereleases: ${{fromJSON(needs.versions.outputs.antelope-spring-dev-prerelease)}}
artifact-name: antelope-spring-dev-ubuntu22-amd64
container-package: antelope-spring-experimental-binaries

- name: Install .deb packages
run: |
Expand Down
2 changes: 2 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ endif()
set(EXTERNAL_DIR ${CMAKE_SOURCE_DIR}/external)
set(SOLIDITY_BYTECODES_DIR ${CMAKE_BINARY_DIR}/solidity_contracts/bytecodes)

add_compile_definitions(PROJECT_VERSION="0.2.0")

add_subdirectory (solidity_contracts)

enable_testing()
Expand Down
118 changes: 97 additions & 21 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -1,21 +1,97 @@
MIT License

Copyright (c) 2023 EOS Network Foundation

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
License text copyright (c) 2023 MariaDB plc, All Rights Reserved. "Business
Source License" is a trademark of MariaDB plc.

Parameters

Licensor: EOS NETWORK FOUNDATION ("ENF")

Licensed Work: EOS-EVM Bridge Contracts Copyright ENF, 2024, All Rights
Reserved

Additional Use Grant: Licensee (You) is granted, free of charge, to deal in
the Licensed Work without restriction, including
without limitation the rights to use, copy, modify,
merge, publish, distribute, sublicense, and/or sell
copies of the Licensed Work, and to permit persons to
whom the Licensed Work is furnished to do so, subject
to the following conditions:

Your use of the Licensed Work is Directly in Service
of or Materially Dependent on the EOS Blockchain
Network

The copyright notice and this permission notice shall
be included in all copies or substantial portions of
the Software.

For the purposes of this license:

"EOS Blockchain Network" is defined as any blockchain
network created with the EOSIO, or Antelope,
protocols, or any future protocols derived
substantially from them whose genesis block id as
defined by the Licensed Work is 00000001405147477ab2f5...
f51cda427b638191c66d2c59aa392d5c2c98076cb0

"Directly in Service" is defined as any use which is
necessary for the EOS Blockchain to persist and
continue operations including but not limited to
hosting network nodes, archives, RPC endpoints, and
integration with 3rd party services.

"Materially Dependent" is defined as use that would
cease to operate effectively or economically if the
EOS blockchain component was removed temporarily or
permanently.

Change Date: Four years from the date the Licensed Work is published

Change License: MIT 2.0

For information about alternative licensing arrangements for the Licensed Work,
please contact [email protected].

Notice

Business Source License 1.1

Terms

The Licensor hereby grants you the right to copy, modify, create derivative
works, redistribute, and make non-production use of the Licensed Work. The
Licensor may make an Additional Use Grant, above, permitting limited production
use.

Effective on the Change Date, or the fourth anniversary of the first publicly
available distribution of a specific version of the Licensed Work under this
License, whichever comes first, the Licensor hereby grants you rights under
the terms of the Change License, and the rights granted in the paragraph
above terminate.

If your use of the Licensed Work does not comply with the requirements
currently in effect as described in this License, you must purchase a
commercial license from the Licensor, its affiliated entities, or authorized
resellers, or you must refrain from using the Licensed Work.

All copies of the original and modified Licensed Work, and derivative works
of the Licensed Work, are subject to this License. This License applies
separately for each version of the Licensed Work and the Change Date may vary
for each version of the Licensed Work released by Licensor.

You must conspicuously display this License on each original or modified copy
of the Licensed Work. If you receive the Licensed Work in original or
modified form from a third party, the terms and conditions set forth in this
License apply to your use of that work.

Any use of the Licensed Work in violation of this License will automatically
terminate your rights under this License for the current and all other
versions of the Licensed Work.

This License does not grant you any right in any trademark or logo of
Licensor or its affiliates (provided that you may use a trademark or logo of
Licensor as expressly required by this License).

TO THE EXTENT PERMITTED BY APPLICABLE LAW, THE LICENSED WORK IS PROVIDED ON
AN "AS IS" BASIS. LICENSOR HEREBY DISCLAIMS ALL WARRANTIES AND CONDITIONS,
EXPRESS OR IMPLIED, INCLUDING (WITHOUT LIMITATION) WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, AND TITLE.
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ void deposit_proxy::transfer(eosio::name from, eosio::name to, eosio::asset quan

eosio::check(memo_has_evm_address, "memo must be a valid EVM address");

constexpr extended_symbol EOS = eosio::extended_symbol{eosio::symbol{"EOS",4}, "eosio.token"_n};
constexpr extended_symbol EOS = eosio::extended_symbol{eosio::symbol{"UOS",4}, "eosio.token"_n};
const auto s = eosio::extended_symbol{quantity.symbol, get_first_receiver()};

auto destination = s == EOS ? "eosio.evm"_n : "eosio.erc2o"_n;
Expand Down
21 changes: 13 additions & 8 deletions antelope_contracts/contracts/erc20/include/erc20/erc20.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,11 @@ class [[eosio::contract]] erc20 : public contract {
[[eosio::action]] void withdrawfee(eosio::name token_contract, eosio::asset quantity, eosio::name to, std::string memo);

[[eosio::action]] void unregtoken(eosio::name eos_contract_name, eosio::symbol_code token_symbol_code);
[[eosio::action]] void setconfig(std::optional<eosio::name> evm_account, std::optional<eosio::symbol> gas_token_symbol, std::optional<uint64_t> gaslimit, std::optional<uint64_t> init_gaslimit);

[[eosio::action]] void init(eosio::name evm_account, eosio::symbol gas_token_symbol, uint64_t gaslimit, uint64_t init_gaslimit);

[[eosio::action]] void setgaslimit(std::optional<uint64_t> gaslimit, std::optional<uint64_t> init_gaslimit);
[[eosio::action]] void callupgrade(eosio::name token_contract, eosio::symbol token_symbol);

struct [[eosio::table("implcontract")]] impl_contract_t {
uint64_t id = 0;
Expand Down Expand Up @@ -115,24 +119,25 @@ class [[eosio::contract]] erc20 : public contract {
EOSLIB_SERIALIZE(config_t, (evm_gaslimit)(evm_init_gaslimit)(evm_account)(evm_gas_token_symbol));
};
typedef eosio::singleton<"config"_n, config_t> config_singleton_t;

config_t get_config() const {
config_singleton_t config(get_self(), get_self().value);
if (!config.exists()) {
return config_t{};
} else {
return config.get();
}
eosio::check(config.exists(), "erc20 config not exist");
return config.get();
}
intx::uint256 get_minimum_natively_representable() const {
return intx::exp(10_u256, intx::uint256(evm_precision - get_config().evm_gas_token_symbol.precision()));

intx::uint256 get_minimum_natively_representable(const config_t& config) const {
return intx::exp(10_u256, intx::uint256(evm_precision - config.evm_gas_token_symbol.precision()));
}

void set_config(const config_t &v) {
config_singleton_t config(get_self(), get_self().value);
config.set(v, get_self());
}

uint64_t get_next_nonce();
void handle_erc20_transfer(const token_t &token, eosio::asset quantity, const std::string &memo);
void handle_call_upgrade(const bytes& proxy_address);

private:
eosio::name receiver_account()const;
Expand Down
2 changes: 1 addition & 1 deletion antelope_contracts/contracts/erc20/include/erc20/types.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,6 @@ constexpr uint64_t default_evm_init_gaslimit = 10000000;
constexpr eosio::name default_evm_account(eosio::name("eosio.evm"));

constexpr unsigned evm_precision = 18; // precision of native token(aka.EOS) in EVM side
constexpr eosio::symbol default_native_token_symbol("EOS", 4u);
constexpr eosio::symbol default_native_token_symbol("UOS", 4u);

} // namespace erc20
Loading
Loading