diff --git a/.gitignore b/.gitignore index f363516..6ac5530 100644 --- a/.gitignore +++ b/.gitignore @@ -103,4 +103,6 @@ dist # TernJS port file .tern-port +.vscode/ + lib \ No newline at end of file diff --git a/.husky/pre-commit b/.husky/pre-commit index 2bccb3c..1bc36df 100755 --- a/.husky/pre-commit +++ b/.husky/pre-commit @@ -2,4 +2,5 @@ . "$(dirname "$0")/_/husky.sh" yarn lint +yarn format yarn check \ No newline at end of file diff --git a/example/aggregator.ts b/example/aggregator.ts index 332c04d..ebd24b0 100644 --- a/example/aggregator.ts +++ b/example/aggregator.ts @@ -23,7 +23,7 @@ const run = async () => { '0x490000001000000030000000310000009bd7e06f3ecf4be0f2fcd2188b23f1b9fcc88e5d4b65a8637b17723bbda3cce80114000000dc70f33de86fdf381b4fc5bf092bb23d02774801', page: 0, pageSize: 3, - cotaId: "0xb066e0f068aa8be6548063a18d811c489a9e2141", + cotaId: '0xb066e0f068aa8be6548063a18d811c489a9e2141', }) console.log(JSON.stringify(holdsWithCotaId)) @@ -63,7 +63,7 @@ const run = async () => { const cotaCount = await aggregator.getCotaCount({ lockScript: '0x490000001000000030000000310000009bd7e06f3ecf4be0f2fcd2188b23f1b9fcc88e5d4b65a8637b17723bbda3cce80114000000dc70f33de86fdf381b4fc5bf092bb23d02774801', - cotaId: '0xb22585a8053af3fed0fd39127f5b1487ce08b756', + cotaId: '0xb22585a8053af3fed0fd39127f5b1487ce08b756', }) console.log(JSON.stringify(cotaCount)) } diff --git a/example/aggregator/index.js b/example/aggregator/index.js index a400a31..c762d7e 100644 --- a/example/aggregator/index.js +++ b/example/aggregator/index.js @@ -1,7 +1,10 @@ const { Aggregator } = require('@nervina-labs/cota-sdk') const run = async () => { - const aggregator = new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }) + const aggregator = new Aggregator({ + registryUrl: 'http://localhost:3050', + cotaUrl: 'https://cota.nervina.dev/mainnet-aggregator', + }) const holds = await aggregator.getHoldCotaNft({ lockScript: '0x490000001000000030000000310000009bd7e06f3ecf4be0f2fcd2188b23f1b9fcc88e5d4b65a8637b17723bbda3cce80114000000dc70f33de86fdf381b4fc5bf092bb23d02774801', diff --git a/example/aggregator/package.json b/example/aggregator/package.json index 46f3018..47d4a00 100644 --- a/example/aggregator/package.json +++ b/example/aggregator/package.json @@ -8,10 +8,10 @@ "build": "tsc" }, "dependencies": { - "@nervina-labs/cota-sdk": "0.7.1", - "@types/node": "18.11.9", + "@nervina-labs/cota-sdk": "0.8.0", + "@types/node": "18.11.13", "ts-node": "10.9.1", "tslib": "2.4.1", - "typescript": "4.8.3" + "typescript": "4.9.5" } -} \ No newline at end of file +} diff --git a/example/aggregator/yarn.lock b/example/aggregator/yarn.lock index 074db62..11b7900 100644 --- a/example/aggregator/yarn.lock +++ b/example/aggregator/yarn.lock @@ -27,15 +27,15 @@ "@jridgewell/resolve-uri" "^3.0.3" "@jridgewell/sourcemap-codec" "^1.4.10" -"@nervina-labs/cota-sdk@0.7.1": - version "0.7.1" - resolved "https://registry.yarnpkg.com/@nervina-labs/cota-sdk/-/cota-sdk-0.7.1.tgz#a083a390ac514e56139a356701a368fe964f6e2e" - integrity sha512-EBnhifgro41OsSCBFF6s/f3cJP5CVv/aRv/9L3x5nm471ePZ2cHNMXNBIkjjlfximfmQnV29Mrt3kctV82EvjQ== +"@nervina-labs/cota-sdk@0.8.0": + version "0.8.0" + resolved "https://registry.yarnpkg.com/@nervina-labs/cota-sdk/-/cota-sdk-0.8.0.tgz#89028c2874e2bf1f226f3fc95bbc567bca8f34ac" + integrity sha512-3DwI26csftPtvnjFS8Cauf2ybu+8ESLVsGEUQn69aK5m3PKhXJqfuT2DpsXK2v4dmDEQ8MojgK2S0OooH/37ng== dependencies: "@nervosnetwork/ckb-sdk-core" "^0.103.0" "@nervosnetwork/ckb-sdk-utils" "^0.103.0" "@nervosnetwork/ckb-types" "^0.103.0" - axios "^0.27.2" + axios "^1.0.0" camelcase-keys "^7.0.2" convert-keys "1.3.4" @@ -94,10 +94,10 @@ resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.2.tgz#423c77877d0569db20e1fc80885ac4118314010e" integrity sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA== -"@types/node@18.11.9": - version "18.11.9" - resolved "https://registry.yarnpkg.com/@types/node/-/node-18.11.9.tgz#02d013de7058cea16d36168ef2fc653464cfbad4" - integrity sha512-CRpX21/kGdzjOpFsZSkcrXMGIBWMGNIHXXBVFSH+ggkftxg+XYP20TESbh+zFvFj3EQOl5byk0HTRn1IL6hbqg== +"@types/node@18.11.13": + version "18.11.13" + resolved "https://registry.yarnpkg.com/@types/node/-/node-18.11.13.tgz#dff34f226ec1ac0432ae3b136ec5552bd3b9c0fe" + integrity sha512-IASpMGVcWpUsx5xBOrxMj7Bl8lqfuTY7FKAnPmu5cHkfQVWF8GulWS1jbRqA934qZL35xh5xN/+Xe/i26Bod4w== acorn-walk@^8.1.1: version "8.2.0" @@ -126,13 +126,14 @@ axios@0.21.4: dependencies: follow-redirects "^1.14.0" -axios@^0.27.2: - version "0.27.2" - resolved "https://registry.yarnpkg.com/axios/-/axios-0.27.2.tgz#207658cc8621606e586c85db4b41a750e756d972" - integrity sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ== +axios@^1.0.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/axios/-/axios-1.2.0.tgz#1cb65bd75162c70e9f8d118a905126c4a201d383" + integrity sha512-zT7wZyNYu3N5Bu0wuZ6QccIf93Qk1eV8LOewxgjOZFd2DenOs98cJ7+Y6703d0wkaXGY6/nZd4EweJaHz9uzQw== dependencies: - follow-redirects "^1.14.9" + follow-redirects "^1.15.0" form-data "^4.0.0" + proxy-from-env "^1.1.0" bech32@2.0.0: version "2.0.0" @@ -214,10 +215,10 @@ follow-redirects@^1.14.0: resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.9.tgz#dd4ea157de7bfaf9ea9b3fbd85aa16951f78d8d7" integrity sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w== -follow-redirects@^1.14.9: - version "1.15.0" - resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.0.tgz#06441868281c86d0dda4ad8bdaead2d02dca89d4" - integrity sha512-aExlJShTV4qOUOL7yF1U5tvLCB0xQuudbf6toyYA0E/acBNw71mvjFTnLaRp50aQaYocMR0a/RMMBIHeZnGyjQ== +follow-redirects@^1.15.0: + version "1.15.2" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.2.tgz#b460864144ba63f2681096f274c4e57026da2c13" + integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA== form-data@^4.0.0: version "4.0.0" @@ -307,6 +308,11 @@ minimalistic-crypto-utils@^1.0.1: resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" integrity sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo= +proxy-from-env@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2" + integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== + quick-lru@^5.1.1: version "5.1.1" resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" @@ -346,10 +352,10 @@ type-fest@^1.2.1: resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-1.4.0.tgz#e9fb813fe3bf1744ec359d55d1affefa76f14be1" integrity sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA== -typescript@4.8.3: - version "4.8.3" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.8.3.tgz#d59344522c4bc464a65a730ac695007fdb66dd88" - integrity sha512-goMHfm00nWPa8UvR/CPSvykqf6dVV8x/dp0c5mFTMTIu0u0FlGWRioyy7Nn0PGAdHxpJZnuO/ut+PpQ8UiHAig== +typescript@4.9.5: + version "4.9.5" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" + integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== v8-compile-cache-lib@^3.0.1: version "3.0.1" diff --git a/example/claim-update.ts b/example/claim-update.ts index 7842130..6a9ec1e 100644 --- a/example/claim-update.ts +++ b/example/claim-update.ts @@ -10,15 +10,21 @@ const RECEIVER_ADDRESS = 'ckt1qyqy6xew5q449zg5du7wdjhgrxschjkg3n2q8h5ycc' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/example/claim.ts b/example/claim.ts index 3e6758a..f9017f9 100644 --- a/example/claim.ts +++ b/example/claim.ts @@ -10,15 +10,21 @@ const RECEIVER_ADDRESS = 'ckt1qyqy6xew5q449zg5du7wdjhgrxschjkg3n2q8h5ycc' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/example/issuer.ts b/example/issuer.ts index 4210c9a..4bbc81f 100644 --- a/example/issuer.ts +++ b/example/issuer.ts @@ -9,15 +9,21 @@ const TEST_ADDRESS = 'ckt1qyq0scej4vn0uka238m63azcel7cmcme7f2sxj5ska' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { @@ -32,9 +38,9 @@ const run = async () => { const cotaLock = addressToScript(TEST_ADDRESS) const issuer: IssuerInfo = { - name: "Nervina Labs", - description: "Melting Two Worlds Together.", - avatar: "https://i.loli.net/2021/04/29/IigbpOWP8fw9qDn.png", + name: 'Nervina Labs', + description: 'Melting Two Worlds Together.', + avatar: 'https://i.loli.net/2021/04/29/IigbpOWP8fw9qDn.png', } let rawTx = await generateIssuerInfoTx(service, cotaLock, issuer, FEE, isMainnet) diff --git a/example/mainnet/define.js b/example/mainnet/define.js index 638259a..e26f6ac 100644 --- a/example/mainnet/define.js +++ b/example/mainnet/define.js @@ -29,8 +29,14 @@ const run = async () => { const isMainnet = true const service = { - collector: new Collector({ ckbNodeUrl: 'http://localhost:8114', ckbIndexerUrl: 'http://localhost:8116' }), - aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), + collector: new Collector({ + ckbNodeUrl: 'https://mainnet.ckb.dev/rpc', + ckbIndexerUrl: 'https://mainnet.ckb.dev/indexer', + }), + aggregator: new Aggregator({ + registryUrl: 'http://localhost:3050', + cotaUrl: 'https://cota.nervina.dev/mainnet-aggregator', + }), } const ckb = service.collector.getCkb() const defineLock = addressToScript(TEST_ADDRESS) @@ -48,10 +54,12 @@ const run = async () => { console.log(`cotaId: ${cotaId}`) rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) + console.log(JSON.stringify(rawTx)) + const signedTx = ckb.signTransaction(TEST_PRIVATE_KEY)(rawTx) console.log(JSON.stringify(signedTx)) - let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') - console.info(`Define cota nft tx has been sent with tx hash ${txHash}`) + // let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') + // console.info(`Define cota nft tx has been sent with tx hash ${txHash}`) } run() diff --git a/example/mainnet/mint.js b/example/mainnet/mint.js index dbd019c..e3c0d82 100644 --- a/example/mainnet/mint.js +++ b/example/mainnet/mint.js @@ -6,6 +6,14 @@ const TEST_PRIVATE_KEY = '0x-example' const TEST_ADDRESS = 'ckb1qyqxx0xdw7g67eu35nuj0f237eg8skpdctuqwx39xm' const RECEIVER_ADDRESS = 'ckb1qyqxx0xdw7g67eu35nuj0f237eg8skpdctuqwx39xm' +const withdrawals = Array(100) + .fill(0) + .map(() => ({ + state: '0x00', + characteristic: '0x0505050505050505050505050505050505050505', + toLockScript: serializeScript(addressToScript(RECEIVER_ADDRESS)), + })) + const secp256k1CellDep = isMainnet => { if (isMainnet) { return { @@ -30,15 +38,21 @@ const run = async () => { const isMainnet = true const service = { - collector: new Collector({ ckbNodeUrl: 'http://localhost:8114', ckbIndexerUrl: 'http://localhost:8116' }), - aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), + collector: new Collector({ + ckbNodeUrl: 'https://mainnet.ckb.dev/rpc', + ckbIndexerUrl: 'https://mainnet.ckb.dev/indexer', + }), + aggregator: new Aggregator({ + registryUrl: 'http://localhost:3050', + cotaUrl: 'https://cota.nervina.dev/mainnet-aggregator', + }), } const ckb = service.collector.getCkb() const mintLock = addressToScript(TEST_ADDRESS) // If any tokenIndex of MintCotaInfo is not set, the tokenIndex will be set automatically with issued count. const mintCotaInfo = { - cotaId: '0xae223946058e5b148045d11483df60b36dc28a30', + cotaId: '0xc4a5cbf26b597acf3b35c74f61931c33aa16a55e', withdrawals: [ { // tokenIndex: '0x00000000', @@ -58,10 +72,12 @@ const run = async () => { let rawTx = await generateMintCotaTx(service, mintLock, mintCotaInfo, FEE, isMainnet) rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) + console.log(JSON.stringify(rawTx)) + const signedTx = ckb.signTransaction(TEST_PRIVATE_KEY)(rawTx) console.log(JSON.stringify(signedTx)) - let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') - console.info(`Mint cota nft tx has been sent with tx hash ${txHash}`) + // let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') + // console.info(`Mint cota nft tx has been sent with tx hash ${txHash}`) } run() diff --git a/example/mainnet/package.json b/example/mainnet/package.json index 92b355c..0993ee5 100644 --- a/example/mainnet/package.json +++ b/example/mainnet/package.json @@ -4,6 +4,6 @@ "description": "The examples for mainnet", "license": "MIT", "dependencies": { - "@nervina-labs/cota-sdk": "0.7.1" + "@nervina-labs/cota-sdk": "0.8.0" } -} \ No newline at end of file +} diff --git a/example/mainnet/registry.js b/example/mainnet/registry.js index 4cd1ba3..2759acc 100644 --- a/example/mainnet/registry.js +++ b/example/mainnet/registry.js @@ -34,12 +34,20 @@ const run = async () => { const isMainnet = true const service = { - collector: new Collector({ ckbNodeUrl: 'http://localhost:8114', ckbIndexerUrl: 'http://localhost:8116' }), - aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), + collector: new Collector({ + ckbNodeUrl: 'https://mainnet.ckb.dev/rpc', + ckbIndexerUrl: 'https://mainnet.ckb.dev/indexer', + }), + aggregator: new Aggregator({ + registryUrl: 'https://cota.nervina.dev/mainnet-registry-aggregator', + cotaUrl: 'https://cota.nervina.dev/mainnet-aggregator', + }), } const ckb = service.collector.getCkb() const provideCKBLock = addressToScript(TEST_ADDRESS) - const unregisteredCotaLock = addressToScript(TEST_ADDRESS) + const unregisteredCotaLock = addressToScript( + 'ckb1qzl58smqy32hnrq6vxjedcxe2fugvnz497h7yvwqvwel40uh4rltcqdjejyul32m2jmnu86w4esltzkg5k3ej3gpwhzrx', + ) let rawTx = await generateRegisterCotaTx(service, [unregisteredCotaLock], provideCKBLock, FEE, isMainnet) rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) @@ -68,8 +76,8 @@ const run = async () => { witnesses: signedWitnesses.map(witness => (typeof witness === 'string' ? witness : serializeWitnessArgs(witness))), } console.log(JSON.stringify(signedTx)) - let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') - console.log(`Register cota cell tx has been sent with tx hash ${txHash}`) + // let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') + // console.log(`Register cota cell tx has been sent with tx hash ${txHash}`) } run() diff --git a/example/mainnet/transfer.js b/example/mainnet/transfer.js index fb30088..bd72d0e 100644 --- a/example/mainnet/transfer.js +++ b/example/mainnet/transfer.js @@ -30,8 +30,14 @@ const run = async () => { const isMainnet = true const service = { - collector: new Collector({ ckbNodeUrl: 'http://localhost:8114', ckbIndexerUrl: 'http://localhost:8116' }), - aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), + collector: new Collector({ + ckbNodeUrl: 'https://mainnet.ckb.dev/rpc', + ckbIndexerUrl: 'https://mainnet.ckb.dev/indexer', + }), + aggregator: new Aggregator({ + registryUrl: 'https://cota.nervina.dev/mainnet-registry-aggregator', + cotaUrl: 'https://cota.nervina.dev/mainnet-aggregator', + }), } const ckb = service.collector.getCkb() const cotaLock = addressToScript(RECEIVER_ADDRESS) @@ -39,18 +45,22 @@ const run = async () => { const transfers = [ { - cotaId: '0xae223946058e5b148045d11483df60b36dc28a30', - tokenIndex: '0x00000000', + cotaId: '0xc4a5cbf26b597acf3b35c74f61931c33aa16a55e', + tokenIndex: '0x00000008', toLockScript: serializeScript(addressToScript(OTHER_ADDRESS)), }, ] let rawTx = await generateTransferCotaTx(service, cotaLock, withdrawLock, transfers, FEE, isMainnet) rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) + console.log(JSON.stringify(rawTx)) + const signedTx = ckb.signTransaction(RECEIVER_PRIVATE_KEY)(rawTx) console.log(JSON.stringify(signedTx)) - let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') - console.info(`Transfer cota nft tx has been sent with tx hash ${txHash}`) + const result = await ckb.rpc.dryRunTransaction(signedTx) + console.log(JSON.stringify(result)) + // let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') + // console.info(`Transfer cota nft tx has been sent with tx hash ${txHash}`) } run() diff --git a/example/mainnet/yarn.lock b/example/mainnet/yarn.lock index 6354df9..366cef7 100644 --- a/example/mainnet/yarn.lock +++ b/example/mainnet/yarn.lock @@ -2,15 +2,15 @@ # yarn lockfile v1 -"@nervina-labs/cota-sdk@0.7.1": - version "0.7.1" - resolved "https://registry.yarnpkg.com/@nervina-labs/cota-sdk/-/cota-sdk-0.7.1.tgz#a083a390ac514e56139a356701a368fe964f6e2e" - integrity sha512-EBnhifgro41OsSCBFF6s/f3cJP5CVv/aRv/9L3x5nm471ePZ2cHNMXNBIkjjlfximfmQnV29Mrt3kctV82EvjQ== +"@nervina-labs/cota-sdk@0.8.0": + version "0.8.0" + resolved "https://registry.yarnpkg.com/@nervina-labs/cota-sdk/-/cota-sdk-0.8.0.tgz#89028c2874e2bf1f226f3fc95bbc567bca8f34ac" + integrity sha512-3DwI26csftPtvnjFS8Cauf2ybu+8ESLVsGEUQn69aK5m3PKhXJqfuT2DpsXK2v4dmDEQ8MojgK2S0OooH/37ng== dependencies: "@nervosnetwork/ckb-sdk-core" "^0.103.0" "@nervosnetwork/ckb-sdk-utils" "^0.103.0" "@nervosnetwork/ckb-types" "^0.103.0" - axios "^0.27.2" + axios "^1.0.0" camelcase-keys "^7.0.2" convert-keys "1.3.4" @@ -61,13 +61,14 @@ axios@0.21.4: dependencies: follow-redirects "^1.14.0" -axios@^0.27.2: - version "0.27.2" - resolved "https://registry.yarnpkg.com/axios/-/axios-0.27.2.tgz#207658cc8621606e586c85db4b41a750e756d972" - integrity sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ== +axios@^1.0.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/axios/-/axios-1.2.0.tgz#1cb65bd75162c70e9f8d118a905126c4a201d383" + integrity sha512-zT7wZyNYu3N5Bu0wuZ6QccIf93Qk1eV8LOewxgjOZFd2DenOs98cJ7+Y6703d0wkaXGY6/nZd4EweJaHz9uzQw== dependencies: - follow-redirects "^1.14.9" + follow-redirects "^1.15.0" form-data "^4.0.0" + proxy-from-env "^1.1.0" bech32@2.0.0: version "2.0.0" @@ -134,11 +135,16 @@ elliptic@6.5.4: minimalistic-assert "^1.0.1" minimalistic-crypto-utils "^1.0.1" -follow-redirects@^1.14.0, follow-redirects@^1.14.9: +follow-redirects@^1.14.0: version "1.15.0" resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.0.tgz#06441868281c86d0dda4ad8bdaead2d02dca89d4" integrity sha512-aExlJShTV4qOUOL7yF1U5tvLCB0xQuudbf6toyYA0E/acBNw71mvjFTnLaRp50aQaYocMR0a/RMMBIHeZnGyjQ== +follow-redirects@^1.15.0: + version "1.15.2" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.2.tgz#b460864144ba63f2681096f274c4e57026da2c13" + integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA== + form-data@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" @@ -222,6 +228,11 @@ minimalistic-crypto-utils@^1.0.1: resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" integrity sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo= +proxy-from-env@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2" + integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== + quick-lru@^5.1.1: version "5.1.1" resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" diff --git a/example/mint.ts b/example/mint.ts index beb5473..de53fc0 100644 --- a/example/mint.ts +++ b/example/mint.ts @@ -10,15 +10,21 @@ const RECEIVER_ADDRESS = 'ckt1qyqy6xew5q449zg5du7wdjhgrxschjkg3n2q8h5ycc' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/example/registry-ccids.ts b/example/registry-ccids.ts index 870bed5..9b2e1e8 100644 --- a/example/registry-ccids.ts +++ b/example/registry-ccids.ts @@ -6,13 +6,15 @@ import { generateUpdateCcidsTx } from '../src/service/registry' import { Service } from '../src' import signWitnesses from '@nervosnetwork/ckb-sdk-core/lib/signWitnesses' - const run = async () => { // True for mainnet and false for testnet const isMainnet = false const service: Service = { - collector: new Collector({ ckbNodeUrl: 'https://testnet.ckb.dev/rpc', ckbIndexerUrl: 'https://testnet.ckb.dev/indexer' }), + collector: new Collector({ + ckbNodeUrl: 'https://testnet.ckb.dev/rpc', + ckbIndexerUrl: 'https://testnet.ckb.dev/indexer', + }), aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), } const ckb = service.collector.getCkb() diff --git a/example/registry.js b/example/registry.js index f05c6e8..88c24ab 100644 --- a/example/registry.js +++ b/example/registry.js @@ -13,17 +13,23 @@ const signWitnesses = require('@nervosnetwork/ckb-sdk-core/lib/signWitnesses') const TEST_PRIVATE_KEY = '0xc5bd09c9b954559c70a77d68bde95369e2ce910556ddc20f739080cde3b62ef2' const TEST_ADDRESS = 'ckt1qyq0scej4vn0uka238m63azcel7cmcme7f2sxj5ska' -const secp256k1CellDep = (isMainnet) => { +const secp256k1CellDep = isMainnet => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { @@ -37,7 +43,7 @@ const run = async () => { const ckb = service.collector.getCkb() const provideCKBLock = addressToScript(TEST_ADDRESS) const unregisteredCotaLock = addressToScript(TEST_ADDRESS) - + let rawTx = await generateRegisterCotaTx(service, [unregisteredCotaLock], provideCKBLock, FEE, isMainnet) rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) diff --git a/example/registry.ts b/example/registry.ts index ae56fd2..d16c183 100644 --- a/example/registry.ts +++ b/example/registry.ts @@ -11,15 +11,21 @@ const TEST_ADDRESS = 'ckt1qyq0scej4vn0uka238m63azcel7cmcme7f2sxj5ska' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/example/transfer-update.ts b/example/transfer-update.ts index cdc1356..eabbbe7 100644 --- a/example/transfer-update.ts +++ b/example/transfer-update.ts @@ -2,7 +2,7 @@ import { addressToScript, serializeScript } from '@nervosnetwork/ckb-sdk-utils' import { Collector } from '../src/collector' import { Aggregator } from '../src/aggregator' import { generateTransferUpdateCotaTx } from '../src/service/cota' -import { Service, TransferUpdate, FEE } from '../src' +import { Service, TransferUpdate, FEE } from '../src' const TEST_ADDRESS = 'ckt1qyq0scej4vn0uka238m63azcel7cmcme7f2sxj5ska' const RECEIVER_PRIVATE_KEY = '0xf0d72b5e3a27e603efb304aa16608ba3e480cb1c6790bced80fb82c53a822cee' @@ -11,15 +11,21 @@ const OTHER_ADDRESS = 'ckt1qyqz8vxeyrv4nur4j27ktp34fmwnua9wuyqqggd748' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/example/transfer.ts b/example/transfer.ts index 3b6513c..d05ae66 100644 --- a/example/transfer.ts +++ b/example/transfer.ts @@ -11,15 +11,21 @@ const OTHER_ADDRESS = 'ckt1qyqz8vxeyrv4nur4j27ktp34fmwnua9wuyqqggd748' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { @@ -37,7 +43,7 @@ const run = async () => { const transfers: TransferWithdrawal[] = [ { cotaId: '0xc27328c95e27723d42770261d05355977aa5c89a', - tokenIndex: "0x00000013", + tokenIndex: '0x00000013', toLockScript: serializeScript(addressToScript(OTHER_ADDRESS)), }, ] @@ -50,5 +56,4 @@ const run = async () => { console.info(`Transfer cota nft tx has been sent with tx hash ${txHash}`) } - - run() \ No newline at end of file +run() diff --git a/example/update-cota-meta.ts b/example/update-cota-meta.ts index 1933fe9..9697849 100644 --- a/example/update-cota-meta.ts +++ b/example/update-cota-meta.ts @@ -1,51 +1,60 @@ -import { addressToScript } from '@nervosnetwork/ckb-sdk-utils' -import { Collector } from '../src/collector' -import { Aggregator } from '../src/aggregator' -import { Service, FEE, CotaInfo } from '../src' -import { generateCotaMetadataTx } from '../src/service/cota/cota-meta' - -const TEST_PRIVATE_KEY = '0xc5bd09c9b954559c70a77d68bde95369e2ce910556ddc20f739080cde3b62ef2' -const TEST_ADDRESS = 'ckt1qyq0scej4vn0uka238m63azcel7cmcme7f2sxj5ska' - -const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { - if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } - } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } -} - -const run = async () => { - // True for mainnet and false for testnet - const isMainnet = false - - const service: Service = { - collector: new Collector({ ckbNodeUrl: 'https://testnet.ckb.dev/rpc', ckbIndexerUrl: 'https://testnet.ckb.dev/indexer' }), - aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), - } - const ckb = service.collector.getCkb() - const cotaLock = addressToScript(TEST_ADDRESS) - - const cotaInfo: CotaInfo = { - name: 'Update First Step', - description: - 'First step to Blockchain mass adoption. NFT platform launch memento.\n\n-- Nervina Labs & Lay2 Tech, 4/30/2021.', - image: 'https://i.loli.net/2021/04/29/qyJNSE4iHAas7GL.png', - } - const cotaId = '0x36cd7eb40416a61b1f90631b4ddfedd95aea6820' - - let rawTx = await generateCotaMetadataTx(service, cotaLock, cotaId, cotaInfo, FEE, isMainnet) - rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) - - const signedTx = ckb.signTransaction(TEST_PRIVATE_KEY)(rawTx) - console.log(JSON.stringify(signedTx)) - let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') - console.info(`Update cota metadata information tx has been sent with tx hash ${txHash}`) -} - -run() +import { addressToScript } from '@nervosnetwork/ckb-sdk-utils' +import { Collector } from '../src/collector' +import { Aggregator } from '../src/aggregator' +import { Service, FEE, CotaInfo } from '../src' +import { generateCotaMetadataTx } from '../src/service/cota/cota-meta' + +const TEST_PRIVATE_KEY = '0xc5bd09c9b954559c70a77d68bde95369e2ce910556ddc20f739080cde3b62ef2' +const TEST_ADDRESS = 'ckt1qyq0scej4vn0uka238m63azcel7cmcme7f2sxj5ska' + +const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { + if (isMainnet) { + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', + } +} + +const run = async () => { + // True for mainnet and false for testnet + const isMainnet = false + + const service: Service = { + collector: new Collector({ + ckbNodeUrl: 'https://testnet.ckb.dev/rpc', + ckbIndexerUrl: 'https://testnet.ckb.dev/indexer', + }), + aggregator: new Aggregator({ registryUrl: 'http://localhost:3050', cotaUrl: 'http://localhost:3030' }), + } + const ckb = service.collector.getCkb() + const cotaLock = addressToScript(TEST_ADDRESS) + + const cotaInfo: CotaInfo = { + name: 'Update First Step', + description: + 'First step to Blockchain mass adoption. NFT platform launch memento.\n\n-- Nervina Labs & Lay2 Tech, 4/30/2021.', + image: 'https://i.loli.net/2021/04/29/qyJNSE4iHAas7GL.png', + } + const cotaId = '0x36cd7eb40416a61b1f90631b4ddfedd95aea6820' + + let rawTx = await generateCotaMetadataTx(service, cotaLock, cotaId, cotaInfo, FEE, isMainnet) + rawTx.cellDeps.push(secp256k1CellDep(isMainnet)) + + const signedTx = ckb.signTransaction(TEST_PRIVATE_KEY)(rawTx) + console.log(JSON.stringify(signedTx)) + let txHash = await ckb.rpc.sendTransaction(signedTx, 'passthrough') + console.info(`Update cota metadata information tx has been sent with tx hash ${txHash}`) +} + +run() diff --git a/example/update.ts b/example/update.ts index febf462..9797e61 100644 --- a/example/update.ts +++ b/example/update.ts @@ -9,15 +9,21 @@ const RECEIVER_ADDRESS = 'ckt1qyqy6xew5q449zg5du7wdjhgrxschjkg3n2q8h5ycc' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/example/withdraw.ts b/example/withdraw.ts index f607524..9e6c25a 100644 --- a/example/withdraw.ts +++ b/example/withdraw.ts @@ -10,15 +10,21 @@ const RECEIVER_ADDRESS = 'ckt1qyqy6xew5q449zg5du7wdjhgrxschjkg3n2q8h5ycc' const secp256k1CellDep = (isMainnet: boolean): CKBComponents.CellDep => { if (isMainnet) { - return { outPoint: { - txHash: "0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c", - index: "0x0", - }, depType: 'depGroup' } + return { + outPoint: { + txHash: '0x71a7ba8fc96349fea0ed3a5c47992e3b4084b031a42264a018e0072e8172e46c', + index: '0x0', + }, + depType: 'depGroup', + } + } + return { + outPoint: { + txHash: '0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37', + index: '0x0', + }, + depType: 'depGroup', } - return { outPoint: { - txHash: "0xf8de3bb47d055cdf460d93a2a6e1b05f7432f9777c8c474abf4eec1d4aee5d37", - index: "0x0", - }, depType: 'depGroup' } } const run = async () => { diff --git a/package.json b/package.json index c3431cc..d97cddf 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@nervina-labs/cota-sdk", - "version": "0.8.0", + "version": "0.9.0", "description": "The SDK of CoTA", "repository": "git@github.com:nervina-labs/cota-sdk-js.git", "author": "duanyytop ", @@ -24,27 +24,27 @@ "prepare": "husky install" }, "dependencies": { - "@nervosnetwork/ckb-sdk-core": "^0.103.0", - "@nervosnetwork/ckb-sdk-utils": "^0.103.0", - "@nervosnetwork/ckb-types": "^0.103.0", - "axios": "^1.0.0", - "camelcase-keys": "^7.0.2", + "@nervosnetwork/ckb-sdk-core": "^0.103.1", + "@nervosnetwork/ckb-sdk-utils": "^0.103.1", + "@nervosnetwork/ckb-types": "^0.103.1", + "axios": "^1.2.1", + "camelcase-keys": "7.0.2", "convert-keys": "1.3.4" }, "devDependencies": { "@types/crypto-js": "4.1.1", - "@types/node": "18.11.9", - "@typescript-eslint/parser": "5.45.0", + "@types/node": "18.11.13", + "@typescript-eslint/parser": "5.49.0", "babel-eslint": "10.1.0", - "eslint": "8.28.0", - "eslint-config-prettier": "8.5.0", + "eslint": "8.31.0", + "eslint-config-prettier": "8.6.0", "eslint-plugin-import": "2.26.0", "eslint-plugin-prettier": "4.2.1", - "husky": "8.0.2", - "prettier": "2.8.0", + "husky": "8.0.3", + "prettier": "2.8.1", "ts-node": "10.9.1", "tslib": "2.4.1", - "typescript": "4.8.3" + "typescript": "4.9.5" }, "homepage": "https://github.com/nervina-labs/cota-sdk-js#readme" -} \ No newline at end of file +} diff --git a/src/constants/index.ts b/src/constants/index.ts index b9ba838..d251bf2 100644 --- a/src/constants/index.ts +++ b/src/constants/index.ts @@ -45,7 +45,7 @@ const MainnetInfo = { } as CKBComponents.Script, CotaTypeDep: { - outPoint: { txHash: '0x875db3381ebe7a730676c110e1c0d78ae1bdd0c11beacb7db4db08e368c2cd95', index: '0x0' }, + outPoint: { txHash: '0xabaa25237554f0d6c586dc010e7e85e6870bcfd9fb8773257ecacfbe1fd738a0', index: '0x0' }, depType: 'depGroup', } as CKBComponents.CellDep, diff --git a/src/service/cota/extension.ts b/src/service/cota/extension.ts index 40638fc..3cf9c5e 100644 --- a/src/service/cota/extension.ts +++ b/src/service/cota/extension.ts @@ -1,76 +1,73 @@ -import { serializeScript } from '@nervosnetwork/ckb-sdk-utils' -import { Service } from '../..' -import { FEE, getCotaTypeScript, getCotaCellDep } from '../../constants' -import { ExtensionReq } from '../../types' - - -enum Action { - Add, - Update -} - -const generateExtensionTx = async ( - service: Service, - cotaLock: CKBComponents.Script, - fee = FEE, - isMainnet = false, - action: Action, -) => { - const cotaType = getCotaTypeScript(isMainnet) - const cotaCells = await service.collector.getCells(cotaLock, cotaType) - if (!cotaCells || cotaCells.length === 0) { - throw new Error("Cota cell doesn't exist") - } - const cotaCell = cotaCells[0] - const inputs = [ - { - previousOutput: cotaCell.outPoint, - since: '0x0', - }, - ] - - const outputs = [cotaCell.output] - outputs[0].capacity = `0x${(BigInt(outputs[0].capacity) - fee).toString(16)}` - - const extensionReq: ExtensionReq = { - lockScript: serializeScript(cotaLock), - } - - const { smtRootHash, extensionSmtEntry } = await service.aggregator.generateExtensionSmt(extensionReq) - const cotaCellData = `0x02${smtRootHash}` - - const outputsData = [cotaCellData] - const cellDeps = [getCotaCellDep(isMainnet)] - - const rawTx = { - version: '0x0', - cellDeps, - headerDeps: [], - inputs, - outputs, - outputsData, - witnesses: [], - } as any - - const prefix = action == Action.Add ? '0xF0' : '0xF1' - rawTx.witnesses = rawTx.inputs.map((_, i) => - i > 0 ? '0x' : { lock: '', inputType: `${prefix}${extensionSmtEntry}`, outputType: '' }, - ) - return rawTx -} - - -export const generateAddExtensionTx = async ( - service: Service, - cotaLock: CKBComponents.Script, - fee = FEE, - isMainnet = false -) => await generateExtensionTx(service, cotaLock, fee, isMainnet, Action.Add) - - - export const generateUpdateExtensionTx = async ( - service: Service, - cotaLock: CKBComponents.Script, - fee = FEE, - isMainnet = false -) => await generateExtensionTx(service, cotaLock, fee, isMainnet, Action.Update) \ No newline at end of file +import { serializeScript } from '@nervosnetwork/ckb-sdk-utils' +import { Service } from '../..' +import { FEE, getCotaTypeScript, getCotaCellDep } from '../../constants' +import { ExtensionReq } from '../../types' + +enum Action { + Add, + Update, +} + +const generateExtensionTx = async ( + service: Service, + cotaLock: CKBComponents.Script, + fee = FEE, + isMainnet = false, + action: Action, +) => { + const cotaType = getCotaTypeScript(isMainnet) + const cotaCells = await service.collector.getCells(cotaLock, cotaType) + if (!cotaCells || cotaCells.length === 0) { + throw new Error("Cota cell doesn't exist") + } + const cotaCell = cotaCells[0] + const inputs = [ + { + previousOutput: cotaCell.outPoint, + since: '0x0', + }, + ] + + const outputs = [cotaCell.output] + outputs[0].capacity = `0x${(BigInt(outputs[0].capacity) - fee).toString(16)}` + + const extensionReq: ExtensionReq = { + lockScript: serializeScript(cotaLock), + } + + const { smtRootHash, extensionSmtEntry } = await service.aggregator.generateExtensionSmt(extensionReq) + const cotaCellData = `0x02${smtRootHash}` + + const outputsData = [cotaCellData] + const cellDeps = [getCotaCellDep(isMainnet)] + + const rawTx = { + version: '0x0', + cellDeps, + headerDeps: [], + inputs, + outputs, + outputsData, + witnesses: [], + } as any + + const prefix = action == Action.Add ? '0xF0' : '0xF1' + rawTx.witnesses = rawTx.inputs.map((_, i) => + i > 0 ? '0x' : { lock: '', inputType: `${prefix}${extensionSmtEntry}`, outputType: '' }, + ) + return rawTx +} + +export const generateAddExtensionTx = async ( + service: Service, + cotaLock: CKBComponents.Script, + fee = FEE, + isMainnet = false, +) => await generateExtensionTx(service, cotaLock, fee, isMainnet, Action.Add) + +export const generateUpdateExtensionTx = async ( + service: Service, + cotaLock: CKBComponents.Script, + fee = FEE, + isMainnet = false, +) => await generateExtensionTx(service, cotaLock, fee, isMainnet, Action.Update) diff --git a/src/service/registry/index.ts b/src/service/registry/index.ts index 6aff5b1..28de560 100644 --- a/src/service/registry/index.ts +++ b/src/service/registry/index.ts @@ -75,9 +75,7 @@ export const generateRegisterCotaTx = async ( outputs[length - 1].capacity = `0x${(BigInt(outputs[length - 1].capacity) - fee).toString(16)}` const lockHashes = cotaLocks.map(lock => scriptToHash(lock)) - const { smtRootHash, registrySmtEntry } = await service.aggregator.generateRegisterCotaSmt( - lockHashes, - ) + const { smtRootHash, registrySmtEntry } = await service.aggregator.generateRegisterCotaSmt(lockHashes) const registryCellData = `0x02${smtRootHash}` const outputsData = outputs.map((_, i) => (i === 0 ? registryCellData : i !== outputs.length - 1 ? '0x02' : '0x')) diff --git a/yarn.lock b/yarn.lock index 932f75e..48247c8 100644 --- a/yarn.lock +++ b/yarn.lock @@ -104,25 +104,25 @@ dependencies: "@jridgewell/trace-mapping" "0.3.9" -"@eslint/eslintrc@^1.3.3": - version "1.3.3" - resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-1.3.3.tgz#2b044ab39fdfa75b4688184f9e573ce3c5b0ff95" - integrity sha512-uj3pT6Mg+3t39fvLrj8iuCIJ38zKO9FpGtJ4BBJebJhEwjoT+KLVNCcHT5QC9NGRIEi7fZ0ZR8YRb884auB4Lg== +"@eslint/eslintrc@^1.4.1": + version "1.4.1" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-1.4.1.tgz#af58772019a2d271b7e2d4c23ff4ddcba3ccfb3e" + integrity sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA== dependencies: ajv "^6.12.4" debug "^4.3.2" espree "^9.4.0" - globals "^13.15.0" + globals "^13.19.0" ignore "^5.2.0" import-fresh "^3.2.1" js-yaml "^4.1.0" minimatch "^3.1.2" strip-json-comments "^3.1.1" -"@humanwhocodes/config-array@^0.11.6": - version "0.11.7" - resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.7.tgz#38aec044c6c828f6ed51d5d7ae3d9b9faf6dbb0f" - integrity sha512-kBbPWzN8oVMLb0hOUYXhmxggL/1cJE6ydvjDIGi9EnAGUyA7cLVKQg+d/Dsm+KZwx2czGHrCmMVLiyg8s5JPKw== +"@humanwhocodes/config-array@^0.11.8": + version "0.11.8" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.8.tgz#03595ac2075a4dc0f191cc2131de14fbd7d410b9" + integrity sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g== dependencies: "@humanwhocodes/object-schema" "^1.2.1" debug "^4.1.1" @@ -178,7 +178,7 @@ "@jridgewell/resolve-uri" "^3.0.3" "@jridgewell/sourcemap-codec" "^1.4.10" -"@nervosnetwork/ckb-sdk-core@^0.103.0": +"@nervosnetwork/ckb-sdk-core@^0.103.1": version "0.103.1" resolved "https://registry.yarnpkg.com/@nervosnetwork/ckb-sdk-core/-/ckb-sdk-core-0.103.1.tgz#136d616ec53af96d3b93dcbce593e6db484c802d" integrity sha512-LeNwId3GaQILVpnY1zfNBY897XQJPODKeP6d7w6tww9anu0jSxrvXVxGMDTTn3Yz5mixzBgpFGo4SXRrH0eiaQ== @@ -197,7 +197,7 @@ axios "0.21.4" tslib "2.3.1" -"@nervosnetwork/ckb-sdk-utils@0.103.1", "@nervosnetwork/ckb-sdk-utils@^0.103.0": +"@nervosnetwork/ckb-sdk-utils@0.103.1", "@nervosnetwork/ckb-sdk-utils@^0.103.1": version "0.103.1" resolved "https://registry.yarnpkg.com/@nervosnetwork/ckb-sdk-utils/-/ckb-sdk-utils-0.103.1.tgz#8356f88027a4054835fee0648617cc7020c8db1b" integrity sha512-OzpFNKkOOqYWDHDjPf11uOfOf8EQOEstOBxVtyFjrGEx3B9FwsGxItlHYeuTfpFkHF2Ut+G9M3X71w8h/IApdQ== @@ -208,7 +208,7 @@ jsbi "3.1.3" tslib "2.3.1" -"@nervosnetwork/ckb-types@0.103.1", "@nervosnetwork/ckb-types@^0.103.0": +"@nervosnetwork/ckb-types@0.103.1", "@nervosnetwork/ckb-types@^0.103.1": version "0.103.1" resolved "https://registry.yarnpkg.com/@nervosnetwork/ckb-types/-/ckb-types-0.103.1.tgz#b5626ce905353e70136bfaccf9def0819b76ca27" integrity sha512-gGRR1VvUS/KRq2ChhXHPiHpgyLYazPM2R8lK87shQI82Gp2/m6k1HVDeNR5XOYwQ3YmBbxHGQtQr/kMq7DUlZA== @@ -264,53 +264,53 @@ resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" integrity sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ== -"@types/node@18.11.9": - version "18.11.9" - resolved "https://registry.yarnpkg.com/@types/node/-/node-18.11.9.tgz#02d013de7058cea16d36168ef2fc653464cfbad4" - integrity sha512-CRpX21/kGdzjOpFsZSkcrXMGIBWMGNIHXXBVFSH+ggkftxg+XYP20TESbh+zFvFj3EQOl5byk0HTRn1IL6hbqg== +"@types/node@18.11.13": + version "18.11.13" + resolved "https://registry.yarnpkg.com/@types/node/-/node-18.11.13.tgz#dff34f226ec1ac0432ae3b136ec5552bd3b9c0fe" + integrity sha512-IASpMGVcWpUsx5xBOrxMj7Bl8lqfuTY7FKAnPmu5cHkfQVWF8GulWS1jbRqA934qZL35xh5xN/+Xe/i26Bod4w== -"@typescript-eslint/parser@5.45.0": - version "5.45.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.45.0.tgz#b18a5f6b3cf1c2b3e399e9d2df4be40d6b0ddd0e" - integrity sha512-brvs/WSM4fKUmF5Ot/gEve6qYiCMjm6w4HkHPfS6ZNmxTS0m0iNN4yOChImaCkqc1hRwFGqUyanMXuGal6oyyQ== +"@typescript-eslint/parser@5.49.0": + version "5.49.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.49.0.tgz#d699734b2f20e16351e117417d34a2bc9d7c4b90" + integrity sha512-veDlZN9mUhGqU31Qiv2qEp+XrJj5fgZpJ8PW30sHU+j/8/e5ruAhLaVDAeznS7A7i4ucb/s8IozpDtt9NqCkZg== dependencies: - "@typescript-eslint/scope-manager" "5.45.0" - "@typescript-eslint/types" "5.45.0" - "@typescript-eslint/typescript-estree" "5.45.0" + "@typescript-eslint/scope-manager" "5.49.0" + "@typescript-eslint/types" "5.49.0" + "@typescript-eslint/typescript-estree" "5.49.0" debug "^4.3.4" -"@typescript-eslint/scope-manager@5.45.0": - version "5.45.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.45.0.tgz#7a4ac1bfa9544bff3f620ab85947945938319a96" - integrity sha512-noDMjr87Arp/PuVrtvN3dXiJstQR1+XlQ4R1EvzG+NMgXi8CuMCXpb8JqNtFHKceVSQ985BZhfRdowJzbv4yKw== +"@typescript-eslint/scope-manager@5.49.0": + version "5.49.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.49.0.tgz#81b5d899cdae446c26ddf18bd47a2f5484a8af3e" + integrity sha512-clpROBOiMIzpbWNxCe1xDK14uPZh35u4QaZO1GddilEzoCLAEz4szb51rBpdgurs5k2YzPtJeTEN3qVbG+LRUQ== dependencies: - "@typescript-eslint/types" "5.45.0" - "@typescript-eslint/visitor-keys" "5.45.0" + "@typescript-eslint/types" "5.49.0" + "@typescript-eslint/visitor-keys" "5.49.0" -"@typescript-eslint/types@5.45.0": - version "5.45.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.45.0.tgz#794760b9037ee4154c09549ef5a96599621109c5" - integrity sha512-QQij+u/vgskA66azc9dCmx+rev79PzX8uDHpsqSjEFtfF2gBUTRCpvYMh2gw2ghkJabNkPlSUCimsyBEQZd1DA== +"@typescript-eslint/types@5.49.0": + version "5.49.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.49.0.tgz#ad66766cb36ca1c89fcb6ac8b87ec2e6dac435c3" + integrity sha512-7If46kusG+sSnEpu0yOz2xFv5nRz158nzEXnJFCGVEHWnuzolXKwrH5Bsf9zsNlOQkyZuk0BZKKoJQI+1JPBBg== -"@typescript-eslint/typescript-estree@5.45.0": - version "5.45.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.45.0.tgz#f70a0d646d7f38c0dfd6936a5e171a77f1e5291d" - integrity sha512-maRhLGSzqUpFcZgXxg1qc/+H0bT36lHK4APhp0AEUVrpSwXiRAomm/JGjSG+kNUio5kAa3uekCYu/47cnGn5EQ== +"@typescript-eslint/typescript-estree@5.49.0": + version "5.49.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.49.0.tgz#ebd6294c0ea97891fce6af536048181e23d729c8" + integrity sha512-PBdx+V7deZT/3GjNYPVQv1Nc0U46dAHbIuOG8AZ3on3vuEKiPDwFE/lG1snN2eUB9IhF7EyF7K1hmTcLztNIsA== dependencies: - "@typescript-eslint/types" "5.45.0" - "@typescript-eslint/visitor-keys" "5.45.0" + "@typescript-eslint/types" "5.49.0" + "@typescript-eslint/visitor-keys" "5.49.0" debug "^4.3.4" globby "^11.1.0" is-glob "^4.0.3" semver "^7.3.7" tsutils "^3.21.0" -"@typescript-eslint/visitor-keys@5.45.0": - version "5.45.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.45.0.tgz#e0d160e9e7fdb7f8da697a5b78e7a14a22a70528" - integrity sha512-jc6Eccbn2RtQPr1s7th6jJWQHBHI6GBVQkCHoJFQ5UreaKm59Vxw+ynQUPPY2u2Amquc+7tmEoC2G52ApsGNNg== +"@typescript-eslint/visitor-keys@5.49.0": + version "5.49.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.49.0.tgz#2561c4da3f235f5c852759bf6c5faec7524f90fe" + integrity sha512-v9jBMjpNWyn8B6k/Mjt6VbUS4J1GvUlR4x3Y+ibnP1z7y7V4n0WRz+50DY6+Myj0UaXVSuUlHohO+eZ8IJEnkg== dependencies: - "@typescript-eslint/types" "5.45.0" + "@typescript-eslint/types" "5.49.0" eslint-visitor-keys "^3.3.0" acorn-jsx@^5.3.2: @@ -405,10 +405,10 @@ axios@0.21.4: dependencies: follow-redirects "^1.14.0" -axios@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/axios/-/axios-1.0.0.tgz#16ded6096c1d37650db9f6a8d48a2f7c1bb58622" - integrity sha512-SsHsGFN1qNPFT5QhSoSD37SHDfGyLSW5AESmyLk2JeCMHv5g0I9g0Hz/zQHx2KNe0jGXh2q2hAm7OdkXm360CA== +axios@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/axios/-/axios-1.2.1.tgz#44cf04a3c9f0c2252ebd85975361c026cb9f864a" + integrity sha512-I88cFiGu9ryt/tfVEi4kX2SITsvDddTajXTOFmt2uK1ZVA8LytjtdeyefdQWEf5PU8w+4SSJDoYnggflB5tW4A== dependencies: follow-redirects "^1.15.0" form-data "^4.0.0" @@ -474,7 +474,7 @@ callsites@^3.0.0: resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== -camelcase-keys@^7.0.2: +camelcase-keys@7.0.2: version "7.0.2" resolved "https://registry.yarnpkg.com/camelcase-keys/-/camelcase-keys-7.0.2.tgz#d048d8c69448745bb0de6fc4c1c52a30dfbe7252" integrity sha512-Rjs1H+A9R+Ig+4E/9oyB66UC5Mj9Xq3N//vcLf2WzgdTi/3gUu3Z9KoqmlrEG4VuuLK8wJHofxzdQXz/knhiYg== @@ -699,10 +699,10 @@ escape-string-regexp@^4.0.0: resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== -eslint-config-prettier@8.5.0: - version "8.5.0" - resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.5.0.tgz#5a81680ec934beca02c7b1a61cf8ca34b66feab1" - integrity sha512-obmWKLUNCnhtQRKc+tmnYuQl0pFU1ibYJQ5BGhTVB08bHe9wC8qUeG7c08dj9XX+AuPj1YSGSQIHl1pnDHZR0Q== +eslint-config-prettier@8.6.0: + version "8.6.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.6.0.tgz#dec1d29ab728f4fa63061774e1672ac4e363d207" + integrity sha512-bAF0eLpLVqP5oEVUFKpMA+NnRFICwn9X8B5jrR9FcqnYBuPbqWEjTEspPWMj5ye6czoSLDweCzSo3Ko7gGrZaA== eslint-import-resolver-node@^0.3.6: version "0.3.6" @@ -776,13 +776,13 @@ eslint-visitor-keys@^3.3.0: resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz#f6480fa6b1f30efe2d1968aa8ac745b862469826" integrity sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA== -eslint@8.28.0: - version "8.28.0" - resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.28.0.tgz#81a680732634677cc890134bcdd9fdfea8e63d6e" - integrity sha512-S27Di+EVyMxcHiwDrFzk8dJYAaD+/5SoWKxL1ri/71CRHsnJnRDPNt2Kzj24+MT9FDupf4aqqyqPrvI8MvQ4VQ== +eslint@8.31.0: + version "8.31.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.31.0.tgz#75028e77cbcff102a9feae1d718135931532d524" + integrity sha512-0tQQEVdmPZ1UtUKXjX7EMm9BlgJ08G90IhWh0PKDCb3ZLsgAOHI8fYSIzYVZej92zsgq+ft0FGsxhJ3xo2tbuA== dependencies: - "@eslint/eslintrc" "^1.3.3" - "@humanwhocodes/config-array" "^0.11.6" + "@eslint/eslintrc" "^1.4.1" + "@humanwhocodes/config-array" "^0.11.8" "@humanwhocodes/module-importer" "^1.0.1" "@nodelib/fs.walk" "^1.2.8" ajv "^6.10.0" @@ -801,7 +801,7 @@ eslint@8.28.0: file-entry-cache "^6.0.1" find-up "^5.0.0" glob-parent "^6.0.2" - globals "^13.15.0" + globals "^13.19.0" grapheme-splitter "^1.0.4" ignore "^5.2.0" import-fresh "^3.0.0" @@ -1026,10 +1026,10 @@ globals@^11.1.0: resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== -globals@^13.15.0: - version "13.17.0" - resolved "https://registry.yarnpkg.com/globals/-/globals-13.17.0.tgz#902eb1e680a41da93945adbdcb5a9f361ba69bd4" - integrity sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw== +globals@^13.19.0: + version "13.19.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.19.0.tgz#7a42de8e6ad4f7242fbcca27ea5b23aca367b5c8" + integrity sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ== dependencies: type-fest "^0.20.2" @@ -1108,10 +1108,10 @@ hmac-drbg@^1.0.1: minimalistic-assert "^1.0.0" minimalistic-crypto-utils "^1.0.1" -husky@8.0.2: - version "8.0.2" - resolved "https://registry.yarnpkg.com/husky/-/husky-8.0.2.tgz#5816a60db02650f1f22c8b69b928fd6bcd77a236" - integrity sha512-Tkv80jtvbnkK3mYWxPZePGFpQ/tT3HNSs/sasF9P2YfkMezDl3ON37YN6jUUI4eTg5LcyVynlb6r4eyvOmspvg== +husky@8.0.3: + version "8.0.3" + resolved "https://registry.yarnpkg.com/husky/-/husky-8.0.3.tgz#4936d7212e46d1dea28fef29bb3a108872cd9184" + integrity sha512-+dQSyqPh4x1hlO1swXBiNb2HzTDN1I2IGLQx1GrBuiqFJfoMrnZWwVmatvSiO+Iz8fBUnf+lekwNo4c2LlXItg== ignore@^5.2.0: version "5.2.0" @@ -1573,10 +1573,10 @@ prettier-linter-helpers@^1.0.0: dependencies: fast-diff "^1.1.2" -prettier@2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.8.0.tgz#c7df58393c9ba77d6fba3921ae01faf994fb9dc9" - integrity sha512-9Lmg8hTFZKG0Asr/kW9Bp8tJjRVluO8EJQVfY2T7FMw9T5jy4I/Uvx0Rca/XWf50QQ1/SS48+6IJWnrb+2yemA== +prettier@2.8.1: + version "2.8.1" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.8.1.tgz#4e1fd11c34e2421bc1da9aea9bd8127cd0a35efc" + integrity sha512-lqGoSJBQNJidqCHE80vqZJHWHRFoNYsSpP9AjFhlhi9ODCJA541svILes/+/1GM3VaL/abZi7cpFzOpdR9UPKg== proxy-from-env@^1.1.0: version "1.1.0" @@ -1817,10 +1817,10 @@ type-fest@^1.2.1: resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-1.4.0.tgz#e9fb813fe3bf1744ec359d55d1affefa76f14be1" integrity sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA== -typescript@4.8.3: - version "4.8.3" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.8.3.tgz#d59344522c4bc464a65a730ac695007fdb66dd88" - integrity sha512-goMHfm00nWPa8UvR/CPSvykqf6dVV8x/dp0c5mFTMTIu0u0FlGWRioyy7Nn0PGAdHxpJZnuO/ut+PpQ8UiHAig== +typescript@4.9.5: + version "4.9.5" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" + integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== unbox-primitive@^1.0.2: version "1.0.2"