From 9c923c67a0727ebd736b5aac3b2910ef55b055c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?K=C3=A9vin=20Lambert?= <44363395+lambertkevin@users.noreply.github.com> Date: Thu, 7 Apr 2022 17:40:00 +0200 Subject: [PATCH] Fix nft operations wrong order to infer balance (#1865) --- src/families/ethereum/nft.unit.test.ts | 20 +++++++++++++------- src/nft/helpers.ts | 2 ++ 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/src/families/ethereum/nft.unit.test.ts b/src/families/ethereum/nft.unit.test.ts index ed61974653..69639b6ad2 100644 --- a/src/families/ethereum/nft.unit.test.ts +++ b/src/families/ethereum/nft.unit.test.ts @@ -83,7 +83,11 @@ describe("nft merging", () => { describe("OpenSea lazy minting bs", () => { test("should have a correct on-chain nft amount even with OpenSea lazy minting", () => { - const makeNftOperation = (type: Operation["type"], value): Operation => { + const makeNftOperation = ( + type: Operation["type"], + value: string | number, + dateOrder: number + ): Operation => { if (!["NFT_IN", "NFT_OUT"].includes(type)) { return {} as Operation; } @@ -101,6 +105,7 @@ describe("OpenSea lazy minting bs", () => { const fee = new BigNumber(0); const tokenId = "42069"; const hash = "FaKeHasH"; + const date = new Date(Date.now() + dateOrder ?? 0); return { id, @@ -114,17 +119,18 @@ describe("OpenSea lazy minting bs", () => { value: new BigNumber(value), type, accountId: id, + date, } as Operation; }; // scenario with bob lazy minting 10 NFTs const ops = [ - makeNftOperation("NFT_OUT", 5), // lazy mint sending 5 NFT - makeNftOperation("NFT_IN", 1), // receiving 1 of them back - makeNftOperation("NFT_IN", 2), // receiving 2 of them back - makeNftOperation("NFT_OUT", 2), // lazy mint sending 5 NFT (transformed by OpenSea in 2 txs) 1/2 (off-chain) - makeNftOperation("NFT_OUT", 3), // lazy mint sending 5 NFT (transformed by OpenSea in 2 txs) 2/2 (on-chain) - makeNftOperation("NFT_IN", 1), // receiving 1 back + makeNftOperation("NFT_OUT", 5, 0), // lazy mint sending 5 NFT + makeNftOperation("NFT_IN", 1, 1), // receiving 1 of them back + makeNftOperation("NFT_IN", 2, 2), // receiving 2 of them back + makeNftOperation("NFT_OUT", 2, 3), // lazy mint sending 5 NFT (transformed by OpenSea in 2 txs) 1/2 (off-chain) + makeNftOperation("NFT_OUT", 3, 4), // lazy mint sending 5 NFT (transformed by OpenSea in 2 txs) 2/2 (on-chain) + makeNftOperation("NFT_IN", 1, 5), // receiving 1 back ]; // What happened for bob: diff --git a/src/nft/helpers.ts b/src/nft/helpers.ts index 3484bf2f51..dec479ad9d 100644 --- a/src/nft/helpers.ts +++ b/src/nft/helpers.ts @@ -15,6 +15,8 @@ import { API, apiForCurrency } from "../api/Ethereum"; export const nftsFromOperations = (ops: Operation[]): ProtoNFT[] => { const nftsMap = ops + // make sure we have the operation in chronological order (older first) + .sort((a, b) => a.date.getTime() - b.date.getTime()) // if ops are Operations get the prop nftOperations, else ops are considered nftOperations already .flatMap((op) => (op?.nftOperations?.length ? op.nftOperations : op)) .reduce((acc: Record, nftOp: Operation) => {