From 7d17b698543171094024e0e5fd38836728eb5c80 Mon Sep 17 00:00:00 2001 From: Duncan Dam Date: Tue, 22 Oct 2024 18:42:01 +0700 Subject: [PATCH 1/4] [BLOCK-2560] update docs to remove vector and change float and double --- .../nft-actions/addkeys.a.experimental.md | 38 +++++-------- .../nft-actions/setktypes.experimental.md | 56 ++++++------------- .../nft-actions/setvals.a.experimental.md | 38 +++++-------- 3 files changed, 46 insertions(+), 86 deletions(-) diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md index d8bff32d50..5526e884c4 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md @@ -48,30 +48,20 @@ The properties of this type are provided below: `key_value_store` will be an array with first element is type of the value and second is the value. Here is the support list and example: -| Value Type | Key Def Type string | Example | -| ---------- | ------------------- | -------------------------- | -| int8 | int8 | ["int8", 0] | -| int16 | int16 | ["int16", 0] | -| int32 | int32 | ["int32", 0] | -| int64 | int64 | ["int64", 0] | -| uint8 | uint8 | ["uint8", 0] | -| uint16 | uint16 | ["uint16", 0] | -| uint32 | uint32 | ["uint32", 0] | -| uint64 | uint64 | ["uint64", 0] | -| float | float | ["float", 0.1] | -| double | double | ["double", 0.1] | -| string | string | ["string", "a"] | -| INT8_VEC | int8[] | ["INT8_VEC", [0,1,2]] | -| INT16_VEC | int16[] | ["INT16_VEC", [0,1,2]] | -| INT32_VEC | int32[] | ["INT32_VEC", [0,1,2]] | -| INT64_VEC | int64[] | ["INT64_VEC", [0,1,2]] | -| UINT8_VEC | uint8[] | ["UINT8_VEC", [0,1,2]] | -| UINT16_VEC | uint16[] | ["UINT16_VEC", [0,1,2]] | -| UINT32_VEC | uint32[] | ["UINT32_VEC", [0,1,2]] | -| UINT64_VEC | uint64[] | ["UINT64_VEC", [0,1,2]] | -| FLOAT_VEC | float[] | ["FLOAT_VEC", [0.1,1.2]] | -| DOUBLE_VEC | double[] | ["DOUBLE_VEC", [0.1,1.2]] | -| STRING_VEC | string[] | ["STRING_VEC", ["a", "b"]] | +| Value Type | Key Def Type string | Example | +| ---------- | ------------------- | ---------------- | +| int8 | int8 | ["int8", 0] | +| int16 | int16 | ["int16", 0] | +| int32 | int32 | ["int32", 0] | +| int64 | int64 | ["int64", 0] | +| uint8 | uint8 | ["uint8", 0] | +| uint16 | uint16 | ["uint16", 0] | +| uint32 | uint32 | ["uint32", 0] | +| uint64 | uint64 | ["uint64", 0] | +| float | float32 | ["float32", 0.1] | +| double | float64 | ["float64", 0.1] | +| string | string | ["string", "a"] | +| bool | bool | ["bool", 1] | ### `edit_rights` bitmask breakdown diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md index 34993f06b5..adfea3c263 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md @@ -12,30 +12,20 @@ Update supported value type for on chain data Here is the default table of supported value type and its limit. -| C++ Type | Type string | Limit by element | -| ---------- | ----------- | ---------------- | -| int8 | int8 | 1 | -| int16 | int16 | 1 | -| int32 | int32 | 1 | -| int64 | int64 | 1 | -| uint8 | uint8 | 1 | -| uint16 | uint16 | 1 | -| uint32 | uint32 | 1 | -| uint64 | uint64 | 1 | -| float | float | 1 | -| double | double | 1 | -| string | string | 128 | -| INT8_VEC | int8[] | 128 | -| INT16_VEC | int16[] | 64 | -| INT32_VEC | int32[] | 32 | -| INT64_VEC | int64[] | 16 | -| UINT8_VEC | uint8[] | 128 | -| UINT16_VEC | uint16[] | 64 | -| UINT32_VEC | uint32[] | 32 | -| UINT64_VEC | uint64[] | 16 | -| FLOAT_VEC | float[] | 32 | -| DOUBLE_VEC | double[] | 16 | -| STRING_VEC | string[] | 256 | +| C++ Type | Type string | Limit by element | +| -------- | ----------- | ---------------- | +| int8 | int8 | 1 | +| int16 | int16 | 1 | +| int32 | int32 | 1 | +| int64 | int64 | 1 | +| uint8 | uint8 | 1 | +| uint16 | uint16 | 1 | +| uint32 | uint32 | 1 | +| uint64 | uint64 | 1 | +| float | float32 | 1 | +| double | float64 | 1 | +| string | string | 128 | +| bool | bool | 1 | **Note**: In case of `string` and `string[]`, it will count the total characters instead. @@ -61,7 +51,7 @@ The properties of this type are provided below: ## CLI - cleos ```bash -cleos push action eosio.nft.ft setktypes '{ "key_types": [ {"key_type": "int8", "element_number_limit": 1}, {"key_type": "int16", "element_number_limit": 1}, {"key_type": "int32", "element_number_limit": 1}, {"key_type": "int64", "element_number_limit": 1}, {"key_type": "uint8", "element_number_limit": 1}, {"key_type": "uint16", "element_number_limit": 1}, {"key_type": "uint32", "element_number_limit": 1}, {"key_type": "uint64", "element_number_limit": 1}, {"key_type": "float", "element_number_limit": 1}, {"key_type": "double", "element_number_limit": 1}, {"key_type": "string", "element_number_limit": 128}, {"key_type": "int8[]", "element_number_limit": 128}, {"key_type": "int16[]", "element_number_limit": 64}, {"key_type": "int32[]", "element_number_limit": 32}, {"key_type": "int64[]", "element_number_limit": 16}, {"key_type": "uint8[]", "element_number_limit": 128}, {"key_type": "uint16[]", "element_number_limit": 64}, {"key_type": "uint32[]", "element_number_limit": 32}, {"key_type": "uint64[]", "element_number_limit": 16}, {"key_type": "float[]", "element_number_limit": 32}, {"key_type": "double[]", "element_number_limit": 16}, {"key_type": "string[]", "element_number_limit": 256} ] }' -p ultra.nft.ft@active +cleos push action eosio.nft.ft setktypes '{ "key_types": [ {"key_type": "int8", "element_number_limit": 1}, {"key_type": "int16", "element_number_limit": 1}, {"key_type": "int32", "element_number_limit": 1}, {"key_type": "int64", "element_number_limit": 1}, {"key_type": "uint8", "element_number_limit": 1}, {"key_type": "uint16", "element_number_limit": 1}, {"key_type": "uint32", "element_number_limit": 1}, {"key_type": "uint64", "element_number_limit": 1}, {"key_type": "float32", "element_number_limit": 1}, {"key_type": "float64", "element_number_limit": 1}, {"key_type": "string", "element_number_limit": 128}, {"key_type": "bool", "element_number_limit": 1} ] }' -p ultra.nft.ft@active ``` ## JavaScript - eosjs @@ -83,20 +73,10 @@ await transact( {key_type: "uint16", element_number_limit: 1}, {key_type: "uint32", element_number_limit: 1}, {key_type: "uint64", element_number_limit: 1}, - {key_type: "float", element_number_limit: 1}, - {key_type: "double", element_number_limit: 1}, + {key_type: "float32", element_number_limit: 1}, + {key_type: "float64", element_number_limit: 1}, {key_type: "string", element_number_limit: 128}, - {key_type: "int8[]", element_number_limit: 128}, - {key_type: "int16[]", element_number_limit: 64}, - {key_type: "int32[]", element_number_limit: 32}, - {key_type: "int64[]", element_number_limit: 16}, - {key_type: "uint8[]", element_number_limit: 128}, - {key_type: "uint16[]", element_number_limit: 64}, - {key_type: "uint32[]", element_number_limit: 32}, - {key_type: "uint64[]", element_number_limit: 16}, - {key_type: "float[]", element_number_limit: 32}, - {key_type: "double[]", element_number_limit: 16}, - {key_type: "string[]", element_number_limit: 256} + {key_type: "bool", element_number_limit: 1}, ] }, }, diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md index b3e0da348e..91e05cc629 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md @@ -45,30 +45,20 @@ The properties of this type are provided below: `key_value_store` will be an array with first element is type of the value and second is the value. Here is the support list and example: -| Value Type | Key Def Type string | Example | -| ---------- | ------------------- | -------------------------- | -| int8 | int8 | ["int8", 0] | -| int16 | int16 | ["int16", 0] | -| int32 | int32 | ["int32", 0] | -| int64 | int64 | ["int64", 0] | -| uint8 | uint8 | ["uint8", 0] | -| uint16 | uint16 | ["uint16", 0] | -| uint32 | uint32 | ["uint32", 0] | -| uint64 | uint64 | ["uint64", 0] | -| float | float | ["float", 0.1] | -| double | double | ["double", 0.1] | -| string | string | ["string", "a"] | -| INT8_VEC | int8[] | ["INT8_VEC", [0,1,2]] | -| INT16_VEC | int16[] | ["INT16_VEC", [0,1,2]] | -| INT32_VEC | int32[] | ["INT32_VEC", [0,1,2]] | -| INT64_VEC | int64[] | ["INT64_VEC", [0,1,2]] | -| UINT8_VEC | uint8[] | ["UINT8_VEC", [0,1,2]] | -| UINT16_VEC | uint16[] | ["UINT16_VEC", [0,1,2]] | -| UINT32_VEC | uint32[] | ["UINT32_VEC", [0,1,2]] | -| UINT64_VEC | uint64[] | ["UINT64_VEC", [0,1,2]] | -| FLOAT_VEC | float[] | ["FLOAT_VEC", [0.1,1.2]] | -| DOUBLE_VEC | double[] | ["DOUBLE_VEC", [0.1,1.2]] | -| STRING_VEC | string[] | ["STRING_VEC", ["a", "b"]] | +| Value Type | Key Def Type string | Example | +| ---------- | ------------------- | ---------------- | +| int8 | int8 | ["int8", 0] | +| int16 | int16 | ["int16", 0] | +| int32 | int32 | ["int32", 0] | +| int64 | int64 | ["int64", 0] | +| uint8 | uint8 | ["uint8", 0] | +| uint16 | uint16 | ["uint16", 0] | +| uint32 | uint32 | ["uint32", 0] | +| uint64 | uint64 | ["uint64", 0] | +| float | float32 | ["float32", 0.1] | +| double | float64 | ["float64", 0.1] | +| string | string | ["string", "a"] | +| bool | bool | ["bool", 1] | ## CLI - cleos From 6e714bb3591caafe3d3ff437c0d7c5bfa6abc7ec Mon Sep 17 00:00:00 2001 From: Duncan Dam Date: Wed, 23 Oct 2024 11:21:00 +0700 Subject: [PATCH 2/4] update --- .../nft-contract/nft-actions/addkeys.a.experimental.md | 2 +- .../nft-contract/nft-actions/setvals.a.experimental.md | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md index 5526e884c4..0b1d39ea37 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md @@ -61,7 +61,7 @@ The properties of this type are provided below: | float | float32 | ["float32", 0.1] | | double | float64 | ["float64", 0.1] | | string | string | ["string", "a"] | -| bool | bool | ["bool", 1] | +| bool | bool | ["bool", true] | ### `edit_rights` bitmask breakdown diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md index 91e05cc629..2889eacb8f 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md @@ -58,7 +58,7 @@ The properties of this type are provided below: | float | float32 | ["float32", 0.1] | | double | float64 | ["float64", 0.1] | | string | string | ["string", "a"] | -| bool | bool | ["bool", 1] | +| bool | bool | ["bool", true] | ## CLI - cleos From 77c7e5432ce4861a35b21daea9d1faefe6c82b05 Mon Sep 17 00:00:00 2001 From: Duncan Dam Date: Wed, 23 Oct 2024 15:38:07 +0700 Subject: [PATCH 3/4] remove bool --- .../nft-contract/nft-actions/addkeys.a.experimental.md | 1 - .../nft-contract/nft-actions/setktypes.experimental.md | 6 ++---- .../nft-contract/nft-actions/setvals.a.experimental.md | 1 - 3 files changed, 2 insertions(+), 6 deletions(-) diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md index 0b1d39ea37..abcfbbeb40 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md @@ -61,7 +61,6 @@ The properties of this type are provided below: | float | float32 | ["float32", 0.1] | | double | float64 | ["float64", 0.1] | | string | string | ["string", "a"] | -| bool | bool | ["bool", true] | ### `edit_rights` bitmask breakdown diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md index adfea3c263..65c0dc57a7 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/setktypes.experimental.md @@ -25,7 +25,6 @@ Here is the default table of supported value type and its limit. | float | float32 | 1 | | double | float64 | 1 | | string | string | 128 | -| bool | bool | 1 | **Note**: In case of `string` and `string[]`, it will count the total characters instead. @@ -51,7 +50,7 @@ The properties of this type are provided below: ## CLI - cleos ```bash -cleos push action eosio.nft.ft setktypes '{ "key_types": [ {"key_type": "int8", "element_number_limit": 1}, {"key_type": "int16", "element_number_limit": 1}, {"key_type": "int32", "element_number_limit": 1}, {"key_type": "int64", "element_number_limit": 1}, {"key_type": "uint8", "element_number_limit": 1}, {"key_type": "uint16", "element_number_limit": 1}, {"key_type": "uint32", "element_number_limit": 1}, {"key_type": "uint64", "element_number_limit": 1}, {"key_type": "float32", "element_number_limit": 1}, {"key_type": "float64", "element_number_limit": 1}, {"key_type": "string", "element_number_limit": 128}, {"key_type": "bool", "element_number_limit": 1} ] }' -p ultra.nft.ft@active +cleos push action eosio.nft.ft setktypes '{ "key_types": [ {"key_type": "int8", "element_number_limit": 1}, {"key_type": "int16", "element_number_limit": 1}, {"key_type": "int32", "element_number_limit": 1}, {"key_type": "int64", "element_number_limit": 1}, {"key_type": "uint8", "element_number_limit": 1}, {"key_type": "uint16", "element_number_limit": 1}, {"key_type": "uint32", "element_number_limit": 1}, {"key_type": "uint64", "element_number_limit": 1}, {"key_type": "float32", "element_number_limit": 1}, {"key_type": "float64", "element_number_limit": 1}, {"key_type": "string", "element_number_limit": 128} ] }' -p ultra.nft.ft@active ``` ## JavaScript - eosjs @@ -75,8 +74,7 @@ await transact( {key_type: "uint64", element_number_limit: 1}, {key_type: "float32", element_number_limit: 1}, {key_type: "float64", element_number_limit: 1}, - {key_type: "string", element_number_limit: 128}, - {key_type: "bool", element_number_limit: 1}, + {key_type: "string", element_number_limit: 128} ] }, }, diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md index 2889eacb8f..c27dc74d90 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/setvals.a.experimental.md @@ -58,7 +58,6 @@ The properties of this type are provided below: | float | float32 | ["float32", 0.1] | | double | float64 | ["float64", 0.1] | | string | string | ["string", "a"] | -| bool | bool | ["bool", true] | ## CLI - cleos From 8b1fa32d50f1454c3d46fefdc0a6444f97f4fc95 Mon Sep 17 00:00:00 2001 From: Duncan Dam Date: Fri, 25 Oct 2024 13:36:46 +0700 Subject: [PATCH 4/4] update --- .../nft-actions/addkeys.a.experimental.md | 93 ++++++++++++++++--- 1 file changed, 80 insertions(+), 13 deletions(-) diff --git a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md index abcfbbeb40..fabbf5ac93 100644 --- a/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md +++ b/docs/blockchain/contracts/nft-contract/nft-actions/addkeys.a.experimental.md @@ -74,7 +74,7 @@ The properties of this type are provided below: ## CLI - cleos ```bash -cleos push action eosio.nft.ft addkeys.a '{ "factory_id": "10", "key_defs": [ { "name": "id", "type": "uint8[]", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "UINT8_VEC", [0, 1] ] } ], "memo": "new key pairs" }' -p alice@active +cleos push action eosio.nft.ft addkeys.a '{ "factory_id": 10, "key_defs": [ { "name": "id1", "type": "int8", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "int8", -8 ] }, { "name": "id2", "type": "int16", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "int16", 16 ] }, { "name": "id3", "type": "int32", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "int32", -32 ] }, { "name": "id4", "type": "int64", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "int64", 64 ] }, { "name": "id5", "type": "uint8", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "uint8", 8 ] }, { "name": "id6", "type": "uint16", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "uint16", 16 ] }, { "name": "id7", "type": "uint32", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "uint32", 32 ] }, { "name": "id8", "type": "uint64", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "uint64", 64 ] }, { "name": "id9", "type": "float32", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "float32", -1.32 ] }, { "name": "id10", "type": "float64", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "float64", 1.64 ] }, { "name": "id11", "type": "string", "edit_rights": 8, "editors": [ "bob" ], "default_value": [ "string", "abc" ] } ], "memo": "add new key pairs" }' -p alice@active ``` ## JavaScript - eosjs @@ -88,18 +88,85 @@ await transact( authorization: [{ actor: 'alice', permission: 'active' }], data: { factory_id: 10, - key_defs: [{ - name: "id", - type: "uint8[]", - edit_rights: 8, - editors: [ - "bob" - ], - default_value: [ - "UINT8_VEC", - [0, 1] - ] - }], + key_defs: [ + { + name: "id1", + type: "int8", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "int8", -8 ] + }, + { + name: "id2", + type: "int16", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "int16", 16 ] + }, + { + name: "id3", + type: "int32", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "int32", -32 ] + }, + { + name: "id4", + type: "int64", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "int64", 64 ] + }, + { + name: "id5", + type: "uint8", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "uint8", 8 ] + }, + { + name: "id6", + type: "uint16", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "uint16", 16 ] + }, + { + name: "id7", + type: "uint32", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "uint32", 32 ] + }, + { + name: "id8", + type: "uint64", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "uint64", 64 ] + }, + { + name: "id9", + type: "float32", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "float32", -1.32 ] + }, + { + name: "id10", + type: "float64", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "float64", 1.64 ] + }, + { + name: "id11", + type: "string", + edit_rights: 8, + editors: [ "bob" ], + default_value: [ "string", "abc" ] + } + ], "memo": "add new key pairs" }, },