From c6b399c428e4433ad5e3517942b50141342b8621 Mon Sep 17 00:00:00 2001 From: Stefan Date: Wed, 27 Mar 2024 11:31:32 +0200 Subject: [PATCH] fix(wallet) serializing type for collectibles settings to backend It seems `%*` operator we use in the `rpc` generics doesn't use the `serializedFieldName` marker and `type` was serialized as `itemType` and value the enum name instead of `type` and integer value Updates: #13971 --- .../all_collectibles/controller.nim | 2 +- .../service/collectible/service.nim | 2 +- src/backend/collectibles_types.nim | 29 ++++++++++++------- 3 files changed, 20 insertions(+), 13 deletions(-) diff --git a/src/app/modules/main/wallet_section/all_collectibles/controller.nim b/src/app/modules/main/wallet_section/all_collectibles/controller.nim index 760154c0b4..b1cbdc07f6 100644 --- a/src/app/modules/main/wallet_section/all_collectibles/controller.nim +++ b/src/app/modules/main/wallet_section/all_collectibles/controller.nim @@ -42,7 +42,7 @@ proc init*(self: Controller) = self.events.on(SIGNAL_WALLET_ACCOUNT_DELETED) do(e:Args): self.delegate.refreshWalletAccounts() - + self.events.on(SIGNAL_WALLET_ACCOUNT_NETWORK_ENABLED_UPDATED) do(e: Args): self.delegate.refreshNetworks() diff --git a/src/app_service/service/collectible/service.nim b/src/app_service/service/collectible/service.nim index 012cb6e990..b739fe1a3b 100644 --- a/src/app_service/service/collectible/service.nim +++ b/src/app_service/service/collectible/service.nim @@ -12,7 +12,7 @@ logScope: # Signals which may be emitted by this service: const SIGNAL_COLLECTIBLE_PREFERENCES_UPDATED* = "collectiblePreferencesUpdated" -type +type ResultArgs* = ref object of Args success*: bool diff --git a/src/backend/collectibles_types.nim b/src/backend/collectibles_types.nim index e8da69505e..915f6db989 100644 --- a/src/backend/collectibles_types.nim +++ b/src/backend/collectibles_types.nim @@ -108,7 +108,7 @@ proc `$`*(self: ContractID): string = address:{self.address} )""" -proc `==`*(a, b: ContractID): bool = +proc `==`*(a, b: ContractID): bool = result = a.chainID == b.chainID and a.address == b.address @@ -116,7 +116,7 @@ proc `%`*(t: ContractID): JsonNode {.inline.} = result = newJObject() result["chainID"] = %(t.chainID) result["address"] = %(t.address) - + proc `%`*(t: ref ContractID): JsonNode {.inline.} = return %(t[]) @@ -148,7 +148,7 @@ proc `$`*(self: CollectibleUniqueID): string = tokenID:{self.tokenID} )""" -proc `==`*(a, b: CollectibleUniqueID): bool = +proc `==`*(a, b: CollectibleUniqueID): bool = result = a.contractID == b.contractID and a.tokenID == b.tokenID @@ -156,7 +156,7 @@ proc `%`*(t: CollectibleUniqueID): JsonNode {.inline.} = result = newJObject() result["contractID"] = %(t.contractID) result["tokenID"] = %(t.tokenID.toString()) - + proc `%`*(t: ref CollectibleUniqueID): JsonNode {.inline.} = return %(t[]) @@ -176,7 +176,7 @@ proc toCollectibleUniqueID*(t: string): CollectibleUniqueID = var parts = t.split("+") return CollectibleUniqueID( contractID: ContractID( - chainID: parts[0].parseInt(), + chainID: parts[0].parseInt(), address: parts[1] ), tokenID: stint.parse(parts[2], UInt256) @@ -386,7 +386,7 @@ proc toIds(self: seq[Collectible]): seq[CollectibleUniqueID] = # CollectibleBalance proc `$`*(self: CollectibleBalance): string = return fmt"""CollectibleBalance( - tokenId:{self.tokenId}, + tokenId:{self.tokenId}, balance:{self.balance} """ @@ -402,7 +402,7 @@ proc getCollectibleBalances*(jsonAsset: JsonNode): seq[CollectibleBalance] = # CollectibleOwner proc `$`*(self: CollectibleOwner): string = return fmt"""CollectibleOwner( - address:{self.address}, + address:{self.address}, balances:{self.balances} """ @@ -426,7 +426,7 @@ proc getCollectibleOwners(jsonAsset: JsonNode): seq[CollectibleOwner] = # CollectibleContractOwnership proc `$`*(self: CollectibleContractOwnership): string = return fmt"""CollectibleContractOwnership( - contractAddress:{self.contractAddress}, + contractAddress:{self.contractAddress}, owners:{self.owners} """ @@ -439,9 +439,9 @@ proc fromJson*(t: JsonNode, T: typedesc[CollectibleContractOwnership]): Collecti # CollectiblePreferences proc `$`*(self: CollectiblePreferences): string = return fmt"""CollectiblePreferences( - type:{self.itemType}, - key:{self.key}, - position:{self.position}, + type:{self.itemType}, + key:{self.key}, + position:{self.position}, visible:{self.visible} """ @@ -451,3 +451,10 @@ proc fromJson*(t: JsonNode, T: typedesc[CollectiblePreferences]): CollectiblePre discard t.getProp("key", result.key) discard t.getProp("position", result.position) discard t.getProp("visible", result.visible) + +proc `%`*(cp: CollectiblePreferences): JsonNode {.inline.} = + result = newJObject() + result["type"] = %int(cp.itemType) + result["key"] = %cp.key + result["position"] = %cp.position + result["visible"] = %cp.visible \ No newline at end of file