From 66a32f3760b2eafdbaba0521b7d0edb8327fdc36 Mon Sep 17 00:00:00 2001 From: websterlcl Date: Thu, 27 May 2021 12:50:09 +0800 Subject: [PATCH 1/6] added updatetokenany --- .../src/script/defi/dftx.ts | 4 ++- .../src/script/defi/dftx_token.ts | 33 ++++++++++++++++++- .../src/script/mapping.ts | 10 +++++- 3 files changed, 44 insertions(+), 3 deletions(-) diff --git a/packages/jellyfish-transaction/src/script/defi/dftx.ts b/packages/jellyfish-transaction/src/script/defi/dftx.ts index ce6e0f58d4..b68e11427c 100644 --- a/packages/jellyfish-transaction/src/script/defi/dftx.ts +++ b/packages/jellyfish-transaction/src/script/defi/dftx.ts @@ -15,7 +15,7 @@ import { CPoolAddLiquidity, CPoolRemoveLiquidity, CPoolSwap, PoolAddLiquidity, PoolRemoveLiquidity, PoolSwap } from './dftx_pool' -import { CTokenCreate, CTokenMint, TokenCreate, TokenMint } from './dftx_token' +import { CTokenCreate, CTokenMint, CTokenUpdateAny, TokenCreate, TokenMint, TokenUpdateAny } from './dftx_token' import { CAppointOracle, AppointOracle, @@ -113,6 +113,8 @@ export class CDfTx extends ComposableBuffer> { return compose(CTokenMint.OP_NAME, d => new CTokenMint(d)) case CTokenCreate.OP_CODE: return compose(CTokenCreate.OP_NAME, d => new CTokenCreate(d)) + case CTokenUpdateAny.OP_CODE: + return compose(CTokenUpdateAny.OP_NAME, d => new CTokenUpdateAny(d)) case CUtxosToAccount.OP_CODE: return compose(CUtxosToAccount.OP_NAME, d => new CUtxosToAccount(d)) case CAccountToUtxos.OP_CODE: diff --git a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts index 0632faef1b..09436276a4 100644 --- a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts +++ b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts @@ -41,7 +41,7 @@ export interface TokenCreate { } /** - * Composable TokenMint, C stands for Composable. + * Composable TokenCreate, C stands for Composable. * Immutable by design, bi-directional fromBuffer, toBuffer deep composer. */ export class CTokenCreate extends ComposableBuffer { @@ -62,3 +62,34 @@ export class CTokenCreate extends ComposableBuffer { ] } } + +/** + * TokenUpdateAny DeFi Transaction + */ +export interface TokenUpdateAny extends TokenCreate { + creationTx: string +} + +/** + * Composable TokenMint, C stands for Composable. + * Immutable by design, bi-directional fromBuffer, toBuffer deep composer. + */ +export class CTokenUpdateAny extends ComposableBuffer { + static OP_CODE = 0x6e /// 'n' + static OP_NAME = 'OP_DEFI_TX_TOKEN_UPDATE_ANY' + + composers (tua: TokenUpdateAny): BufferComposer[] { + return [ + ComposableBuffer.hex(32, () => tua.creationTx, v => tua.creationTx = v), + ComposableBuffer.varUIntUtf8BE(() => tua.symbol, v => tua.symbol = v), + ComposableBuffer.varUIntUtf8BE(() => tua.name, v => tua.name = v), + ComposableBuffer.uInt8(() => tua.decimal, v => tua.decimal = v), + ComposableBuffer.bigNumberUInt64(() => tua.limit, v => tua.limit = v), + ComposableBuffer.bitmask1Byte(3, () => [tua.isDAT, tua.tradeable, tua.mintable], v => { + tua.isDAT = v[0] + tua.tradeable = v[1] + tua.mintable = v[2] + }) + ] + } +} diff --git a/packages/jellyfish-transaction/src/script/mapping.ts b/packages/jellyfish-transaction/src/script/mapping.ts index fc9a4f29cc..8d30a398ab 100644 --- a/packages/jellyfish-transaction/src/script/mapping.ts +++ b/packages/jellyfish-transaction/src/script/mapping.ts @@ -18,7 +18,7 @@ import { PoolRemoveLiquidity, PoolSwap } from './defi/dftx_pool' -import { CTokenCreate, CTokenMint, TokenCreate, TokenMint } from './defi/dftx_token' +import { CTokenCreate, CTokenUpdateAny, CTokenMint, TokenCreate, TokenUpdateAny, TokenMint } from './defi/dftx_token' import { AccountToAccount, AccountToUtxos, @@ -169,6 +169,14 @@ export const OP_CODES = { data: tokenCreate }) }, + OP_DEFI_TX_TOKEN_UPDATE_ANY: (tokenUpdateAny: TokenUpdateAny): OP_DEFI_TX => { + return new OP_DEFI_TX({ + signature: CDfTx.SIGNATURE, + type: CTokenUpdateAny.OP_CODE, + name: CTokenUpdateAny.OP_NAME, + data: tokenUpdateAny + }) + }, OP_DEFI_TX_UTXOS_TO_ACCOUNT: (utxosToAccount: UtxosToAccount): OP_DEFI_TX => { return new OP_DEFI_TX({ signature: CDfTx.SIGNATURE, From 6399a1169ba026affbb469f5542a0e3b4790987d Mon Sep 17 00:00:00 2001 From: websterlcl Date: Thu, 27 May 2021 14:10:56 +0800 Subject: [PATCH 2/6] added updatetoken --- .../defi/dftx_token/TokenUpdate.test.ts | 57 +++++++++++++++++ .../defi/dftx_token/TokenUpdateAny.test.ts | 63 +++++++++++++++++++ .../src/script/defi/dftx.ts | 4 +- .../src/script/defi/dftx_token.ts | 31 ++++++++- .../src/script/mapping.ts | 10 ++- 5 files changed, 161 insertions(+), 4 deletions(-) create mode 100644 packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts create mode 100644 packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts new file mode 100644 index 0000000000..085c7918a9 --- /dev/null +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts @@ -0,0 +1,57 @@ +import { SmartBuffer } from 'smart-buffer' +import { OP_DEFI_TX } from '../../../../src/script/defi' +import { CTokenUpdate, TokenUpdate } from '../../../../src/script/defi/dftx_token' +import { OP_CODES } from '../../../../src/script' +import { toBuffer, toOPCodes } from '../../../../src/script/_buffer' + +it('should bi-directional buffer-object-buffer', () => { + const fixtures = [ + // regtest fixtures + '6a26446654784effe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb247100' + ] + + fixtures.forEach(hex => { + const stack: any = toOPCodes( + SmartBuffer.fromBuffer(Buffer.from(hex, 'hex')) + ) + console.log('stack: ', stack[1]) + const buffer = toBuffer(stack) + expect(buffer.toString('hex')).toBe(hex) + expect((stack[1] as OP_DEFI_TX).tx.type).toBe(0x4e) + }) +}) + +const header = '6a37446654784e' // OP_RETURN, PUSH_DATA(44665478, 4e) +const data = 'ffe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb247100' +const tokenUpdate: TokenUpdate = { + isDAT: false, + creationTx: 'ffe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb2471' +} + +it('should craft dftx with OP_CODES._()', () => { + const stack = [ + OP_CODES.OP_RETURN, + OP_CODES.OP_DEFI_TX_TOKEN_UPDATE(tokenUpdate) + ] + + const buffer = toBuffer(stack) + console.log('ddd: ', buffer.toString('hex')) + expect(buffer.toString('hex')).toBe(header + data) +}) + +describe('Composable', () => { + it('should compose from buffer to composable', () => { + const buffer = SmartBuffer.fromBuffer(Buffer.from(data, 'hex')) + const composable = new CTokenUpdate(buffer) + + expect(composable.toObject()).toEqual(tokenUpdate) + }) + + it('should compose from composable to buffer', () => { + const composable = new CTokenUpdate(tokenUpdate) + const buffer = new SmartBuffer() + composable.toBuffer(buffer) + + expect(buffer.toBuffer().toString('hex')).toEqual(data) + }) +}) diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts new file mode 100644 index 0000000000..93941e612f --- /dev/null +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts @@ -0,0 +1,63 @@ +import { SmartBuffer } from 'smart-buffer' +import { OP_DEFI_TX } from '../../../../src/script/defi' +import { CTokenUpdateAny, TokenUpdateAny } from '../../../../src/script/defi/dftx_token' +import { OP_CODES } from '../../../../src/script' +import { toBuffer, toOPCodes } from '../../../../src/script/_buffer' +import BigNumber from 'bignumber.js' + +it('should bi-directional buffer-object-buffer', () => { + const fixtures = [ + // regtest fixtures + '6a37446654786ed819f622ced3616e3c02e5337b54cbf921c364e182a80925219e1f60461ee5fc034341540343415408000000000000000001' + ] + + fixtures.forEach(hex => { + const stack: any = toOPCodes( + SmartBuffer.fromBuffer(Buffer.from(hex, 'hex')) + ) + const buffer = toBuffer(stack) + expect(buffer.toString('hex')).toBe(hex) + expect((stack[1] as OP_DEFI_TX).tx.type).toBe(0x6e) + }) +}) + +const header = '6a37446654786e' // OP_RETURN, PUSH_DATA(44665478, 6e) +const data = 'd819f622ced3616e3c02e5337b54cbf921c364e182a80925219e1f60461ee5fc034341540343415408000000000000000007' +const tokenUpdateAny: TokenUpdateAny = { + symbol: 'CAT', + name: 'CAT', + decimal: 8, + limit: new BigNumber('0'), + mintable: true, + tradeable: true, + isDAT: true, + creationTx: 'd819f622ced3616e3c02e5337b54cbf921c364e182a80925219e1f60461ee5fc' +} + +it('should craft dftx with OP_CODES._()', () => { + const stack = [ + OP_CODES.OP_RETURN, + OP_CODES.OP_DEFI_TX_TOKEN_UPDATE_ANY(tokenUpdateAny) + ] + + const buffer = toBuffer(stack) + console.log('ddd: ', buffer.toString('hex')) + expect(buffer.toString('hex')).toBe(header + data) +}) + +describe('Composable', () => { + it('should compose from buffer to composable', () => { + const buffer = SmartBuffer.fromBuffer(Buffer.from(data, 'hex')) + const composable = new CTokenUpdateAny(buffer) + + expect(composable.toObject()).toEqual(tokenUpdateAny) + }) + + it('should compose from composable to buffer', () => { + const composable = new CTokenUpdateAny(tokenUpdateAny) + const buffer = new SmartBuffer() + composable.toBuffer(buffer) + + expect(buffer.toBuffer().toString('hex')).toEqual(data) + }) +}) diff --git a/packages/jellyfish-transaction/src/script/defi/dftx.ts b/packages/jellyfish-transaction/src/script/defi/dftx.ts index b68e11427c..16072a6b15 100644 --- a/packages/jellyfish-transaction/src/script/defi/dftx.ts +++ b/packages/jellyfish-transaction/src/script/defi/dftx.ts @@ -15,7 +15,7 @@ import { CPoolAddLiquidity, CPoolRemoveLiquidity, CPoolSwap, PoolAddLiquidity, PoolRemoveLiquidity, PoolSwap } from './dftx_pool' -import { CTokenCreate, CTokenMint, CTokenUpdateAny, TokenCreate, TokenMint, TokenUpdateAny } from './dftx_token' +import { CTokenCreate, CTokenMint, CTokenUpdate, CTokenUpdateAny, TokenCreate, TokenMint, TokenUpdate, TokenUpdateAny } from './dftx_token' import { CAppointOracle, AppointOracle, @@ -113,6 +113,8 @@ export class CDfTx extends ComposableBuffer> { return compose(CTokenMint.OP_NAME, d => new CTokenMint(d)) case CTokenCreate.OP_CODE: return compose(CTokenCreate.OP_NAME, d => new CTokenCreate(d)) + case CTokenUpdate.OP_CODE: + return compose(CTokenUpdate.OP_NAME, d => new CTokenUpdate(d)) case CTokenUpdateAny.OP_CODE: return compose(CTokenUpdateAny.OP_NAME, d => new CTokenUpdateAny(d)) case CUtxosToAccount.OP_CODE: diff --git a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts index 09436276a4..ce942362d0 100644 --- a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts +++ b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts @@ -63,15 +63,42 @@ export class CTokenCreate extends ComposableBuffer { } } +/** + * TokenUpdate DeFi Transaction + * Note(canonbrother): Only 'isDAT' flag modification allowed before Bayfront fork (<10000) + */ +export interface TokenUpdate { + creationTx: string // -----------------| hex + isDAT: boolean // ---------------------| 1 byte bitmask start, position 0 +} + +/** + * Composable CTokenUpdate, C stands for Composable. + * Immutable by design, bi-directional fromBuffer, toBuffer deep composer. + */ +export class CTokenUpdate extends ComposableBuffer { + static OP_CODE = 0x4e /// 'N' + static OP_NAME = 'OP_DEFI_TX_TOKEN_UPDATE' + + composers (tu: TokenUpdate): BufferComposer[] { + return [ + ComposableBuffer.hex(32, () => tu.creationTx, v => tu.creationTx = v), + ComposableBuffer.bitmask1Byte(3, () => [tu.isDAT], v => { + tu.isDAT = v[0] + }) + ] + } +} + /** * TokenUpdateAny DeFi Transaction */ export interface TokenUpdateAny extends TokenCreate { - creationTx: string + creationTx: string // -----------------| hex } /** - * Composable TokenMint, C stands for Composable. + * Composable TokenUpdateAny, C stands for Composable. * Immutable by design, bi-directional fromBuffer, toBuffer deep composer. */ export class CTokenUpdateAny extends ComposableBuffer { diff --git a/packages/jellyfish-transaction/src/script/mapping.ts b/packages/jellyfish-transaction/src/script/mapping.ts index 8d30a398ab..862ad9488d 100644 --- a/packages/jellyfish-transaction/src/script/mapping.ts +++ b/packages/jellyfish-transaction/src/script/mapping.ts @@ -18,7 +18,7 @@ import { PoolRemoveLiquidity, PoolSwap } from './defi/dftx_pool' -import { CTokenCreate, CTokenUpdateAny, CTokenMint, TokenCreate, TokenUpdateAny, TokenMint } from './defi/dftx_token' +import { CTokenCreate, CTokenUpdate, CTokenUpdateAny, CTokenMint, TokenCreate, TokenUpdate, TokenUpdateAny, TokenMint } from './defi/dftx_token' import { AccountToAccount, AccountToUtxos, @@ -169,6 +169,14 @@ export const OP_CODES = { data: tokenCreate }) }, + OP_DEFI_TX_TOKEN_UPDATE: (tokenUpdate: TokenUpdate): OP_DEFI_TX => { + return new OP_DEFI_TX({ + signature: CDfTx.SIGNATURE, + type: CTokenUpdate.OP_CODE, + name: CTokenUpdate.OP_NAME, + data: tokenUpdate + }) + }, OP_DEFI_TX_TOKEN_UPDATE_ANY: (tokenUpdateAny: TokenUpdateAny): OP_DEFI_TX => { return new OP_DEFI_TX({ signature: CDfTx.SIGNATURE, From 191a11258cabb3db43210f544abc5b36adfa14ca Mon Sep 17 00:00:00 2001 From: websterlcl Date: Thu, 27 May 2021 14:18:03 +0800 Subject: [PATCH 3/6] remove log --- .../__tests__/script/defi/dftx_token/TokenUpdate.test.ts | 2 -- .../__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts | 1 - 2 files changed, 3 deletions(-) diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts index 085c7918a9..51eb625ecc 100644 --- a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts @@ -14,7 +14,6 @@ it('should bi-directional buffer-object-buffer', () => { const stack: any = toOPCodes( SmartBuffer.fromBuffer(Buffer.from(hex, 'hex')) ) - console.log('stack: ', stack[1]) const buffer = toBuffer(stack) expect(buffer.toString('hex')).toBe(hex) expect((stack[1] as OP_DEFI_TX).tx.type).toBe(0x4e) @@ -35,7 +34,6 @@ it('should craft dftx with OP_CODES._()', () => { ] const buffer = toBuffer(stack) - console.log('ddd: ', buffer.toString('hex')) expect(buffer.toString('hex')).toBe(header + data) }) diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts index 93941e612f..1c6bb61790 100644 --- a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts @@ -41,7 +41,6 @@ it('should craft dftx with OP_CODES._()', () => { ] const buffer = toBuffer(stack) - console.log('ddd: ', buffer.toString('hex')) expect(buffer.toString('hex')).toBe(header + data) }) From a25e91ccc573907b957b5a3d65cb3acc50793958 Mon Sep 17 00:00:00 2001 From: websterlcl Date: Thu, 27 May 2021 14:37:05 +0800 Subject: [PATCH 4/6] added more fixtures and notes --- .../script/defi/dftx_token/TokenUpdate.test.ts | 5 +++++ .../script/defi/dftx_token/TokenUpdateAny.test.ts | 11 ++++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts index 51eb625ecc..058ecfe094 100644 --- a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts @@ -7,7 +7,12 @@ import { toBuffer, toOPCodes } from '../../../../src/script/_buffer' it('should bi-directional buffer-object-buffer', () => { const fixtures = [ // regtest fixtures + // 1 fixture as only 'isDAT' flag modification allowed before Bayfront fork + // and only 'UpdateToken' is triggered while before Bayfront fork + // https://github.com/DeFiCh/ain/blob/c7b13959cc84c6d6210927b0e2377432c0dcadeb/src/masternodes/rpc_tokens.cpp#L278 '6a26446654784effe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb247100' + + // Note(canonbrother): isDAT is not updated after modified ] fixtures.forEach(hex => { diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts index 1c6bb61790..205023617c 100644 --- a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts @@ -8,7 +8,16 @@ import BigNumber from 'bignumber.js' it('should bi-directional buffer-object-buffer', () => { const fixtures = [ // regtest fixtures - '6a37446654786ed819f622ced3616e3c02e5337b54cbf921c364e182a80925219e1f60461ee5fc034341540343415408000000000000000001' + // flags + '6a37446654786ed819f622ced3616e3c02e5337b54cbf921c364e182a80925219e1f60461ee5fc034341540343415408000000000000000001', + + // symbol (symbolKey) + '6a38446654786effe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb2471044f57574c034f574c08000000000000000007', + + // name + '6a39446654786effe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb2471034f574c054e4947485408000000000000000007' + + // Note(canonbrother): collateralAddress and creationTx are not updated after modified ] fixtures.forEach(hex => { From 03f37131e2a852a89a9e8de4155043d4601a069c Mon Sep 17 00:00:00 2001 From: websterlcl Date: Thu, 27 May 2021 17:58:09 +0800 Subject: [PATCH 5/6] fix req: use hexBEBufferLE and update doc --- .../script/defi/dftx_token/TokenUpdate.test.ts | 7 ++++--- .../script/defi/dftx_token/TokenUpdateAny.test.ts | 4 +--- .../src/script/defi/dftx_token.ts | 12 +++++++----- 3 files changed, 12 insertions(+), 11 deletions(-) diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts index 058ecfe094..bdc14b2846 100644 --- a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdate.test.ts @@ -12,7 +12,8 @@ it('should bi-directional buffer-object-buffer', () => { // https://github.com/DeFiCh/ain/blob/c7b13959cc84c6d6210927b0e2377432c0dcadeb/src/masternodes/rpc_tokens.cpp#L278 '6a26446654784effe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb247100' - // Note(canonbrother): isDAT is not updated after modified + // BUG(canonbrother): isDAT is not updated after modified + // Issue is submitted: https://github.com/DeFiCh/ain/issues/440 ] fixtures.forEach(hex => { @@ -25,11 +26,11 @@ it('should bi-directional buffer-object-buffer', () => { }) }) -const header = '6a37446654784e' // OP_RETURN, PUSH_DATA(44665478, 4e) +const header = '6a26446654784e' // OP_RETURN, PUSH_DATA(44665478, 4e) const data = 'ffe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb247100' const tokenUpdate: TokenUpdate = { isDAT: false, - creationTx: 'ffe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb2471' + creationTx: '7124cbc1ed8b03fbc4b637eab4e056f2cccaa933e80174a8e92543cd270be5ff' } it('should craft dftx with OP_CODES._()', () => { diff --git a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts index 205023617c..cbc015cca0 100644 --- a/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts +++ b/packages/jellyfish-transaction/__tests__/script/defi/dftx_token/TokenUpdateAny.test.ts @@ -16,8 +16,6 @@ it('should bi-directional buffer-object-buffer', () => { // name '6a39446654786effe50b27cd4325e9a87401e833a9caccf256e0b4ea37b6c4fb038bedc1cb2471034f574c054e4947485408000000000000000007' - - // Note(canonbrother): collateralAddress and creationTx are not updated after modified ] fixtures.forEach(hex => { @@ -40,7 +38,7 @@ const tokenUpdateAny: TokenUpdateAny = { mintable: true, tradeable: true, isDAT: true, - creationTx: 'd819f622ced3616e3c02e5337b54cbf921c364e182a80925219e1f60461ee5fc' + creationTx: 'fce51e46601f9e212509a882e164c321f9cb547b33e5023c6e61d3ce22f619d8' } it('should craft dftx with OP_CODES._()', () => { diff --git a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts index ce942362d0..bb935df86f 100644 --- a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts +++ b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts @@ -68,7 +68,7 @@ export class CTokenCreate extends ComposableBuffer { * Note(canonbrother): Only 'isDAT' flag modification allowed before Bayfront fork (<10000) */ export interface TokenUpdate { - creationTx: string // -----------------| hex + creationTx: string // -----------------| 32 bytes hex string isDAT: boolean // ---------------------| 1 byte bitmask start, position 0 } @@ -82,8 +82,8 @@ export class CTokenUpdate extends ComposableBuffer { composers (tu: TokenUpdate): BufferComposer[] { return [ - ComposableBuffer.hex(32, () => tu.creationTx, v => tu.creationTx = v), - ComposableBuffer.bitmask1Byte(3, () => [tu.isDAT], v => { + ComposableBuffer.hexBEBufferLE(32, () => tu.creationTx, v => tu.creationTx = v), + ComposableBuffer.bitmask1Byte(1, () => [tu.isDAT], v => { tu.isDAT = v[0] }) ] @@ -92,9 +92,11 @@ export class CTokenUpdate extends ComposableBuffer { /** * TokenUpdateAny DeFi Transaction + * + * Note(canonbrother): collateralAddress and creationTx are be able to be updated */ export interface TokenUpdateAny extends TokenCreate { - creationTx: string // -----------------| hex + creationTx: string // -----------------| 32 bytes hex string } /** @@ -107,7 +109,7 @@ export class CTokenUpdateAny extends ComposableBuffer { composers (tua: TokenUpdateAny): BufferComposer[] { return [ - ComposableBuffer.hex(32, () => tua.creationTx, v => tua.creationTx = v), + ComposableBuffer.hexBEBufferLE(32, () => tua.creationTx, v => tua.creationTx = v), ComposableBuffer.varUIntUtf8BE(() => tua.symbol, v => tua.symbol = v), ComposableBuffer.varUIntUtf8BE(() => tua.name, v => tua.name = v), ComposableBuffer.uInt8(() => tua.decimal, v => tua.decimal = v), From 5b51c951176e44d169ae375ba9de0ca043ad98e9 Mon Sep 17 00:00:00 2001 From: Fuxing Loh <4266087+fuxingloh@users.noreply.github.com> Date: Fri, 28 May 2021 13:34:36 +0800 Subject: [PATCH 6/6] Apply suggestions from code review --- packages/jellyfish-transaction/src/script/defi/dftx_token.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts index bb935df86f..dad8647e35 100644 --- a/packages/jellyfish-transaction/src/script/defi/dftx_token.ts +++ b/packages/jellyfish-transaction/src/script/defi/dftx_token.ts @@ -92,8 +92,6 @@ export class CTokenUpdate extends ComposableBuffer { /** * TokenUpdateAny DeFi Transaction - * - * Note(canonbrother): collateralAddress and creationTx are be able to be updated */ export interface TokenUpdateAny extends TokenCreate { creationTx: string // -----------------| 32 bytes hex string