From ca80e82939acd612626e8385d6b8cfab770b00ce Mon Sep 17 00:00:00 2001 From: WaDadidou Date: Wed, 18 Sep 2024 14:42:55 -0400 Subject: [PATCH 1/5] feat: add marketing contract --- .../marketing/.cargo/config.toml | 4 + cosmwasm-contracts/marketing/Cargo.lock | 891 ++++++++++++++++++ cosmwasm-contracts/marketing/Cargo.toml | 19 + .../marketing/src/bin/schema.rs | 10 + cosmwasm-contracts/marketing/src/contract.rs | 295 ++++++ cosmwasm-contracts/marketing/src/error.rs | 56 ++ cosmwasm-contracts/marketing/src/lib.rs | 2 + 7 files changed, 1277 insertions(+) create mode 100644 cosmwasm-contracts/marketing/.cargo/config.toml create mode 100644 cosmwasm-contracts/marketing/Cargo.lock create mode 100644 cosmwasm-contracts/marketing/Cargo.toml create mode 100644 cosmwasm-contracts/marketing/src/bin/schema.rs create mode 100644 cosmwasm-contracts/marketing/src/contract.rs create mode 100644 cosmwasm-contracts/marketing/src/error.rs create mode 100644 cosmwasm-contracts/marketing/src/lib.rs diff --git a/cosmwasm-contracts/marketing/.cargo/config.toml b/cosmwasm-contracts/marketing/.cargo/config.toml new file mode 100644 index 0000000000..9354fae229 --- /dev/null +++ b/cosmwasm-contracts/marketing/.cargo/config.toml @@ -0,0 +1,4 @@ +[alias] +wasm = "build --target wasm32-unknown-unknown --release --lib" +wasm-debug = "build --target wasm32-unknown-unknown --lib" +schema = "run schema" diff --git a/cosmwasm-contracts/marketing/Cargo.lock b/cosmwasm-contracts/marketing/Cargo.lock new file mode 100644 index 0000000000..14d26e5305 --- /dev/null +++ b/cosmwasm-contracts/marketing/Cargo.lock @@ -0,0 +1,891 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "ahash" +version = "0.7.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "891477e0c6a8957309ee5c45a6368af3ae14bb510732d2684ffa19af310920f9" +dependencies = [ + "getrandom", + "once_cell", + "version_check", +] + +[[package]] +name = "base16ct" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf" + +[[package]] +name = "base64" +version = "0.21.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" + +[[package]] +name = "base64ct" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b" + +[[package]] +name = "bech32" +version = "0.9.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d86b93f97252c47b41663388e6d155714a9d0c398b99f1005cbc5f978b29f445" + +[[package]] +name = "block-buffer" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4152116fd6e9dadb291ae18fc1ec3575ed6d84c29642d97890f4b4a3417297e4" +dependencies = [ + "generic-array", +] + +[[package]] +name = "block-buffer" +version = "0.10.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3078c7629b62d3f0439517fa394996acacc5cbc91c5a20d8c658e77abd503a71" +dependencies = [ + "generic-array", +] + +[[package]] +name = "bnum" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "56953345e39537a3e18bdaeba4cb0c58a78c1f61f361dc0fa7c5c7340ae87c5f" + +[[package]] +name = "byteorder" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "const-oid" +version = "0.9.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c2459377285ad874054d797f3ccebf984978aa39129f6eafde5cdc8315b612f8" + +[[package]] +name = "const_panic" +version = "0.2.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7782af8f90fe69a4bb41e460abe1727d493403d8b2cc43201a3a3e906b24379f" + +[[package]] +name = "convert_case" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ec182b0ca2f35d8fc196cf3404988fd8b8c739a4d270ff118a398feb0cbec1ca" +dependencies = [ + "unicode-segmentation", +] + +[[package]] +name = "cosmwasm-crypto" +version = "1.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0f862b355f7e47711e0acfe6af92cb3fd8fd5936b66a9eaa338b51edabd1e77d" +dependencies = [ + "digest 0.10.7", + "ed25519-zebra", + "k256", + "rand_core 0.6.4", + "thiserror", +] + +[[package]] +name = "cosmwasm-derive" +version = "1.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cd85de6467cd1073688c86b39833679ae6db18cf4771471edd9809f15f1679f1" +dependencies = [ + "syn 1.0.109", +] + +[[package]] +name = "cosmwasm-schema" +version = "1.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5b4cd28147a66eba73720b47636a58097a979ad8c8bfdb4ed437ebcbfe362576" +dependencies = [ + "cosmwasm-schema-derive", + "schemars", + "serde", + "serde_json", + "thiserror", +] + +[[package]] +name = "cosmwasm-schema-derive" +version = "1.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9acd45c63d41bc9b16bc6dc7f6bd604a8c2ad29ce96c8f3c96d7fc8ef384392e" +dependencies = [ + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "cosmwasm-std" +version = "1.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2685c2182624b2e9e17f7596192de49a3f86b7a0c9a5f6b25c1df5e24592e836" +dependencies = [ + "base64", + "bech32", + "bnum", + "cosmwasm-crypto", + "cosmwasm-derive", + "derivative", + "forward_ref", + "hex", + "schemars", + "serde", + "serde-json-wasm", + "sha2 0.10.8", + "static_assertions", + "thiserror", +] + +[[package]] +name = "cpufeatures" +version = "0.2.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "608697df725056feaccfa42cffdaeeec3fccc4ffc38358ecd19b243e716a78e0" +dependencies = [ + "libc", +] + +[[package]] +name = "crypto-bigint" +version = "0.5.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0dc92fb57ca44df6db8059111ab3af99a63d5d0f8375d9972e319a379c6bab76" +dependencies = [ + "generic-array", + "rand_core 0.6.4", + "subtle", + "zeroize", +] + +[[package]] +name = "crypto-common" +version = "0.1.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bfb12502f3fc46cca1bb51ac28df9d618d813cdc3d2f25b9fe775a34af26bb3" +dependencies = [ + "generic-array", + "typenum", +] + +[[package]] +name = "curve25519-dalek" +version = "3.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b9fdf9972b2bd6af2d913799d9ebc165ea4d2e65878e329d9c6b372c4491b61" +dependencies = [ + "byteorder", + "digest 0.9.0", + "rand_core 0.5.1", + "subtle", + "zeroize", +] + +[[package]] +name = "cw-storage-plus" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d5ff29294ee99373e2cd5fd21786a3c0ced99a52fec2ca347d565489c61b723c" +dependencies = [ + "cosmwasm-std", + "schemars", + "serde", +] + +[[package]] +name = "der" +version = "0.7.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f55bf8e7b65898637379c1b74eb1551107c8294ed26d855ceb9fd1a09cfc9bc0" +dependencies = [ + "const-oid", + "zeroize", +] + +[[package]] +name = "derivative" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fcc3dd5e9e9c0b295d6e1e4d811fb6f157d5ffd784b8d202fc62eac8035a770b" +dependencies = [ + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "digest" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3dd60d1080a57a05ab032377049e0591415d2b31afd7028356dbf3cc6dcb066" +dependencies = [ + "generic-array", +] + +[[package]] +name = "digest" +version = "0.10.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" +dependencies = [ + "block-buffer 0.10.4", + "const-oid", + "crypto-common", + "subtle", +] + +[[package]] +name = "dyn-clone" +version = "1.0.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d6ef0072f8a535281e4876be788938b528e9a1d43900b82c2569af7da799125" + +[[package]] +name = "ecdsa" +version = "0.16.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee27f32b5c5292967d2d4a9d7f1e0b0aed2c15daded5a60300e4abb9d8020bca" +dependencies = [ + "der", + "digest 0.10.7", + "elliptic-curve", + "rfc6979", + "signature", + "spki", +] + +[[package]] +name = "ed25519-zebra" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7c24f403d068ad0b359e577a77f92392118be3f3c927538f2bb544a5ecd828c6" +dependencies = [ + "curve25519-dalek", + "hashbrown 0.12.3", + "hex", + "rand_core 0.6.4", + "serde", + "sha2 0.9.9", + "zeroize", +] + +[[package]] +name = "elliptic-curve" +version = "0.13.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b5e6043086bf7973472e0c7dff2142ea0b680d30e18d9cc40f267efbf222bd47" +dependencies = [ + "base16ct", + "crypto-bigint", + "digest 0.10.7", + "ff", + "generic-array", + "group", + "pkcs8", + "rand_core 0.6.4", + "sec1", + "subtle", + "zeroize", +] + +[[package]] +name = "equivalent" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" + +[[package]] +name = "ff" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ded41244b729663b1e574f1b4fb731469f69f79c17667b5d776b16cda0479449" +dependencies = [ + "rand_core 0.6.4", + "subtle", +] + +[[package]] +name = "forward_ref" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c8cbd1169bd7b4a0a20d92b9af7a7e0422888bd38a6f5ec29c1fd8c1558a272e" + +[[package]] +name = "generic-array" +version = "0.14.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "85649ca51fd72272d7821adaf274ad91c288277713d9c18820d8499a7ff69e9a" +dependencies = [ + "typenum", + "version_check", + "zeroize", +] + +[[package]] +name = "getrandom" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7" +dependencies = [ + "cfg-if", + "libc", + "wasi", +] + +[[package]] +name = "group" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f0f9ef7462f7c099f518d754361858f86d8a07af53ba9af0fe635bbccb151a63" +dependencies = [ + "ff", + "rand_core 0.6.4", + "subtle", +] + +[[package]] +name = "hashbrown" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" +dependencies = [ + "ahash", +] + +[[package]] +name = "hashbrown" +version = "0.14.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e5274423e17b7c9fc20b6e7e208532f9b19825d82dfd615708b70edd83df41f1" + +[[package]] +name = "hex" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" + +[[package]] +name = "hmac" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e" +dependencies = [ + "digest 0.10.7", +] + +[[package]] +name = "indexmap" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68b900aa2f7301e21c36462b170ee99994de34dff39a4a6a528e80e7376d07e5" +dependencies = [ + "equivalent", + "hashbrown 0.14.5", +] + +[[package]] +name = "itoa" +version = "1.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" + +[[package]] +name = "k256" +version = "0.13.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "956ff9b67e26e1a6a866cb758f12c6f8746208489e3e4a4b5580802f2f0a587b" +dependencies = [ + "cfg-if", + "ecdsa", + "elliptic-curve", + "once_cell", + "sha2 0.10.8", + "signature", +] + +[[package]] +name = "konst" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "50a0ba6de5f7af397afff922f22c149ff605c766cd3269cf6c1cd5e466dbe3b9" +dependencies = [ + "const_panic", + "konst_kernel", + "konst_proc_macros", + "typewit", +] + +[[package]] +name = "konst_kernel" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "be0a455a1719220fd6adf756088e1c69a85bf14b6a9e24537a5cc04f503edb2b" +dependencies = [ + "typewit", +] + +[[package]] +name = "konst_proc_macros" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4e28ab1dc35e09d60c2b8c90d12a9a8d9666c876c10a3739a3196db0103b6043" + +[[package]] +name = "libc" +version = "0.2.158" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d8adc4bb1803a324070e64a98ae98f38934d91957a99cfb3a43dcbc01bc56439" + +[[package]] +name = "marketing" +version = "0.1.0" +dependencies = [ + "base64", + "cosmwasm-schema", + "cosmwasm-std", + "cw-storage-plus", + "schemars", + "serde", + "sylvia", + "thiserror", +] + +[[package]] +name = "memchr" +version = "2.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3" + +[[package]] +name = "once_cell" +version = "1.19.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" + +[[package]] +name = "opaque-debug" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c08d65885ee38876c4f86fa503fb49d7b507c2b62552df7c70b2fce627e06381" + +[[package]] +name = "pkcs8" +version = "0.10.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f950b2377845cebe5cf8b5165cb3cc1a5e0fa5cfa3e1f7f55707d8fd82e0a7b7" +dependencies = [ + "der", + "spki", +] + +[[package]] +name = "proc-macro-crate" +version = "1.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f4c021e1093a56626774e81216a4ce732a735e5bad4868a03f3ed65ca0c3919" +dependencies = [ + "once_cell", + "toml_edit", +] + +[[package]] +name = "proc-macro-error" +version = "1.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da25490ff9892aab3fcf7c36f08cfb902dd3e71ca0f9f9517bea02a73a5ce38c" +dependencies = [ + "proc-macro-error-attr", + "proc-macro2", + "quote", + "syn 1.0.109", + "version_check", +] + +[[package]] +name = "proc-macro-error-attr" +version = "1.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a1be40180e52ecc98ad80b184934baf3d0d29f979574e439af5a55274b35f869" +dependencies = [ + "proc-macro2", + "quote", + "version_check", +] + +[[package]] +name = "proc-macro2" +version = "1.0.86" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5e719e8df665df0d1c8fbfd238015744736151d4445ec0836b8e628aae103b77" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "quote" +version = "1.0.37" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b5b9d34b8991d19d98081b46eacdd8eb58c6f2b201139f7c5f643cc155a633af" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "rand_core" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "90bde5296fc891b0cef12a6d03ddccc162ce7b2aff54160af9338f8d40df6d19" + +[[package]] +name = "rand_core" +version = "0.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" +dependencies = [ + "getrandom", +] + +[[package]] +name = "rfc6979" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f8dd2a808d456c4a54e300a23e9f5a67e122c3024119acbfd73e3bf664491cb2" +dependencies = [ + "hmac", + "subtle", +] + +[[package]] +name = "ryu" +version = "1.0.18" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" + +[[package]] +name = "schemars" +version = "0.8.21" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "09c024468a378b7e36765cd36702b7a90cc3cba11654f6685c8f233408e89e92" +dependencies = [ + "dyn-clone", + "schemars_derive", + "serde", + "serde_json", +] + +[[package]] +name = "schemars_derive" +version = "0.8.21" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b1eee588578aff73f856ab961cd2f79e36bc45d7ded33a7562adba4667aecc0e" +dependencies = [ + "proc-macro2", + "quote", + "serde_derive_internals", + "syn 2.0.77", +] + +[[package]] +name = "sec1" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc" +dependencies = [ + "base16ct", + "der", + "generic-array", + "pkcs8", + "subtle", + "zeroize", +] + +[[package]] +name = "serde" +version = "1.0.210" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c8e3592472072e6e22e0a54d5904d9febf8508f65fb8552499a1abc7d1078c3a" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde-cw-value" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a75d32da6b8ed758b7d850b6c3c08f1d7df51a4df3cb201296e63e34a78e99d4" +dependencies = [ + "serde", +] + +[[package]] +name = "serde-json-wasm" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e9213a07d53faa0b8dd81e767a54a8188a242fdb9be99ab75ec576a774bfdd7" +dependencies = [ + "serde", +] + +[[package]] +name = "serde_derive" +version = "1.0.210" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "243902eda00fad750862fc144cea25caca5e20d615af0a81bee94ca738f1df1f" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.77", +] + +[[package]] +name = "serde_derive_internals" +version = "0.29.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "18d26a20a969b9e3fdf2fc2d9f21eda6c40e2de84c9408bb5d3b05d499aae711" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.77", +] + +[[package]] +name = "serde_json" +version = "1.0.128" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6ff5456707a1de34e7e37f2a6fd3d3f808c318259cbd01ab6377795054b483d8" +dependencies = [ + "itoa", + "memchr", + "ryu", + "serde", +] + +[[package]] +name = "sha2" +version = "0.9.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4d58a1e1bf39749807d89cf2d98ac2dfa0ff1cb3faa38fbb64dd88ac8013d800" +dependencies = [ + "block-buffer 0.9.0", + "cfg-if", + "cpufeatures", + "digest 0.9.0", + "opaque-debug", +] + +[[package]] +name = "sha2" +version = "0.10.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "793db75ad2bcafc3ffa7c68b215fee268f537982cd901d132f89c6343f3a3dc8" +dependencies = [ + "cfg-if", + "cpufeatures", + "digest 0.10.7", +] + +[[package]] +name = "signature" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77549399552de45a898a580c1b41d445bf730df867cc44e6c0233bbc4b8329de" +dependencies = [ + "digest 0.10.7", + "rand_core 0.6.4", +] + +[[package]] +name = "spki" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d91ed6c858b01f942cd56b37a94b3e0a1798290327d1236e4d9cf4eaca44d29d" +dependencies = [ + "base64ct", + "der", +] + +[[package]] +name = "static_assertions" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f" + +[[package]] +name = "subtle" +version = "2.6.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "13c2bddecc57b384dee18652358fb23172facb8a2c51ccc10d74c157bdea3292" + +[[package]] +name = "sylvia" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f358d505f46900e55154f028f18811961ebb58f7a92954ec03086ffb2b26cf51" +dependencies = [ + "cosmwasm-schema", + "cosmwasm-std", + "konst", + "schemars", + "serde", + "serde-cw-value", + "serde-json-wasm", + "sylvia-derive", +] + +[[package]] +name = "sylvia-derive" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bed182fb775d756fdfe7e87174a4e43f1c446c8f9aff1de38a2165dd04b7d805" +dependencies = [ + "convert_case", + "proc-macro-crate", + "proc-macro-error", + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "syn" +version = "1.0.109" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "syn" +version = "2.0.77" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9f35bcdf61fd8e7be6caf75f429fdca8beb3ed76584befb503b1569faee373ed" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "thiserror" +version = "1.0.63" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c0342370b38b6a11b6cc11d6a805569958d54cfa061a29969c3b5ce2ea405724" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.63" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4558b58466b9ad7ca0f102865eccc95938dca1a74a856f2b57b6629050da261" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.77", +] + +[[package]] +name = "toml_datetime" +version = "0.6.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0dd7358ecb8fc2f8d014bf86f6f638ce72ba252a2c3a2572f2a795f1d23efb41" + +[[package]] +name = "toml_edit" +version = "0.19.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1b5bb770da30e5cbfde35a2d7b9b8a2c4b8ef89548a7a6aeab5c9a576e3e7421" +dependencies = [ + "indexmap", + "toml_datetime", + "winnow", +] + +[[package]] +name = "typenum" +version = "1.17.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "42ff0bf0c66b8238c6f3b578df37d0b7848e55df8577b3f74f92a69acceeb825" + +[[package]] +name = "typewit" +version = "1.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6fb9ae6a3cafaf0a5d14c2302ca525f9ae8e07a0f0e6949de88d882c37a6e24" +dependencies = [ + "typewit_proc_macros", +] + +[[package]] +name = "typewit_proc_macros" +version = "1.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e36a83ea2b3c704935a01b4642946aadd445cea40b10935e3f8bd8052b8193d6" + +[[package]] +name = "unicode-ident" +version = "1.0.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe" + +[[package]] +name = "unicode-segmentation" +version = "1.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d4c87d22b6e3f4a18d4d40ef354e97c90fcb14dd91d7dc0aa9d8a1172ebf7202" + +[[package]] +name = "version_check" +version = "0.9.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a" + +[[package]] +name = "wasi" +version = "0.11.0+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" + +[[package]] +name = "winnow" +version = "0.5.40" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f593a95398737aeed53e489c785df13f3618e41dbcd6718c6addbf1395aa6876" +dependencies = [ + "memchr", +] + +[[package]] +name = "zeroize" +version = "1.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ced3678a2879b30306d323f4542626697a464a97c0a07c9aebf7ebca65cd4dde" diff --git a/cosmwasm-contracts/marketing/Cargo.toml b/cosmwasm-contracts/marketing/Cargo.toml new file mode 100644 index 0000000000..4b0caf8027 --- /dev/null +++ b/cosmwasm-contracts/marketing/Cargo.toml @@ -0,0 +1,19 @@ +[package] +name = "marketing" +version = "0.1.0" +edition = "2021" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[lib] +crate-type = ["cdylib", "rlib"] + +[dependencies] +schemars = "0.8.12" +cosmwasm-std = "1.3.1" +cosmwasm-schema = "1.3.1" +cw-storage-plus = "1.1.0" +serde = "1.0.180" +sylvia = "0.7.0" +thiserror = "1.0.44" +base64 = "0.21.7" diff --git a/cosmwasm-contracts/marketing/src/bin/schema.rs b/cosmwasm-contracts/marketing/src/bin/schema.rs new file mode 100644 index 0000000000..74ef290505 --- /dev/null +++ b/cosmwasm-contracts/marketing/src/bin/schema.rs @@ -0,0 +1,10 @@ +use cosmwasm_schema::write_api; +use marketing::contract::{ContractExecMsg, ContractQueryMsg, InstantiateMsg}; + +fn main() { + write_api! { + instantiate: InstantiateMsg, + execute: ContractExecMsg, + query: ContractQueryMsg, + } +} diff --git a/cosmwasm-contracts/marketing/src/contract.rs b/cosmwasm-contracts/marketing/src/contract.rs new file mode 100644 index 0000000000..aba3a5c681 --- /dev/null +++ b/cosmwasm-contracts/marketing/src/contract.rs @@ -0,0 +1,295 @@ + +use cosmwasm_std::{attr,Addr, + Response, StdResult +}; +use cosmwasm_schema::cw_serde; +use crate::error::ContractError; +use cw_storage_plus::{Item, Map}; +use sylvia::{types::{ExecCtx, InstantiateCtx, QueryCtx},contract, entry_points}; + + +#[cw_serde] +pub struct Banner { + image: String, + url: String, +} + +#[cw_serde] +pub struct Action { + label: String, + url: String, +} + +#[cw_serde] +pub struct News { + title: String, + subtitle: String, + text: String, + image: String, + actions: Option, +} + +#[cw_serde] +pub struct MarketingCollectionPreview { + address: String, + image_uri: String, + collection_name: String, + creator_name: String, + twitter_url: String, + secondary_during_mint: bool, +} + +#[cw_serde] +pub struct Config { + pub admin_addr: Addr, +} + +pub struct MarketingContract { + pub(crate) config: Item<'static, Config>, + pub(crate) banners: Map<'static, u64, Banner>, + pub(crate) news: Map<'static, u64, News>, + pub(crate) upcoming_collections: Map<'static, u64, MarketingCollectionPreview>, + pub(crate) live_collections: Map<'static, u64, MarketingCollectionPreview>, + pub(crate) highlighted_collections: Map<'static, u64, MarketingCollectionPreview>, +} + +#[entry_points] +#[contract] +#[error(ContractError)] +impl MarketingContract { + pub const fn new() -> Self { + Self { + config: Item::new("config"), + banners: Map::new("banners"), + news: Map::new("news"), + upcoming_collections: Map::new("upcoming_collections"), + live_collections: Map::new("live_collections"), + highlighted_collections: Map::new("highlighted_collections"), + } + } + + #[msg(instantiate)] + pub fn instantiate(&self, ctx: InstantiateCtx + , config: Config + , banners: Vec + , news: Vec + , upcoming_collections: Vec + , live_collections: Vec + , highlighted_collections: Vec + ) -> StdResult { + self.config.save(ctx.deps.storage, &config)?; + for (index, banner) in banners.into_iter().enumerate() { + self.banners.save(ctx.deps.storage, index as u64, &banner)?; + } + for (index, news_item) in news.into_iter().enumerate() { + self.news.save(ctx.deps.storage, index as u64, &news_item)?; + } + for (index, upcoming_collection) in upcoming_collections.into_iter().enumerate() { + self.upcoming_collections.save(ctx.deps.storage, index as u64, &upcoming_collection)?; + } + for (index, live_collection) in live_collections.into_iter().enumerate() { + self.live_collections.save(ctx.deps.storage, index as u64, &live_collection)?; + } + for (index, highlighted_collection) in highlighted_collections.into_iter().enumerate() { + self.highlighted_collections.save(ctx.deps.storage, index as u64, &highlighted_collection)?; + } + Ok(Response::default()) + } + + #[msg(exec)] + // Only the admin can execute it + pub fn update_config( + &self, + ctx: ExecCtx, + admin_addr: Option, + ) -> Result { + let attributes = vec![attr("action", "update_config")]; + self.config.update(ctx.deps.storage, |mut config| { + // Permission check + if ctx.info.sender != config.admin_addr { + return Err(ContractError::Unauthorized); + } + // Validate and save the new admin_addr in config + if let Some(admin_addr) = admin_addr { + config.admin_addr = ctx.deps.api.addr_validate(admin_addr.as_str())?; + } + + Ok(config) + })?; + + Ok(Response::new().add_attributes(attributes)) + } + + #[msg(exec)] + // Only the admin can execute it + pub fn update_banners( + &self, + ctx: ExecCtx, + banners: Vec, + ) -> Result { + let attributes = vec![attr("action", "update_banners")]; + let config = self.config.load(ctx.deps.storage)?; + // Permission check + if ctx.info.sender != config.admin_addr { + return Err(ContractError::Unauthorized); + } + // Replace all banners with the new ones + self.banners.clear(ctx.deps.storage); + for (index, banner) in banners.into_iter().enumerate() { + self.banners.save(ctx.deps.storage, index as u64, &banner)?; + } + + Ok(Response::new().add_attributes(attributes)) + } + + #[msg(exec)] + // Only the admin can execute it + pub fn update_news( + &self, + ctx: ExecCtx, + news: Vec, + ) -> Result { + let attributes = vec![attr("action", "update_news")]; + let config = self.config.load(ctx.deps.storage)?; + // Permission check + if ctx.info.sender != config.admin_addr { + return Err(ContractError::Unauthorized); + } + // Replace all news with the new ones + self.news.clear(ctx.deps.storage); + for (index, news_item) in news.into_iter().enumerate() { + self.news.save(ctx.deps.storage, index as u64, &news_item)?; + } + + Ok(Response::new().add_attributes(attributes)) + } + + #[msg(exec)] + // Only the admin can execute it + pub fn update_live_collections( + &self, + ctx: ExecCtx, + live_collections: Vec, + ) -> Result { + let attributes = vec![attr("action", "update_live_collections")]; + let config = self.config.load(ctx.deps.storage)?; + // Permission check + if ctx.info.sender != config.admin_addr { + return Err(ContractError::Unauthorized); + } + // Replace all live_collections with the new ones + self.live_collections.clear(ctx.deps.storage); + for (index, live_collection) in live_collections.into_iter().enumerate() { + self.live_collections.save(ctx.deps.storage, index as u64, &live_collection)?; + } + + Ok(Response::new().add_attributes(attributes)) + } + + #[msg(exec)] + // Only the admin can execute it + pub fn update_upcoming_collections( + &self, + ctx: ExecCtx, + upcoming_collections: Vec, + ) -> Result { + let attributes = vec![attr("action", "update_upcoming_collections")]; + let config = self.config.load(ctx.deps.storage)?; + // Permission check + if ctx.info.sender != config.admin_addr { + return Err(ContractError::Unauthorized); + } + // Replace all upcoming_collections with the new ones + self.upcoming_collections.clear(ctx.deps.storage); + for (index, upcoming_collection) in upcoming_collections.into_iter().enumerate() { + self.upcoming_collections.save(ctx.deps.storage, index as u64, &upcoming_collection)?; + } + + Ok(Response::new().add_attributes(attributes)) + } + + #[msg(exec)] + // Only the admin can execute it + pub fn update_highlighted_collections( + &self, + ctx: ExecCtx, + highlighted_collections: Vec, + ) -> Result { + let attributes = vec![attr("action", "update_highlighted_collections")]; + let config = self.config.load(ctx.deps.storage)?; + // Permission check + if ctx.info.sender != config.admin_addr { + return Err(ContractError::Unauthorized); + } + // Replace all highlighted_collections with the new ones + self.highlighted_collections.clear(ctx.deps.storage); + for (index, highlighted_collection) in highlighted_collections.into_iter().enumerate() { + self.highlighted_collections.save(ctx.deps.storage, index as u64, &highlighted_collection)?; + } + + Ok(Response::new().add_attributes(attributes)) + } + + #[msg(query)] + pub fn get_config(&self, ctx: QueryCtx) -> StdResult { + let config = self.config.load(ctx.deps.storage)?; + Ok(config) + } + + #[msg(query)] + pub fn get_banners(&self, ctx: QueryCtx) -> StdResult> { + let banners: Vec = self + .banners + .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) + .map(|item| item.map(|(_, banner)| banner)) + .collect::>>()?; + + Ok(banners) + } + + #[msg(query)] + pub fn get_news(&self, ctx: QueryCtx) -> StdResult> { + let news: Vec = self + .news + .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) + .map(|item| item.map(|(_, news_item)| news_item)) + .collect::>>()?; + + Ok(news) + } + + #[msg(query)] + pub fn get_live_collections(&self, ctx: QueryCtx) -> StdResult> { + let live_collections: Vec = self + .live_collections + .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) + .map(|item| item.map(|(_, live_collection)| live_collection)) + .collect::>>()?; + + Ok(live_collections) + } + + #[msg(query)] + pub fn get_upcoming_collections(&self, ctx: QueryCtx) -> StdResult> { + let upcoming_collections: Vec = self + .upcoming_collections + .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) + .map(|item| item.map(|(_, upcoming_collection)| upcoming_collection)) + .collect::>>()?; + + Ok(upcoming_collections) + } + + #[msg(query)] + pub fn get_highlighted_collections(&self, ctx: QueryCtx) -> StdResult> { + let highlighted_collections: Vec = self + .highlighted_collections + .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) + .map(|item| item.map(|(_, highlighted_collection)| highlighted_collection)) + .collect::>>()?; + + Ok(highlighted_collections) + } +} + + diff --git a/cosmwasm-contracts/marketing/src/error.rs b/cosmwasm-contracts/marketing/src/error.rs new file mode 100644 index 0000000000..d0d8dbb8e0 --- /dev/null +++ b/cosmwasm-contracts/marketing/src/error.rs @@ -0,0 +1,56 @@ +use cosmwasm_std::{DivideByZeroError, OverflowError, StdError}; +use thiserror::Error; + +#[derive(Error, Debug, PartialEq)] +pub enum ContractError { + #[error("{0}")] + Std(#[from] StdError), + + #[error("{0}")] + Overflow(#[from] OverflowError), + + #[error("{0}")] + DivideByZero(#[from] DivideByZeroError), + + #[error("{0}")] + DecodeError(#[from] base64::DecodeError), + + #[error("{0}")] + ParseIntError(#[from] std::num::ParseIntError), + + #[error("Channel already exists.")] + ChannelExists, + + #[error("This address does not own a channel.")] + UnknownChannelAddress, + + #[error("Channel does not exist.")] + ChannelNotFound, + + #[error("Membership kind does not exists.")] + MembershipKindNotFound, + + #[error("Unauthorized.")] + Unauthorized, + + #[error("Invalid token ID.")] + InvalidTokenId, + + #[error("Nft not found.")] + NftNotFound, + + #[error("Cannot transfer to self.")] + CannotTransferToSelf, + + #[error("Invalid funds.")] + InvalidFunds, + + #[error("Serialization error.")] + SerializationError, + + #[error("Internal error.")] + InternalError, + + #[error("No changes.")] + NoChanges, +} diff --git a/cosmwasm-contracts/marketing/src/lib.rs b/cosmwasm-contracts/marketing/src/lib.rs new file mode 100644 index 0000000000..5c639a809f --- /dev/null +++ b/cosmwasm-contracts/marketing/src/lib.rs @@ -0,0 +1,2 @@ +pub mod contract; +pub mod error; \ No newline at end of file From c340ad8d4dc562cddbe120c5316816bb944ce061 Mon Sep 17 00:00:00 2001 From: WaDadidou Date: Thu, 19 Sep 2024 16:54:57 -0400 Subject: [PATCH 2/5] feat: marketing: add multitest --- cosmwasm-contracts/marketing/Cargo.lock | 300 ++++++++++++++++-- cosmwasm-contracts/marketing/Cargo.toml | 3 + cosmwasm-contracts/marketing/src/contract.rs | 62 ++-- cosmwasm-contracts/marketing/src/lib.rs | 4 +- cosmwasm-contracts/marketing/src/multitest.rs | 75 +++++ 5 files changed, 379 insertions(+), 65 deletions(-) create mode 100644 cosmwasm-contracts/marketing/src/multitest.rs diff --git a/cosmwasm-contracts/marketing/Cargo.lock b/cosmwasm-contracts/marketing/Cargo.lock index 14d26e5305..47eeb4e2b9 100644 --- a/cosmwasm-contracts/marketing/Cargo.lock +++ b/cosmwasm-contracts/marketing/Cargo.lock @@ -13,6 +13,18 @@ dependencies = [ "version_check", ] +[[package]] +name = "anyhow" +version = "1.0.86" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b3d1d046238990b9cf5bcde22a3fb3584ee5cf65fb2765f454ed428c7a0063da" + +[[package]] +name = "base16ct" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "349a06037c7bf932dd7e7d1f653678b2038b9ad46a74102f1fc7bd7872678cce" + [[package]] name = "base16ct" version = "0.2.0" @@ -67,6 +79,12 @@ version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" +[[package]] +name = "bytes" +version = "1.6.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a12916984aab3fa6e39d655a33e09c0071eb36d6ab3aea5c2d78551f1df6d952" + [[package]] name = "cfg-if" version = "1.0.0" @@ -102,7 +120,7 @@ checksum = "0f862b355f7e47711e0acfe6af92cb3fd8fd5936b66a9eaa338b51edabd1e77d" dependencies = [ "digest 0.10.7", "ed25519-zebra", - "k256", + "k256 0.13.3", "rand_core 0.6.4", "thiserror", ] @@ -171,6 +189,18 @@ dependencies = [ "libc", ] +[[package]] +name = "crypto-bigint" +version = "0.4.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ef2b4b23cddf68b89b8f8069890e8c270d54e2d5fe1b143820234805e4cb17ef" +dependencies = [ + "generic-array", + "rand_core 0.6.4", + "subtle", + "zeroize", +] + [[package]] name = "crypto-bigint" version = "0.5.5" @@ -206,6 +236,25 @@ dependencies = [ "zeroize", ] +[[package]] +name = "cw-multi-test" +version = "0.16.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "127c7bb95853b8e828bdab97065c81cb5ddc20f7339180b61b2300565aaa99d1" +dependencies = [ + "anyhow", + "cosmwasm-std", + "cw-storage-plus", + "cw-utils", + "derivative", + "itertools", + "k256 0.11.6", + "prost", + "schemars", + "serde", + "thiserror", +] + [[package]] name = "cw-storage-plus" version = "1.2.0" @@ -217,6 +266,46 @@ dependencies = [ "serde", ] +[[package]] +name = "cw-utils" +version = "1.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1c4a657e5caacc3a0d00ee96ca8618745d050b8f757c709babafb81208d4239c" +dependencies = [ + "cosmwasm-schema", + "cosmwasm-std", + "cw2", + "schemars", + "semver", + "serde", + "thiserror", +] + +[[package]] +name = "cw2" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6c120b24fbbf5c3bedebb97f2cc85fbfa1c3287e09223428e7e597b5293c1fa" +dependencies = [ + "cosmwasm-schema", + "cosmwasm-std", + "cw-storage-plus", + "schemars", + "semver", + "serde", + "thiserror", +] + +[[package]] +name = "der" +version = "0.6.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1a467a65c5e759bce6e65eaf91cc29f466cdc57cb65777bd646872a8a1fd4de" +dependencies = [ + "const-oid", + "zeroize", +] + [[package]] name = "der" version = "0.7.9" @@ -265,18 +354,30 @@ version = "1.0.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0d6ef0072f8a535281e4876be788938b528e9a1d43900b82c2569af7da799125" +[[package]] +name = "ecdsa" +version = "0.14.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "413301934810f597c1d19ca71c8710e99a3f1ba28a0d2ebc01551a2daeea3c5c" +dependencies = [ + "der 0.6.1", + "elliptic-curve 0.12.3", + "rfc6979 0.3.1", + "signature 1.6.4", +] + [[package]] name = "ecdsa" version = "0.16.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ee27f32b5c5292967d2d4a9d7f1e0b0aed2c15daded5a60300e4abb9d8020bca" dependencies = [ - "der", + "der 0.7.9", "digest 0.10.7", - "elliptic-curve", - "rfc6979", - "signature", - "spki", + "elliptic-curve 0.13.8", + "rfc6979 0.4.0", + "signature 2.2.0", + "spki 0.7.3", ] [[package]] @@ -294,21 +395,47 @@ dependencies = [ "zeroize", ] +[[package]] +name = "either" +version = "1.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "60b1af1c220855b6ceac025d3f6ecdd2b7c4894bfe9cd9bda4fbb4bc7c0d4cf0" + +[[package]] +name = "elliptic-curve" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e7bb888ab5300a19b8e5bceef25ac745ad065f3c9f7efc6de1b91958110891d3" +dependencies = [ + "base16ct 0.1.1", + "crypto-bigint 0.4.9", + "der 0.6.1", + "digest 0.10.7", + "ff 0.12.1", + "generic-array", + "group 0.12.1", + "pkcs8 0.9.0", + "rand_core 0.6.4", + "sec1 0.3.0", + "subtle", + "zeroize", +] + [[package]] name = "elliptic-curve" version = "0.13.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b5e6043086bf7973472e0c7dff2142ea0b680d30e18d9cc40f267efbf222bd47" dependencies = [ - "base16ct", - "crypto-bigint", + "base16ct 0.2.0", + "crypto-bigint 0.5.5", "digest 0.10.7", - "ff", + "ff 0.13.0", "generic-array", - "group", - "pkcs8", + "group 0.13.0", + "pkcs8 0.10.2", "rand_core 0.6.4", - "sec1", + "sec1 0.7.3", "subtle", "zeroize", ] @@ -319,6 +446,16 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" +[[package]] +name = "ff" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d013fc25338cc558c5c2cfbad646908fb23591e2404481826742b651c9af7160" +dependencies = [ + "rand_core 0.6.4", + "subtle", +] + [[package]] name = "ff" version = "0.13.0" @@ -357,13 +494,24 @@ dependencies = [ "wasi", ] +[[package]] +name = "group" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5dfbfb3a6cfbd390d5c9564ab283a0349b9b9fcd46a706c1eb10e0db70bfbac7" +dependencies = [ + "ff 0.12.1", + "rand_core 0.6.4", + "subtle", +] + [[package]] name = "group" version = "0.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f0f9ef7462f7c099f518d754361858f86d8a07af53ba9af0fe635bbccb151a63" dependencies = [ - "ff", + "ff 0.13.0", "rand_core 0.6.4", "subtle", ] @@ -408,12 +556,33 @@ dependencies = [ "hashbrown 0.14.5", ] +[[package]] +name = "itertools" +version = "0.10.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b0fd2260e829bddf4cb6ea802289de2f86d6a7a690192fbe91b3f46e0f2c8473" +dependencies = [ + "either", +] + [[package]] name = "itoa" version = "1.0.11" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" +[[package]] +name = "k256" +version = "0.11.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72c1e0b51e7ec0a97369623508396067a486bd0cbed95a2659a4b863d28cfc8b" +dependencies = [ + "cfg-if", + "ecdsa 0.14.8", + "elliptic-curve 0.12.3", + "sha2 0.10.8", +] + [[package]] name = "k256" version = "0.13.3" @@ -421,11 +590,11 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "956ff9b67e26e1a6a866cb758f12c6f8746208489e3e4a4b5580802f2f0a587b" dependencies = [ "cfg-if", - "ecdsa", - "elliptic-curve", + "ecdsa 0.16.9", + "elliptic-curve 0.13.8", "once_cell", "sha2 0.10.8", - "signature", + "signature 2.2.0", ] [[package]] @@ -493,14 +662,24 @@ version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c08d65885ee38876c4f86fa503fb49d7b507c2b62552df7c70b2fce627e06381" +[[package]] +name = "pkcs8" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9eca2c590a5f85da82668fa685c09ce2888b9430e83299debf1f34b65fd4a4ba" +dependencies = [ + "der 0.6.1", + "spki 0.6.0", +] + [[package]] name = "pkcs8" version = "0.10.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f950b2377845cebe5cf8b5165cb3cc1a5e0fa5cfa3e1f7f55707d8fd82e0a7b7" dependencies = [ - "der", - "spki", + "der 0.7.9", + "spki 0.7.3", ] [[package]] @@ -546,6 +725,29 @@ dependencies = [ "unicode-ident", ] +[[package]] +name = "prost" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "444879275cb4fd84958b1a1d5420d15e6fcf7c235fe47f053c9c2a80aceb6001" +dependencies = [ + "bytes", + "prost-derive", +] + +[[package]] +name = "prost-derive" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f9cc1a3263e07e0bf68e96268f37665207b49560d98739662cdfaae215c720fe" +dependencies = [ + "anyhow", + "itertools", + "proc-macro2", + "quote", + "syn 1.0.109", +] + [[package]] name = "quote" version = "1.0.37" @@ -570,6 +772,17 @@ dependencies = [ "getrandom", ] +[[package]] +name = "rfc6979" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7743f17af12fa0b03b803ba12cd6a8d9483a587e89c69445e3909655c0b9fabb" +dependencies = [ + "crypto-bigint 0.4.9", + "hmac", + "zeroize", +] + [[package]] name = "rfc6979" version = "0.4.0" @@ -610,20 +823,40 @@ dependencies = [ "syn 2.0.77", ] +[[package]] +name = "sec1" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3be24c1842290c45df0a7bf069e0c268a747ad05a192f2fd7dcfdbc1cba40928" +dependencies = [ + "base16ct 0.1.1", + "der 0.6.1", + "generic-array", + "pkcs8 0.9.0", + "subtle", + "zeroize", +] + [[package]] name = "sec1" version = "0.7.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc" dependencies = [ - "base16ct", - "der", + "base16ct 0.2.0", + "der 0.7.9", "generic-array", - "pkcs8", + "pkcs8 0.10.2", "subtle", "zeroize", ] +[[package]] +name = "semver" +version = "1.0.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61697e0a1c7e512e84a621326239844a24d8207b4669b41bc18b32ea5cbf988b" + [[package]] name = "serde" version = "1.0.210" @@ -709,6 +942,16 @@ dependencies = [ "digest 0.10.7", ] +[[package]] +name = "signature" +version = "1.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "74233d3b3b2f6d4b006dc19dee745e73e2a6bfb6f93607cd3b02bd5b00797d7c" +dependencies = [ + "digest 0.10.7", + "rand_core 0.6.4", +] + [[package]] name = "signature" version = "2.2.0" @@ -719,6 +962,16 @@ dependencies = [ "rand_core 0.6.4", ] +[[package]] +name = "spki" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "67cf02bbac7a337dc36e4f5a693db6c21e7863f45070f7064577eb4367a3212b" +dependencies = [ + "base64ct", + "der 0.6.1", +] + [[package]] name = "spki" version = "0.7.3" @@ -726,7 +979,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d91ed6c858b01f942cd56b37a94b3e0a1798290327d1236e4d9cf4eaca44d29d" dependencies = [ "base64ct", - "der", + "der 0.7.9", ] [[package]] @@ -747,8 +1000,11 @@ version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f358d505f46900e55154f028f18811961ebb58f7a92954ec03086ffb2b26cf51" dependencies = [ + "anyhow", "cosmwasm-schema", "cosmwasm-std", + "cw-multi-test", + "derivative", "konst", "schemars", "serde", diff --git a/cosmwasm-contracts/marketing/Cargo.toml b/cosmwasm-contracts/marketing/Cargo.toml index 4b0caf8027..a5fe015cc0 100644 --- a/cosmwasm-contracts/marketing/Cargo.toml +++ b/cosmwasm-contracts/marketing/Cargo.toml @@ -17,3 +17,6 @@ serde = "1.0.180" sylvia = "0.7.0" thiserror = "1.0.44" base64 = "0.21.7" + +[dev-dependencies] +sylvia = { version = "0.7.0", features = ["mt"] } \ No newline at end of file diff --git a/cosmwasm-contracts/marketing/src/contract.rs b/cosmwasm-contracts/marketing/src/contract.rs index aba3a5c681..d8115c4c3a 100644 --- a/cosmwasm-contracts/marketing/src/contract.rs +++ b/cosmwasm-contracts/marketing/src/contract.rs @@ -1,4 +1,3 @@ - use cosmwasm_std::{attr,Addr, Response, StdResult }; @@ -10,33 +9,33 @@ use sylvia::{types::{ExecCtx, InstantiateCtx, QueryCtx},contract, entry_points}; #[cw_serde] pub struct Banner { - image: String, - url: String, + pub image: String, + pub url: String, } #[cw_serde] pub struct Action { - label: String, - url: String, + pub label: String, + pub url: String, } #[cw_serde] pub struct News { - title: String, - subtitle: String, - text: String, - image: String, - actions: Option, + pub title: String, + pub subtitle: String, + pub text: String, + pub image: String, + pub actions: Option>, } #[cw_serde] pub struct MarketingCollectionPreview { - address: String, - image_uri: String, - collection_name: String, - creator_name: String, - twitter_url: String, - secondary_during_mint: bool, + pub address: String, + pub image_uri: String, + pub collection_name: String, + pub creator_name: String, + pub twitter_url: String, + pub secondary_during_mint: bool, } #[cw_serde] @@ -70,29 +69,10 @@ impl MarketingContract { #[msg(instantiate)] pub fn instantiate(&self, ctx: InstantiateCtx - , config: Config - , banners: Vec - , news: Vec - , upcoming_collections: Vec - , live_collections: Vec - , highlighted_collections: Vec + , admin_addr: String ) -> StdResult { - self.config.save(ctx.deps.storage, &config)?; - for (index, banner) in banners.into_iter().enumerate() { - self.banners.save(ctx.deps.storage, index as u64, &banner)?; - } - for (index, news_item) in news.into_iter().enumerate() { - self.news.save(ctx.deps.storage, index as u64, &news_item)?; - } - for (index, upcoming_collection) in upcoming_collections.into_iter().enumerate() { - self.upcoming_collections.save(ctx.deps.storage, index as u64, &upcoming_collection)?; - } - for (index, live_collection) in live_collections.into_iter().enumerate() { - self.live_collections.save(ctx.deps.storage, index as u64, &live_collection)?; - } - for (index, highlighted_collection) in highlighted_collections.into_iter().enumerate() { - self.highlighted_collections.save(ctx.deps.storage, index as u64, &highlighted_collection)?; - } + let admin_addr = ctx.deps.api.addr_validate(admin_addr.as_str())?; + self.config.save(ctx.deps.storage, &Config {admin_addr})?; Ok(Response::default()) } @@ -101,7 +81,7 @@ impl MarketingContract { pub fn update_config( &self, ctx: ExecCtx, - admin_addr: Option, + admin_addr: String, ) -> Result { let attributes = vec![attr("action", "update_config")]; self.config.update(ctx.deps.storage, |mut config| { @@ -110,9 +90,7 @@ impl MarketingContract { return Err(ContractError::Unauthorized); } // Validate and save the new admin_addr in config - if let Some(admin_addr) = admin_addr { config.admin_addr = ctx.deps.api.addr_validate(admin_addr.as_str())?; - } Ok(config) })?; @@ -120,7 +98,7 @@ impl MarketingContract { Ok(Response::new().add_attributes(attributes)) } - #[msg(exec)] + #[msg(exec)] // Only the admin can execute it pub fn update_banners( &self, diff --git a/cosmwasm-contracts/marketing/src/lib.rs b/cosmwasm-contracts/marketing/src/lib.rs index 5c639a809f..ae5b855d2f 100644 --- a/cosmwasm-contracts/marketing/src/lib.rs +++ b/cosmwasm-contracts/marketing/src/lib.rs @@ -1,2 +1,4 @@ pub mod contract; -pub mod error; \ No newline at end of file +pub mod error; +#[cfg(test)] +pub mod multitest; diff --git a/cosmwasm-contracts/marketing/src/multitest.rs b/cosmwasm-contracts/marketing/src/multitest.rs new file mode 100644 index 0000000000..4d88e80cd3 --- /dev/null +++ b/cosmwasm-contracts/marketing/src/multitest.rs @@ -0,0 +1,75 @@ +use sylvia::multitest::App; + +use crate::contract::{multitest_utils::CodeId, Action, News}; +use crate::error::ContractError; + +#[test] +fn basic_full_flow() { + let app = App::default(); + let code_id = CodeId::store_code(&app); + + let admin = "admin"; + let new_admin = "new_admin"; + let contract_creator = "creator"; + let unauthorized_sender = "unauthorized_sender"; + + let action = Action { + label: "".to_string(), + url: "".to_string() + }; + let news_item = News { + title: "a".to_string(), + subtitle: "a".to_string(), + text: "a".to_string(), + image: "a".to_string(), + actions: Some(vec![action]) + }; + let news = vec![news_item]; + + // Instantiate the contract + let contract = code_id + .instantiate( + admin.to_string(), + ) + .call(contract_creator) + .unwrap(); + + // Test get_config + let config = contract.get_config().unwrap(); + assert_eq!(config.admin_addr, admin.to_string()); + + // Test update_config with unauthorized sender + let failed_update_config_res = contract + .update_config(new_admin.to_string()) + .call(unauthorized_sender); + assert_eq!( + failed_update_config_res.err().unwrap(), + ContractError::Unauthorized + ); + // Test update_config with authorized sender, then get_config + contract + .update_config(new_admin.to_string()) + .call(admin) + .unwrap(); + let new_config = contract.get_config().unwrap(); + assert_eq!(new_config.admin_addr, new_admin.to_string()); + + // Test update_news with unauthorized sender + let failed_update_news_res = contract + .update_news(news.clone()) + .call(unauthorized_sender); + assert_eq!( + failed_update_news_res.err().unwrap(), + ContractError::Unauthorized + ); + // Test update_news with authorized sender + contract + .update_news(news.clone()) + .call(new_admin) + .unwrap(); + // Test get_news + contract + .get_news() + .unwrap(); + +} From 8236369b73f8bea9419d1da122cf5139230a7c38 Mon Sep 17 00:00:00 2001 From: WaDadidou Date: Fri, 20 Sep 2024 02:51:42 +0200 Subject: [PATCH 3/5] fix: marketing: add config.json, add Makefile, instantiated on teritori-testnet --- cosmwasm-contracts/marketing/Makefile | 31 ++++++++++++++++++++++++ cosmwasm-contracts/marketing/config.json | 4 +++ 2 files changed, 35 insertions(+) create mode 100644 cosmwasm-contracts/marketing/Makefile create mode 100644 cosmwasm-contracts/marketing/config.json diff --git a/cosmwasm-contracts/marketing/Makefile b/cosmwasm-contracts/marketing/Makefile new file mode 100644 index 0000000000..e5d6b29762 --- /dev/null +++ b/cosmwasm-contracts/marketing/Makefile @@ -0,0 +1,31 @@ +ADMIN=testnet-adm +ADMIN_ADDR=$(shell teritorid keys show $(ADMIN) --keyring-backend test --output json | jq -r .address) +NODE_FLAG=--node https://rpc.testnet.teritori.com:443 +TX_FLAGS=--from $(ADMIN) --chain-id teritori-test-7 $(NODE_FLAG) --gas auto --gas-adjustment 1.3 -y -b sync --output json --keyring-backend test -o json +QUERY_FLAGS=$(NODE_FLAG) -o json +CODE_ID=53 +CONFIG=$(shell cat config.json | jq -r '.admin_addr="$(ADMIN_ADDR)" | tojson | @sh') + +# only informative +# CONTRACT_ADDRESS=tori1xz0acmdjusqv3ntfjuue34stf7z8q3cytjf7jgyuk6ax4vrs6nzshq7d9w + +.PHONY: artifacts/marketing.wasm +artifacts/marketing.wasm: + docker run --rm -v "$(PWD)":/code \ + --platform linux/amd64 \ + --mount type=volume,source=marketing_cache,target=/target \ + --mount type=volume,source=registry_cache,target=/usr/local/cargo/registry \ + cosmwasm/optimizer:0.16.0 + +.PHONY: deploy.testnet +deploy.testnet: artifacts/marketing.wasm + set -o pipefail; \ + TXHASH=$$(teritorid tx wasm store artifacts/marketing.wasm $(TX_FLAGS) | jq -r .txhash); \ + while ! teritorid query tx $$TXHASH $(QUERY_FLAGS) 2>/dev/null | jq -r '.logs[0].events[] | select(.type=="store_code").attributes[] | select(.key=="code_id").value'; do sleep 1; done + +.PHONY: instantiate.testnet +instantiate.testnet: config.json + set -o pipefail; \ + TXHASH=$$(teritorid tx wasm instantiate $(CODE_ID) $(CONFIG) --label Marketing --admin $(ADMIN_ADDR) $(TX_FLAGS) | jq -r .txhash); \ + while ! teritorid query tx $$TXHASH $(QUERY_FLAGS) 2>/dev/null | jq -r '.logs[0].events[] | select(.type=="instantiate").attributes[] | select(.key=="_contract_address").value'; do sleep 1; done + diff --git a/cosmwasm-contracts/marketing/config.json b/cosmwasm-contracts/marketing/config.json new file mode 100644 index 0000000000..1f1fd712ef --- /dev/null +++ b/cosmwasm-contracts/marketing/config.json @@ -0,0 +1,4 @@ +{ + "admin_adrr": "tori1yzjgaql23yxlwxxvmszssg23w3f8k6k2q75jss" +} + From 00c98fc86cb43d3cfb51b399662a0c8882f0f468 Mon Sep 17 00:00:00 2001 From: WaDadidou Date: Thu, 3 Oct 2024 14:55:49 -0400 Subject: [PATCH 4/5] fix: after rebase --- .../cw-contracts}/marketing/.cargo/config.toml | 0 {cosmwasm-contracts => rust/cw-contracts}/marketing/Cargo.lock | 0 {cosmwasm-contracts => rust/cw-contracts}/marketing/Cargo.toml | 0 {cosmwasm-contracts => rust/cw-contracts}/marketing/Makefile | 0 {cosmwasm-contracts => rust/cw-contracts}/marketing/config.json | 0 .../cw-contracts}/marketing/src/bin/schema.rs | 0 .../cw-contracts}/marketing/src/contract.rs | 0 {cosmwasm-contracts => rust/cw-contracts}/marketing/src/error.rs | 0 {cosmwasm-contracts => rust/cw-contracts}/marketing/src/lib.rs | 0 .../cw-contracts}/marketing/src/multitest.rs | 0 10 files changed, 0 insertions(+), 0 deletions(-) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/.cargo/config.toml (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/Cargo.lock (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/Cargo.toml (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/Makefile (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/config.json (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/src/bin/schema.rs (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/src/contract.rs (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/src/error.rs (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/src/lib.rs (100%) rename {cosmwasm-contracts => rust/cw-contracts}/marketing/src/multitest.rs (100%) diff --git a/cosmwasm-contracts/marketing/.cargo/config.toml b/rust/cw-contracts/marketing/.cargo/config.toml similarity index 100% rename from cosmwasm-contracts/marketing/.cargo/config.toml rename to rust/cw-contracts/marketing/.cargo/config.toml diff --git a/cosmwasm-contracts/marketing/Cargo.lock b/rust/cw-contracts/marketing/Cargo.lock similarity index 100% rename from cosmwasm-contracts/marketing/Cargo.lock rename to rust/cw-contracts/marketing/Cargo.lock diff --git a/cosmwasm-contracts/marketing/Cargo.toml b/rust/cw-contracts/marketing/Cargo.toml similarity index 100% rename from cosmwasm-contracts/marketing/Cargo.toml rename to rust/cw-contracts/marketing/Cargo.toml diff --git a/cosmwasm-contracts/marketing/Makefile b/rust/cw-contracts/marketing/Makefile similarity index 100% rename from cosmwasm-contracts/marketing/Makefile rename to rust/cw-contracts/marketing/Makefile diff --git a/cosmwasm-contracts/marketing/config.json b/rust/cw-contracts/marketing/config.json similarity index 100% rename from cosmwasm-contracts/marketing/config.json rename to rust/cw-contracts/marketing/config.json diff --git a/cosmwasm-contracts/marketing/src/bin/schema.rs b/rust/cw-contracts/marketing/src/bin/schema.rs similarity index 100% rename from cosmwasm-contracts/marketing/src/bin/schema.rs rename to rust/cw-contracts/marketing/src/bin/schema.rs diff --git a/cosmwasm-contracts/marketing/src/contract.rs b/rust/cw-contracts/marketing/src/contract.rs similarity index 100% rename from cosmwasm-contracts/marketing/src/contract.rs rename to rust/cw-contracts/marketing/src/contract.rs diff --git a/cosmwasm-contracts/marketing/src/error.rs b/rust/cw-contracts/marketing/src/error.rs similarity index 100% rename from cosmwasm-contracts/marketing/src/error.rs rename to rust/cw-contracts/marketing/src/error.rs diff --git a/cosmwasm-contracts/marketing/src/lib.rs b/rust/cw-contracts/marketing/src/lib.rs similarity index 100% rename from cosmwasm-contracts/marketing/src/lib.rs rename to rust/cw-contracts/marketing/src/lib.rs diff --git a/cosmwasm-contracts/marketing/src/multitest.rs b/rust/cw-contracts/marketing/src/multitest.rs similarity index 100% rename from cosmwasm-contracts/marketing/src/multitest.rs rename to rust/cw-contracts/marketing/src/multitest.rs From adf1db553c51a59f7a716823c246b674eb34b9a5 Mon Sep 17 00:00:00 2001 From: WaDadidou Date: Thu, 3 Oct 2024 15:01:12 -0400 Subject: [PATCH 5/5] fix: Marketing: remove collection stuff from contract, cargo check --- Cargo.lock | 14 +++ rust/cw-contracts/marketing/src/contract.rs | 119 +------------------ rust/cw-contracts/marketing/src/multitest.rs | 4 +- 3 files changed, 18 insertions(+), 119 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 4d14d11115..c80816c40d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -926,6 +926,20 @@ version = "0.2.159" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "561d97a539a36e26a9a5fad1ea11a3039a67714694aaa379433e580854bc3dc5" +[[package]] +name = "marketing" +version = "0.1.0" +dependencies = [ + "base64", + "cosmwasm-schema", + "cosmwasm-std", + "cw-storage-plus 1.2.0", + "schemars", + "serde", + "sylvia", + "thiserror", +] + [[package]] name = "memchr" version = "2.7.4" diff --git a/rust/cw-contracts/marketing/src/contract.rs b/rust/cw-contracts/marketing/src/contract.rs index d8115c4c3a..bcc52962f3 100644 --- a/rust/cw-contracts/marketing/src/contract.rs +++ b/rust/cw-contracts/marketing/src/contract.rs @@ -14,7 +14,7 @@ pub struct Banner { } #[cw_serde] -pub struct Action { +pub struct NewsAction { pub label: String, pub url: String, } @@ -25,17 +25,7 @@ pub struct News { pub subtitle: String, pub text: String, pub image: String, - pub actions: Option>, -} - -#[cw_serde] -pub struct MarketingCollectionPreview { - pub address: String, - pub image_uri: String, - pub collection_name: String, - pub creator_name: String, - pub twitter_url: String, - pub secondary_during_mint: bool, + pub actions: Option>, } #[cw_serde] @@ -47,9 +37,6 @@ pub struct MarketingContract { pub(crate) config: Item<'static, Config>, pub(crate) banners: Map<'static, u64, Banner>, pub(crate) news: Map<'static, u64, News>, - pub(crate) upcoming_collections: Map<'static, u64, MarketingCollectionPreview>, - pub(crate) live_collections: Map<'static, u64, MarketingCollectionPreview>, - pub(crate) highlighted_collections: Map<'static, u64, MarketingCollectionPreview>, } #[entry_points] @@ -61,9 +48,6 @@ impl MarketingContract { config: Item::new("config"), banners: Map::new("banners"), news: Map::new("news"), - upcoming_collections: Map::new("upcoming_collections"), - live_collections: Map::new("live_collections"), - highlighted_collections: Map::new("highlighted_collections"), } } @@ -142,72 +126,6 @@ impl MarketingContract { Ok(Response::new().add_attributes(attributes)) } - #[msg(exec)] - // Only the admin can execute it - pub fn update_live_collections( - &self, - ctx: ExecCtx, - live_collections: Vec, - ) -> Result { - let attributes = vec![attr("action", "update_live_collections")]; - let config = self.config.load(ctx.deps.storage)?; - // Permission check - if ctx.info.sender != config.admin_addr { - return Err(ContractError::Unauthorized); - } - // Replace all live_collections with the new ones - self.live_collections.clear(ctx.deps.storage); - for (index, live_collection) in live_collections.into_iter().enumerate() { - self.live_collections.save(ctx.deps.storage, index as u64, &live_collection)?; - } - - Ok(Response::new().add_attributes(attributes)) - } - - #[msg(exec)] - // Only the admin can execute it - pub fn update_upcoming_collections( - &self, - ctx: ExecCtx, - upcoming_collections: Vec, - ) -> Result { - let attributes = vec![attr("action", "update_upcoming_collections")]; - let config = self.config.load(ctx.deps.storage)?; - // Permission check - if ctx.info.sender != config.admin_addr { - return Err(ContractError::Unauthorized); - } - // Replace all upcoming_collections with the new ones - self.upcoming_collections.clear(ctx.deps.storage); - for (index, upcoming_collection) in upcoming_collections.into_iter().enumerate() { - self.upcoming_collections.save(ctx.deps.storage, index as u64, &upcoming_collection)?; - } - - Ok(Response::new().add_attributes(attributes)) - } - - #[msg(exec)] - // Only the admin can execute it - pub fn update_highlighted_collections( - &self, - ctx: ExecCtx, - highlighted_collections: Vec, - ) -> Result { - let attributes = vec![attr("action", "update_highlighted_collections")]; - let config = self.config.load(ctx.deps.storage)?; - // Permission check - if ctx.info.sender != config.admin_addr { - return Err(ContractError::Unauthorized); - } - // Replace all highlighted_collections with the new ones - self.highlighted_collections.clear(ctx.deps.storage); - for (index, highlighted_collection) in highlighted_collections.into_iter().enumerate() { - self.highlighted_collections.save(ctx.deps.storage, index as u64, &highlighted_collection)?; - } - - Ok(Response::new().add_attributes(attributes)) - } - #[msg(query)] pub fn get_config(&self, ctx: QueryCtx) -> StdResult { let config = self.config.load(ctx.deps.storage)?; @@ -235,39 +153,6 @@ impl MarketingContract { Ok(news) } - - #[msg(query)] - pub fn get_live_collections(&self, ctx: QueryCtx) -> StdResult> { - let live_collections: Vec = self - .live_collections - .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) - .map(|item| item.map(|(_, live_collection)| live_collection)) - .collect::>>()?; - - Ok(live_collections) - } - - #[msg(query)] - pub fn get_upcoming_collections(&self, ctx: QueryCtx) -> StdResult> { - let upcoming_collections: Vec = self - .upcoming_collections - .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) - .map(|item| item.map(|(_, upcoming_collection)| upcoming_collection)) - .collect::>>()?; - - Ok(upcoming_collections) - } - - #[msg(query)] - pub fn get_highlighted_collections(&self, ctx: QueryCtx) -> StdResult> { - let highlighted_collections: Vec = self - .highlighted_collections - .range(ctx.deps.storage, None, None, cosmwasm_std::Order::Ascending) - .map(|item| item.map(|(_, highlighted_collection)| highlighted_collection)) - .collect::>>()?; - - Ok(highlighted_collections) - } } diff --git a/rust/cw-contracts/marketing/src/multitest.rs b/rust/cw-contracts/marketing/src/multitest.rs index 4d88e80cd3..2b61b4c9d0 100644 --- a/rust/cw-contracts/marketing/src/multitest.rs +++ b/rust/cw-contracts/marketing/src/multitest.rs @@ -1,6 +1,6 @@ use sylvia::multitest::App; -use crate::contract::{multitest_utils::CodeId, Action, News}; +use crate::contract::{multitest_utils::CodeId, NewsAction, News}; use crate::error::ContractError; #[test] @@ -13,7 +13,7 @@ fn basic_full_flow() { let contract_creator = "creator"; let unauthorized_sender = "unauthorized_sender"; - let action = Action { + let action = NewsAction { label: "".to_string(), url: "".to_string() };