@layerzerolabs/protocol-stellar-v2 0.2.13 → 0.2.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +484 -337
- package/.turbo/turbo-lint.log +126 -56
- package/.turbo/turbo-test.log +1403 -984
- package/Cargo.lock +142 -3
- package/Cargo.toml +5 -1
- package/contracts/ERROR_SPEC.md +44 -0
- package/contracts/common-macros/src/auth.rs +113 -0
- package/contracts/common-macros/src/contract_ttl.rs +84 -0
- package/contracts/common-macros/src/lib.rs +219 -29
- package/contracts/common-macros/src/lz_contract.rs +83 -0
- package/contracts/common-macros/src/storage.rs +1 -1
- package/contracts/common-macros/src/tests/{ownable.rs → auth.rs} +48 -15
- package/contracts/common-macros/src/tests/contract_ttl.rs +662 -0
- package/contracts/common-macros/src/tests/mod.rs +3 -2
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_multisig_code.snap +20 -0
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_ownable_code.snap +24 -0
- package/contracts/common-macros/src/tests/snapshots/{common_macros__tests__ownable__snapshot_only_owner_preserves_function_signature.snap → common_macros__tests__auth__snapshot_only_auth_preserves_function_signature.snap} +4 -4
- package/contracts/common-macros/src/tests/snapshots/{common_macros__tests__contract_impl__snapshot_generated_contract_impl_code.snap → common_macros__tests__contract_ttl__snapshot_generated_contractimpl_code.snap} +26 -10
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__contract_ttl__snapshot_generated_contracttrait_code.snap +69 -0
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__storage__snapshot_generated_storage_code.snap +48 -48
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__ttl_configurable__snapshot_generated_ttl_configurable_code.snap +7 -41
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__upgradeable__snapshot_generated_upgradeable_code.snap +21 -0
- package/contracts/common-macros/src/tests/upgradeable.rs +31 -0
- package/contracts/common-macros/src/ttl_configurable.rs +21 -66
- package/contracts/common-macros/src/ttl_extendable.rs +36 -0
- package/contracts/common-macros/src/upgradeable.rs +76 -0
- package/contracts/common-macros/src/utils.rs +9 -0
- package/contracts/endpoint-v2/src/constants.rs +4 -4
- package/contracts/endpoint-v2/src/endpoint_v2.rs +58 -36
- package/contracts/endpoint-v2/src/errors.rs +4 -3
- package/contracts/endpoint-v2/src/events.rs +1 -1
- package/contracts/endpoint-v2/src/message_lib_manager.rs +18 -5
- package/contracts/endpoint-v2/src/messaging_channel.rs +11 -1
- package/contracts/endpoint-v2/src/messaging_composer.rs +11 -1
- package/contracts/endpoint-v2/src/storage.rs +1 -1
- package/contracts/endpoint-v2/src/tests/endpoint_setup.rs +175 -8
- package/contracts/endpoint-v2/src/tests/endpoint_v2/build_outbound_packet.rs +76 -0
- package/contracts/endpoint-v2/src/tests/endpoint_v2/clear.rs +342 -159
- package/contracts/endpoint-v2/src/tests/endpoint_v2/delegate.rs +3 -15
- package/contracts/endpoint-v2/src/tests/endpoint_v2/initializable.rs +20 -31
- package/contracts/endpoint-v2/src/tests/endpoint_v2/lz_receive_alert.rs +126 -164
- package/contracts/endpoint-v2/src/tests/endpoint_v2/mod.rs +1 -0
- package/contracts/endpoint-v2/src/tests/endpoint_v2/native_token.rs +0 -1
- package/contracts/endpoint-v2/src/tests/endpoint_v2/owner.rs +0 -1
- package/contracts/endpoint-v2/src/tests/endpoint_v2/pay_messaging_fees.rs +311 -304
- package/contracts/endpoint-v2/src/tests/endpoint_v2/quote.rs +423 -96
- package/contracts/endpoint-v2/src/tests/endpoint_v2/recover_token.rs +1 -1
- package/contracts/endpoint-v2/src/tests/endpoint_v2/require_oapp_auth.rs +47 -20
- package/contracts/endpoint-v2/src/tests/endpoint_v2/send.rs +373 -403
- package/contracts/endpoint-v2/src/tests/endpoint_v2/set_delegate.rs +96 -22
- package/contracts/endpoint-v2/src/tests/endpoint_v2/set_zro.rs +62 -10
- package/contracts/endpoint-v2/src/tests/endpoint_v2/transfer_ownership.rs +4 -4
- package/contracts/endpoint-v2/src/tests/endpoint_v2/ttl_config.rs +8 -11
- package/contracts/endpoint-v2/src/tests/endpoint_v2/verifiable.rs +81 -30
- package/contracts/endpoint-v2/src/tests/endpoint_v2/verify.rs +209 -76
- package/contracts/endpoint-v2/src/tests/endpoint_v2/zro.rs +0 -1
- package/contracts/endpoint-v2/src/tests/message_lib_manager/default_receive_library.rs +24 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/default_receive_library_timeout.rs +40 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/default_send_library.rs +24 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/get_config.rs +108 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/get_library_index.rs +52 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/get_receive_library.rs +92 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/get_registered_libraries.rs +74 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/get_send_library.rs +83 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/is_registered_library.rs +32 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/is_supported_eid.rs +28 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/is_valid_receive_library.rs +261 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/mod.rs +16 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/receive_library_timeout.rs +62 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/register_library.rs +65 -43
- package/contracts/endpoint-v2/src/tests/message_lib_manager/registered_libraries_count.rs +42 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/require_receive_lib_for_eid.rs +61 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/require_registered.rs +4 -6
- package/contracts/endpoint-v2/src/tests/message_lib_manager/require_send_lib_for_eid.rs +59 -0
- package/contracts/endpoint-v2/src/tests/message_lib_manager/require_supported_eid.rs +16 -2
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_config.rs +155 -51
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_receive_lib_timeout.rs +114 -92
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_receive_library.rs +235 -132
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_send_library.rs +93 -87
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_receive_library.rs +346 -245
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_receive_library_timeout.rs +406 -60
- package/contracts/endpoint-v2/src/tests/message_lib_manager/set_send_library.rs +252 -78
- package/contracts/endpoint-v2/src/tests/message_lib_manager/timeout.rs +102 -0
- package/contracts/endpoint-v2/src/tests/messaging_channel/burn.rs +212 -273
- package/contracts/endpoint-v2/src/tests/messaging_channel/clear_payload.rs +203 -0
- package/contracts/endpoint-v2/src/tests/messaging_channel/inbound.rs +94 -0
- package/contracts/endpoint-v2/src/tests/messaging_channel/inbound_nonce.rs +78 -248
- package/contracts/endpoint-v2/src/tests/messaging_channel/inbound_payload_hash.rs +7 -282
- package/contracts/endpoint-v2/src/tests/messaging_channel/lazy_inbound_nonce.rs +6 -274
- package/contracts/endpoint-v2/src/tests/messaging_channel/mod.rs +3 -2
- package/contracts/endpoint-v2/src/tests/messaging_channel/next_guid.rs +86 -178
- package/contracts/endpoint-v2/src/tests/messaging_channel/nilify.rs +328 -212
- package/contracts/endpoint-v2/src/tests/messaging_channel/outbound.rs +68 -0
- package/contracts/endpoint-v2/src/tests/messaging_channel/outbound_nonce.rs +6 -209
- package/contracts/endpoint-v2/src/tests/messaging_channel/skip.rs +207 -159
- package/contracts/endpoint-v2/src/tests/messaging_composer/clear_compose.rs +142 -153
- package/contracts/endpoint-v2/src/tests/messaging_composer/compose_queue.rs +6 -179
- package/contracts/endpoint-v2/src/tests/messaging_composer/lz_compose_alert.rs +163 -221
- package/contracts/endpoint-v2/src/tests/messaging_composer/send_compose.rs +90 -121
- package/contracts/endpoint-v2/src/tests/mock.rs +18 -4
- package/contracts/endpoint-v2/src/tests/util/build_payload.rs +4 -70
- package/contracts/endpoint-v2/src/tests/util/compute_guid.rs +2 -1
- package/contracts/endpoint-v2/src/tests/util/keccak256.rs +17 -106
- package/contracts/layerzero-views/Cargo.toml +35 -0
- package/contracts/layerzero-views/src/errors.rs +10 -0
- package/contracts/layerzero-views/src/layerzero_view.rs +226 -0
- package/contracts/layerzero-views/src/lib.rs +38 -0
- package/contracts/layerzero-views/src/storage.rs +18 -0
- package/contracts/layerzero-views/src/tests/layerzero_view_tests.rs +423 -0
- package/contracts/layerzero-views/src/tests/mod.rs +4 -0
- package/contracts/layerzero-views/src/tests/setup.rs +377 -0
- package/contracts/layerzero-views/src/types.rs +50 -0
- package/contracts/macro-integration-tests/Cargo.toml +30 -0
- package/contracts/macro-integration-tests/src/lib.rs +1 -0
- package/contracts/macro-integration-tests/tests/runtime/ownable/initialization.rs +62 -0
- package/contracts/macro-integration-tests/tests/runtime/ownable/mod.rs +22 -0
- package/contracts/macro-integration-tests/tests/runtime/ownable/only_auth_guard.rs +97 -0
- package/contracts/macro-integration-tests/tests/runtime/ownable/ownership_transfer.rs +101 -0
- package/contracts/macro-integration-tests/tests/runtime/storage/keyed_roundtrip.rs +225 -0
- package/contracts/macro-integration-tests/tests/runtime/storage/mod.rs +4 -0
- package/contracts/macro-integration-tests/tests/runtime/storage/name_override_runtime.rs +52 -0
- package/contracts/macro-integration-tests/tests/runtime/storage/ttl_extension.rs +261 -0
- package/contracts/macro-integration-tests/tests/runtime/storage/unkeyed_roundtrip.rs +137 -0
- package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/configuration.rs +113 -0
- package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/freeze.rs +139 -0
- package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/mod.rs +2 -0
- package/contracts/macro-integration-tests/tests/runtime.rs +5 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/attr_not_empty.rs +12 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/attr_not_empty.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/decreasing_discriminant.rs +12 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/decreasing_discriminant.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/non_int_discriminant.rs +21 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/non_int_discriminant.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/non_unit_variant.rs +13 -0
- package/contracts/macro-integration-tests/tests/ui/error/fail/non_unit_variant.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/error/pass/attr_on_variant_allowed.rs +20 -0
- package/contracts/macro-integration-tests/tests/ui/error/pass/basic_auto_discriminants.rs +15 -0
- package/contracts/macro-integration-tests/tests/ui/error/pass/mixed_discriminants.rs +16 -0
- package/contracts/macro-integration-tests/tests/ui/ownable/fail/only_auth_missing_env.rs +22 -0
- package/contracts/macro-integration-tests/tests/ui/ownable/fail/only_auth_missing_env.stderr +16 -0
- package/contracts/macro-integration-tests/tests/ui/ownable/pass/minimal_contract.rs +26 -0
- package/contracts/macro-integration-tests/tests/ui/ownable/pass/namespacing_and_imports.rs +21 -0
- package/contracts/macro-integration-tests/tests/ui/ownable/pass/only_auth_env_param_variants.rs +46 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/invalid_storage_type_param.rs +13 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/invalid_storage_type_param.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/missing_storage_type_param.rs +13 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/missing_storage_type_param.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/multiple_storage_kinds.rs +10 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/multiple_storage_kinds.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/multiple_type_params.rs +12 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/multiple_type_params.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/no_ttl_extension_on_non_persistent.rs +10 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/no_ttl_extension_on_non_persistent.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/non_enum_input.rs +10 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/non_enum_input.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/storage_attr_rejects_args.rs +12 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/storage_attr_rejects_args.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/tuple_variant_rejected.rs +13 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/tuple_variant_rejected.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/unknown_variant_attr.rs +13 -0
- package/contracts/macro-integration-tests/tests/ui/storage/fail/unknown_variant_attr.stderr +7 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/default_value_on_variant.rs +14 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/enum_instance_unit_basic.rs +14 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/enum_persistent_named_fields_keyed.rs +16 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/enum_temporary_unit_option.rs +15 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/name_override.rs +14 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/no_auto_ttl_extension.rs +19 -0
- package/contracts/macro-integration-tests/tests/ui/storage/pass/ttl_provider_basic.rs +15 -0
- package/contracts/macro-integration-tests/tests/ui/ttl_configurable/pass/minimal_contract.rs +44 -0
- package/contracts/macro-integration-tests/tests/ui_error.rs +11 -0
- package/contracts/macro-integration-tests/tests/ui_ownable.rs +11 -0
- package/contracts/macro-integration-tests/tests/ui_storage.rs +11 -0
- package/contracts/macro-integration-tests/tests/ui_ttl_configurable.rs +12 -0
- package/contracts/message-libs/blocked-message-lib/src/lib.rs +17 -17
- package/contracts/message-libs/message-lib-common/src/errors.rs +7 -2
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/decode_packet_header.rs +64 -0
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/encode_packet.rs +58 -0
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/encode_packet_header.rs +138 -0
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/mod.rs +6 -0
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/payload.rs +30 -0
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/payload_hash.rs +15 -0
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/test_helper.rs +39 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/append_dvn_option.rs +57 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/append_lz_receive_option.rs +49 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/append_native_drop_option.rs +73 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/convert_legacy_options.rs +280 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/extract_type_3_options.rs +126 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/left_pad_to_bytes32.rs +48 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/mod.rs +7 -0
- package/contracts/message-libs/message-lib-common/src/tests/worker_options/split_worker_options.rs +139 -0
- package/contracts/message-libs/message-lib-common/src/worker_options.rs +31 -1
- package/contracts/message-libs/simple-message-lib/src/simple_message_lib.rs +7 -9
- package/contracts/message-libs/treasury/src/errors.rs +2 -3
- package/contracts/message-libs/treasury/src/events.rs +1 -1
- package/contracts/message-libs/treasury/src/interfaces/zro_fee_lib.rs +2 -2
- package/contracts/message-libs/treasury/src/lib.rs +3 -3
- package/contracts/message-libs/treasury/src/storage.rs +3 -1
- package/contracts/message-libs/treasury/src/tests/treasury_tests.rs +1 -1
- package/contracts/message-libs/treasury/src/treasury.rs +23 -26
- package/contracts/message-libs/uln-302/Cargo.toml +1 -1
- package/contracts/message-libs/uln-302/src/errors.rs +0 -5
- package/contracts/message-libs/uln-302/src/events.rs +5 -6
- package/contracts/message-libs/uln-302/src/receive_uln.rs +37 -56
- package/contracts/message-libs/uln-302/src/send_uln.rs +112 -138
- package/contracts/message-libs/uln-302/src/storage.rs +5 -5
- package/contracts/message-libs/uln-302/src/tests/receive_uln302/effective_receive_uln_config.rs +5 -7
- package/contracts/message-libs/uln-302/src/tests/receive_uln302/set_default_receive_uln_configs.rs +3 -3
- package/contracts/message-libs/uln-302/src/tests/send_uln302/effective_send_uln_config.rs +6 -9
- package/contracts/message-libs/uln-302/src/tests/send_uln302/set_default_executor_configs.rs +2 -2
- package/contracts/message-libs/uln-302/src/tests/send_uln302/set_default_send_uln_configs.rs +3 -3
- package/contracts/message-libs/uln-302/src/tests/setup.rs +9 -0
- package/contracts/message-libs/uln-302/src/tests/testing_utils.rs +5 -0
- package/contracts/message-libs/uln-302/src/tests/uln302/get_app_receive_uln_config.rs +1 -2
- package/contracts/message-libs/uln-302/src/tests/uln302/get_app_send_uln_config.rs +1 -2
- package/contracts/message-libs/uln-302/src/tests/uln302/set_config.rs +37 -55
- package/contracts/message-libs/uln-302/src/uln302.rs +10 -25
- package/contracts/oapps/counter/Cargo.toml +14 -1
- package/contracts/oapps/counter/integration_tests/mod.rs +4 -1
- package/contracts/oapps/counter/integration_tests/setup_sml.rs +169 -0
- package/contracts/oapps/counter/integration_tests/setup_uln.rs +997 -0
- package/contracts/oapps/counter/integration_tests/signing.rs +62 -0
- package/contracts/oapps/counter/integration_tests/test_with_sml.rs +24 -55
- package/contracts/oapps/counter/integration_tests/test_with_uln.rs +314 -0
- package/contracts/oapps/counter/integration_tests/utils.rs +196 -53
- package/contracts/oapps/counter/src/counter.rs +67 -44
- package/contracts/oapps/counter/src/tests/mod.rs +0 -13
- package/contracts/oapps/counter/src/tests/test_counter.rs +5 -7
- package/contracts/oapps/oapp/src/errors.rs +5 -1
- package/contracts/oapps/oapp/src/macro_tests/test_macros.rs +318 -221
- package/contracts/oapps/oapp/src/oapp_core.rs +36 -21
- package/contracts/oapps/oapp/src/oapp_options_type3.rs +48 -12
- package/contracts/oapps/oapp/src/oapp_receiver.rs +106 -41
- package/contracts/oapps/oapp/src/oapp_sender.rs +26 -34
- package/contracts/oapps/oapp/src/tests/test_oapp_core.rs +9 -9
- package/contracts/oapps/oapp/src/tests/test_oapp_options_type3.rs +25 -18
- package/contracts/oapps/oapp/src/tests/test_oapp_receiver.rs +7 -8
- package/contracts/oapps/oapp/src/tests/test_oapp_sender.rs +14 -16
- package/contracts/oapps/oapp-macros/src/generators.rs +128 -0
- package/contracts/oapps/oapp-macros/src/lib.rs +211 -0
- package/contracts/oapps/oft/integration-tests/setup.rs +34 -9
- package/contracts/oapps/oft/integration-tests/utils.rs +1 -1
- package/contracts/oapps/oft/src/errors.rs +6 -1
- package/contracts/oapps/oft/src/extensions/oft_fee.rs +13 -13
- package/contracts/oapps/oft/src/extensions/pausable.rs +5 -5
- package/contracts/oapps/oft/src/extensions/rate_limiter.rs +23 -23
- package/contracts/oapps/oft/src/lib.rs +4 -2
- package/contracts/oapps/oft/src/oft.rs +31 -71
- package/contracts/oapps/oft/src/oft_impl.rs +201 -0
- package/contracts/oapps/oft/src/oft_types/lock_unlock.rs +2 -4
- package/contracts/oapps/oft/src/oft_types/mint_burn.rs +1 -4
- package/contracts/oapps/oft/src/storage.rs +2 -0
- package/contracts/oapps/oft/src/tests/extensions/setup.rs +60 -31
- package/contracts/oapps/oft/src/tests/extensions/test_oft_fee.rs +5 -3
- package/contracts/oapps/oft/src/tests/extensions/test_pausable.rs +5 -3
- package/contracts/oapps/oft/src/tests/extensions/test_rate_limiter.rs +6 -4
- package/contracts/oapps/oft/src/tests/test_decimals.rs +2 -2
- package/contracts/oapps/oft/src/tests/test_oft_msg_codec.rs +1 -2
- package/contracts/oapps/oft/src/tests/test_send.rs +4 -4
- package/contracts/oapps/oft/src/tests/test_utils.rs +122 -81
- package/contracts/oapps/oft/src/types.rs +20 -0
- package/contracts/oapps/oft-std/Cargo.toml +6 -0
- package/contracts/oapps/oft-std/integration-tests/extensions/mod.rs +3 -0
- package/contracts/oapps/oft-std/integration-tests/extensions/test_oft_fee.rs +157 -0
- package/contracts/oapps/oft-std/integration-tests/extensions/test_pausable.rs +162 -0
- package/contracts/oapps/oft-std/integration-tests/extensions/test_rate_limiter.rs +186 -0
- package/contracts/oapps/oft-std/integration-tests/mod.rs +3 -0
- package/contracts/oapps/{counter/integration_tests → oft-std/integration-tests}/setup.rs +76 -30
- package/contracts/oapps/oft-std/integration-tests/utils.rs +427 -0
- package/contracts/oapps/oft-std/src/lib.rs +12 -1
- package/contracts/oapps/oft-std/src/oft.rs +141 -26
- package/contracts/upgrader/Cargo.toml +19 -0
- package/contracts/upgrader/src/lib.rs +96 -0
- package/contracts/upgrader/src/tests/mod.rs +1 -0
- package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract1.wasm +0 -0
- package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract2.wasm +0 -0
- package/contracts/upgrader/src/tests/test_upgrader.rs +120 -0
- package/contracts/utils/src/auth.rs +44 -0
- package/contracts/utils/src/errors.rs +32 -5
- package/contracts/utils/src/lib.rs +5 -1
- package/contracts/utils/src/multisig.rs +211 -0
- package/contracts/utils/src/ownable.rs +50 -60
- package/contracts/utils/src/tests/buffer_reader.rs +6 -6
- package/contracts/utils/src/tests/buffer_writer.rs +6 -6
- package/contracts/utils/src/tests/bytes_ext.rs +2 -4
- package/contracts/utils/src/tests/mod.rs +4 -1
- package/contracts/utils/src/tests/multisig.rs +731 -0
- package/contracts/utils/src/tests/option_ext.rs +18 -0
- package/contracts/utils/src/tests/ownable.rs +22 -70
- package/contracts/utils/src/tests/ttl_configurable.rs +607 -0
- package/contracts/utils/src/tests/upgradeable.rs +290 -0
- package/contracts/utils/src/ttl_configurable.rs +153 -0
- package/contracts/utils/src/ttl_extendable.rs +27 -0
- package/contracts/utils/src/upgradeable.rs +56 -0
- package/contracts/workers/dvn/Cargo.toml +2 -2
- package/contracts/workers/dvn/src/auth.rs +24 -35
- package/contracts/workers/dvn/src/dvn.rs +23 -14
- package/contracts/workers/dvn/src/errors.rs +1 -7
- package/contracts/workers/dvn/src/events.rs +1 -14
- package/contracts/workers/dvn/src/interfaces/dvn.rs +2 -2
- package/contracts/workers/dvn/src/interfaces/mod.rs +0 -2
- package/contracts/workers/dvn/src/storage.rs +3 -13
- package/contracts/workers/dvn/src/tests/auth.rs +4 -4
- package/contracts/workers/dvn/src/tests/dvn.rs +1 -2
- package/contracts/workers/dvn/src/tests/multisig/set_signer.rs +7 -8
- package/contracts/workers/dvn/src/tests/multisig/set_threshold.rs +11 -8
- package/contracts/workers/dvn/src/tests/multisig/verify_signatures.rs +11 -12
- package/contracts/workers/dvn/src/tests/setup.rs +5 -5
- package/contracts/workers/dvn-fee-lib/Cargo.toml +0 -1
- package/contracts/workers/dvn-fee-lib/src/dvn_fee_lib.rs +45 -16
- package/contracts/workers/dvn-fee-lib/src/errors.rs +3 -2
- package/contracts/workers/dvn-fee-lib/src/lib.rs +5 -11
- package/contracts/workers/dvn-fee-lib/src/tests/dvn_fee_lib.rs +30 -16
- package/contracts/workers/executor/src/auth.rs +80 -16
- package/contracts/workers/executor/src/executor.rs +17 -29
- package/contracts/workers/executor/src/storage.rs +2 -9
- package/contracts/workers/executor-fee-lib/Cargo.toml +1 -1
- package/contracts/workers/executor-fee-lib/src/errors.rs +9 -7
- package/contracts/workers/executor-fee-lib/src/executor_fee_lib.rs +153 -121
- package/contracts/workers/executor-helper/Cargo.toml +1 -6
- package/contracts/workers/executor-helper/src/executor_helper.rs +53 -73
- package/contracts/workers/executor-helper/src/lib.rs +1 -7
- package/contracts/workers/price-feed/Cargo.toml +1 -2
- package/contracts/workers/price-feed/src/errors.rs +3 -2
- package/contracts/workers/price-feed/src/lib.rs +5 -6
- package/contracts/workers/price-feed/src/price_feed.rs +42 -23
- package/contracts/workers/worker/Cargo.toml +4 -0
- package/contracts/workers/worker/src/errors.rs +4 -0
- package/contracts/workers/worker/src/interfaces/price_feed.rs +3 -3
- package/contracts/workers/worker/src/lib.rs +2 -2
- package/contracts/workers/worker/src/tests/mod.rs +4 -0
- package/contracts/workers/worker/src/tests/setup.rs +147 -0
- package/contracts/workers/worker/src/tests/worker.rs +502 -0
- package/contracts/workers/worker/src/worker.rs +28 -30
- package/package.json +8 -5
- package/sdk/.turbo/turbo-build.log +1 -0
- package/sdk/.turbo/turbo-test.log +1009 -0
- package/sdk/dist/generated/bml.d.ts +104 -37
- package/sdk/dist/generated/bml.js +83 -42
- package/sdk/dist/generated/counter.d.ts +334 -175
- package/sdk/dist/generated/counter.js +109 -63
- package/sdk/dist/generated/dvn.d.ts +1985 -0
- package/sdk/dist/generated/dvn.js +326 -0
- package/sdk/dist/generated/dvn_fee_lib.d.ts +690 -0
- package/sdk/dist/generated/dvn_fee_lib.js +163 -0
- package/sdk/dist/generated/endpoint.d.ts +155 -46
- package/sdk/dist/generated/endpoint.js +93 -50
- package/sdk/dist/generated/executor.d.ts +1841 -0
- package/sdk/dist/generated/executor.js +312 -0
- package/sdk/dist/generated/executor_fee_lib.d.ts +1083 -0
- package/sdk/dist/generated/executor_fee_lib.js +255 -0
- package/sdk/dist/generated/executor_helper.d.ts +981 -0
- package/sdk/dist/generated/executor_helper.js +236 -0
- package/sdk/dist/generated/oft_std.d.ts +1722 -0
- package/sdk/dist/generated/oft_std.js +316 -0
- package/sdk/dist/generated/price_feed.d.ts +1077 -0
- package/sdk/dist/generated/price_feed.js +210 -0
- package/sdk/dist/generated/sml.d.ts +171 -56
- package/sdk/dist/generated/sml.js +111 -62
- package/sdk/dist/generated/treasury.d.ts +896 -0
- package/sdk/dist/generated/treasury.js +219 -0
- package/sdk/dist/generated/uln302.d.ts +175 -75
- package/sdk/dist/generated/uln302.js +126 -82
- package/sdk/dist/generated/upgrader.d.ts +70 -0
- package/sdk/dist/generated/upgrader.js +19 -0
- package/sdk/dist/index.d.ts +10 -0
- package/sdk/dist/index.js +14 -0
- package/sdk/dist/wasm/blocked-message-lib.d.ts +1 -0
- package/sdk/dist/wasm/blocked-message-lib.js +2 -0
- package/sdk/dist/wasm/counter.d.ts +1 -0
- package/sdk/dist/wasm/counter.js +2 -0
- package/sdk/dist/wasm/dvn-fee-lib.d.ts +1 -0
- package/sdk/dist/wasm/dvn-fee-lib.js +2 -0
- package/sdk/dist/wasm/dvn.d.ts +1 -0
- package/sdk/dist/wasm/dvn.js +2 -0
- package/sdk/dist/wasm/endpoint-v2.d.ts +1 -0
- package/sdk/dist/wasm/endpoint-v2.js +2 -0
- package/sdk/dist/wasm/executor-fee-lib.d.ts +1 -0
- package/sdk/dist/wasm/executor-fee-lib.js +2 -0
- package/sdk/dist/wasm/executor-helper.d.ts +1 -0
- package/sdk/dist/wasm/executor-helper.js +2 -0
- package/sdk/dist/wasm/executor.d.ts +1 -0
- package/sdk/dist/wasm/executor.js +2 -0
- package/sdk/dist/wasm/layerzero-views.d.ts +1 -0
- package/sdk/dist/wasm/layerzero-views.js +2 -0
- package/sdk/dist/wasm/oft-std.d.ts +1 -0
- package/sdk/dist/wasm/oft-std.js +2 -0
- package/sdk/dist/wasm/price-feed.d.ts +1 -0
- package/sdk/dist/wasm/price-feed.js +2 -0
- package/sdk/dist/wasm/simple-message-lib.d.ts +1 -0
- package/sdk/dist/wasm/simple-message-lib.js +2 -0
- package/sdk/dist/wasm/treasury.d.ts +1 -0
- package/sdk/dist/wasm/treasury.js +2 -0
- package/sdk/dist/wasm/uln302.d.ts +1 -0
- package/sdk/dist/wasm/uln302.js +2 -0
- package/sdk/dist/wasm/upgrader.d.ts +1 -0
- package/sdk/dist/wasm/upgrader.js +2 -0
- package/sdk/dist/wasm.d.ts +15 -0
- package/sdk/dist/wasm.js +15 -0
- package/sdk/package.json +7 -4
- package/sdk/src/index.ts +17 -0
- package/sdk/test/counter-sml.test.ts +376 -0
- package/sdk/test/counter-uln.test.ts +493 -0
- package/sdk/test/{oft.test.ts → oft-sml.test.ts} +187 -323
- package/sdk/test/suites/constants.ts +22 -2
- package/sdk/test/suites/dummyContractClient.ts +169 -0
- package/sdk/test/suites/globalSetup.ts +450 -0
- package/sdk/test/suites/localnet.ts +23 -6
- package/sdk/test/upgrader.test.ts +300 -0
- package/sdk/test/utils.ts +558 -85
- package/sdk/vitest.config.ts +21 -0
- package/tools/ts-bindings-gen/src/main.rs +12 -1
- package/turbo.json +2 -0
- package/contracts/common-macros/src/contract_impl.rs +0 -47
- package/contracts/common-macros/src/ownable.rs +0 -59
- package/contracts/common-macros/src/tests/contract_impl.rs +0 -381
- package/contracts/common-macros/src/tests/snapshots/common_macros__tests__ownable__snapshot_generated_ownable_code.snap +0 -32
- package/contracts/endpoint-v2/src/tests/messaging_channel/clear.rs +0 -316
- package/contracts/endpoint-v2/src/tests/messaging_channel/internal.rs +0 -388
- package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1.rs +0 -162
- package/contracts/message-libs/message-lib-common/src/tests/worker_options.rs +0 -319
- package/contracts/oapp-macros/src/lib.rs +0 -154
- package/contracts/oapp-macros/src/oapp_core.rs +0 -40
- package/contracts/oapp-macros/src/oapp_full.rs +0 -21
- package/contracts/oapp-macros/src/oapp_options_type3.rs +0 -31
- package/contracts/oapp-macros/src/oapp_receiver.rs +0 -48
- package/contracts/oapp-macros/src/oapp_sender.rs +0 -21
- package/contracts/oapp-macros/src/util.rs +0 -107
- package/contracts/oapps/oft/src/constants.rs +0 -5
- package/contracts/oapps/oft/src/default_oft_impl.rs +0 -146
- package/contracts/utils/src/tests/ttl.rs +0 -421
- package/contracts/utils/src/ttl.rs +0 -123
- package/contracts/workers/dvn/src/interfaces/multisig.rs +0 -56
- package/contracts/workers/dvn/src/multisig.rs +0 -153
- package/sdk/test/index.test.ts +0 -376
- /package/contracts/{oapp-macros → oapps/oapp-macros}/Cargo.toml +0 -0
|
@@ -1,10 +1,19 @@
|
|
|
1
|
-
use common_macros::{
|
|
1
|
+
use common_macros::{contract_trait, only_auth, storage};
|
|
2
2
|
use endpoint_v2::LayerZeroEndpointV2Client;
|
|
3
|
-
use soroban_sdk::{contractevent,
|
|
4
|
-
use utils::ownable::Ownable;
|
|
5
|
-
use utils::ownable::OwnableInitializer;
|
|
3
|
+
use soroban_sdk::{contractevent, Address, BytesN, Env};
|
|
4
|
+
use utils::ownable::{Ownable, OwnableInitializer};
|
|
6
5
|
|
|
7
|
-
|
|
6
|
+
/// Initializes the OApp with the specified configuration.
|
|
7
|
+
///
|
|
8
|
+
/// This function sets up the OApp by initializing ownership, storing the LayerZero endpoint,
|
|
9
|
+
/// and optionally setting a delegate address for the endpoint.
|
|
10
|
+
///
|
|
11
|
+
/// # Arguments
|
|
12
|
+
/// * `env` - The Soroban environment
|
|
13
|
+
/// * `owner` - The address that will own this OApp
|
|
14
|
+
/// * `endpoint` - The LayerZero endpoint address to associate with this OApp
|
|
15
|
+
/// * `delegate` - Optional delegate address to set on the endpoint for this OApp
|
|
16
|
+
pub fn initialize_oapp<T: OAppCore + OwnableInitializer>(
|
|
8
17
|
env: &Env,
|
|
9
18
|
owner: &Address,
|
|
10
19
|
endpoint: &Address,
|
|
@@ -12,17 +21,16 @@ pub fn oapp_initialize<T: OAppCore + OwnableInitializer>(
|
|
|
12
21
|
) {
|
|
13
22
|
T::init_owner(env, owner);
|
|
14
23
|
OAppCoreStorage::set_endpoint(env, endpoint);
|
|
15
|
-
|
|
16
|
-
let endpoint_client = endpoint_v2::LayerZeroEndpointV2Client::new(env, endpoint);
|
|
17
|
-
endpoint_client.set_delegate(&env.current_contract_address(), delegate);
|
|
24
|
+
LayerZeroEndpointV2Client::new(env, endpoint).set_delegate(&env.current_contract_address(), delegate);
|
|
18
25
|
}
|
|
19
26
|
|
|
20
27
|
// =====================================================
|
|
21
|
-
// OAppCore Storage
|
|
28
|
+
// OAppCore Storage and Events
|
|
22
29
|
// =====================================================
|
|
23
30
|
|
|
24
31
|
#[storage]
|
|
25
32
|
pub enum OAppCoreStorage {
|
|
33
|
+
// Immutable endpoint address
|
|
26
34
|
#[instance(Address)]
|
|
27
35
|
Endpoint,
|
|
28
36
|
|
|
@@ -37,22 +45,26 @@ pub struct PeerSet {
|
|
|
37
45
|
pub peer: Option<BytesN<32>>,
|
|
38
46
|
}
|
|
39
47
|
|
|
40
|
-
|
|
41
|
-
|
|
48
|
+
// =====================================================
|
|
49
|
+
// OAppCore Interface and Default Implementation
|
|
50
|
+
// =====================================================
|
|
51
|
+
|
|
52
|
+
#[contract_trait]
|
|
53
|
+
pub trait OAppCore: Ownable {
|
|
42
54
|
/// Retrieves the OApp version information.
|
|
43
55
|
///
|
|
44
56
|
/// # Returns
|
|
45
57
|
/// A tuple containing:
|
|
46
|
-
/// - `sender_version`: The version of the OAppSender
|
|
47
|
-
/// - `receiver_version`: The version of the OAppReceiver
|
|
58
|
+
/// - `sender_version`: The version of the OAppSender
|
|
59
|
+
/// - `receiver_version`: The version of the OAppReceiver
|
|
48
60
|
fn oapp_version(_env: &Env) -> (u64, u64) {
|
|
49
|
-
(
|
|
61
|
+
(1, 1)
|
|
50
62
|
}
|
|
51
63
|
|
|
52
|
-
/// Retrieves the LayerZero endpoint associated with the OApp.
|
|
64
|
+
/// Retrieves the LayerZero endpoint address associated with the OApp.
|
|
53
65
|
///
|
|
54
66
|
/// # Returns
|
|
55
|
-
/// The LayerZero endpoint
|
|
67
|
+
/// The LayerZero endpoint address
|
|
56
68
|
fn endpoint(env: &Env) -> Address {
|
|
57
69
|
OAppCoreStorage::endpoint(env).unwrap()
|
|
58
70
|
}
|
|
@@ -73,7 +85,7 @@ pub trait OAppCore: Ownable + Sized {
|
|
|
73
85
|
/// # Arguments
|
|
74
86
|
/// * `eid` - The endpoint ID
|
|
75
87
|
/// * `peer` - The address of the peer to be associated with the corresponding endpoint, or None to remove the peer
|
|
76
|
-
#[
|
|
88
|
+
#[only_auth]
|
|
77
89
|
fn set_peer(env: &Env, eid: u32, peer: &Option<BytesN<32>>) {
|
|
78
90
|
OAppCoreStorage::set_or_remove_peer(env, eid, peer);
|
|
79
91
|
PeerSet { eid, peer: peer.clone() }.publish(env);
|
|
@@ -83,10 +95,13 @@ pub trait OAppCore: Ownable + Sized {
|
|
|
83
95
|
///
|
|
84
96
|
/// # Arguments
|
|
85
97
|
/// * `delegate` - The address of the delegate to be set, or None to remove the delegate
|
|
86
|
-
#[
|
|
98
|
+
#[only_auth]
|
|
87
99
|
fn set_delegate(env: &Env, delegate: &Option<Address>) {
|
|
88
|
-
|
|
89
|
-
let endpoint_client = LayerZeroEndpointV2Client::new(env, &endpoint);
|
|
90
|
-
endpoint_client.set_delegate(&env.current_contract_address(), delegate);
|
|
100
|
+
endpoint_client::<Self>(env).set_delegate(&env.current_contract_address(), delegate);
|
|
91
101
|
}
|
|
92
102
|
}
|
|
103
|
+
|
|
104
|
+
/// Returns a client for the LayerZero endpoint.
|
|
105
|
+
pub fn endpoint_client<'a, T: OAppCore>(env: &'a Env) -> LayerZeroEndpointV2Client<'a> {
|
|
106
|
+
LayerZeroEndpointV2Client::new(env, &T::endpoint(env))
|
|
107
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
use crate::errors::OAppError;
|
|
2
|
-
use common_macros::{
|
|
3
|
-
use soroban_sdk::{assert_with_error, contractevent,
|
|
4
|
-
use utils::ownable::Ownable;
|
|
2
|
+
use common_macros::{contract_trait, only_auth, storage};
|
|
3
|
+
use soroban_sdk::{assert_with_error, contractevent, contracttype, panic_with_error, Bytes, Env, Vec};
|
|
4
|
+
use utils::{buffer_reader::BufferReader, ownable::Ownable};
|
|
5
5
|
|
|
6
|
-
pub const OPTION_TYPE3:
|
|
6
|
+
pub const OPTION_TYPE3: u16 = 3;
|
|
7
7
|
|
|
8
8
|
#[contracttype]
|
|
9
9
|
#[derive(Clone, Debug, Eq, PartialEq)]
|
|
@@ -30,13 +30,31 @@ pub struct EnforcedOptionSet {
|
|
|
30
30
|
// OAppOptionsType3 Trait and Default Implementation
|
|
31
31
|
// =========================================================================
|
|
32
32
|
|
|
33
|
-
#[
|
|
34
|
-
pub trait OAppOptionsType3: Ownable
|
|
33
|
+
#[contract_trait]
|
|
34
|
+
pub trait OAppOptionsType3: Ownable {
|
|
35
|
+
/// Retrieves the enforced options for a given endpoint and message type.
|
|
36
|
+
///
|
|
37
|
+
/// # Arguments
|
|
38
|
+
/// * `eid` - The endpoint ID
|
|
39
|
+
/// * `msg_type` - The OApp message type
|
|
40
|
+
///
|
|
41
|
+
/// # Returns
|
|
42
|
+
/// The enforced options for the given endpoint and message type
|
|
35
43
|
fn enforced_options(env: &Env, eid: u32, msg_type: u32) -> Bytes {
|
|
36
44
|
OAppOptionsType3Storage::enforced_options(env, eid, msg_type)
|
|
37
45
|
}
|
|
38
46
|
|
|
39
|
-
|
|
47
|
+
/// Sets the enforced options for specific endpoint and message type combinations.
|
|
48
|
+
///
|
|
49
|
+
/// Only the `authorizer` of the OApp can call this function.
|
|
50
|
+
/// Provides a way for the OApp to enforce things like paying for PreCrime, AND/OR minimum dst lzReceive gas amounts etc.
|
|
51
|
+
/// These enforced options can vary as the potential options/execution on the remote may differ as per the msg_type.
|
|
52
|
+
/// e.g. Amount of lzReceive() gas necessary to deliver a lzCompose() message adds overhead you don't want to pay
|
|
53
|
+
/// if you are only making a standard LayerZero message ie. lzReceive() WITHOUT sendCompose().
|
|
54
|
+
///
|
|
55
|
+
/// # Arguments
|
|
56
|
+
/// * `options` - A vector of EnforcedOptionParam structures specifying enforced options
|
|
57
|
+
#[only_auth]
|
|
40
58
|
fn set_enforced_options(env: &Env, options: Vec<EnforcedOptionParam>) {
|
|
41
59
|
for option in &options {
|
|
42
60
|
assert_option_type3(env, &option.options);
|
|
@@ -45,6 +63,20 @@ pub trait OAppOptionsType3: Ownable + Sized {
|
|
|
45
63
|
EnforcedOptionSet { enforced_option_params: options }.publish(env);
|
|
46
64
|
}
|
|
47
65
|
|
|
66
|
+
/// Combines options for a given endpoint and message type.
|
|
67
|
+
///
|
|
68
|
+
/// If there is an enforced lzReceive option:
|
|
69
|
+
/// - {gas_limit: 200k, value: 1 XLM} AND a caller supplies a lzReceive option: {gas_limit: 100k, value: 0.5 XLM}
|
|
70
|
+
/// - The resulting options will be {gas_limit: 300k, value: 1.5 XLM} when the message is executed on the remote lz_receive() function.
|
|
71
|
+
/// The presence of duplicated options is handled off-chain in the verifier/executor.
|
|
72
|
+
///
|
|
73
|
+
/// # Arguments
|
|
74
|
+
/// * `eid` - The endpoint ID
|
|
75
|
+
/// * `msg_type` - The OApp message type
|
|
76
|
+
/// * `extra_options` - Additional options passed by the caller
|
|
77
|
+
///
|
|
78
|
+
/// # Returns
|
|
79
|
+
/// The combination of caller specified options AND enforced options
|
|
48
80
|
fn combine_options(env: &Env, eid: u32, msg_type: u32, extra_options: &Bytes) -> Bytes {
|
|
49
81
|
let mut enforced_options = Self::enforced_options(env, eid, msg_type);
|
|
50
82
|
|
|
@@ -71,10 +103,14 @@ pub trait OAppOptionsType3: Ownable + Sized {
|
|
|
71
103
|
// Helpers Functions
|
|
72
104
|
// =========================================================================
|
|
73
105
|
|
|
106
|
+
/// Asserts that the provided options are of type 3.
|
|
107
|
+
///
|
|
108
|
+
/// # Arguments
|
|
109
|
+
/// * `options` - The options to be checked
|
|
110
|
+
///
|
|
111
|
+
/// # Panics
|
|
112
|
+
/// If the options are not of type 3
|
|
74
113
|
pub fn assert_option_type3(env: &Env, options: &Bytes) {
|
|
75
|
-
let
|
|
76
|
-
|
|
77
|
-
let options_version = u16::from_be_bytes(options_version_bytes);
|
|
78
|
-
|
|
79
|
-
assert_with_error!(env, options_version as u32 == OPTION_TYPE3, OAppError::InvalidOptions);
|
|
114
|
+
let options_type = BufferReader::new(options).read_u16();
|
|
115
|
+
assert_with_error!(env, options_type == OPTION_TYPE3, OAppError::InvalidOptions);
|
|
80
116
|
}
|
|
@@ -1,43 +1,76 @@
|
|
|
1
|
-
use crate::{
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
use crate::{
|
|
2
|
+
errors::OAppError,
|
|
3
|
+
oapp_core::{endpoint_client, OAppCore},
|
|
4
|
+
};
|
|
5
|
+
use common_macros::contract_trait;
|
|
6
|
+
use endpoint_v2::Origin;
|
|
7
|
+
use soroban_sdk::{assert_with_error, token::TokenClient, Address, Bytes, BytesN, Env};
|
|
8
|
+
|
|
9
|
+
// =====================================================
|
|
10
|
+
// LzReceiveInternal Trait
|
|
11
|
+
// =====================================================
|
|
12
|
+
|
|
13
|
+
/// Application-specific handler for incoming LayerZero messages.
|
|
14
|
+
///
|
|
15
|
+
/// Implement this trait to define how your OApp processes cross-chain messages.
|
|
16
|
+
/// The default `OAppReceiver::lz_receive` calls `clear_payload_and_transfer` first,
|
|
17
|
+
/// then delegates to your `__lz_receive` implementation.
|
|
18
|
+
///
|
|
19
|
+
/// **Important:** Do NOT call `clear_payload_and_transfer` in your implementation -
|
|
20
|
+
/// it is handled automatically by the default `lz_receive`.
|
|
21
|
+
pub trait LzReceiveInternal {
|
|
22
|
+
/// Processes a verified cross-chain message.
|
|
23
|
+
///
|
|
24
|
+
/// Called after payload verification. Implement your message handling logic here.
|
|
25
|
+
fn __lz_receive(
|
|
26
|
+
env: &Env,
|
|
27
|
+
origin: &Origin,
|
|
28
|
+
guid: &BytesN<32>,
|
|
29
|
+
message: &Bytes,
|
|
30
|
+
extra_data: &Bytes,
|
|
31
|
+
executor: &Address,
|
|
32
|
+
value: i128,
|
|
33
|
+
);
|
|
34
|
+
}
|
|
4
35
|
|
|
5
36
|
// =====================================================
|
|
6
37
|
// OAppReceiver Trait
|
|
7
38
|
// =====================================================
|
|
8
39
|
|
|
9
|
-
///
|
|
40
|
+
/// Receiver trait for OApps that accept cross-chain messages from LayerZero.
|
|
10
41
|
///
|
|
11
|
-
///
|
|
12
|
-
///
|
|
13
|
-
/// for `allow_initialize_path`, `next_nonce`, and `lz_receive`, which allows the endpoint
|
|
14
|
-
/// to call these methods via `LayerZeroReceiverClient` (client calls are resolved by function name).
|
|
42
|
+
/// Mirrors `ILayerZeroReceiver` function signatures, allowing the executor to call
|
|
43
|
+
/// these methods via `LayerZeroReceiverClient`.
|
|
15
44
|
///
|
|
16
45
|
/// # Default Implementations
|
|
17
|
-
///
|
|
18
|
-
///
|
|
19
|
-
///
|
|
20
|
-
///
|
|
21
|
-
///
|
|
22
|
-
///
|
|
46
|
+
/// | Method | Behavior |
|
|
47
|
+
/// |--------|----------|
|
|
48
|
+
/// | `allow_initialize_path` | Returns true if origin sender matches configured peer |
|
|
49
|
+
/// | `next_nonce` | Returns 0 (unordered delivery) |
|
|
50
|
+
/// | `lz_receive` | Verifies payload, then calls `LzReceiveInternal::__lz_receive` |
|
|
51
|
+
/// | `is_compose_msg_sender` | Returns true if sender is current contract |
|
|
23
52
|
///
|
|
24
53
|
/// # Usage
|
|
25
|
-
/// When using `#[oapp_macros::oapp]`, the macro generates `lz_receive` that
|
|
26
|
-
/// automatically calls `verify_and_clear_payload` before delegating to `__lz_receive`.
|
|
27
|
-
/// **Do NOT call `verify_and_clear_payload` in your `__lz_receive` implementation.**
|
|
28
54
|
///
|
|
29
55
|
/// ```ignore
|
|
56
|
+
/// use oapp::oapp_receiver::LzReceiveInternal;
|
|
57
|
+
///
|
|
30
58
|
/// #[oapp_macros::oapp]
|
|
31
59
|
/// pub struct MyOApp;
|
|
32
60
|
///
|
|
33
|
-
/// impl MyOApp {
|
|
34
|
-
///
|
|
35
|
-
///
|
|
61
|
+
/// impl LzReceiveInternal for MyOApp {
|
|
62
|
+
/// fn __lz_receive(env: &Env, origin: &Origin, guid: &BytesN<32>,
|
|
63
|
+
/// message: &Bytes, extra_data: &Bytes, executor: &Address, value: i128) {
|
|
64
|
+
/// // Your message handling logic here
|
|
36
65
|
/// }
|
|
37
66
|
/// }
|
|
38
67
|
/// ```
|
|
39
|
-
|
|
40
|
-
|
|
68
|
+
///
|
|
69
|
+
/// # Customization
|
|
70
|
+
/// For custom behavior (e.g., ordered nonce enforcement), use `#[oapp(custom = [receiver])]`
|
|
71
|
+
/// and implement both `LzReceiveInternal` and `OAppReceiver`.
|
|
72
|
+
#[contract_trait]
|
|
73
|
+
pub trait OAppReceiver: OAppCore + LzReceiveInternal {
|
|
41
74
|
/// Checks if a messaging path can be initialized for the given origin.
|
|
42
75
|
///
|
|
43
76
|
/// # Arguments
|
|
@@ -50,24 +83,37 @@ pub trait OAppReceiver: OAppCore {
|
|
|
50
83
|
peer.is_some_and(|peer| peer == origin.sender)
|
|
51
84
|
}
|
|
52
85
|
|
|
53
|
-
///
|
|
54
|
-
///
|
|
86
|
+
/// Retrieves the next nonce for a given source endpoint and sender address.
|
|
87
|
+
///
|
|
88
|
+
/// The path nonce starts from 1. If 0 is returned it means that there is NO nonce ordered enforcement.
|
|
89
|
+
/// This is required by the off-chain executor to determine if the OApp expects message execution to be ordered.
|
|
90
|
+
/// This is also enforced by the OApp.
|
|
91
|
+
/// By default this is NOT enabled, i.e. next_nonce is hardcoded to return 0.
|
|
55
92
|
///
|
|
56
93
|
/// # Arguments
|
|
57
94
|
/// * `src_eid` - The source endpoint ID
|
|
58
95
|
/// * `sender` - The sender OApp address
|
|
96
|
+
///
|
|
97
|
+
/// # Returns
|
|
98
|
+
/// The next nonce
|
|
59
99
|
fn next_nonce(_env: &Env, _src_eid: u32, _sender: &BytesN<32>) -> u64 {
|
|
60
100
|
0
|
|
61
101
|
}
|
|
62
102
|
|
|
63
|
-
///
|
|
103
|
+
/// Entry point for receiving messages or packets from the LayerZero endpoint.
|
|
104
|
+
///
|
|
105
|
+
/// The default implementation calls `clear_payload_and_transfer` to validate the message
|
|
106
|
+
/// and clear it from the endpoint, then delegates to `__lz_receive` for application logic.
|
|
64
107
|
///
|
|
65
108
|
/// # Arguments
|
|
66
|
-
/// * `executor` - The
|
|
67
|
-
/// * `origin` - The origin information
|
|
68
|
-
///
|
|
69
|
-
///
|
|
70
|
-
///
|
|
109
|
+
/// * `executor` - The address of the executor for the received message
|
|
110
|
+
/// * `origin` - The origin information containing the source endpoint and sender address:
|
|
111
|
+
/// - `src_eid`: The source chain endpoint ID
|
|
112
|
+
/// - `sender`: The sender address on the source chain
|
|
113
|
+
/// - `nonce`: The nonce of the message
|
|
114
|
+
/// * `guid` - The unique identifier for the received LayerZero message
|
|
115
|
+
/// * `message` - The payload of the received message
|
|
116
|
+
/// * `extra_data` - Additional arbitrary data provided by the corresponding executor
|
|
71
117
|
/// * `value` - The native token value sent with the message
|
|
72
118
|
fn lz_receive(
|
|
73
119
|
env: &Env,
|
|
@@ -77,7 +123,10 @@ pub trait OAppReceiver: OAppCore {
|
|
|
77
123
|
message: &Bytes,
|
|
78
124
|
extra_data: &Bytes,
|
|
79
125
|
value: i128,
|
|
80
|
-
)
|
|
126
|
+
) {
|
|
127
|
+
clear_payload_and_transfer::<Self>(env, executor, origin, guid, message, value);
|
|
128
|
+
Self::__lz_receive(env, origin, guid, message, extra_data, executor, value)
|
|
129
|
+
}
|
|
81
130
|
|
|
82
131
|
/// Indicates whether an address is an approved composeMsg sender to the Endpoint.
|
|
83
132
|
///
|
|
@@ -100,7 +149,16 @@ pub trait OAppReceiver: OAppCore {
|
|
|
100
149
|
// Helper functions
|
|
101
150
|
// =====================================================
|
|
102
151
|
|
|
103
|
-
|
|
152
|
+
/// Clears the message payload from the endpoint and transfers native tokens from the executor to the oapp if has value.
|
|
153
|
+
///
|
|
154
|
+
/// # Arguments
|
|
155
|
+
/// * `env` - The environment
|
|
156
|
+
/// * `executor` - The address of the executor delivering the message
|
|
157
|
+
/// * `origin` - The origin information (source EID, sender, nonce)
|
|
158
|
+
/// * `guid` - The unique identifier for the LayerZero message to clear the payload from
|
|
159
|
+
/// * `message` - The message payload to clear
|
|
160
|
+
/// * `value` - The native token value to transfer from the executor to the oapp if has value
|
|
161
|
+
pub fn clear_payload_and_transfer<T: OAppCore>(
|
|
104
162
|
env: &Env,
|
|
105
163
|
executor: &Address,
|
|
106
164
|
origin: &Origin,
|
|
@@ -108,16 +166,23 @@ pub fn verify_and_clear_payload<T: OAppCore>(
|
|
|
108
166
|
message: &Bytes,
|
|
109
167
|
value: i128,
|
|
110
168
|
) {
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
let curr_address = env.current_contract_address();
|
|
115
|
-
let endpoint = LayerZeroEndpointV2Client::new(env, &T::endpoint(env));
|
|
116
|
-
endpoint.clear(&curr_address, origin, &curr_address, guid, message);
|
|
169
|
+
let this_address = env.current_contract_address();
|
|
170
|
+
let endpoint_client = endpoint_client::<T>(env);
|
|
117
171
|
|
|
172
|
+
// Require authorization from the executor and transfer the value from the executor to the oapp if has value
|
|
173
|
+
executor.require_auth();
|
|
118
174
|
if value > 0 {
|
|
119
|
-
let
|
|
120
|
-
|
|
121
|
-
token_client.transfer(executor, &curr_address, &value);
|
|
175
|
+
let token_client = TokenClient::new(env, &endpoint_client.native_token());
|
|
176
|
+
token_client.transfer(executor, &this_address, &value);
|
|
122
177
|
}
|
|
178
|
+
|
|
179
|
+
// Assert that the message is from the expected peer
|
|
180
|
+
assert_with_error!(
|
|
181
|
+
env,
|
|
182
|
+
T::peer(env, origin.src_eid).is_some_and(|peer| peer == origin.sender),
|
|
183
|
+
OAppError::OnlyPeer
|
|
184
|
+
);
|
|
185
|
+
|
|
186
|
+
// Clear the message payload from the endpoint
|
|
187
|
+
endpoint_client.clear(&this_address, origin, &this_address, guid, message);
|
|
123
188
|
}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
use crate::{
|
|
2
|
-
|
|
1
|
+
use crate::{
|
|
2
|
+
errors::OAppError,
|
|
3
|
+
oapp_core::{endpoint_client, OAppCore},
|
|
4
|
+
};
|
|
5
|
+
use endpoint_v2::{MessagingFee, MessagingParams, MessagingReceipt};
|
|
3
6
|
use soroban_sdk::{token::TokenClient, Address, Bytes, Env};
|
|
4
7
|
use utils::option_ext::OptionExt;
|
|
5
8
|
|
|
6
9
|
/// A helper trait for sending cross-chain messages via LayerZero.
|
|
7
10
|
///
|
|
8
|
-
/// Contracts should implement this trait to gain access to the `
|
|
11
|
+
/// Contracts should implement this trait to gain access to the `__lz_quote` and `__lz_send` helper
|
|
9
12
|
/// methods for cross-chain messaging. This trait provides default implementations that handle
|
|
10
13
|
/// fee payment and message dispatch through the LayerZero endpoint.
|
|
11
14
|
///
|
|
@@ -14,7 +17,7 @@ use utils::option_ext::OptionExt;
|
|
|
14
17
|
/// methods as part of your contract's public interface (i.e., do not use `#[contractimpl]` on
|
|
15
18
|
/// the implementation of this trait). Instead, call these methods internally from your
|
|
16
19
|
/// contract's own public functions.
|
|
17
|
-
pub trait
|
|
20
|
+
pub trait OAppSenderInternal: OAppCore {
|
|
18
21
|
/// Quote the messaging fee for sending a message to the other chain
|
|
19
22
|
///
|
|
20
23
|
/// # Arguments
|
|
@@ -25,11 +28,9 @@ pub trait OAppSender: OAppCore {
|
|
|
25
28
|
///
|
|
26
29
|
/// # Returns
|
|
27
30
|
/// * `MessagingFee`: The messaging fee for the message
|
|
28
|
-
fn
|
|
29
|
-
let endpoint = Self::endpoint(env);
|
|
30
|
-
let endpoint_client = LayerZeroEndpointV2Client::new(env, &endpoint);
|
|
31
|
+
fn __quote(env: &Env, dst_eid: u32, message: &Bytes, options: &Bytes, pay_in_zro: bool) -> MessagingFee {
|
|
31
32
|
let receiver = Self::peer(env, dst_eid).unwrap_or_panic(env, OAppError::NoPeer);
|
|
32
|
-
endpoint_client.quote(
|
|
33
|
+
endpoint_client::<Self>(env).quote(
|
|
33
34
|
&env.current_contract_address(),
|
|
34
35
|
&MessagingParams { dst_eid, receiver, message: message.clone(), options: options.clone(), pay_in_zro },
|
|
35
36
|
)
|
|
@@ -38,38 +39,37 @@ pub trait OAppSender: OAppCore {
|
|
|
38
39
|
/// Send a message to the other chain
|
|
39
40
|
///
|
|
40
41
|
/// # Arguments
|
|
41
|
-
/// * `payer`: The address of the payer
|
|
42
42
|
/// * `dst_eid`: The destination endpoint ID
|
|
43
43
|
/// * `message`: The message to send
|
|
44
44
|
/// * `options`: The options for the message
|
|
45
|
+
/// * `fee_payer`: The address of the payer for paying the messaging fees
|
|
45
46
|
/// * `fee`: The messaging fee
|
|
46
47
|
/// * `refund_address`: The address to receive any excess fees
|
|
47
48
|
///
|
|
48
49
|
/// # Returns
|
|
49
50
|
/// * `MessagingReceipt`: The receipt for the sent message
|
|
50
|
-
fn
|
|
51
|
+
fn __lz_send(
|
|
51
52
|
env: &Env,
|
|
52
|
-
payer: &Address,
|
|
53
53
|
dst_eid: u32,
|
|
54
54
|
message: &Bytes,
|
|
55
55
|
options: &Bytes,
|
|
56
|
+
fee_payer: &Address,
|
|
56
57
|
fee: &MessagingFee,
|
|
57
58
|
refund_address: &Address,
|
|
58
59
|
) -> MessagingReceipt {
|
|
59
60
|
// Pay the messaging fees
|
|
60
|
-
Self::
|
|
61
|
-
if fee.zro_fee
|
|
62
|
-
Self::
|
|
61
|
+
Self::__pay_native(env, fee_payer, fee.native_fee);
|
|
62
|
+
if fee.zro_fee != 0 {
|
|
63
|
+
Self::__pay_zro(env, fee_payer, fee.zro_fee);
|
|
63
64
|
}
|
|
64
65
|
|
|
65
66
|
// Send the message to the other chain
|
|
66
|
-
let
|
|
67
|
-
|
|
68
|
-
endpoint_client.send(
|
|
67
|
+
let receiver = Self::peer(env, dst_eid).unwrap_or_panic(env, OAppError::NoPeer);
|
|
68
|
+
endpoint_client::<Self>(env).send(
|
|
69
69
|
&env.current_contract_address(),
|
|
70
70
|
&MessagingParams {
|
|
71
71
|
dst_eid,
|
|
72
|
-
receiver
|
|
72
|
+
receiver,
|
|
73
73
|
message: message.clone(),
|
|
74
74
|
options: options.clone(),
|
|
75
75
|
pay_in_zro: fee.zro_fee > 0,
|
|
@@ -81,28 +81,20 @@ pub trait OAppSender: OAppCore {
|
|
|
81
81
|
/// Pay the native fee to the endpoint for sending a message to the other chain
|
|
82
82
|
///
|
|
83
83
|
/// # Arguments
|
|
84
|
-
/// * `
|
|
84
|
+
/// * `fee_payer`: The address of the fee payer
|
|
85
85
|
/// * `native_fee`: The native fee to pay
|
|
86
|
-
fn
|
|
87
|
-
let
|
|
88
|
-
|
|
89
|
-
let native_token = endpoint_client.native_token();
|
|
90
|
-
let token_client = TokenClient::new(env, &native_token);
|
|
91
|
-
|
|
92
|
-
token_client.transfer(payer, &endpoint, &native_fee);
|
|
86
|
+
fn __pay_native(env: &Env, fee_payer: &Address, native_fee: i128) {
|
|
87
|
+
let token_client = TokenClient::new(env, &endpoint_client::<Self>(env).native_token());
|
|
88
|
+
token_client.transfer(fee_payer, Self::endpoint(env), &native_fee);
|
|
93
89
|
}
|
|
94
90
|
|
|
95
91
|
/// Pay the ZRO fee to the endpoint for sending a message to the other chain
|
|
96
92
|
///
|
|
97
93
|
/// # Arguments
|
|
98
|
-
/// * `
|
|
94
|
+
/// * `fee_payer`: The address of the fee payer
|
|
99
95
|
/// * `zro_fee`: The ZRO fee to pay
|
|
100
|
-
fn
|
|
101
|
-
let
|
|
102
|
-
|
|
103
|
-
let zro_token = endpoint_client.zro().unwrap_or_panic(env, OAppError::ZROTokenUnavailable);
|
|
104
|
-
let token_client = TokenClient::new(env, &zro_token);
|
|
105
|
-
|
|
106
|
-
token_client.transfer(payer, &endpoint, &zro_fee);
|
|
96
|
+
fn __pay_zro(env: &Env, fee_payer: &Address, zro_fee: i128) {
|
|
97
|
+
let zro_token = endpoint_client::<Self>(env).zro().unwrap_or_panic(env, OAppError::ZroTokenUnavailable);
|
|
98
|
+
TokenClient::new(env, &zro_token).transfer(fee_payer, Self::endpoint(env), &zro_fee);
|
|
107
99
|
}
|
|
108
100
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
use crate::{self as oapp, oapp_core::PeerSet};
|
|
1
|
+
use crate::{self as oapp, oapp_core::PeerSet, oapp_receiver::LzReceiveInternal};
|
|
2
|
+
use endpoint_v2::Origin;
|
|
2
3
|
use soroban_sdk::{
|
|
3
4
|
contract, contractimpl,
|
|
4
5
|
testutils::{Address as _, MockAuth, MockAuthInvoke},
|
|
5
|
-
Address, BytesN, Env, IntoVal,
|
|
6
|
+
Address, Bytes, BytesN, Env, IntoVal,
|
|
6
7
|
};
|
|
7
|
-
use utils::ownable::Ownable;
|
|
8
8
|
use utils::testing_utils::assert_event;
|
|
9
9
|
|
|
10
10
|
#[contract]
|
|
@@ -20,14 +20,14 @@ impl DummyEndpoint {
|
|
|
20
20
|
#[oapp_macros::oapp]
|
|
21
21
|
pub struct DummyOApp;
|
|
22
22
|
|
|
23
|
-
impl DummyOApp {
|
|
23
|
+
impl LzReceiveInternal for DummyOApp {
|
|
24
24
|
fn __lz_receive(
|
|
25
25
|
_env: &Env,
|
|
26
|
-
|
|
27
|
-
_origin: &endpoint_v2::Origin,
|
|
26
|
+
_origin: &Origin,
|
|
28
27
|
_guid: &BytesN<32>,
|
|
29
|
-
_message: &
|
|
30
|
-
_extra_data: &
|
|
28
|
+
_message: &Bytes,
|
|
29
|
+
_extra_data: &Bytes,
|
|
30
|
+
_executor: &Address,
|
|
31
31
|
_value: i128,
|
|
32
32
|
) {
|
|
33
33
|
// Not used in core tests
|
|
@@ -37,7 +37,7 @@ impl DummyOApp {
|
|
|
37
37
|
#[contractimpl]
|
|
38
38
|
impl DummyOApp {
|
|
39
39
|
pub fn __constructor(env: &Env, owner: &Address, endpoint: &Address) {
|
|
40
|
-
oapp::oapp_core::
|
|
40
|
+
oapp::oapp_core::initialize_oapp::<Self>(env, owner, endpoint, &None);
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
|
|
@@ -1,14 +1,16 @@
|
|
|
1
|
-
use crate
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
use crate::{
|
|
2
|
+
self as oapp,
|
|
3
|
+
oapp_core::OAppCore,
|
|
4
|
+
oapp_options_type3::{EnforcedOptionParam, EnforcedOptionSet},
|
|
5
|
+
oapp_receiver::{LzReceiveInternal, OAppReceiver},
|
|
6
|
+
};
|
|
4
7
|
use common_macros::contract_impl;
|
|
5
|
-
use
|
|
6
|
-
use soroban_sdk::contractimpl;
|
|
8
|
+
use endpoint_v2::Origin;
|
|
7
9
|
use soroban_sdk::{
|
|
10
|
+
contract, contractimpl,
|
|
8
11
|
testutils::{Address as _, MockAuth, MockAuthInvoke},
|
|
9
|
-
vec, Address, Bytes, Env, IntoVal,
|
|
12
|
+
vec, Address, Bytes, BytesN, Env, IntoVal,
|
|
10
13
|
};
|
|
11
|
-
use utils::ownable::Ownable;
|
|
12
14
|
use utils::testing_utils::assert_event;
|
|
13
15
|
|
|
14
16
|
const OPTION_TYPE_3: u32 = 3;
|
|
@@ -27,31 +29,36 @@ impl DummyEndpoint {
|
|
|
27
29
|
}
|
|
28
30
|
}
|
|
29
31
|
|
|
30
|
-
#[oapp_macros::oapp]
|
|
31
|
-
#[oapp_macros::oapp_manual_impl(core, sender, receiver)]
|
|
32
|
+
#[oapp_macros::oapp(custom = [core, sender, receiver])]
|
|
32
33
|
pub struct DummyOAppOptionsType3;
|
|
33
34
|
|
|
34
|
-
#[contract_impl]
|
|
35
|
-
impl DummyOAppOptionsType3 {
|
|
36
|
-
pub fn __constructor(env: &Env, owner: &Address, endpoint: &Address, delegate: &Option<Address>) {
|
|
37
|
-
oapp::oapp_core::oapp_initialize::<Self>(env, owner, endpoint, delegate);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
35
|
+
#[contract_impl(contracttrait)]
|
|
36
|
+
impl OAppCore for DummyOAppOptionsType3 {}
|
|
40
37
|
|
|
41
|
-
impl DummyOAppOptionsType3 {
|
|
38
|
+
impl LzReceiveInternal for DummyOAppOptionsType3 {
|
|
42
39
|
fn __lz_receive(
|
|
43
40
|
_env: &Env,
|
|
44
|
-
_executor: &Address,
|
|
45
41
|
_origin: &endpoint_v2::Origin,
|
|
46
|
-
_guid: &
|
|
42
|
+
_guid: &BytesN<32>,
|
|
47
43
|
_message: &Bytes,
|
|
48
44
|
_extra_data: &Bytes,
|
|
45
|
+
_executor: &Address,
|
|
49
46
|
_value: i128,
|
|
50
47
|
) {
|
|
51
48
|
// Dummy implementation for testing
|
|
52
49
|
}
|
|
53
50
|
}
|
|
54
51
|
|
|
52
|
+
#[contract_impl(contracttrait)]
|
|
53
|
+
impl OAppReceiver for DummyOAppOptionsType3 {}
|
|
54
|
+
|
|
55
|
+
#[contract_impl]
|
|
56
|
+
impl DummyOAppOptionsType3 {
|
|
57
|
+
pub fn __constructor(env: &Env, owner: &Address, endpoint: &Address, delegate: &Option<Address>) {
|
|
58
|
+
oapp::oapp_core::initialize_oapp::<Self>(env, owner, endpoint, delegate);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
55
62
|
struct TestSetup<'a> {
|
|
56
63
|
env: Env,
|
|
57
64
|
owner: Address,
|