From 8d73ecc004112873ee3d2eef6a391504d047bfb5 Mon Sep 17 00:00:00 2001 From: Miles Zhang Date: Tue, 6 Aug 2024 16:03:48 +0800 Subject: [PATCH 1/2] feat: handle single use lock tag Signed-off-by: Miles Zhang --- app/models/ckb_sync/api.rb | 4 ++++ app/models/token_collection.rb | 2 +- app/workers/token_collection_tag_worker.rb | 7 +++++++ app/workers/xudt_tag_worker.rb | 7 +++++++ config/settings.mainnet.yml | 2 ++ config/settings.testnet.yml | 2 ++ 6 files changed, 23 insertions(+), 1 deletion(-) diff --git a/app/models/ckb_sync/api.rb b/app/models/ckb_sync/api.rb index 1cf7674dd..ecbe2aa26 100644 --- a/app/models/ckb_sync/api.rb +++ b/app/models/ckb_sync/api.rb @@ -119,6 +119,10 @@ def btc_time_code_hash Settings.btc_time_code_hash end + def single_use_lock_code_hash + Settings.single_use_lock_code_hash + end + METHOD_NAMES.each do |name| define_method name do |*params| call_rpc(name, params:) diff --git a/app/models/token_collection.rb b/app/models/token_collection.rb index 3bff9f90e..331bb4ae5 100644 --- a/app/models/token_collection.rb +++ b/app/models/token_collection.rb @@ -1,5 +1,5 @@ class TokenCollection < ApplicationRecord - VALID_TAGS = ["invalid", "suspicious", "out-of-length-range", "rgb++", "layer-1-asset", "layer-2-asset"] + VALID_TAGS = ["invalid", "suspicious", "out-of-length-range", "rgb++", "layer-1-asset", "layer-2-asset", "supply-limited"] enum standard: { cota: "cota", spore: "spore", m_nft: "m_nft", nrc721: "nrc721" } diff --git a/app/workers/token_collection_tag_worker.rb b/app/workers/token_collection_tag_worker.rb index e30b00525..a3668e387 100644 --- a/app/workers/token_collection_tag_worker.rb +++ b/app/workers/token_collection_tag_worker.rb @@ -21,6 +21,8 @@ def mark_tags(token_collection) ["suspicious"] elsif out_of_length?(token_collection.name) ["out-of-length-range"] + elsif single_use_lock?(udt.issuer_address) + ["supply-limited"] elsif rgbpp_lock?(token_collection.creator.address_hash) ["rgb++", "layer-1-asset"] else @@ -48,4 +50,9 @@ def rgbpp_lock?(issuer_address) address_code_hash = CkbUtils.parse_address(issuer_address).script.code_hash issuer_address.present? && CkbSync::Api.instance.rgbpp_code_hash.include?(address_code_hash) end + + def single_use_lock?(issuer_address) + address_script = CkbUtils.parse_address(issuer_address).script + issuer_address.present? && CkbSync::Api.instance.single_use_lock_code_hash == address_script.code_hash && address_script.hash_type == "data1" + end end diff --git a/app/workers/xudt_tag_worker.rb b/app/workers/xudt_tag_worker.rb index cb0b25bd2..be35c1be8 100644 --- a/app/workers/xudt_tag_worker.rb +++ b/app/workers/xudt_tag_worker.rb @@ -28,6 +28,8 @@ def mark_tags(udt) ["utility"] elsif !first_xudt?(udt.symbol, udt.block_timestamp) ["suspicious"] + elsif single_use_lock?(udt.issuer_address) + ["supply-limited"] elsif rgbpp_lock?(udt.issuer_address) ["rgb++", "layer-1-asset", "supply-limited"] else @@ -56,6 +58,11 @@ def rgbpp_lock?(issuer_address) issuer_address.present? && CkbSync::Api.instance.rgbpp_code_hash.include?(address_code_hash) end + def single_use_lock?(issuer_address) + address_script = CkbUtils.parse_address(issuer_address).script + issuer_address.present? && CkbSync::Api.instance.single_use_lock_code_hash == address_script.code_hash && address_script.hash_type == "data1" + end + def utility_lp_token?(args) args.length == 74 end diff --git a/config/settings.mainnet.yml b/config/settings.mainnet.yml index 52583dd77..1e47acde2 100644 --- a/config/settings.mainnet.yml +++ b/config/settings.mainnet.yml @@ -86,3 +86,5 @@ rgbpp_code_hash: # btc time code hash btc_time_code_hash: - "0x70d64497a075bd651e98ac030455ea200637ee325a12ad08aff03f1a117e5a62" + +single_use_lock_code_hash: "0x8290467a512e5b9a6b816469b0edabba1f4ac474e28ffdd604c2a7c76446bbaf" diff --git a/config/settings.testnet.yml b/config/settings.testnet.yml index 8cfbd8363..7126e4b5b 100644 --- a/config/settings.testnet.yml +++ b/config/settings.testnet.yml @@ -92,3 +92,5 @@ rgbpp_code_hash: btc_time_code_hash: - "0x00cdf8fab0f8ac638758ebf5ea5e4052b1d71e8a77b9f43139718621f6849326" - "0x80a09eca26d77cea1f5a69471c59481be7404febf40ee90f886c36a948385b55" + +single_use_lock_code_hash: "0x8290467a512e5b9a6b816469b0edabba1f4ac474e28ffdd604c2a7c76446bbaf" From e30a3cddc2df413a797b5bab5c3c9b66f514bb8c Mon Sep 17 00:00:00 2001 From: Miles Zhang Date: Tue, 6 Aug 2024 17:18:17 +0800 Subject: [PATCH 2/2] feat: token collection suspicious tag not include chinese Signed-off-by: Miles Zhang --- app/workers/token_collection_tag_worker.rb | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/app/workers/token_collection_tag_worker.rb b/app/workers/token_collection_tag_worker.rb index a3668e387..7d05e86d8 100644 --- a/app/workers/token_collection_tag_worker.rb +++ b/app/workers/token_collection_tag_worker.rb @@ -21,7 +21,7 @@ def mark_tags(token_collection) ["suspicious"] elsif out_of_length?(token_collection.name) ["out-of-length-range"] - elsif single_use_lock?(udt.issuer_address) + elsif single_use_lock?(token_collection.creator.address_hash) ["supply-limited"] elsif rgbpp_lock?(token_collection.creator.address_hash) ["rgb++", "layer-1-asset"] @@ -31,11 +31,11 @@ def mark_tags(token_collection) end def invalid_char?(name) - !name.ascii_only? + !name.ascii_only? && (name =~ /^[\u4E00-\u9FFF]+$/).nil? end def invisible_char?(name) - (name =~ /^[\x21-\x7E]+(?:\s[\x21-\x7E]+)?$/).nil? + (name =~ /^[\x21-\x7E\u4E00-\u9FFF]+(?:\s[\x21-\x7E\u4E00-\u9FFF]+)?$/).nil? end def out_of_length?(name)