@sorare/crypto
Advanced tools
Comparing version 0.0.5 to 0.1.0
@@ -65,3 +65,14 @@ "use strict"; | ||
var hashTransfer = function hashTransfer(transfer) { | ||
return (0, _signature.getTransferMsgHash)(transfer.amount, transfer.nonce, transfer.senderVaultId, transfer.token, transfer.receiverVaultId, transfer.receiverPublicKey, transfer.expirationTimestamp, transfer.condition); | ||
var amount = transfer.amount, | ||
nonce = transfer.nonce, | ||
senderVaultId = transfer.senderVaultId, | ||
token = transfer.token, | ||
receiverVaultId = transfer.receiverVaultId, | ||
receiverPublicKey = transfer.receiverPublicKey, | ||
expirationTimestamp = transfer.expirationTimestamp, | ||
condition = transfer.condition, | ||
fee = transfer.fee; | ||
var args = [amount, nonce, senderVaultId, token, receiverVaultId, receiverPublicKey, expirationTimestamp, condition]; | ||
if (fee) return _signature.getTransferMsgHashWithFee.apply(void 0, args.concat([fee.token, fee.vaultId, fee.limit])); | ||
return _signature.getTransferMsgHash.apply(void 0, args); | ||
}; | ||
@@ -72,3 +83,14 @@ | ||
var hashLimitOrder = function hashLimitOrder(limitOrder) { | ||
return (0, _signature.getLimitOrderMsgHash)(limitOrder.vaultIdSell, limitOrder.vaultIdBuy, limitOrder.amountSell, limitOrder.amountBuy, limitOrder.tokenSell, limitOrder.tokenBuy, limitOrder.nonce, limitOrder.expirationTimestamp); | ||
var vaultIdSell = limitOrder.vaultIdSell, | ||
vaultIdBuy = limitOrder.vaultIdBuy, | ||
amountSell = limitOrder.amountSell, | ||
amountBuy = limitOrder.amountBuy, | ||
tokenSell = limitOrder.tokenSell, | ||
tokenBuy = limitOrder.tokenBuy, | ||
nonce = limitOrder.nonce, | ||
expirationTimestamp = limitOrder.expirationTimestamp, | ||
fee = limitOrder.fee; | ||
var args = [vaultIdSell, vaultIdBuy, amountSell, amountBuy, tokenSell, tokenBuy, nonce, expirationTimestamp]; | ||
if (fee) return _signature.getLimitOrderMsgHashWithFee.apply(void 0, args.concat([fee.token, fee.vaultId, fee.limit])); | ||
return _signature.getLimitOrderMsgHash.apply(void 0, args); | ||
}; | ||
@@ -131,2 +153,2 @@ | ||
exports.verifyLimitOrder = verifyLimitOrder; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/index.ts"],"names":["PATH","generateKey","mnemonic","seed","ethereumAddress","hdkey","fromMasterSeed","derivePath","getWallet","getAddressString","path","exportPrivateKey","key","getPrivate","padStart","exportPublicKey","getPublic","exportPublicKeyX","getX","toString","loadPrivateKey","privateKey","starkEc","keyFromPrivate","substring","loadPublicKey","publicKey","keyFromPublic","hashTransfer","transfer","amount","nonce","senderVaultId","token","receiverVaultId","receiverPublicKey","expirationTimestamp","condition","hashLimitOrder","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","sign","message","r","s","verify","signature","sig","BN","signTransfer","verifyTransfer","signLimitOrder","verifyLimitOrder"],"mappings":"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","sourcesContent":["import BN from 'bn.js';\nimport { generateMnemonic, mnemonicToSeedSync } from 'bip39';\nimport { ec } from 'elliptic';\nimport { hdkey } from 'ethereumjs-wallet';\n\nimport { LimitOrder, Transfer, Signature } from './types';\nimport { getAccountPath, getKeyPairFromPath } from './keyDerivation';\nimport {\n  starkEc,\n  sign as starkSign,\n  verify as starkVerify,\n  getTransferMsgHash,\n  getLimitOrderMsgHash\n} from './signature';\n\nexport const PATH = \"m/44'/60'/0'/0/0\";\n\nexport const generateKey = (mnemonic?: string) => {\n  const seed = mnemonicToSeedSync(mnemonic || generateMnemonic());\n  const ethereumAddress = hdkey\n    .fromMasterSeed(seed)\n    .derivePath(PATH)\n    .getWallet()\n    .getAddressString();\n\n  const path = getAccountPath('starkex', 'sorare', ethereumAddress, 0);\n  return getKeyPairFromPath(mnemonic, path);\n};\n\nexport const exportPrivateKey = (key: ec.KeyPair) =>\n  `0x${key.getPrivate('hex').padStart(64, '0')}`;\n\nexport const exportPublicKey = (key: ec.KeyPair) =>\n  `0x${key.getPublic(true, 'hex')}`;\n\nexport const exportPublicKeyX = (key: ec.KeyPair) =>\n  `0x${key\n    .getPublic()\n    .getX()\n    .toString('hex')\n    .padStart(64, '0')}`;\n\nexport const loadPrivateKey = (privateKey: string) =>\n  starkEc.keyFromPrivate(privateKey.substring(2), 'hex');\n\nexport const loadPublicKey = (publicKey: string) =>\n  starkEc.keyFromPublic(publicKey.substring(2), 'hex');\n\nexport const hashTransfer = (transfer: Transfer) =>\n  getTransferMsgHash(\n    transfer.amount,\n    transfer.nonce,\n    transfer.senderVaultId,\n    transfer.token,\n    transfer.receiverVaultId,\n    transfer.receiverPublicKey,\n    transfer.expirationTimestamp,\n    transfer.condition\n  );\n\nexport const hashLimitOrder = (limitOrder: LimitOrder) =>\n  getLimitOrderMsgHash(\n    limitOrder.vaultIdSell,\n    limitOrder.vaultIdBuy,\n    limitOrder.amountSell,\n    limitOrder.amountBuy,\n    limitOrder.tokenSell,\n    limitOrder.tokenBuy,\n    limitOrder.nonce,\n    limitOrder.expirationTimestamp\n  );\n\nexport const sign = (privateKey: string, message: string) => {\n  const key = loadPrivateKey(privateKey);\n  const { r, s } = starkSign(key, message);\n\n  return {\n    r: `0x${r.toString(16)}`,\n    s: `0x${s.toString(16)}`\n  };\n};\n\nexport const verify = (\n  publicKey: string,\n  message: string,\n  signature: Signature\n) => {\n  const key = loadPublicKey(publicKey);\n  const sig = {\n    r: new BN(signature.r.substring(2), 16),\n    s: new BN(signature.s.substring(2), 16)\n  };\n\n  return starkVerify(key, message, sig);\n};\n\nexport const signTransfer = (privateKey: string, transfer: Transfer) => {\n  const message = hashTransfer(transfer);\n\n  return sign(privateKey, message);\n};\n\nexport const verifyTransfer = (\n  publicKey: string,\n  transfer: Transfer,\n  signature: Signature\n) => {\n  const message = hashTransfer(transfer);\n\n  return verify(publicKey, message, signature);\n};\n\nexport const signLimitOrder = (privateKey: string, limitOrder: LimitOrder) => {\n  const message = hashLimitOrder(limitOrder);\n\n  return sign(privateKey, message);\n};\n\nexport const verifyLimitOrder = (\n  publicKey: string,\n  limitOrder: LimitOrder,\n  signature: Signature\n) => {\n  const message = hashLimitOrder(limitOrder);\n\n  return verify(publicKey, message, signature);\n};\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/index.ts"],"names":["PATH","generateKey","mnemonic","seed","ethereumAddress","hdkey","fromMasterSeed","derivePath","getWallet","getAddressString","path","exportPrivateKey","key","getPrivate","padStart","exportPublicKey","getPublic","exportPublicKeyX","getX","toString","loadPrivateKey","privateKey","starkEc","keyFromPrivate","substring","loadPublicKey","publicKey","keyFromPublic","hashTransfer","transfer","amount","nonce","senderVaultId","token","receiverVaultId","receiverPublicKey","expirationTimestamp","condition","fee","args","getTransferMsgHashWithFee","vaultId","limit","getTransferMsgHash","hashLimitOrder","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","getLimitOrderMsgHashWithFee","getLimitOrderMsgHash","sign","message","r","s","verify","signature","sig","BN","signTransfer","verifyTransfer","signLimitOrder","verifyLimitOrder"],"mappings":"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","sourcesContent":["import BN from 'bn.js';\nimport { generateMnemonic, mnemonicToSeedSync } from 'bip39';\nimport { ec } from 'elliptic';\nimport { hdkey } from 'ethereumjs-wallet';\n\nimport { LimitOrder, Transfer, Signature } from './types';\nimport { getAccountPath, getKeyPairFromPath } from './keyDerivation';\nimport {\n  starkEc,\n  sign as starkSign,\n  verify as starkVerify,\n  getTransferMsgHash,\n  getTransferMsgHashWithFee,\n  getLimitOrderMsgHash,\n  getLimitOrderMsgHashWithFee,\n} from './signature';\n\nexport const PATH = \"m/44'/60'/0'/0/0\";\n\nexport const generateKey = (mnemonic?: string) => {\n  const seed = mnemonicToSeedSync(mnemonic || generateMnemonic());\n  const ethereumAddress = hdkey\n    .fromMasterSeed(seed)\n    .derivePath(PATH)\n    .getWallet()\n    .getAddressString();\n\n  const path = getAccountPath('starkex', 'sorare', ethereumAddress, 0);\n  return getKeyPairFromPath(mnemonic, path);\n};\n\nexport const exportPrivateKey = (key: ec.KeyPair) =>\n  `0x${key.getPrivate('hex').padStart(64, '0')}`;\n\nexport const exportPublicKey = (key: ec.KeyPair) =>\n  `0x${key.getPublic(true, 'hex')}`;\n\nexport const exportPublicKeyX = (key: ec.KeyPair) =>\n  `0x${key\n    .getPublic()\n    .getX()\n    .toString('hex')\n    .padStart(64, '0')}`;\n\nexport const loadPrivateKey = (privateKey: string) =>\n  starkEc.keyFromPrivate(privateKey.substring(2), 'hex');\n\nexport const loadPublicKey = (publicKey: string) =>\n  starkEc.keyFromPublic(publicKey.substring(2), 'hex');\n\nexport const hashTransfer = (transfer: Transfer) => {\n  const {\n    amount,\n    nonce,\n    senderVaultId,\n    token,\n    receiverVaultId,\n    receiverPublicKey,\n    expirationTimestamp,\n    condition,\n    fee,\n  } = transfer;\n\n  const args = [\n    amount,\n    nonce,\n    senderVaultId,\n    token,\n    receiverVaultId,\n    receiverPublicKey,\n    expirationTimestamp,\n    condition,\n  ];\n\n  if (fee)\n    return getTransferMsgHashWithFee(\n      ...args,\n      fee.token,\n      fee.vaultId,\n      fee.limit\n    );\n\n  return getTransferMsgHash(...args);\n};\n\nexport const hashLimitOrder = (limitOrder: LimitOrder) => {\n  const {\n    vaultIdSell,\n    vaultIdBuy,\n    amountSell,\n    amountBuy,\n    tokenSell,\n    tokenBuy,\n    nonce,\n    expirationTimestamp,\n    fee,\n  } = limitOrder;\n\n  const args = [\n    vaultIdSell,\n    vaultIdBuy,\n    amountSell,\n    amountBuy,\n    tokenSell,\n    tokenBuy,\n    nonce,\n    expirationTimestamp,\n  ];\n\n  if (fee)\n    return getLimitOrderMsgHashWithFee(\n      ...args,\n      fee.token,\n      fee.vaultId,\n      fee.limit\n    );\n\n  return getLimitOrderMsgHash(...args);\n};\n\nexport const sign = (privateKey: string, message: string) => {\n  const key = loadPrivateKey(privateKey);\n  const { r, s } = starkSign(key, message);\n\n  return {\n    r: `0x${r.toString(16)}`,\n    s: `0x${s.toString(16)}`,\n  };\n};\n\nexport const verify = (\n  publicKey: string,\n  message: string,\n  signature: Signature\n) => {\n  const key = loadPublicKey(publicKey);\n  const sig = {\n    r: new BN(signature.r.substring(2), 16),\n    s: new BN(signature.s.substring(2), 16),\n  };\n\n  return starkVerify(key, message, sig);\n};\n\nexport const signTransfer = (privateKey: string, transfer: Transfer) => {\n  const message = hashTransfer(transfer);\n\n  return sign(privateKey, message);\n};\n\nexport const verifyTransfer = (\n  publicKey: string,\n  transfer: Transfer,\n  signature: Signature\n) => {\n  const message = hashTransfer(transfer);\n\n  return verify(publicKey, message, signature);\n};\n\nexport const signLimitOrder = (privateKey: string, limitOrder: LimitOrder) => {\n  const message = hashLimitOrder(limitOrder);\n\n  return sign(privateKey, message);\n};\n\nexport const verifyLimitOrder = (\n  publicKey: string,\n  limitOrder: LimitOrder,\n  signature: Signature\n) => {\n  const message = hashLimitOrder(limitOrder);\n\n  return verify(publicKey, message, signature);\n};\n"]} |
@@ -7,2 +7,8 @@ "use strict"; | ||
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; } | ||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } | ||
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | ||
describe('generateKey', function () { | ||
@@ -26,18 +32,45 @@ var mnemonic = 'range mountain blast problem vibrant void vivid doctor cluster enough melody ' + 'salt layer language laptop boat major space monkey unit glimpse pause change vibrant'; | ||
var privateKey = '0x07cc2767a160d4ea112b436dc6f79024db70b26b11ed7aa2cb6d7eef19ace703'; | ||
describe('without fees', function () { | ||
var _signTransfer = (0, _.signTransfer)(privateKey, transfer), | ||
r = _signTransfer.r, | ||
s = _signTransfer.s; | ||
var _signTransfer = (0, _.signTransfer)(privateKey, transfer), | ||
r = _signTransfer.r, | ||
s = _signTransfer.s; | ||
it('creates the correct signature', function () { | ||
expect(r).toEqual('0x4c21b3df630eab38d75b5538e8f635167f4f7107a885d7adf542a7525240323'); | ||
expect(s).toEqual('0x5eacfaa59ed1b63d75241a1dbd9256d2efbe97f9451f2cf2a2af0bad5b5ab69'); | ||
}); | ||
it('can be verified', function () { | ||
var publicKey = _signature.starkEc.keyFromPrivate(privateKey.substring(2), 'hex').getPublic(true, 'hex'); | ||
it('creates the correct signature', function () { | ||
expect(r).toEqual('0x4c21b3df630eab38d75b5538e8f635167f4f7107a885d7adf542a7525240323'); | ||
expect(s).toEqual('0x5eacfaa59ed1b63d75241a1dbd9256d2efbe97f9451f2cf2a2af0bad5b5ab69'); | ||
expect((0, _.verifyTransfer)("0x".concat(publicKey), transfer, { | ||
r: r, | ||
s: s | ||
})).toEqual(true); | ||
}); | ||
}); | ||
it('can be verified', function () { | ||
var publicKey = _signature.starkEc.keyFromPrivate(privateKey.substring(2), 'hex').getPublic(true, 'hex'); | ||
describe('with fees', function () { | ||
var transferWithFee = _objectSpread(_objectSpread({}, transfer), {}, { | ||
fee: { | ||
vaultId: '46', | ||
token: '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4', | ||
limit: '10' | ||
} | ||
}); | ||
expect((0, _.verifyTransfer)("0x".concat(publicKey), transfer, { | ||
r: r, | ||
s: s | ||
})).toEqual(true); | ||
var _signTransfer2 = (0, _.signTransfer)(privateKey, transferWithFee), | ||
r = _signTransfer2.r, | ||
s = _signTransfer2.s; | ||
it('creates the correct signature', function () { | ||
expect(r).toEqual('0x675deb2b8eaa0f424d630fcb0896e42ccae281f5c7c030af82704954ccfafe3'); | ||
expect(s).toEqual('0x62385cdd1b624ba2ac09b3d0edee4ad745b5402f5363217ad776abb5cec65f8'); | ||
}); | ||
it('can be verified', function () { | ||
var publicKey = _signature.starkEc.keyFromPrivate(privateKey.substring(2), 'hex').getPublic(true, 'hex'); | ||
expect((0, _.verifyTransfer)("0x".concat(publicKey), transferWithFee, { | ||
r: r, | ||
s: s | ||
})).toEqual(true); | ||
}); | ||
}); | ||
@@ -57,20 +90,47 @@ }); | ||
var privateKey = '0x03c1e9550e66958296d11b60f8e8e7a7ad990d07fa65d5f7652c4a6c87d4e3cc'; | ||
describe('without fees', function () { | ||
var _signLimitOrder = (0, _.signLimitOrder)(privateKey, limitOrder), | ||
r = _signLimitOrder.r, | ||
s = _signLimitOrder.s; | ||
var _signLimitOrder = (0, _.signLimitOrder)(privateKey, limitOrder), | ||
r = _signLimitOrder.r, | ||
s = _signLimitOrder.s; | ||
it('creates the correct signature', function () { | ||
expect(r).toEqual('0x173fd03d8b008ee7432977ac27d1e9d1a1f6c98b1a2f05fa84a21c84c44e882'); | ||
expect(s).toEqual('0x4b6d75385aed025aa222f28a0adc6d58db78ff17e51c3f59e259b131cd5a1cc'); | ||
}); | ||
it('can be verified', function () { | ||
var publicKey = _signature.starkEc.keyFromPrivate(privateKey.substring(2), 'hex').getPublic(true, 'hex'); | ||
it('creates the correct signature', function () { | ||
expect(r).toEqual('0x173fd03d8b008ee7432977ac27d1e9d1a1f6c98b1a2f05fa84a21c84c44e882'); | ||
expect(s).toEqual('0x4b6d75385aed025aa222f28a0adc6d58db78ff17e51c3f59e259b131cd5a1cc'); | ||
expect((0, _.verifyLimitOrder)("0x".concat(publicKey), limitOrder, { | ||
r: r, | ||
s: s | ||
})).toEqual(true); | ||
}); | ||
}); | ||
it('can be verified', function () { | ||
var publicKey = _signature.starkEc.keyFromPrivate(privateKey.substring(2), 'hex').getPublic(true, 'hex'); | ||
describe('with fee', function () { | ||
var limitOrderWithFee = _objectSpread(_objectSpread({}, limitOrder), {}, { | ||
fee: { | ||
vaultId: '46', | ||
token: '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4', | ||
limit: '10' | ||
} | ||
}); | ||
expect((0, _.verifyLimitOrder)("0x".concat(publicKey), limitOrder, { | ||
r: r, | ||
s: s | ||
})).toEqual(true); | ||
var _signLimitOrder2 = (0, _.signLimitOrder)(privateKey, limitOrderWithFee), | ||
r = _signLimitOrder2.r, | ||
s = _signLimitOrder2.s; | ||
it('creates the correct signature', function () { | ||
expect(r).toEqual('0x461df4883210443817a91b7792e8ee02b2354b28f415a51a898447558469667'); | ||
expect(s).toEqual('0x1b6d43fba0e3a70dcda6fb595bb7e907f39987703a781508112679332a0454'); | ||
}); | ||
it('can be verified', function () { | ||
var publicKey = _signature.starkEc.keyFromPrivate(privateKey.substring(2), 'hex').getPublic(true, 'hex'); | ||
expect((0, _.verifyLimitOrder)("0x".concat(publicKey), limitOrderWithFee, { | ||
r: r, | ||
s: s | ||
})).toEqual(true); | ||
}); | ||
}); | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdGFya3dhcmUvaW5kZXgudGVzdC50cyJdLCJuYW1lcyI6WyJkZXNjcmliZSIsIm1uZW1vbmljIiwia2V5UGFpciIsIml0IiwiZXhwZWN0IiwiZ2V0UHJpdmF0ZSIsInRvRXF1YWwiLCJ0cmFuc2ZlciIsImFtb3VudCIsIm5vbmNlIiwic2VuZGVyVmF1bHRJZCIsInRva2VuIiwicmVjZWl2ZXJWYXVsdElkIiwicmVjZWl2ZXJQdWJsaWNLZXkiLCJleHBpcmF0aW9uVGltZXN0YW1wIiwicHJpdmF0ZUtleSIsInIiLCJzIiwicHVibGljS2V5Iiwic3RhcmtFYyIsImtleUZyb21Qcml2YXRlIiwic3Vic3RyaW5nIiwiZ2V0UHVibGljIiwibGltaXRPcmRlciIsInZhdWx0SWRTZWxsIiwidmF1bHRJZEJ1eSIsImFtb3VudFNlbGwiLCJhbW91bnRCdXkiLCJ0b2tlblNlbGwiLCJ0b2tlbkJ1eSJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7QUFFQTs7QUFRQUEsUUFBUSxDQUFDLGFBQUQsRUFBZ0IsWUFBTTtBQUM1QixNQUFNQyxRQUFRLEdBQ1osa0ZBQ0Esc0ZBRkY7QUFJQSxNQUFNQyxPQUFPLEdBQUcsbUJBQVlELFFBQVosQ0FBaEI7QUFFQUUsRUFBQUEsRUFBRSxDQUFDLG9DQUFELEVBQXVDLFlBQU07QUFDN0NDLElBQUFBLE1BQU0sQ0FBQ0YsT0FBTyxDQUFDRyxVQUFSLENBQW1CLEtBQW5CLENBQUQsQ0FBTixDQUFrQ0MsT0FBbEMsQ0FDRSxrRUFERjtBQUdELEdBSkMsQ0FBRjtBQUtELENBWk8sQ0FBUjtBQWNBTixRQUFRLENBQUMsVUFBRCxFQUFhLFlBQU07QUFDekIsTUFBTU8sUUFBUSxHQUFHO0FBQ2ZDLElBQUFBLE1BQU0sRUFBRSxxQkFETztBQUVmQyxJQUFBQSxLQUFLLEVBQUUsQ0FGUTtBQUdmQyxJQUFBQSxhQUFhLEVBQUUsSUFIQTtBQUlmQyxJQUFBQSxLQUFLLEVBQUUsbUVBSlE7QUFLZkMsSUFBQUEsZUFBZSxFQUFFLElBTEY7QUFNZkMsSUFBQUEsaUJBQWlCLEVBQ2Ysa0VBUGE7QUFRZkMsSUFBQUEsbUJBQW1CLEVBQUU7QUFSTixHQUFqQjtBQVdBLE1BQU1DLFVBQVUsR0FDZCxvRUFERjs7QUFFQSxzQkFBaUIsb0JBQWFBLFVBQWIsRUFBeUJSLFFBQXpCLENBQWpCO0FBQUEsTUFBUVMsQ0FBUixpQkFBUUEsQ0FBUjtBQUFBLE1BQVdDLENBQVgsaUJBQVdBLENBQVg7O0FBRUFkLEVBQUFBLEVBQUUsQ0FBQywrQkFBRCxFQUFrQyxZQUFNO0FBQ3hDQyxJQUFBQSxNQUFNLENBQUNZLENBQUQsQ0FBTixDQUFVVixPQUFWLENBQ0UsbUVBREY7QUFHQUYsSUFBQUEsTUFBTSxDQUFDYSxDQUFELENBQU4sQ0FBVVgsT0FBVixDQUNFLG1FQURGO0FBR0QsR0FQQyxDQUFGO0FBU0FILEVBQUFBLEVBQUUsQ0FBQyxpQkFBRCxFQUFvQixZQUFNO0FBQzFCLFFBQU1lLFNBQVMsR0FBR0MsbUJBQ2ZDLGNBRGUsQ0FDQUwsVUFBVSxDQUFDTSxTQUFYLENBQXFCLENBQXJCLENBREEsRUFDeUIsS0FEekIsRUFFZkMsU0FGZSxDQUVMLElBRkssRUFFQyxLQUZELENBQWxCOztBQUlBbEIsSUFBQUEsTUFBTSxDQUFDLGtDQUFvQmMsU0FBcEIsR0FBaUNYLFFBQWpDLEVBQTJDO0FBQUVTLE1BQUFBLENBQUMsRUFBREEsQ0FBRjtBQUFLQyxNQUFBQSxDQUFDLEVBQURBO0FBQUwsS0FBM0MsQ0FBRCxDQUFOLENBQTZEWCxPQUE3RCxDQUFxRSxJQUFyRTtBQUNELEdBTkMsQ0FBRjtBQU9ELENBaENPLENBQVI7QUFrQ0FOLFFBQVEsQ0FBQyxZQUFELEVBQWUsWUFBTTtBQUMzQixNQUFNdUIsVUFBVSxHQUFHO0FBQ2pCQyxJQUFBQSxXQUFXLEVBQUUsRUFESTtBQUVqQkMsSUFBQUEsVUFBVSxFQUFFLEVBRks7QUFHakJDLElBQUFBLFVBQVUsRUFBRSxxQkFISztBQUlqQkMsSUFBQUEsU0FBUyxFQUFFLHFCQUpNO0FBS2pCQyxJQUFBQSxTQUFTLEVBQ1Asa0VBTmU7QUFPakJDLElBQUFBLFFBQVEsRUFDTixrRUFSZTtBQVNqQnBCLElBQUFBLEtBQUssRUFBRSxDQVRVO0FBVWpCSyxJQUFBQSxtQkFBbUIsRUFBRTtBQVZKLEdBQW5CO0FBYUEsTUFBTUMsVUFBVSxHQUNkLG9FQURGOztBQUVBLHdCQUFpQixzQkFBZUEsVUFBZixFQUEyQlEsVUFBM0IsQ0FBakI7QUFBQSxNQUFRUCxDQUFSLG1CQUFRQSxDQUFSO0FBQUEsTUFBV0MsQ0FBWCxtQkFBV0EsQ0FBWDs7QUFFQWQsRUFBQUEsRUFBRSxDQUFDLCtCQUFELEVBQWtDLFlBQU07QUFDeENDLElBQUFBLE1BQU0sQ0FBQ1ksQ0FBRCxDQUFOLENBQVVWLE9BQVYsQ0FDRSxtRUFERjtBQUdBRixJQUFBQSxNQUFNLENBQUNhLENBQUQsQ0FBTixDQUFVWCxPQUFWLENBQ0UsbUVBREY7QUFHRCxHQVBDLENBQUY7QUFTQUgsRUFBQUEsRUFBRSxDQUFDLGlCQUFELEVBQW9CLFlBQU07QUFDMUIsUUFBTWUsU0FBUyxHQUFHQyxtQkFDZkMsY0FEZSxDQUNBTCxVQUFVLENBQUNNLFNBQVgsQ0FBcUIsQ0FBckIsQ0FEQSxFQUN5QixLQUR6QixFQUVmQyxTQUZlLENBRUwsSUFGSyxFQUVDLEtBRkQsQ0FBbEI7O0FBSUFsQixJQUFBQSxNQUFNLENBQUMsb0NBQXNCYyxTQUF0QixHQUFtQ0ssVUFBbkMsRUFBK0M7QUFBRVAsTUFBQUEsQ0FBQyxFQUFEQSxDQUFGO0FBQUtDLE1BQUFBLENBQUMsRUFBREE7QUFBTCxLQUEvQyxDQUFELENBQU4sQ0FBaUVYLE9BQWpFLENBQ0UsSUFERjtBQUdELEdBUkMsQ0FBRjtBQVNELENBcENPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzdGFya0VjIH0gZnJvbSAnLi9zaWduYXR1cmUnO1xuXG5pbXBvcnQge1xuICBnZW5lcmF0ZUtleSxcbiAgc2lnblRyYW5zZmVyLFxuICBzaWduTGltaXRPcmRlcixcbiAgdmVyaWZ5VHJhbnNmZXIsXG4gIHZlcmlmeUxpbWl0T3JkZXJcbn0gZnJvbSAnLic7XG5cbmRlc2NyaWJlKCdnZW5lcmF0ZUtleScsICgpID0+IHtcbiAgY29uc3QgbW5lbW9uaWMgPVxuICAgICdyYW5nZSBtb3VudGFpbiBibGFzdCBwcm9ibGVtIHZpYnJhbnQgdm9pZCB2aXZpZCBkb2N0b3IgY2x1c3RlciBlbm91Z2ggbWVsb2R5ICcgK1xuICAgICdzYWx0IGxheWVyIGxhbmd1YWdlIGxhcHRvcCBib2F0IG1ham9yIHNwYWNlIG1vbmtleSB1bml0IGdsaW1wc2UgcGF1c2UgY2hhbmdlIHZpYnJhbnQnO1xuXG4gIGNvbnN0IGtleVBhaXIgPSBnZW5lcmF0ZUtleShtbmVtb25pYyk7XG5cbiAgaXQoJ2dlbmVyYXRlcyB0aGUgZXhwZWN0ZWQgcHJpdmF0ZSBrZXknLCAoKSA9PiB7XG4gICAgZXhwZWN0KGtleVBhaXIuZ2V0UHJpdmF0ZSgnaGV4JykpLnRvRXF1YWwoXG4gICAgICAnMDY0NmJhYTlhZWZiMDU0ZGZhMjA1Yzk0YjQzNzgxYmFhN2IyZWMyZGZiY2VlNjRkYmQ5ZDIxNzIyODNkZTkwMidcbiAgICApO1xuICB9KTtcbn0pO1xuXG5kZXNjcmliZSgndHJhbnNmZXInLCAoKSA9PiB7XG4gIGNvbnN0IHRyYW5zZmVyID0ge1xuICAgIGFtb3VudDogJzIxNTQ1NDk3MDM2NDg5MTA3MTYnLFxuICAgIG5vbmNlOiAxLFxuICAgIHNlbmRlclZhdWx0SWQ6ICczNCcsXG4gICAgdG9rZW46ICcweDMwMDNhNjU2NTFkM2I5ZmIyZWZmOTM0YTQ0MTZkYjMwMWFmZDExMmE4NDkyYWFmOGQ3Mjk3ZmM4N2RjZDlmNCcsXG4gICAgcmVjZWl2ZXJWYXVsdElkOiAnMjEnLFxuICAgIHJlY2VpdmVyUHVibGljS2V5OlxuICAgICAgJzB4NWZhMzM4MzU5NzY5MWVhOWQ4MjdhNzllMWE0ZjBmNzk0OTQzNWNlZDE4Y2E5NjE5ZGU4YWI5N2U2NjEwMjAnLFxuICAgIGV4cGlyYXRpb25UaW1lc3RhbXA6IDQzODk1M1xuICB9O1xuXG4gIGNvbnN0IHByaXZhdGVLZXkgPVxuICAgICcweDA3Y2MyNzY3YTE2MGQ0ZWExMTJiNDM2ZGM2Zjc5MDI0ZGI3MGIyNmIxMWVkN2FhMmNiNmQ3ZWVmMTlhY2U3MDMnO1xuICBjb25zdCB7IHIsIHMgfSA9IHNpZ25UcmFuc2Zlcihwcml2YXRlS2V5LCB0cmFuc2Zlcik7XG5cbiAgaXQoJ2NyZWF0ZXMgdGhlIGNvcnJlY3Qgc2lnbmF0dXJlJywgKCkgPT4ge1xuICAgIGV4cGVjdChyKS50b0VxdWFsKFxuICAgICAgJzB4NGMyMWIzZGY2MzBlYWIzOGQ3NWI1NTM4ZThmNjM1MTY3ZjRmNzEwN2E4ODVkN2FkZjU0MmE3NTI1MjQwMzIzJ1xuICAgICk7XG4gICAgZXhwZWN0KHMpLnRvRXF1YWwoXG4gICAgICAnMHg1ZWFjZmFhNTllZDFiNjNkNzUyNDFhMWRiZDkyNTZkMmVmYmU5N2Y5NDUxZjJjZjJhMmFmMGJhZDViNWFiNjknXG4gICAgKTtcbiAgfSk7XG5cbiAgaXQoJ2NhbiBiZSB2ZXJpZmllZCcsICgpID0+IHtcbiAgICBjb25zdCBwdWJsaWNLZXkgPSBzdGFya0VjXG4gICAgICAua2V5RnJvbVByaXZhdGUocHJpdmF0ZUtleS5zdWJzdHJpbmcoMiksICdoZXgnKVxuICAgICAgLmdldFB1YmxpYyh0cnVlLCAnaGV4Jyk7XG5cbiAgICBleHBlY3QodmVyaWZ5VHJhbnNmZXIoYDB4JHtwdWJsaWNLZXl9YCwgdHJhbnNmZXIsIHsgciwgcyB9KSkudG9FcXVhbCh0cnVlKTtcbiAgfSk7XG59KTtcblxuZGVzY3JpYmUoJ2xpbWl0T3JkZXInLCAoKSA9PiB7XG4gIGNvbnN0IGxpbWl0T3JkZXIgPSB7XG4gICAgdmF1bHRJZFNlbGw6IDIxLFxuICAgIHZhdWx0SWRCdXk6IDI3LFxuICAgIGFtb3VudFNlbGw6ICcyMTU0Njg2NzQ5NzQ4OTEwNzE2JyxcbiAgICBhbW91bnRCdXk6ICcxNDcwMjQyMTE1NDg5NTIwNDU5JyxcbiAgICB0b2tlblNlbGw6XG4gICAgICAnMHg1ZmEzMzgzNTk3NjkxZWE5ZDgyN2E3OWUxYTRmMGY3OTg5YzM1Y2VkMThjYTk2MTlkZThhYjk3ZTY2MTAyMCcsXG4gICAgdG9rZW5CdXk6XG4gICAgICAnMHg3NzQ5NjFjODI0YTNiMGZiM2QyOTY1ZjAxNDcxYzljNzczNGJmOGRiZGU2NTllMGMwOGRjYTJlZjE4ZDU2YScsXG4gICAgbm9uY2U6IDAsXG4gICAgZXhwaXJhdGlvblRpbWVzdGFtcDogNDM4OTUzXG4gIH07XG5cbiAgY29uc3QgcHJpdmF0ZUtleSA9XG4gICAgJzB4MDNjMWU5NTUwZTY2OTU4Mjk2ZDExYjYwZjhlOGU3YTdhZDk5MGQwN2ZhNjVkNWY3NjUyYzRhNmM4N2Q0ZTNjYyc7XG4gIGNvbnN0IHsgciwgcyB9ID0gc2lnbkxpbWl0T3JkZXIocHJpdmF0ZUtleSwgbGltaXRPcmRlcik7XG5cbiAgaXQoJ2NyZWF0ZXMgdGhlIGNvcnJlY3Qgc2lnbmF0dXJlJywgKCkgPT4ge1xuICAgIGV4cGVjdChyKS50b0VxdWFsKFxuICAgICAgJzB4MTczZmQwM2Q4YjAwOGVlNzQzMjk3N2FjMjdkMWU5ZDFhMWY2Yzk4YjFhMmYwNWZhODRhMjFjODRjNDRlODgyJ1xuICAgICk7XG4gICAgZXhwZWN0KHMpLnRvRXF1YWwoXG4gICAgICAnMHg0YjZkNzUzODVhZWQwMjVhYTIyMmYyOGEwYWRjNmQ1OGRiNzhmZjE3ZTUxYzNmNTllMjU5YjEzMWNkNWExY2MnXG4gICAgKTtcbiAgfSk7XG5cbiAgaXQoJ2NhbiBiZSB2ZXJpZmllZCcsICgpID0+IHtcbiAgICBjb25zdCBwdWJsaWNLZXkgPSBzdGFya0VjXG4gICAgICAua2V5RnJvbVByaXZhdGUocHJpdmF0ZUtleS5zdWJzdHJpbmcoMiksICdoZXgnKVxuICAgICAgLmdldFB1YmxpYyh0cnVlLCAnaGV4Jyk7XG5cbiAgICBleHBlY3QodmVyaWZ5TGltaXRPcmRlcihgMHgke3B1YmxpY0tleX1gLCBsaW1pdE9yZGVyLCB7IHIsIHMgfSkpLnRvRXF1YWwoXG4gICAgICB0cnVlXG4gICAgKTtcbiAgfSk7XG59KTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/index.test.ts"],"names":["describe","mnemonic","keyPair","it","expect","getPrivate","toEqual","transfer","amount","nonce","senderVaultId","token","receiverVaultId","receiverPublicKey","expirationTimestamp","privateKey","r","s","publicKey","starkEc","keyFromPrivate","substring","getPublic","transferWithFee","fee","vaultId","limit","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","limitOrderWithFee"],"mappings":";;AAAA;;AAEA;;;;;;;;AASAA,QAAQ,CAAC,aAAD,EAAgB,YAAM;AAC5B,MAAMC,QAAQ,GACZ,kFACA,sFAFF;AAIA,MAAMC,OAAO,GAAG,mBAAYD,QAAZ,CAAhB;AAEAE,EAAAA,EAAE,CAAC,oCAAD,EAAuC,YAAM;AAC7CC,IAAAA,MAAM,CAACF,OAAO,CAACG,UAAR,CAAmB,KAAnB,CAAD,CAAN,CAAkCC,OAAlC,CACE,kEADF;AAGD,GAJC,CAAF;AAKD,CAZO,CAAR;AAcAN,QAAQ,CAAC,UAAD,EAAa,YAAM;AACzB,MAAMO,QAAkB,GAAG;AACzBC,IAAAA,MAAM,EAAE,qBADiB;AAEzBC,IAAAA,KAAK,EAAE,CAFkB;AAGzBC,IAAAA,aAAa,EAAE,IAHU;AAIzBC,IAAAA,KAAK,EAAE,mEAJkB;AAKzBC,IAAAA,eAAe,EAAE,IALQ;AAMzBC,IAAAA,iBAAiB,EACf,kEAPuB;AAQzBC,IAAAA,mBAAmB,EAAE;AARI,GAA3B;AAWA,MAAMC,UAAU,GACd,oEADF;AAGAf,EAAAA,QAAQ,CAAC,cAAD,EAAiB,YAAM;AAC7B,wBAAiB,oBAAae,UAAb,EAAyBR,QAAzB,CAAjB;AAAA,QAAQS,CAAR,iBAAQA,CAAR;AAAA,QAAWC,CAAX,iBAAWA,CAAX;;AAEAd,IAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAM;AACxCC,MAAAA,MAAM,CAACY,CAAD,CAAN,CAAUV,OAAV,CACE,mEADF;AAGAF,MAAAA,MAAM,CAACa,CAAD,CAAN,CAAUX,OAAV,CACE,mEADF;AAGD,KAPC,CAAF;AASAH,IAAAA,EAAE,CAAC,iBAAD,EAAoB,YAAM;AAC1B,UAAMe,SAAS,GAAGC,mBACfC,cADe,CACAL,UAAU,CAACM,SAAX,CAAqB,CAArB,CADA,EACyB,KADzB,EAEfC,SAFe,CAEL,IAFK,EAEC,KAFD,CAAlB;;AAIAlB,MAAAA,MAAM,CAAC,kCAAoBc,SAApB,GAAiCX,QAAjC,EAA2C;AAAES,QAAAA,CAAC,EAADA,CAAF;AAAKC,QAAAA,CAAC,EAADA;AAAL,OAA3C,CAAD,CAAN,CAA6DX,OAA7D,CACE,IADF;AAGD,KARC,CAAF;AASD,GArBO,CAAR;AAuBAN,EAAAA,QAAQ,CAAC,WAAD,EAAc,YAAM;AAC1B,QAAMuB,eAAe,mCAChBhB,QADgB;AAEnBiB,MAAAA,GAAG,EAAE;AACHC,QAAAA,OAAO,EAAE,IADN;AAEHd,QAAAA,KAAK,EACH,mEAHC;AAIHe,QAAAA,KAAK,EAAE;AAJJ;AAFc,MAArB;;AASA,yBAAiB,oBAAaX,UAAb,EAAyBQ,eAAzB,CAAjB;AAAA,QAAQP,CAAR,kBAAQA,CAAR;AAAA,QAAWC,CAAX,kBAAWA,CAAX;;AAEAd,IAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAM;AACxCC,MAAAA,MAAM,CAACY,CAAD,CAAN,CAAUV,OAAV,CACE,mEADF;AAGAF,MAAAA,MAAM,CAACa,CAAD,CAAN,CAAUX,OAAV,CACE,mEADF;AAGD,KAPC,CAAF;AASAH,IAAAA,EAAE,CAAC,iBAAD,EAAoB,YAAM;AAC1B,UAAMe,SAAS,GAAGC,mBACfC,cADe,CACAL,UAAU,CAACM,SAAX,CAAqB,CAArB,CADA,EACyB,KADzB,EAEfC,SAFe,CAEL,IAFK,EAEC,KAFD,CAAlB;;AAIAlB,MAAAA,MAAM,CACJ,kCAAoBc,SAApB,GAAiCK,eAAjC,EAAkD;AAAEP,QAAAA,CAAC,EAADA,CAAF;AAAKC,QAAAA,CAAC,EAADA;AAAL,OAAlD,CADI,CAAN,CAEEX,OAFF,CAEU,IAFV;AAGD,KARC,CAAF;AASD,GA9BO,CAAR;AA+BD,CArEO,CAAR;AAuEAN,QAAQ,CAAC,YAAD,EAAe,YAAM;AAC3B,MAAM2B,UAAU,GAAG;AACjBC,IAAAA,WAAW,EAAE,EADI;AAEjBC,IAAAA,UAAU,EAAE,EAFK;AAGjBC,IAAAA,UAAU,EAAE,qBAHK;AAIjBC,IAAAA,SAAS,EAAE,qBAJM;AAKjBC,IAAAA,SAAS,EACP,kEANe;AAOjBC,IAAAA,QAAQ,EACN,kEARe;AASjBxB,IAAAA,KAAK,EAAE,CATU;AAUjBK,IAAAA,mBAAmB,EAAE;AAVJ,GAAnB;AAaA,MAAMC,UAAU,GACd,oEADF;AAGAf,EAAAA,QAAQ,CAAC,cAAD,EAAiB,YAAM;AAC7B,0BAAiB,sBAAee,UAAf,EAA2BY,UAA3B,CAAjB;AAAA,QAAQX,CAAR,mBAAQA,CAAR;AAAA,QAAWC,CAAX,mBAAWA,CAAX;;AAEAd,IAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAM;AACxCC,MAAAA,MAAM,CAACY,CAAD,CAAN,CAAUV,OAAV,CACE,mEADF;AAGAF,MAAAA,MAAM,CAACa,CAAD,CAAN,CAAUX,OAAV,CACE,mEADF;AAGD,KAPC,CAAF;AASAH,IAAAA,EAAE,CAAC,iBAAD,EAAoB,YAAM;AAC1B,UAAMe,SAAS,GAAGC,mBACfC,cADe,CACAL,UAAU,CAACM,SAAX,CAAqB,CAArB,CADA,EACyB,KADzB,EAEfC,SAFe,CAEL,IAFK,EAEC,KAFD,CAAlB;;AAIAlB,MAAAA,MAAM,CAAC,oCAAsBc,SAAtB,GAAmCS,UAAnC,EAA+C;AAAEX,QAAAA,CAAC,EAADA,CAAF;AAAKC,QAAAA,CAAC,EAADA;AAAL,OAA/C,CAAD,CAAN,CAAiEX,OAAjE,CACE,IADF;AAGD,KARC,CAAF;AASD,GArBO,CAAR;AAuBAN,EAAAA,QAAQ,CAAC,UAAD,EAAa,YAAM;AACzB,QAAMkC,iBAAiB,mCAClBP,UADkB;AAErBH,MAAAA,GAAG,EAAE;AACHC,QAAAA,OAAO,EAAE,IADN;AAEHd,QAAAA,KAAK,EACH,mEAHC;AAIHe,QAAAA,KAAK,EAAE;AAJJ;AAFgB,MAAvB;;AAUA,2BAAiB,sBAAeX,UAAf,EAA2BmB,iBAA3B,CAAjB;AAAA,QAAQlB,CAAR,oBAAQA,CAAR;AAAA,QAAWC,CAAX,oBAAWA,CAAX;;AAEAd,IAAAA,EAAE,CAAC,+BAAD,EAAkC,YAAM;AACxCC,MAAAA,MAAM,CAACY,CAAD,CAAN,CAAUV,OAAV,CACE,mEADF;AAGAF,MAAAA,MAAM,CAACa,CAAD,CAAN,CAAUX,OAAV,CACE,kEADF;AAGD,KAPC,CAAF;AASAH,IAAAA,EAAE,CAAC,iBAAD,EAAoB,YAAM;AAC1B,UAAMe,SAAS,GAAGC,mBACfC,cADe,CACAL,UAAU,CAACM,SAAX,CAAqB,CAArB,CADA,EACyB,KADzB,EAEfC,SAFe,CAEL,IAFK,EAEC,KAFD,CAAlB;;AAIAlB,MAAAA,MAAM,CACJ,oCAAsBc,SAAtB,GAAmCgB,iBAAnC,EAAsD;AAAElB,QAAAA,CAAC,EAADA,CAAF;AAAKC,QAAAA,CAAC,EAADA;AAAL,OAAtD,CADI,CAAN,CAEEX,OAFF,CAEU,IAFV;AAGD,KARC,CAAF;AASD,GA/BO,CAAR;AAgCD,CAxEO,CAAR","sourcesContent":["import { starkEc } from './signature';\n\nimport {\n  generateKey,\n  signTransfer,\n  signLimitOrder,\n  verifyTransfer,\n  verifyLimitOrder,\n} from '.';\nimport { 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 keyPair = generateKey(mnemonic);\n\n  it('generates the expected private key', () => {\n    expect(keyPair.getPrivate('hex')).toEqual(\n      '0646baa9aefb054dfa205c94b43781baa7b2ec2dfbcee64dbd9d2172283de902'\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 = starkEc\n        .keyFromPrivate(privateKey.substring(2), 'hex')\n        .getPublic(true, 'hex');\n\n      expect(verifyTransfer(`0x${publicKey}`, transfer, { r, s })).toEqual(\n        true\n      );\n    });\n  });\n\n  describe('with fees', () => {\n    const transferWithFee = {\n      ...transfer,\n      fee: {\n        vaultId: '46',\n        token:\n          '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n        limit: '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 = starkEc\n        .keyFromPrivate(privateKey.substring(2), 'hex')\n        .getPublic(true, 'hex');\n\n      expect(\n        verifyTransfer(`0x${publicKey}`, transferWithFee, { r, s })\n      ).toEqual(true);\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 = starkEc\n        .keyFromPrivate(privateKey.substring(2), 'hex')\n        .getPublic(true, 'hex');\n\n      expect(verifyLimitOrder(`0x${publicKey}`, limitOrder, { r, s })).toEqual(\n        true\n      );\n    });\n  });\n\n  describe('with fee', () => {\n    const limitOrderWithFee = {\n      ...limitOrder,\n      fee: {\n        vaultId: '46',\n        token:\n          '0x3003a65651d3b9fb2eff934a4416db301afd112a8492aaf8d7297fc87dcd9f4',\n        limit: '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 = starkEc\n        .keyFromPrivate(privateKey.substring(2), 'hex')\n        .getPublic(true, 'hex');\n\n      expect(\n        verifyLimitOrder(`0x${publicKey}`, limitOrderWithFee, { r, s })\n      ).toEqual(true);\n    });\n  });\n});\n"]} |
@@ -126,2 +126,2 @@ "use strict"; | ||
exports.StarkExEc = StarkExEc; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/keyDerivation.js"],"names":["getIntFromBits","hex","start","end","undefined","bin","bits","slice","int","getAccountPath","layer","application","ethereumAddress","index","layerHash","hash","sha256","update","digest","applicationHash","layerInt","applicationInt","ethAddressInt1","ethAddressInt2","hashKeyWithIndex","key","BN","grindKey","keySeed","keyValLimit","sha256EcMaxDigest","maxAllowedVal","sub","mod","i","lt","toString","umod","getKeyPairFromPath","mnemonic","path","seed","hdkey","fromMasterSeed","derivePath","getWallet","getPrivateKeyString","starkEcOrder","ec","n","keyFromPrivate","StarkExEc"],"mappings":"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","sourcesContent":["/* //////////////////////////////////////////////////////////////////////////////\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 { mnemonicToSeedSync } from 'bip39';\nimport {\n  hexToBinary,\n  binaryToNumber,\n  hexToBuffer,\n  removeHexPrefix,\n  sanitizeBytes,\n  numberToHex\n} from 'enc-utils';\nimport BN from 'bn.js';\nimport hash from 'hash.js';\nimport { hdkey } from 'ethereumjs-wallet';\n\nimport { starkEc as ec } from './signature';\n\n/*\n Returns an integer from a given section of bits out of a hex string.\n hex is the target hex string to slice.\n start represents the index of the first bit to cut from the hex string (binary) in LSB order.\n end represents the index of the last bit to cut from the hex string.\n*/\nfunction getIntFromBits(hex, start, end = undefined) {\n  const bin = hexToBinary(hex);\n  const bits = bin.slice(start, end);\n  const int = binaryToNumber(bits);\n  return int;\n}\n\n/*\n Calculates the stark path based on the layer, application, eth address and a given index.\n layer is a string representing the operating layer (usually 'starkex').\n application is a string representing the relevant application (For a list of valid applications,\n refer to https://starkware.co/starkex/docs/requirementsApplicationParameters.html).\n ethereumAddress is a string representing the ethereum public key from which we derive the stark\n key.\n index represents an index of the possible associated wallets derived from the seed.\n*/\nexport function getAccountPath(layer, application, ethereumAddress, index) {\n  const layerHash = hash\n    .sha256()\n    .update(layer)\n    .digest('hex');\n  const applicationHash = hash\n    .sha256()\n    .update(application)\n    .digest('hex');\n  const layerInt = getIntFromBits(layerHash, -31);\n  const applicationInt = getIntFromBits(applicationHash, -31);\n  // Draws the 31 LSBs of the eth address.\n  const ethAddressInt1 = getIntFromBits(ethereumAddress, -31);\n  // Draws the following 31 LSBs of the eth address.\n  const ethAddressInt2 = getIntFromBits(ethereumAddress, -62, -31);\n  return `m/2645'/${layerInt}'/${applicationInt}'/${ethAddressInt1}'/${ethAddressInt2}'/${index}`;\n}\n\nfunction hashKeyWithIndex(key, index) {\n  return new BN(\n    hash\n      .sha256()\n      .update(\n        hexToBuffer(removeHexPrefix(key) + sanitizeBytes(numberToHex(index), 2))\n      )\n      .digest('hex'),\n    16\n  );\n}\n\n/*\n This function receives a key seed and produces an appropriate StarkEx key from a uniform\n distribution.\n Although it is possible to define a StarkEx key as a residue between the StarkEx EC order and a\n random 256bit digest value, the result would be a biased key. In order to prevent this bias, we\n deterministically search (by applying more hashes, AKA grinding) for a value lower than the largest\n 256bit multiple of StarkEx EC order.\n*/\nexport function grindKey(keySeed, keyValLimit) {\n  const sha256EcMaxDigest = new BN(\n    '1 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000',\n    16\n  );\n  const maxAllowedVal = sha256EcMaxDigest.sub(\n    sha256EcMaxDigest.mod(keyValLimit)\n  );\n  let i = 0;\n  let key = hashKeyWithIndex(keySeed, i);\n  i += 1;\n  // Make sure the produced key is devided by the Stark EC order, and falls within the range\n  // [0, maxAllowedVal).\n  while (!key.lt(maxAllowedVal)) {\n    key = hashKeyWithIndex(keySeed.toString('hex'), i);\n    i += 1;\n  }\n  return key.umod(keyValLimit).toString('hex');\n}\n\n/*\n Derives key-pair from given mnemonic string and path.\n mnemonic should be a sentence comprised of 12 words with single spaces between them.\n path is a formatted string describing the stark key path based on the layer, application and eth\n address.\n*/\nexport function getKeyPairFromPath(mnemonic, path) {\n  const seed = mnemonicToSeedSync(mnemonic);\n  const keySeed = hdkey\n    .fromMasterSeed(seed, 'hex')\n    .derivePath(path)\n    .getWallet()\n    .getPrivateKeyString();\n  const starkEcOrder = ec.n;\n  return ec.keyFromPrivate(grindKey(keySeed, starkEcOrder), 'hex');\n}\n\nexport const StarkExEc = ec.n;\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/keyDerivation.js"],"names":["getIntFromBits","hex","start","end","undefined","bin","bits","slice","int","getAccountPath","layer","application","ethereumAddress","index","layerHash","hash","sha256","update","digest","applicationHash","layerInt","applicationInt","ethAddressInt1","ethAddressInt2","hashKeyWithIndex","key","BN","grindKey","keySeed","keyValLimit","sha256EcMaxDigest","maxAllowedVal","sub","mod","i","lt","toString","umod","getKeyPairFromPath","mnemonic","path","seed","hdkey","fromMasterSeed","derivePath","getWallet","getPrivateKeyString","starkEcOrder","ec","n","keyFromPrivate","StarkExEc"],"mappings":"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","sourcesContent":["/* //////////////////////////////////////////////////////////////////////////////\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 { mnemonicToSeedSync } from 'bip39';\nimport {\n  hexToBinary,\n  binaryToNumber,\n  hexToBuffer,\n  removeHexPrefix,\n  sanitizeBytes,\n  numberToHex,\n} from 'enc-utils';\nimport BN from 'bn.js';\nimport hash from 'hash.js';\nimport { hdkey } from 'ethereumjs-wallet';\n\nimport { starkEc as ec } from './signature';\n\n/*\n Returns an integer from a given section of bits out of a hex string.\n hex is the target hex string to slice.\n start represents the index of the first bit to cut from the hex string (binary) in LSB order.\n end represents the index of the last bit to cut from the hex string.\n*/\nfunction getIntFromBits(hex, start, end = undefined) {\n  const bin = hexToBinary(hex);\n  const bits = bin.slice(start, end);\n  const int = binaryToNumber(bits);\n  return int;\n}\n\n/*\n Calculates the stark path based on the layer, application, eth address and a given index.\n layer is a string representing the operating layer (usually 'starkex').\n application is a string representing the relevant application (For a list of valid applications,\n refer to https://starkware.co/starkex/docs/requirementsApplicationParameters.html).\n ethereumAddress is a string representing the ethereum public key from which we derive the stark\n key.\n index represents an index of the possible associated wallets derived from the seed.\n*/\nexport function getAccountPath(layer, application, ethereumAddress, index) {\n  const layerHash = hash\n    .sha256()\n    .update(layer)\n    .digest('hex');\n  const applicationHash = hash\n    .sha256()\n    .update(application)\n    .digest('hex');\n  const layerInt = getIntFromBits(layerHash, -31);\n  const applicationInt = getIntFromBits(applicationHash, -31);\n  // Draws the 31 LSBs of the eth address.\n  const ethAddressInt1 = getIntFromBits(ethereumAddress, -31);\n  // Draws the following 31 LSBs of the eth address.\n  const ethAddressInt2 = getIntFromBits(ethereumAddress, -62, -31);\n  return `m/2645'/${layerInt}'/${applicationInt}'/${ethAddressInt1}'/${ethAddressInt2}'/${index}`;\n}\n\nfunction hashKeyWithIndex(key, index) {\n  return new BN(\n    hash\n      .sha256()\n      .update(\n        hexToBuffer(removeHexPrefix(key) + sanitizeBytes(numberToHex(index), 2))\n      )\n      .digest('hex'),\n    16\n  );\n}\n\n/*\n This function receives a key seed and produces an appropriate StarkEx key from a uniform\n distribution.\n Although it is possible to define a StarkEx key as a residue between the StarkEx EC order and a\n random 256bit digest value, the result would be a biased key. In order to prevent this bias, we\n deterministically search (by applying more hashes, AKA grinding) for a value lower than the largest\n 256bit multiple of StarkEx EC order.\n*/\nexport function grindKey(keySeed, keyValLimit) {\n  const sha256EcMaxDigest = new BN(\n    '1 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000',\n    16\n  );\n  const maxAllowedVal = sha256EcMaxDigest.sub(\n    sha256EcMaxDigest.mod(keyValLimit)\n  );\n  let i = 0;\n  let key = hashKeyWithIndex(keySeed, i);\n  i += 1;\n  // Make sure the produced key is devided by the Stark EC order, and falls within the range\n  // [0, maxAllowedVal).\n  while (!key.lt(maxAllowedVal)) {\n    key = hashKeyWithIndex(keySeed.toString('hex'), i);\n    i += 1;\n  }\n  return key.umod(keyValLimit).toString('hex');\n}\n\n/*\n Derives key-pair from given mnemonic string and path.\n mnemonic should be a sentence comprised of 12 words with single spaces between them.\n path is a formatted string describing the stark key path based on the layer, application and eth\n address.\n*/\nexport function getKeyPairFromPath(mnemonic, path) {\n  const seed = mnemonicToSeedSync(mnemonic);\n  const keySeed = hdkey\n    .fromMasterSeed(seed, 'hex')\n    .derivePath(path)\n    .getWallet()\n    .getPrivateKeyString();\n  const starkEcOrder = ec.n;\n  return ec.keyFromPrivate(grindKey(keySeed, starkEcOrder), 'hex');\n}\n\nexport const StarkExEc = ec.n;\n"]} |
export function pedersen(input: any): any; | ||
export function getLimitOrderMsgHash(vaultSell: any, vaultBuy: any, amountSell: any, amountBuy: any, tokenSell: any, tokenBuy: any, nonce: any, expirationTimestamp: any): any; | ||
export function getTransferMsgHash(amount: any, nonce: any, senderVaultId: any, token: any, receiverVaultId: any, receiverPublicKey: any, expirationTimestamp: any, condition?: any): any; | ||
export function getLimitOrderMsgHashWithFee(vaultSell: any, vaultBuy: any, amountSell: any, amountBuy: any, tokenSell: any, tokenBuy: any, nonce: any, expirationTimestamp: any, feeToken: any, feeVaultId: any, feeLimit: any): any; | ||
export function getTransferMsgHash(amount: any, nonce: any, senderVaultId: any, token: any, receiverVaultId: any, receiverPublicKey: any, expirationTimestamp: any, condition: any): any; | ||
export function getTransferMsgHashWithFee(amount: any, nonce: any, senderVaultId: any, token: any, receiverVaultId: any, receiverStarkKey: any, expirationTimestamp: any, condition: any, feeToken: any, feeVaultId: any, feeLimit: any): any; | ||
export function sign(privateKey: any, msgHash: any): any; | ||
@@ -5,0 +7,0 @@ export function verify(publicKey: any, msgHash: any, msgSignature: any): any; |
import { ec } from 'elliptic'; | ||
export declare type KeyPair = ec.KeyPair; | ||
export interface Fee { | ||
token: string; | ||
vaultId: string; | ||
limit: string; | ||
} | ||
export interface Transfer { | ||
@@ -12,2 +17,3 @@ senderVaultId: number | string; | ||
condition?: string; | ||
fee?: Fee; | ||
} | ||
@@ -23,2 +29,3 @@ export interface LimitOrder { | ||
expirationTimestamp: number; | ||
fee?: Fee; | ||
} | ||
@@ -25,0 +32,0 @@ export interface Signature { |
@@ -6,3 +6,3 @@ { | ||
"license": "UNLICENSED", | ||
"version": "0.0.5", | ||
"version": "0.1.0", | ||
"main": "dist", | ||
@@ -68,2 +68,2 @@ "types": "dist", | ||
] | ||
} | ||
} |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
322772
1046
0
14