New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@sorare/crypto

Package Overview
Dependencies
Maintainers
34
Versions
40
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@sorare/crypto - npm Package Compare versions

Comparing version 2.0.2 to 3.0.0

4

CHANGELOG.md

@@ -0,1 +1,5 @@

# 3.0.0
- Breaking change: Use bigint type for wei amounts
# 2.0.0

@@ -2,0 +6,0 @@

12

dist/index.test.js

@@ -20,3 +20,3 @@ "use strict";

var transfer = {
amount: '2154549703648910716',
amount: 2154549703648910716n,
nonce: 1,

@@ -52,3 +52,3 @@ senderVaultId: '34',

tokenId: '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',
feeLimit: '10'
feeLimit: 10n
}

@@ -78,4 +78,4 @@ });

vaultIdBuy: 27,
amountSell: '2154686749748910716',
amountBuy: '1470242115489520459',
amountSell: 2154686749748910716n,
amountBuy: 1470242115489520459n,
tokenSell: '0x5fa3383597691ea9d827a79e1a4f0f7989c35ced18ca9619de8ab97e661020',

@@ -109,3 +109,3 @@ tokenBuy: '0x774961c824a3b0fb3d2965f01471c9c7734bf8dbde659e0c08dca2ef18d56a',

tokenId: '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',
feeLimit: '10'
feeLimit: 10n
}

@@ -140,2 +140,2 @@ });

});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.test.ts"],"names":["describe","mnemonic","privateKey","it","expect","toEqual","transfer","amount","nonce","senderVaultId","token","receiverVaultId","receiverPublicKey","expirationTimestamp","r","s","publicKey","transferWithFee","feeInfoUser","sourceVaultId","tokenId","feeLimit","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","limitOrderWithFee","feeInfo","message","signature","toBeTruthy"],"mappings":"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","sourcesContent":["import {\n  generateKey,\n  exportPublicKey,\n  signTransfer,\n  signLimitOrder,\n  verifyTransfer,\n  verifyLimitOrder,\n  signMessage,\n  verifyMessage,\n} from '.';\nimport { LimitOrder, Transfer } from './types';\n\ndescribe('generateKey', () => {\n  const mnemonic =\n    'range mountain blast problem vibrant void vivid doctor cluster enough melody ' +\n    'salt layer language laptop boat major space monkey unit glimpse pause change vibrant';\n\n  const privateKey = generateKey(mnemonic);\n\n  it('generates the expected private key', () => {\n    expect(privateKey).toEqual(\n      '0x0646baa9aefb054dfa205c94b43781baa7b2ec2dfbcee64dbd9d2172283de902'\n    );\n  });\n});\n\ndescribe('transfer', () => {\n  const transfer: Transfer = {\n    amount: '2154549703648910716',\n    nonce: 1,\n    senderVaultId: '34',\n    token: '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n    receiverVaultId: '21',\n    receiverPublicKey:\n      '0x5fa3383597691ea9d827a79e1a4f0f7949435ced18ca9619de8ab97e661020',\n    expirationTimestamp: 438953,\n  };\n\n  const privateKey =\n    '0x07cc2767a160d4ea112b436dc6f79024db70b26b11ed7aa2cb6d7eef19ace703';\n\n  describe('without fees', () => {\n    const { r, s } = signTransfer(privateKey, transfer);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x4c21b3df630eab38d75b5538e8f635167f4f7107a885d7adf542a7525240323'\n      );\n      expect(s).toEqual(\n        '0x5eacfaa59ed1b63d75241a1dbd9256d2efbe97f9451f2cf2a2af0bad5b5ab69'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n      expect(verifyTransfer(publicKey, transfer, { r, s })).toEqual(true);\n    });\n  });\n\n  describe('with fees', () => {\n    const transferWithFee: Transfer = {\n      ...transfer,\n      feeInfoUser: {\n        sourceVaultId: '46',\n        tokenId:\n          '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n        feeLimit: '10',\n      },\n    };\n    const { r, s } = signTransfer(privateKey, transferWithFee);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x675deb2b8eaa0f424d630fcb0896e42ccae281f5c7c030af82704954ccfafe3'\n      );\n      expect(s).toEqual(\n        '0x62385cdd1b624ba2ac09b3d0edee4ad745b5402f5363217ad776abb5cec65f8'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n\n      expect(verifyTransfer(publicKey, transferWithFee, { r, s })).toEqual(\n        true\n      );\n    });\n  });\n});\n\ndescribe('limitOrder', () => {\n  const limitOrder = {\n    vaultIdSell: 21,\n    vaultIdBuy: 27,\n    amountSell: '2154686749748910716',\n    amountBuy: '1470242115489520459',\n    tokenSell:\n      '0x5fa3383597691ea9d827a79e1a4f0f7989c35ced18ca9619de8ab97e661020',\n    tokenBuy:\n      '0x774961c824a3b0fb3d2965f01471c9c7734bf8dbde659e0c08dca2ef18d56a',\n    nonce: 0,\n    expirationTimestamp: 438953,\n  };\n\n  const privateKey =\n    '0x03c1e9550e66958296d11b60f8e8e7a7ad990d07fa65d5f7652c4a6c87d4e3cc';\n\n  describe('without fees', () => {\n    const { r, s } = signLimitOrder(privateKey, limitOrder);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x173fd03d8b008ee7432977ac27d1e9d1a1f6c98b1a2f05fa84a21c84c44e882'\n      );\n      expect(s).toEqual(\n        '0x4b6d75385aed025aa222f28a0adc6d58db78ff17e51c3f59e259b131cd5a1cc'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n\n      expect(verifyLimitOrder(publicKey, limitOrder, { r, s })).toEqual(true);\n    });\n  });\n\n  describe('with fee', () => {\n    const limitOrderWithFee: LimitOrder = {\n      ...limitOrder,\n      feeInfo: {\n        sourceVaultId: '46',\n        tokenId:\n          '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n        feeLimit: '10',\n      },\n    };\n\n    const { r, s } = signLimitOrder(privateKey, limitOrderWithFee);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x461df4883210443817a91b7792e8ee02b2354b28f415a51a898447558469667'\n      );\n      expect(s).toEqual(\n        '0x1b6d43fba0e3a70dcda6fb595bb7e907f39987703a781508112679332a0454'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n\n      expect(verifyLimitOrder(publicKey, limitOrderWithFee, { r, s })).toEqual(\n        true\n      );\n    });\n  });\n});\n\ndescribe('signMessage', () => {\n  const message = 'random message';\n  const privateKey =\n    '0x03c1e9550e66958296d11b60f8e8e7a7ad990d07fa65d5f7652c4a6c87d4e3cc';\n  const publicKey = exportPublicKey(privateKey);\n\n  it('generates a signature that can be verified', () => {\n    const signature = signMessage(privateKey, message);\n    expect(verifyMessage(publicKey, message, signature)).toBeTruthy();\n  });\n});\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.test.ts"],"names":["describe","mnemonic","privateKey","it","expect","toEqual","transfer","amount","nonce","senderVaultId","token","receiverVaultId","receiverPublicKey","expirationTimestamp","r","s","publicKey","transferWithFee","feeInfoUser","sourceVaultId","tokenId","feeLimit","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","limitOrderWithFee","feeInfo","message","signature","toBeTruthy"],"mappings":"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","sourcesContent":["import {\n  generateKey,\n  exportPublicKey,\n  signTransfer,\n  signLimitOrder,\n  verifyTransfer,\n  verifyLimitOrder,\n  signMessage,\n  verifyMessage,\n} from '.';\nimport { LimitOrder, Transfer } from './types';\n\ndescribe('generateKey', () => {\n  const mnemonic =\n    'range mountain blast problem vibrant void vivid doctor cluster enough melody ' +\n    'salt layer language laptop boat major space monkey unit glimpse pause change vibrant';\n\n  const privateKey = generateKey(mnemonic);\n\n  it('generates the expected private key', () => {\n    expect(privateKey).toEqual(\n      '0x0646baa9aefb054dfa205c94b43781baa7b2ec2dfbcee64dbd9d2172283de902'\n    );\n  });\n});\n\ndescribe('transfer', () => {\n  const transfer: Transfer = {\n    amount: 2154549703648910716n,\n    nonce: 1,\n    senderVaultId: '34',\n    token: '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n    receiverVaultId: '21',\n    receiverPublicKey:\n      '0x5fa3383597691ea9d827a79e1a4f0f7949435ced18ca9619de8ab97e661020',\n    expirationTimestamp: 438953,\n  };\n\n  const privateKey =\n    '0x07cc2767a160d4ea112b436dc6f79024db70b26b11ed7aa2cb6d7eef19ace703';\n\n  describe('without fees', () => {\n    const { r, s } = signTransfer(privateKey, transfer);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x4c21b3df630eab38d75b5538e8f635167f4f7107a885d7adf542a7525240323'\n      );\n      expect(s).toEqual(\n        '0x5eacfaa59ed1b63d75241a1dbd9256d2efbe97f9451f2cf2a2af0bad5b5ab69'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n      expect(verifyTransfer(publicKey, transfer, { r, s })).toEqual(true);\n    });\n  });\n\n  describe('with fees', () => {\n    const transferWithFee: Transfer = {\n      ...transfer,\n      feeInfoUser: {\n        sourceVaultId: '46',\n        tokenId:\n          '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n        feeLimit: 10n,\n      },\n    };\n    const { r, s } = signTransfer(privateKey, transferWithFee);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x675deb2b8eaa0f424d630fcb0896e42ccae281f5c7c030af82704954ccfafe3'\n      );\n      expect(s).toEqual(\n        '0x62385cdd1b624ba2ac09b3d0edee4ad745b5402f5363217ad776abb5cec65f8'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n\n      expect(verifyTransfer(publicKey, transferWithFee, { r, s })).toEqual(\n        true\n      );\n    });\n  });\n});\n\ndescribe('limitOrder', () => {\n  const limitOrder = {\n    vaultIdSell: 21,\n    vaultIdBuy: 27,\n    amountSell: 2154686749748910716n,\n    amountBuy: 1470242115489520459n,\n    tokenSell:\n      '0x5fa3383597691ea9d827a79e1a4f0f7989c35ced18ca9619de8ab97e661020',\n    tokenBuy:\n      '0x774961c824a3b0fb3d2965f01471c9c7734bf8dbde659e0c08dca2ef18d56a',\n    nonce: 0,\n    expirationTimestamp: 438953,\n  };\n\n  const privateKey =\n    '0x03c1e9550e66958296d11b60f8e8e7a7ad990d07fa65d5f7652c4a6c87d4e3cc';\n\n  describe('without fees', () => {\n    const { r, s } = signLimitOrder(privateKey, limitOrder);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x173fd03d8b008ee7432977ac27d1e9d1a1f6c98b1a2f05fa84a21c84c44e882'\n      );\n      expect(s).toEqual(\n        '0x4b6d75385aed025aa222f28a0adc6d58db78ff17e51c3f59e259b131cd5a1cc'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n\n      expect(verifyLimitOrder(publicKey, limitOrder, { r, s })).toEqual(true);\n    });\n  });\n\n  describe('with fee', () => {\n    const limitOrderWithFee: LimitOrder = {\n      ...limitOrder,\n      feeInfo: {\n        sourceVaultId: '46',\n        tokenId:\n          '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n        feeLimit: 10n,\n      },\n    };\n\n    const { r, s } = signLimitOrder(privateKey, limitOrderWithFee);\n\n    it('creates the correct signature', () => {\n      expect(r).toEqual(\n        '0x461df4883210443817a91b7792e8ee02b2354b28f415a51a898447558469667'\n      );\n      expect(s).toEqual(\n        '0x1b6d43fba0e3a70dcda6fb595bb7e907f39987703a781508112679332a0454'\n      );\n    });\n\n    it('can be verified', () => {\n      const publicKey = exportPublicKey(privateKey);\n\n      expect(verifyLimitOrder(publicKey, limitOrderWithFee, { r, s })).toEqual(\n        true\n      );\n    });\n  });\n});\n\ndescribe('signMessage', () => {\n  const message = 'random message';\n  const privateKey =\n    '0x03c1e9550e66958296d11b60f8e8e7a7ad990d07fa65d5f7652c4a6c87d4e3cc';\n  const publicKey = exportPublicKey(privateKey);\n\n  it('generates a signature that can be verified', () => {\n    const signature = signMessage(privateKey, message);\n    expect(verifyMessage(publicKey, message, signature)).toBeTruthy();\n  });\n});\n"]}

@@ -9,4 +9,4 @@ /**

@param {string|number} vaultBuy - uint31 (as int)
@param {string} amountSell - uint63 (as decimal string)
@param {string} amountBuy - uint63 (as decimal string)
@param {bigint} amountSell - uint63 (as decimal string)
@param {bigint} amountBuy - uint63 (as decimal string)
@param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)

@@ -17,3 +17,3 @@ @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)

*/
export function getLimitOrderMsgHash(vaultSell: string | number, vaultBuy: string | number, amountSell: string, amountBuy: string, tokenSell: string, tokenBuy: string, nonce: number, expirationTimestamp: number): string;
export function getLimitOrderMsgHash(vaultSell: string | number, vaultBuy: string | number, amountSell: bigint, amountBuy: bigint, tokenSell: string, tokenBuy: string, nonce: number, expirationTimestamp: number): string;
/**

@@ -26,4 +26,4 @@ Same as getLimitOrderMsgHash, but also requires the fee info.

@param {string|number} vaultBuy - uint31 (as int)
@param {string} amountSell - uint63 (as decimal string)
@param {string} amountBuy - uint63 (as decimal string)
@param {bigint} amountSell - uint63 (as decimal string)
@param {bigint} amountBuy - uint63 (as decimal string)
@param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)

@@ -34,6 +34,6 @@ @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)

@param {string|number} feeVaultId - uint31 (as int)
@param {string} feeLimit - uint63 (as decimal string)
@param {bigint} feeLimit - uint63 (as decimal string)
@param {string} feeToken - uint256 field element strictly less than the prime (as hex string with 0x)
*/
export function getLimitOrderMsgHashWithFee(vaultSell: string | number, vaultBuy: string | number, amountSell: string, amountBuy: string, tokenSell: string, tokenBuy: string, nonce: number, expirationTimestamp: number, feeToken: string, feeVaultId: string | number, feeLimit: string): string;
export function getLimitOrderMsgHashWithFee(vaultSell: string | number, vaultBuy: string | number, amountSell: bigint, amountBuy: bigint, tokenSell: string, tokenBuy: string, nonce: number, expirationTimestamp: number, feeToken: string, feeVaultId: string | number, feeLimit: bigint): string;
/**

@@ -47,3 +47,3 @@ Serializes the transfer message in the canonical format expected by the verifier.

---------------
@param {string} amount - uint63 (as decimal string)
@param {bigint} amount - uint63 (as decimal string)
@param {number} nonce - uint31 (as int)

@@ -57,3 +57,3 @@ @param {string|number} senderVaultId - uint31 (as int)

*/
export function getTransferMsgHash(amount: string, nonce: number, senderVaultId: string | number, token: string, receiverVaultId: string | number, receiverPublicKey: string, expirationTimestamp: number, condition?: string | null | undefined): string;
export function getTransferMsgHash(amount: bigint, nonce: number, senderVaultId: string | number, token: string, receiverVaultId: string | number, receiverPublicKey: string, expirationTimestamp: number, condition?: string | null | undefined): string;
/**

@@ -64,3 +64,3 @@ Same as getTransferMsgHash, but also requires the fee info.

---------------
@param {string} amount - uint63 (as decimal string)
@param {bigint} amount - uint63 (as decimal string)
@param {number} nonce - uint31 (as int)

@@ -75,4 +75,4 @@ @param {string|number} senderVaultId - uint31 (as int)

@param {number|string} feeVaultId - uint31 (as int)
@param {string} feeLimit - uint63 (as decimal string)
@param {bigint} feeLimit - uint63 (as decimal string)
*/
export function getTransferMsgHashWithFee(amount: string, nonce: number, senderVaultId: string | number, token: string, receiverVaultId: string | number, receiverStarkKey: string, expirationTimestamp: number, condition: string | null | undefined, feeToken: string, feeVaultId: number | string, feeLimit: string): string;
export function getTransferMsgHashWithFee(amount: bigint, nonce: number, senderVaultId: string | number, token: string, receiverVaultId: string | number, receiverStarkKey: string, expirationTimestamp: number, condition: string | null | undefined, feeToken: string, feeVaultId: number | string, feeLimit: bigint): string;

@@ -202,4 +202,4 @@ "use strict";

@param {string|number} vaultBuy - uint31 (as int)
@param {string} amountSell - uint63 (as decimal string)
@param {string} amountBuy - uint63 (as decimal string)
@param {bigint} amountSell - uint63 (as decimal string)
@param {bigint} amountBuy - uint63 (as decimal string)
@param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)

@@ -216,4 +216,2 @@ @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)

var vaultBuyBi = BigInt(vaultBuy);
var amountSellBi = BigInt(amountSell);
var amountBuyBi = BigInt(amountBuy);
var tokenSellBi = BigInt(tokenSell);

@@ -225,4 +223,4 @@ var tokenBuyBi = BigInt(tokenBuy);

assertInRange(vaultBuyBi, BigInt(0), twoPow31);
assertInRange(amountSellBi, BigInt(0), twoPow63);
assertInRange(amountBuyBi, BigInt(0), twoPow63);
assertInRange(amountSell, BigInt(0), twoPow63);
assertInRange(amountBuy, BigInt(0), twoPow63);
assertInRange(tokenSellBi, BigInt(0), prime);

@@ -233,3 +231,3 @@ assertInRange(tokenBuyBi, BigInt(0), prime);

var instructionType = BigInt(0);
return hashMsg(instructionType, vaultSellBi, vaultBuyBi, amountSellBi, amountBuyBi, nonceBi, expirationTimestampBi, tokenSell.substring(2), tokenBuy.substring(2));
return hashMsg(instructionType, vaultSellBi, vaultBuyBi, amountSell, amountBuy, nonceBi, expirationTimestampBi, tokenSell.substring(2), tokenBuy.substring(2));
}

@@ -243,4 +241,4 @@ /**

@param {string|number} vaultBuy - uint31 (as int)
@param {string} amountSell - uint63 (as decimal string)
@param {string} amountBuy - uint63 (as decimal string)
@param {bigint} amountSell - uint63 (as decimal string)
@param {bigint} amountBuy - uint63 (as decimal string)
@param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)

@@ -251,3 +249,3 @@ @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)

@param {string|number} feeVaultId - uint31 (as int)
@param {string} feeLimit - uint63 (as decimal string)
@param {bigint} feeLimit - uint63 (as decimal string)
@param {string} feeToken - uint256 field element strictly less than the prime (as hex string with 0x)

@@ -261,4 +259,2 @@ */

var vaultBuyBi = BigInt(vaultBuy);
var amountSellBi = BigInt(amountSell);
var amountBuyBi = BigInt(amountBuy);
var tokenSellBi = BigInt(tokenSell);

@@ -270,7 +266,6 @@ var tokenBuyBi = BigInt(tokenBuy);

var feeVaultIdBi = BigInt(feeVaultId);
var feeLimitBi = BigInt(feeLimit);
assertInRange(vaultSellBi, BigInt(0), twoPow31);
assertInRange(vaultBuyBi, BigInt(0), twoPow31);
assertInRange(amountSellBi, BigInt(0), twoPow63);
assertInRange(amountBuyBi, BigInt(0), twoPow63);
assertInRange(amountSell, BigInt(0), twoPow63);
assertInRange(amountBuy, BigInt(0), twoPow63);
assertInRange(tokenSellBi, BigInt(0), prime);

@@ -282,5 +277,5 @@ assertInRange(tokenBuyBi, BigInt(0), prime);

assertInRange(feeVaultIdBi, BigInt(0), twoPow31);
assertInRange(feeLimitBi, BigInt(0), twoPow63);
assertInRange(feeLimit, BigInt(0), twoPow63);
var instructionType = BigInt(3);
return hashLimitOrderMsgWithFee(instructionType, vaultSellBi, vaultBuyBi, amountSellBi, amountBuyBi, nonceBi, expirationTimestampBi, tokenSell.substring(2), tokenBuy.substring(2), feeToken.substring(2), feeVaultIdBi, feeLimitBi);
return hashLimitOrderMsgWithFee(instructionType, vaultSellBi, vaultBuyBi, amountSell, amountBuy, nonceBi, expirationTimestampBi, tokenSell.substring(2), tokenBuy.substring(2), feeToken.substring(2), feeVaultIdBi, feeLimit);
}

@@ -295,3 +290,3 @@ /**

---------------
@param {string} amount - uint63 (as decimal string)
@param {bigint} amount - uint63 (as decimal string)
@param {number} nonce - uint31 (as int)

@@ -309,3 +304,2 @@ @param {string|number} senderVaultId - uint31 (as int)

(0, _assert.default)(hasHexPrefix(token) && hasHexPrefix(receiverPublicKey) && (!condition || hasHexPrefix(condition)), 'Hex strings expected to be prefixed with 0x.');
var amountBi = BigInt(amount);
var nonceBi = BigInt(nonce);

@@ -317,3 +311,3 @@ var senderVaultIdBi = BigInt(senderVaultId);

var expirationTimestampBi = BigInt(expirationTimestamp);
assertInRange(amountBi, BigInt(0), twoPow63);
assertInRange(amount, BigInt(0), twoPow63);
assertInRange(nonceBi, BigInt(0), twoPow31);

@@ -332,3 +326,3 @@ assertInRange(senderVaultIdBi, BigInt(0), twoPow31);

return hashMsg(instructionType, senderVaultIdBi, receiverVaultIdBi, amountBi, BigInt(0), nonceBi, expirationTimestampBi, token.substring(2), receiverPublicKey.substring(2), condition);
return hashMsg(instructionType, senderVaultIdBi, receiverVaultIdBi, amount, BigInt(0), nonceBi, expirationTimestampBi, token.substring(2), receiverPublicKey.substring(2), condition);
}

@@ -340,3 +334,3 @@ /**

---------------
@param {string} amount - uint63 (as decimal string)
@param {bigint} amount - uint63 (as decimal string)
@param {number} nonce - uint31 (as int)

@@ -351,3 +345,3 @@ @param {string|number} senderVaultId - uint31 (as int)

@param {number|string} feeVaultId - uint31 (as int)
@param {string} feeLimit - uint63 (as decimal string)
@param {bigint} feeLimit - uint63 (as decimal string)
*/

@@ -358,3 +352,2 @@

(0, _assert.default)(hasHexPrefix(feeToken) && hasHexPrefix(token) && hasHexPrefix(receiverStarkKey) && (!condition || hasHexPrefix(condition)), 'Hex strings expected to be prefixed with 0x.');
var amountBi = BigInt(amount);
var nonceBi = BigInt(nonce);

@@ -368,4 +361,3 @@ var senderVaultIdBi = BigInt(senderVaultId);

var feeVaultIdBi = BigInt(feeVaultId);
var feeLimitBi = BigInt(feeLimit);
assertInRange(amountBi, BigInt(0), twoPow63);
assertInRange(amount, BigInt(0), twoPow63);
assertInRange(nonceBi, BigInt(0), twoPow31);

@@ -379,3 +371,3 @@ assertInRange(senderVaultIdBi, BigInt(0), twoPow31);

assertInRange(feeVaultIdBi, BigInt(0), twoPow31);
assertInRange(feeLimitBi, BigInt(0), twoPow63);
assertInRange(feeLimit, BigInt(0), twoPow63);
var instructionType = BigInt(4);

@@ -388,4 +380,4 @@

return hashTransferMsgWithFee(instructionType, senderVaultIdBi, receiverVaultIdBi, amountBi, nonceBi, expirationTimestampBi, token.substring(2), receiverStarkKey.substring(2), feeToken.substring(2), feeVaultIdBi, feeLimitBi, condition);
return hashTransferMsgWithFee(instructionType, senderVaultIdBi, receiverVaultIdBi, amount, nonceBi, expirationTimestampBi, token.substring(2), receiverStarkKey.substring(2), feeToken.substring(2), feeVaultIdBi, feeLimit, condition);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/signature.js"],"names":["prime","starknet","CURVE","p","maxEcdsaVal","BigInt","twoPow22","twoPow31","twoPow63","hasHexPrefix","str","substring","assertInRange","input","lowerBound","upperBound","inputName","messageSuffix","hashMsg","instructionTypeBi","vault0","vault1","amount0","amount1","nonce","expirationTimestamp","token0","token1OrPubKey","condition","packedMessage","msgHash","pedersen","toString","hashTransferMsgWithFee","instructionType","senderVaultId","receiverVaultId","amount","transferToken","receiverPublicKey","feeToken","feeVaultId","feeLimit","packedMessage1","packedMessage2","tmpHash","hashLimitOrderMsgWithFee","vaultSell","vaultBuy","amountSell","amountBuy","tokenSell","tokenBuy","getLimitOrderMsgHash","vaultSellBi","vaultBuyBi","amountSellBi","amountBuyBi","tokenSellBi","tokenBuyBi","nonceBi","expirationTimestampBi","getLimitOrderMsgHashWithFee","feeTokenBi","feeVaultIdBi","feeLimitBi","getTransferMsgHash","token","amountBi","senderVaultIdBi","tokenBi","receiverVaultIdBi","receiverPublicKeyBi","getTransferMsgHashWithFee","receiverStarkKey","receiverStarkKeyBi"],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable no-bitwise */\n/* //////////////////////////////////////////////////////////////////////////////\n// Copyright 2019 StarkWare Industries Ltd.                                    //\n//                                                                             //\n// Licensed under the Apache License, Version 2.0 (the \"License\").             //\n// You may not use this file except in compliance with the License.            //\n// You may obtain a copy of the License at                                     //\n//                                                                             //\n// https://www.starkware.co/open-source-license/                               //\n//                                                                             //\n// Unless required by applicable law or agreed to in writing,                  //\n// software distributed under the License is distributed on an \"AS IS\" BASIS,  //\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.    //\n// See the License for the specific language governing permissions             //\n// and limitations under the License.                                          //\n////////////////////////////////////////////////////////////////////////////// */\n\nimport * as starknet from 'micro-starknet';\nimport assert from 'assert';\n/**\n * @param {boolean} test\n * @param {string} message\n */\n// const assert = (test, message) => {\n//   if (!test) {\n//     throw new Error(message);\n//   }\n// };\n\n// Equals 2**251 + 17 * 2**192 + 1.\nconst prime = starknet.CURVE.p;\n\n// Equals 2**251. This value limits msgHash and the signature parts.\nconst maxEcdsaVal = BigInt(\n  '0x800000000000000000000000000000000000000000000000000000000000000'\n);\n\nconst twoPow22 = BigInt('0x400000');\nconst twoPow31 = BigInt('0x80000000');\nconst twoPow63 = BigInt('0x8000000000000000');\n\n/**\n * Checks that the string str start with '0x'.\n * @param {string} str\n */\nfunction hasHexPrefix(str) {\n  return str.substring(0, 2) === '0x';\n}\n\n/**\n * Asserts input is equal to or greater then lowerBound and lower then upperBound.\n * Assert message specifies inputName.\n * inputName should be a string.\n * @param {bigint} input\n * @param {bigint} lowerBound\n * @param {bigint} upperBound\n * @param {string} [inputName]\n */\nfunction assertInRange(input, lowerBound, upperBound, inputName = '') {\n  const messageSuffix =\n    inputName === '' ? 'invalid length' : `invalid ${inputName} length`;\n  assert(\n    input >= lowerBound && input < upperBound,\n    `Message not signable, ${messageSuffix}.`\n  );\n}\n\n/**\n * @param {bigint} instructionTypeBi\n * @param {bigint} vault0\n * @param {bigint} vault1\n * @param {bigint} amount0\n * @param {bigint} amount1\n * @param {bigint} nonce\n * @param {bigint} expirationTimestamp\n * @param {string} token0\n * @param {string} token1OrPubKey\n * @param {string | null} [condition]\n * @returns\n */\nfunction hashMsg(\n  instructionTypeBi,\n  vault0,\n  vault1,\n  amount0,\n  amount1,\n  nonce,\n  expirationTimestamp,\n  token0,\n  token1OrPubKey,\n  condition = null\n) {\n  let packedMessage = instructionTypeBi;\n  packedMessage = (packedMessage << BigInt(31)) + vault0;\n  packedMessage = (packedMessage << BigInt(31)) + vault1;\n  packedMessage = (packedMessage << BigInt(63)) + amount0;\n  packedMessage = (packedMessage << BigInt(63)) + amount1;\n  packedMessage = (packedMessage << BigInt(31)) + nonce;\n  packedMessage = (packedMessage << BigInt(22)) + expirationTimestamp;\n  let msgHash = null;\n  if (condition === null) {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(token0, token1OrPubKey),\n      packedMessage.toString(16)\n    );\n  } else {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(starknet.pedersen(token0, token1OrPubKey), condition),\n      packedMessage.toString(16)\n    );\n  }\n\n  assertInRange(BigInt(msgHash), BigInt(0), maxEcdsaVal, 'msgHash');\n  return msgHash;\n}\n\n/**\n *\n * @param {bigint} instructionType\n * @param {bigint} senderVaultId\n * @param {bigint} receiverVaultId\n * @param {bigint} amount\n * @param {bigint} nonce\n * @param {bigint} expirationTimestamp\n * @param {string} transferToken - non hex prefixed\n * @param {string} receiverPublicKey - non hex prefixed\n * @param {string} feeToken - non hex prefixed\n * @param {bigint} feeVaultId\n * @param {bigint} feeLimit\n * @param {string|null} condition\n * @returns\n */\nfunction hashTransferMsgWithFee(\n  instructionType,\n  senderVaultId,\n  receiverVaultId,\n  amount,\n  nonce,\n  expirationTimestamp,\n  transferToken,\n  receiverPublicKey,\n  feeToken,\n  feeVaultId,\n  feeLimit,\n  condition = null\n) {\n  let packedMessage1 = senderVaultId;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + receiverVaultId;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + feeVaultId;\n  packedMessage1 = (packedMessage1 << BigInt(32)) + nonce;\n  let packedMessage2 = instructionType;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + amount;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + feeLimit;\n  packedMessage2 = (packedMessage2 << BigInt(32)) + expirationTimestamp;\n  packedMessage2 = (packedMessage2 << BigInt(81)) + BigInt(0);\n\n  let msgHash = null;\n  const tmpHash = starknet.pedersen(\n    starknet.pedersen(transferToken, feeToken),\n    receiverPublicKey\n  );\n\n  if (condition === null) {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(tmpHash, packedMessage1.toString(16)),\n      packedMessage2.toString(16)\n    );\n  } else {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(\n        starknet.pedersen(tmpHash, condition),\n        packedMessage1.toString(16)\n      ),\n      packedMessage2.toString(16)\n    );\n  }\n\n  assertInRange(BigInt(msgHash), BigInt(0), maxEcdsaVal, 'msgHash');\n  return msgHash;\n}\n\n/**\n *\n * @param {bigint} instructionType\n * @param {bigint} vaultSell\n * @param {bigint} vaultBuy\n * @param {bigint} amountSell\n * @param {bigint} amountBuy\n * @param {bigint} nonce\n * @param {bigint} expirationTimestamp\n * @param {string} tokenSell - hex without prefix\n * @param {string} tokenBuy - hex without prefix\n * @param {string} feeToken - hex without prefix\n * @param {bigint} feeVaultId\n * @param {bigint} feeLimit\n * @returns\n */\nfunction hashLimitOrderMsgWithFee(\n  instructionType,\n  vaultSell,\n  vaultBuy,\n  amountSell,\n  amountBuy,\n  nonce,\n  expirationTimestamp,\n  tokenSell,\n  tokenBuy,\n  feeToken,\n  feeVaultId,\n  feeLimit\n) {\n  let packedMessage1 = amountSell;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + amountBuy;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + feeLimit;\n  packedMessage1 = (packedMessage1 << BigInt(32)) + nonce;\n  let packedMessage2 = instructionType;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + feeVaultId;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + vaultSell;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + vaultBuy;\n  packedMessage2 = (packedMessage2 << BigInt(32)) + expirationTimestamp;\n  packedMessage2 = (packedMessage2 << BigInt(17)) + BigInt(0);\n\n  let msgHash = null;\n  const tmpHash = starknet.pedersen(\n    starknet.pedersen(tokenSell, tokenBuy),\n    feeToken\n  );\n\n  msgHash = starknet.pedersen(\n    starknet.pedersen(tmpHash, packedMessage1.toString(16)),\n    packedMessage2.toString(16)\n  );\n\n  assertInRange(BigInt(msgHash), BigInt(0), maxEcdsaVal, 'msgHash');\n  return msgHash;\n}\n\n/**\n Serializes the order message in the canonical format expected by the verifier.\n party_a sells amountSell coins of tokenSell from vaultSell.\n party_a buys amountBuy coins of tokenBuy into vaultBuy.\n Expected types:\n ---------------\n @param {string|number} vaultSell - uint31 (as int)\n @param {string|number} vaultBuy - uint31 (as int)\n @param {string} amountSell - uint63 (as decimal string)\n @param {string} amountBuy - uint63 (as decimal string)\n @param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} nonce - uint31 (as int)\n @param {number} expirationTimestamp - uint22 (as int).\n*/\nexport function getLimitOrderMsgHash(\n  vaultSell,\n  vaultBuy,\n  amountSell,\n  amountBuy,\n  tokenSell,\n  tokenBuy,\n  nonce,\n  expirationTimestamp\n) {\n  assert(\n    hasHexPrefix(tokenSell) && hasHexPrefix(tokenBuy),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const vaultSellBi = BigInt(vaultSell);\n  const vaultBuyBi = BigInt(vaultBuy);\n  const amountSellBi = BigInt(amountSell);\n  const amountBuyBi = BigInt(amountBuy);\n  const tokenSellBi = BigInt(tokenSell);\n  const tokenBuyBi = BigInt(tokenBuy);\n  const nonceBi = BigInt(nonce);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n\n  assertInRange(vaultSellBi, BigInt(0), twoPow31);\n  assertInRange(vaultBuyBi, BigInt(0), twoPow31);\n  assertInRange(amountSellBi, BigInt(0), twoPow63);\n  assertInRange(amountBuyBi, BigInt(0), twoPow63);\n  assertInRange(tokenSellBi, BigInt(0), prime);\n  assertInRange(tokenBuyBi, BigInt(0), prime);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n\n  const instructionType = BigInt(0);\n  return hashMsg(\n    instructionType,\n    vaultSellBi,\n    vaultBuyBi,\n    amountSellBi,\n    amountBuyBi,\n    nonceBi,\n    expirationTimestampBi,\n    tokenSell.substring(2),\n    tokenBuy.substring(2)\n  );\n}\n\n/**\n Same as getLimitOrderMsgHash, but also requires the fee info.\n\n Expected types of fee info params:\n ---------------\n @param {string|number} vaultSell - uint31 (as int)\n @param {string|number} vaultBuy - uint31 (as int)\n @param {string} amountSell - uint63 (as decimal string)\n @param {string} amountBuy - uint63 (as decimal string)\n @param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} nonce - uint31 (as int)\n @param {number} expirationTimestamp - uint22 (as int).\n @param {string|number} feeVaultId - uint31 (as int)\n @param {string} feeLimit - uint63 (as decimal string)\n @param {string} feeToken - uint256 field element strictly less than the prime (as hex string with 0x)\n*/\nexport function getLimitOrderMsgHashWithFee(\n  vaultSell,\n  vaultBuy,\n  amountSell,\n  amountBuy,\n  tokenSell,\n  tokenBuy,\n  nonce,\n  expirationTimestamp,\n  feeToken,\n  feeVaultId,\n  feeLimit\n) {\n  assert(\n    hasHexPrefix(tokenSell) && hasHexPrefix(tokenBuy),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const vaultSellBi = BigInt(vaultSell);\n  const vaultBuyBi = BigInt(vaultBuy);\n  const amountSellBi = BigInt(amountSell);\n  const amountBuyBi = BigInt(amountBuy);\n  const tokenSellBi = BigInt(tokenSell);\n  const tokenBuyBi = BigInt(tokenBuy);\n  const nonceBi = BigInt(nonce);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n  const feeTokenBi = BigInt(feeToken);\n  const feeVaultIdBi = BigInt(feeVaultId);\n  const feeLimitBi = BigInt(feeLimit);\n\n  assertInRange(vaultSellBi, BigInt(0), twoPow31);\n  assertInRange(vaultBuyBi, BigInt(0), twoPow31);\n  assertInRange(amountSellBi, BigInt(0), twoPow63);\n  assertInRange(amountBuyBi, BigInt(0), twoPow63);\n  assertInRange(tokenSellBi, BigInt(0), prime);\n  assertInRange(tokenBuyBi, BigInt(0), prime);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n  assertInRange(feeTokenBi, BigInt(0), prime);\n  assertInRange(feeVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(feeLimitBi, BigInt(0), twoPow63);\n\n  const instructionType = BigInt(3);\n  return hashLimitOrderMsgWithFee(\n    instructionType,\n    vaultSellBi,\n    vaultBuyBi,\n    amountSellBi,\n    amountBuyBi,\n    nonceBi,\n    expirationTimestampBi,\n    tokenSell.substring(2),\n    tokenBuy.substring(2),\n    feeToken.substring(2),\n    feeVaultIdBi,\n    feeLimitBi\n  );\n}\n\n/**\n Serializes the transfer message in the canonical format expected by the verifier.\n The sender transfer 'amount' coins of 'token' from vault with id senderVaultId to vault with id\n receiverVaultId. The receiver's public key is receiverPublicKey.\n If a condition is added, it is verified before executing the transfer. The format of the condition\n is defined by the application.\n Expected types:\n ---------------\n @param {string} amount - uint63 (as decimal string)\n @param {number} nonce - uint31 (as int)\n @param {string|number} senderVaultId - uint31 (as int)\n @param {string} token - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string|number} receiverVaultId - uint31 (as int)\n @param {string} receiverPublicKey - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} expirationTimestamp - uint22 (as int).\n @param {string|null} [condition] - uint256 field element strictly less than the prime (as hex string with 0x)\n*/\nexport function getTransferMsgHash(\n  amount,\n  nonce,\n  senderVaultId,\n  token,\n  receiverVaultId,\n  receiverPublicKey,\n  expirationTimestamp,\n  condition\n) {\n  assert(\n    hasHexPrefix(token) &&\n      hasHexPrefix(receiverPublicKey) &&\n      (!condition || hasHexPrefix(condition)),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const amountBi = BigInt(amount);\n  const nonceBi = BigInt(nonce);\n  const senderVaultIdBi = BigInt(senderVaultId);\n  const tokenBi = BigInt(token);\n  const receiverVaultIdBi = BigInt(receiverVaultId);\n  const receiverPublicKeyBi = BigInt(receiverPublicKey);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n\n  assertInRange(amountBi, BigInt(0), twoPow63);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(senderVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(tokenBi, BigInt(0), prime);\n  assertInRange(receiverVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(receiverPublicKeyBi, BigInt(0), prime);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n  let instructionType = BigInt(1);\n  if (condition) {\n    assertInRange(BigInt(condition), BigInt(0), prime, 'condition');\n    instructionType = BigInt(2);\n  }\n  return hashMsg(\n    instructionType,\n    senderVaultIdBi,\n    receiverVaultIdBi,\n    amountBi,\n    BigInt(0),\n    nonceBi,\n    expirationTimestampBi,\n    token.substring(2),\n    receiverPublicKey.substring(2),\n    condition\n  );\n}\n\n/**\n Same as getTransferMsgHash, but also requires the fee info.\n\n Expected types of fee info params:\n ---------------\n @param {string} amount - uint63 (as decimal string)\n @param {number} nonce - uint31 (as int)\n @param {string|number} senderVaultId - uint31 (as int)\n @param {string} token - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string|number} receiverVaultId - uint31 (as int)\n @param {string} receiverStarkKey - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} expirationTimestamp - uint22 (as int).\n @param {string|null|undefined} condition - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string} feeToken - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number|string} feeVaultId - uint31 (as int)\n @param {string} feeLimit - uint63 (as decimal string)\n*/\nexport function getTransferMsgHashWithFee(\n  amount,\n  nonce,\n  senderVaultId,\n  token,\n  receiverVaultId,\n  receiverStarkKey,\n  expirationTimestamp,\n  condition,\n  feeToken,\n  feeVaultId,\n  feeLimit\n) {\n  assert(\n    hasHexPrefix(feeToken) &&\n      hasHexPrefix(token) &&\n      hasHexPrefix(receiverStarkKey) &&\n      (!condition || hasHexPrefix(condition)),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const amountBi = BigInt(amount);\n  const nonceBi = BigInt(nonce);\n  const senderVaultIdBi = BigInt(senderVaultId);\n  const tokenBi = BigInt(token);\n  const receiverVaultIdBi = BigInt(receiverVaultId);\n  const receiverStarkKeyBi = BigInt(receiverStarkKey);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n  const feeTokenBi = BigInt(feeToken);\n  const feeVaultIdBi = BigInt(feeVaultId);\n  const feeLimitBi = BigInt(feeLimit);\n\n  assertInRange(amountBi, BigInt(0), twoPow63);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(senderVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(tokenBi, BigInt(0), prime);\n  assertInRange(receiverVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(receiverStarkKeyBi, BigInt(0), prime);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n  assertInRange(feeTokenBi, BigInt(0), prime);\n  assertInRange(feeVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(feeLimitBi, BigInt(0), twoPow63);\n\n  let instructionType = BigInt(4);\n  if (condition) {\n    assertInRange(BigInt(condition), BigInt(0), prime, 'condition');\n    instructionType = BigInt(5);\n  }\n  return hashTransferMsgWithFee(\n    instructionType,\n    senderVaultIdBi,\n    receiverVaultIdBi,\n    amountBi,\n    nonceBi,\n    expirationTimestampBi,\n    token.substring(2),\n    receiverStarkKey.substring(2),\n    feeToken.substring(2),\n    feeVaultIdBi,\n    feeLimitBi,\n    condition\n  );\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/signature.js"],"names":["prime","starknet","CURVE","p","maxEcdsaVal","BigInt","twoPow22","twoPow31","twoPow63","hasHexPrefix","str","substring","assertInRange","input","lowerBound","upperBound","inputName","messageSuffix","hashMsg","instructionTypeBi","vault0","vault1","amount0","amount1","nonce","expirationTimestamp","token0","token1OrPubKey","condition","packedMessage","msgHash","pedersen","toString","hashTransferMsgWithFee","instructionType","senderVaultId","receiverVaultId","amount","transferToken","receiverPublicKey","feeToken","feeVaultId","feeLimit","packedMessage1","packedMessage2","tmpHash","hashLimitOrderMsgWithFee","vaultSell","vaultBuy","amountSell","amountBuy","tokenSell","tokenBuy","getLimitOrderMsgHash","vaultSellBi","vaultBuyBi","tokenSellBi","tokenBuyBi","nonceBi","expirationTimestampBi","getLimitOrderMsgHashWithFee","feeTokenBi","feeVaultIdBi","getTransferMsgHash","token","senderVaultIdBi","tokenBi","receiverVaultIdBi","receiverPublicKeyBi","getTransferMsgHashWithFee","receiverStarkKey","receiverStarkKeyBi"],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable no-bitwise */\n/* //////////////////////////////////////////////////////////////////////////////\n// Copyright 2019 StarkWare Industries Ltd.                                    //\n//                                                                             //\n// Licensed under the Apache License, Version 2.0 (the \"License\").             //\n// You may not use this file except in compliance with the License.            //\n// You may obtain a copy of the License at                                     //\n//                                                                             //\n// https://www.starkware.co/open-source-license/                               //\n//                                                                             //\n// Unless required by applicable law or agreed to in writing,                  //\n// software distributed under the License is distributed on an \"AS IS\" BASIS,  //\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.    //\n// See the License for the specific language governing permissions             //\n// and limitations under the License.                                          //\n////////////////////////////////////////////////////////////////////////////// */\n\nimport * as starknet from 'micro-starknet';\nimport assert from 'assert';\n/**\n * @param {boolean} test\n * @param {string} message\n */\n// const assert = (test, message) => {\n//   if (!test) {\n//     throw new Error(message);\n//   }\n// };\n\n// Equals 2**251 + 17 * 2**192 + 1.\nconst prime = starknet.CURVE.p;\n\n// Equals 2**251. This value limits msgHash and the signature parts.\nconst maxEcdsaVal = BigInt(\n  '0x800000000000000000000000000000000000000000000000000000000000000'\n);\n\nconst twoPow22 = BigInt('0x400000');\nconst twoPow31 = BigInt('0x80000000');\nconst twoPow63 = BigInt('0x8000000000000000');\n\n/**\n * Checks that the string str start with '0x'.\n * @param {string} str\n */\nfunction hasHexPrefix(str) {\n  return str.substring(0, 2) === '0x';\n}\n\n/**\n * Asserts input is equal to or greater then lowerBound and lower then upperBound.\n * Assert message specifies inputName.\n * inputName should be a string.\n * @param {bigint} input\n * @param {bigint} lowerBound\n * @param {bigint} upperBound\n * @param {string} [inputName]\n */\nfunction assertInRange(input, lowerBound, upperBound, inputName = '') {\n  const messageSuffix =\n    inputName === '' ? 'invalid length' : `invalid ${inputName} length`;\n  assert(\n    input >= lowerBound && input < upperBound,\n    `Message not signable, ${messageSuffix}.`\n  );\n}\n\n/**\n * @param {bigint} instructionTypeBi\n * @param {bigint} vault0\n * @param {bigint} vault1\n * @param {bigint} amount0\n * @param {bigint} amount1\n * @param {bigint} nonce\n * @param {bigint} expirationTimestamp\n * @param {string} token0\n * @param {string} token1OrPubKey\n * @param {string | null} [condition]\n * @returns\n */\nfunction hashMsg(\n  instructionTypeBi,\n  vault0,\n  vault1,\n  amount0,\n  amount1,\n  nonce,\n  expirationTimestamp,\n  token0,\n  token1OrPubKey,\n  condition = null\n) {\n  let packedMessage = instructionTypeBi;\n  packedMessage = (packedMessage << BigInt(31)) + vault0;\n  packedMessage = (packedMessage << BigInt(31)) + vault1;\n  packedMessage = (packedMessage << BigInt(63)) + amount0;\n  packedMessage = (packedMessage << BigInt(63)) + amount1;\n  packedMessage = (packedMessage << BigInt(31)) + nonce;\n  packedMessage = (packedMessage << BigInt(22)) + expirationTimestamp;\n  let msgHash = null;\n  if (condition === null) {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(token0, token1OrPubKey),\n      packedMessage.toString(16)\n    );\n  } else {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(starknet.pedersen(token0, token1OrPubKey), condition),\n      packedMessage.toString(16)\n    );\n  }\n\n  assertInRange(BigInt(msgHash), BigInt(0), maxEcdsaVal, 'msgHash');\n  return msgHash;\n}\n\n/**\n *\n * @param {bigint} instructionType\n * @param {bigint} senderVaultId\n * @param {bigint} receiverVaultId\n * @param {bigint} amount\n * @param {bigint} nonce\n * @param {bigint} expirationTimestamp\n * @param {string} transferToken - non hex prefixed\n * @param {string} receiverPublicKey - non hex prefixed\n * @param {string} feeToken - non hex prefixed\n * @param {bigint} feeVaultId\n * @param {bigint} feeLimit\n * @param {string|null} condition\n * @returns\n */\nfunction hashTransferMsgWithFee(\n  instructionType,\n  senderVaultId,\n  receiverVaultId,\n  amount,\n  nonce,\n  expirationTimestamp,\n  transferToken,\n  receiverPublicKey,\n  feeToken,\n  feeVaultId,\n  feeLimit,\n  condition = null\n) {\n  let packedMessage1 = senderVaultId;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + receiverVaultId;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + feeVaultId;\n  packedMessage1 = (packedMessage1 << BigInt(32)) + nonce;\n  let packedMessage2 = instructionType;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + amount;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + feeLimit;\n  packedMessage2 = (packedMessage2 << BigInt(32)) + expirationTimestamp;\n  packedMessage2 = (packedMessage2 << BigInt(81)) + BigInt(0);\n\n  let msgHash = null;\n  const tmpHash = starknet.pedersen(\n    starknet.pedersen(transferToken, feeToken),\n    receiverPublicKey\n  );\n\n  if (condition === null) {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(tmpHash, packedMessage1.toString(16)),\n      packedMessage2.toString(16)\n    );\n  } else {\n    msgHash = starknet.pedersen(\n      starknet.pedersen(\n        starknet.pedersen(tmpHash, condition),\n        packedMessage1.toString(16)\n      ),\n      packedMessage2.toString(16)\n    );\n  }\n\n  assertInRange(BigInt(msgHash), BigInt(0), maxEcdsaVal, 'msgHash');\n  return msgHash;\n}\n\n/**\n *\n * @param {bigint} instructionType\n * @param {bigint} vaultSell\n * @param {bigint} vaultBuy\n * @param {bigint} amountSell\n * @param {bigint} amountBuy\n * @param {bigint} nonce\n * @param {bigint} expirationTimestamp\n * @param {string} tokenSell - hex without prefix\n * @param {string} tokenBuy - hex without prefix\n * @param {string} feeToken - hex without prefix\n * @param {bigint} feeVaultId\n * @param {bigint} feeLimit\n * @returns\n */\nfunction hashLimitOrderMsgWithFee(\n  instructionType,\n  vaultSell,\n  vaultBuy,\n  amountSell,\n  amountBuy,\n  nonce,\n  expirationTimestamp,\n  tokenSell,\n  tokenBuy,\n  feeToken,\n  feeVaultId,\n  feeLimit\n) {\n  let packedMessage1 = amountSell;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + amountBuy;\n  packedMessage1 = (packedMessage1 << BigInt(64)) + feeLimit;\n  packedMessage1 = (packedMessage1 << BigInt(32)) + nonce;\n  let packedMessage2 = instructionType;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + feeVaultId;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + vaultSell;\n  packedMessage2 = (packedMessage2 << BigInt(64)) + vaultBuy;\n  packedMessage2 = (packedMessage2 << BigInt(32)) + expirationTimestamp;\n  packedMessage2 = (packedMessage2 << BigInt(17)) + BigInt(0);\n\n  let msgHash = null;\n  const tmpHash = starknet.pedersen(\n    starknet.pedersen(tokenSell, tokenBuy),\n    feeToken\n  );\n\n  msgHash = starknet.pedersen(\n    starknet.pedersen(tmpHash, packedMessage1.toString(16)),\n    packedMessage2.toString(16)\n  );\n\n  assertInRange(BigInt(msgHash), BigInt(0), maxEcdsaVal, 'msgHash');\n  return msgHash;\n}\n\n/**\n Serializes the order message in the canonical format expected by the verifier.\n party_a sells amountSell coins of tokenSell from vaultSell.\n party_a buys amountBuy coins of tokenBuy into vaultBuy.\n Expected types:\n ---------------\n @param {string|number} vaultSell - uint31 (as int)\n @param {string|number} vaultBuy - uint31 (as int)\n @param {bigint} amountSell - uint63 (as decimal string)\n @param {bigint} amountBuy - uint63 (as decimal string)\n @param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} nonce - uint31 (as int)\n @param {number} expirationTimestamp - uint22 (as int).\n*/\nexport function getLimitOrderMsgHash(\n  vaultSell,\n  vaultBuy,\n  amountSell,\n  amountBuy,\n  tokenSell,\n  tokenBuy,\n  nonce,\n  expirationTimestamp\n) {\n  assert(\n    hasHexPrefix(tokenSell) && hasHexPrefix(tokenBuy),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const vaultSellBi = BigInt(vaultSell);\n  const vaultBuyBi = BigInt(vaultBuy);\n  const tokenSellBi = BigInt(tokenSell);\n  const tokenBuyBi = BigInt(tokenBuy);\n  const nonceBi = BigInt(nonce);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n\n  assertInRange(vaultSellBi, BigInt(0), twoPow31);\n  assertInRange(vaultBuyBi, BigInt(0), twoPow31);\n  assertInRange(amountSell, BigInt(0), twoPow63);\n  assertInRange(amountBuy, BigInt(0), twoPow63);\n  assertInRange(tokenSellBi, BigInt(0), prime);\n  assertInRange(tokenBuyBi, BigInt(0), prime);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n\n  const instructionType = BigInt(0);\n  return hashMsg(\n    instructionType,\n    vaultSellBi,\n    vaultBuyBi,\n    amountSell,\n    amountBuy,\n    nonceBi,\n    expirationTimestampBi,\n    tokenSell.substring(2),\n    tokenBuy.substring(2)\n  );\n}\n\n/**\n Same as getLimitOrderMsgHash, but also requires the fee info.\n\n Expected types of fee info params:\n ---------------\n @param {string|number} vaultSell - uint31 (as int)\n @param {string|number} vaultBuy - uint31 (as int)\n @param {bigint} amountSell - uint63 (as decimal string)\n @param {bigint} amountBuy - uint63 (as decimal string)\n @param {string} tokenSell - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string} tokenBuy - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} nonce - uint31 (as int)\n @param {number} expirationTimestamp - uint22 (as int).\n @param {string|number} feeVaultId - uint31 (as int)\n @param {bigint} feeLimit - uint63 (as decimal string)\n @param {string} feeToken - uint256 field element strictly less than the prime (as hex string with 0x)\n*/\nexport function getLimitOrderMsgHashWithFee(\n  vaultSell,\n  vaultBuy,\n  amountSell,\n  amountBuy,\n  tokenSell,\n  tokenBuy,\n  nonce,\n  expirationTimestamp,\n  feeToken,\n  feeVaultId,\n  feeLimit\n) {\n  assert(\n    hasHexPrefix(tokenSell) && hasHexPrefix(tokenBuy),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const vaultSellBi = BigInt(vaultSell);\n  const vaultBuyBi = BigInt(vaultBuy);\n  const tokenSellBi = BigInt(tokenSell);\n  const tokenBuyBi = BigInt(tokenBuy);\n  const nonceBi = BigInt(nonce);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n  const feeTokenBi = BigInt(feeToken);\n  const feeVaultIdBi = BigInt(feeVaultId);\n\n  assertInRange(vaultSellBi, BigInt(0), twoPow31);\n  assertInRange(vaultBuyBi, BigInt(0), twoPow31);\n  assertInRange(amountSell, BigInt(0), twoPow63);\n  assertInRange(amountBuy, BigInt(0), twoPow63);\n  assertInRange(tokenSellBi, BigInt(0), prime);\n  assertInRange(tokenBuyBi, BigInt(0), prime);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n  assertInRange(feeTokenBi, BigInt(0), prime);\n  assertInRange(feeVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(feeLimit, BigInt(0), twoPow63);\n\n  const instructionType = BigInt(3);\n  return hashLimitOrderMsgWithFee(\n    instructionType,\n    vaultSellBi,\n    vaultBuyBi,\n    amountSell,\n    amountBuy,\n    nonceBi,\n    expirationTimestampBi,\n    tokenSell.substring(2),\n    tokenBuy.substring(2),\n    feeToken.substring(2),\n    feeVaultIdBi,\n    feeLimit\n  );\n}\n\n/**\n Serializes the transfer message in the canonical format expected by the verifier.\n The sender transfer 'amount' coins of 'token' from vault with id senderVaultId to vault with id\n receiverVaultId. The receiver's public key is receiverPublicKey.\n If a condition is added, it is verified before executing the transfer. The format of the condition\n is defined by the application.\n Expected types:\n ---------------\n @param {bigint} amount - uint63 (as decimal string)\n @param {number} nonce - uint31 (as int)\n @param {string|number} senderVaultId - uint31 (as int)\n @param {string} token - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string|number} receiverVaultId - uint31 (as int)\n @param {string} receiverPublicKey - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} expirationTimestamp - uint22 (as int).\n @param {string|null} [condition] - uint256 field element strictly less than the prime (as hex string with 0x)\n*/\nexport function getTransferMsgHash(\n  amount,\n  nonce,\n  senderVaultId,\n  token,\n  receiverVaultId,\n  receiverPublicKey,\n  expirationTimestamp,\n  condition\n) {\n  assert(\n    hasHexPrefix(token) &&\n      hasHexPrefix(receiverPublicKey) &&\n      (!condition || hasHexPrefix(condition)),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const nonceBi = BigInt(nonce);\n  const senderVaultIdBi = BigInt(senderVaultId);\n  const tokenBi = BigInt(token);\n  const receiverVaultIdBi = BigInt(receiverVaultId);\n  const receiverPublicKeyBi = BigInt(receiverPublicKey);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n\n  assertInRange(amount, BigInt(0), twoPow63);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(senderVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(tokenBi, BigInt(0), prime);\n  assertInRange(receiverVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(receiverPublicKeyBi, BigInt(0), prime);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n  let instructionType = BigInt(1);\n  if (condition) {\n    assertInRange(BigInt(condition), BigInt(0), prime, 'condition');\n    instructionType = BigInt(2);\n  }\n  return hashMsg(\n    instructionType,\n    senderVaultIdBi,\n    receiverVaultIdBi,\n    amount,\n    BigInt(0),\n    nonceBi,\n    expirationTimestampBi,\n    token.substring(2),\n    receiverPublicKey.substring(2),\n    condition\n  );\n}\n\n/**\n Same as getTransferMsgHash, but also requires the fee info.\n\n Expected types of fee info params:\n ---------------\n @param {bigint} amount - uint63 (as decimal string)\n @param {number} nonce - uint31 (as int)\n @param {string|number} senderVaultId - uint31 (as int)\n @param {string} token - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string|number} receiverVaultId - uint31 (as int)\n @param {string} receiverStarkKey - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number} expirationTimestamp - uint22 (as int).\n @param {string|null|undefined} condition - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {string} feeToken - uint256 field element strictly less than the prime (as hex string with 0x)\n @param {number|string} feeVaultId - uint31 (as int)\n @param {bigint} feeLimit - uint63 (as decimal string)\n*/\nexport function getTransferMsgHashWithFee(\n  amount,\n  nonce,\n  senderVaultId,\n  token,\n  receiverVaultId,\n  receiverStarkKey,\n  expirationTimestamp,\n  condition,\n  feeToken,\n  feeVaultId,\n  feeLimit\n) {\n  assert(\n    hasHexPrefix(feeToken) &&\n      hasHexPrefix(token) &&\n      hasHexPrefix(receiverStarkKey) &&\n      (!condition || hasHexPrefix(condition)),\n    'Hex strings expected to be prefixed with 0x.'\n  );\n  const nonceBi = BigInt(nonce);\n  const senderVaultIdBi = BigInt(senderVaultId);\n  const tokenBi = BigInt(token);\n  const receiverVaultIdBi = BigInt(receiverVaultId);\n  const receiverStarkKeyBi = BigInt(receiverStarkKey);\n  const expirationTimestampBi = BigInt(expirationTimestamp);\n  const feeTokenBi = BigInt(feeToken);\n  const feeVaultIdBi = BigInt(feeVaultId);\n\n  assertInRange(amount, BigInt(0), twoPow63);\n  assertInRange(nonceBi, BigInt(0), twoPow31);\n  assertInRange(senderVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(tokenBi, BigInt(0), prime);\n  assertInRange(receiverVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(receiverStarkKeyBi, BigInt(0), prime);\n  assertInRange(expirationTimestampBi, BigInt(0), twoPow22);\n  assertInRange(feeTokenBi, BigInt(0), prime);\n  assertInRange(feeVaultIdBi, BigInt(0), twoPow31);\n  assertInRange(feeLimit, BigInt(0), twoPow63);\n\n  let instructionType = BigInt(4);\n  if (condition) {\n    assertInRange(BigInt(condition), BigInt(0), prime, 'condition');\n    instructionType = BigInt(5);\n  }\n  return hashTransferMsgWithFee(\n    instructionType,\n    senderVaultIdBi,\n    receiverVaultIdBi,\n    amount,\n    nonceBi,\n    expirationTimestampBi,\n    token.substring(2),\n    receiverStarkKey.substring(2),\n    feeToken.substring(2),\n    feeVaultIdBi,\n    feeLimit,\n    condition\n  );\n}\n"]}
export interface Fee {
tokenId: string;
sourceVaultId: number | string;
feeLimit: string;
feeLimit: bigint;
}

@@ -9,3 +9,3 @@ export interface Transfer {

receiverVaultId: number | string;
amount: string;
amount: bigint;
token: string;

@@ -21,4 +21,4 @@ receiverPublicKey: string;

vaultIdBuy: number | string;
amountSell: string;
amountBuy: string;
amountSell: bigint;
amountBuy: bigint;
tokenSell: string;

@@ -25,0 +25,0 @@ tokenBuy: string;

@@ -6,3 +6,3 @@ {

"license": "MIT",
"version": "2.0.2",
"version": "3.0.0",
"main": "lib.js",

@@ -9,0 +9,0 @@ "dependencies": {

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc