@sorare/crypto
Advanced tools
Comparing version 1.3.1-beta.7 to 1.3.1-beta.8
@@ -11,3 +11,3 @@ import { ec } from 'elliptic'; | ||
export declare const signMessage: (privateKey: string, message: string) => Signature; | ||
export declare const verifyMessage: (publicKey: string, message: string, signature: Signature) => boolean; | ||
export declare const verifyMessage: (publicKey: string, message: string, signature: Signature) => any; | ||
export declare const signTransfer: (privateKey: string, transfer: Transfer) => Signature; | ||
@@ -14,0 +14,0 @@ export declare const verifyTransfer: (publicKey: string, transfer: Transfer, signature: Signature) => boolean; |
@@ -34,10 +34,8 @@ "use strict"; | ||
var _keyDerivation = require("./starkware/cpp/keyDerivation"); | ||
var _keyDerivation = require("./starkware/keyDerivation"); | ||
var _signature = require("./starkware/cpp/signature"); | ||
var _signature = require("./starkware/signature"); | ||
var _useCpp = require("./starkware/cpp/useCpp"); | ||
var _crypto = require("./starkware/crypto"); | ||
var _crypto = require("./starkware/cpp/crypto"); | ||
var _types = require("./types"); | ||
@@ -135,3 +133,3 @@ | ||
var verify = function verify(publicKey, message, signature) { | ||
if (_useCpp.useCryptoCpp) { | ||
if (_crypto.useCryptoCpp) { | ||
return (0, _crypto.verify)(BigInt(publicKey), BigInt("0x".concat(message)), BigInt(signature.r), BigInt(signature.s)); | ||
@@ -193,2 +191,2 @@ } | ||
exports.verifyLimitOrder = verifyLimitOrder; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/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","feeInfoUser","args","getTransferMsgHashWithFee","tokenId","sourceVaultId","feeLimit","getTransferMsgHash","hashLimitOrder","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","feeInfo","getLimitOrderMsgHashWithFee","getLimitOrderMsgHash","sign","message","r","s","verify","signature","useCryptoCpp","BigInt","sig","BN","hashMessage","h","hash","sha256","update","digest","signMessage","verifyMessage","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';\nimport hash from 'hash.js';\n\nimport { LimitOrder, Transfer, Signature } from './types';\nimport {\n  getAccountPath,\n  getKeyPairFromPath,\n} from './starkware/cpp/keyDerivation';\nimport {\n  starkEc,\n  sign as starkSign,\n  verify as starkVerify,\n  getTransferMsgHash,\n  getTransferMsgHashWithFee,\n  getLimitOrderMsgHash,\n  getLimitOrderMsgHashWithFee,\n  pedersen,\n} from './starkware/cpp/signature';\nimport { useCryptoCpp } from './starkware/cpp/useCpp';\nimport { verify as starkVerifyCpp } from './starkware/cpp/crypto';\n\nexport { LimitOrder, Transfer, Signature } from './types';\n\nconst 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 // force line-break (https://github.com/prettier/prettier/issues/3107)\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\nconst hashTransfer = (transfer: Transfer) => {\n  const {\n    amount,\n    nonce,\n    senderVaultId,\n    token,\n    receiverVaultId,\n    receiverPublicKey,\n    expirationTimestamp,\n    condition,\n    feeInfoUser,\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 (feeInfoUser)\n    return getTransferMsgHashWithFee(\n      ...args,\n      feeInfoUser.tokenId,\n      feeInfoUser.sourceVaultId,\n      feeInfoUser.feeLimit\n    );\n\n  return getTransferMsgHash(...args);\n};\n\nconst hashLimitOrder = (limitOrder: LimitOrder) => {\n  const {\n    vaultIdSell,\n    vaultIdBuy,\n    amountSell,\n    amountBuy,\n    tokenSell,\n    tokenBuy,\n    nonce,\n    expirationTimestamp,\n    feeInfo,\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 (feeInfo)\n    return getLimitOrderMsgHashWithFee(\n      ...args,\n      feeInfo.tokenId,\n      feeInfo.sourceVaultId,\n      feeInfo.feeLimit\n    );\n\n  return getLimitOrderMsgHash(...args);\n};\n\nconst sign = (privateKey: string, message: string): Signature => {\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\nconst verify = (\n  publicKey: string,\n  message: string,\n  signature: Signature\n): boolean => {\n  if (useCryptoCpp) {\n    return starkVerifyCpp(\n      BigInt(publicKey),\n      BigInt(`0x${message}`),\n      BigInt(signature.r),\n      BigInt(signature.s)\n    );\n  }\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\nconst hashMessage = (message: string) => {\n  const h = hash.sha256().update(message).digest('hex');\n  return pedersen([h.substring(0, 32), h.substring(32)]);\n};\n\nexport const signMessage = (privateKey: string, message: string): Signature =>\n  sign(privateKey, hashMessage(message));\n\nexport const verifyMessage = (\n  publicKey: string,\n  message: string,\n  signature: Signature\n) => verify(publicKey, hashMessage(message), signature);\n\nexport const signTransfer = (\n  privateKey: string,\n  transfer: Transfer\n): Signature => {\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): boolean => {\n  const message = hashTransfer(transfer);\n\n  return verify(publicKey, message, signature);\n};\n\nexport const signLimitOrder = (\n  privateKey: string,\n  limitOrder: LimitOrder\n): Signature => {\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): boolean => {\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/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","feeInfoUser","args","getTransferMsgHashWithFee","tokenId","sourceVaultId","feeLimit","getTransferMsgHash","hashLimitOrder","limitOrder","vaultIdSell","vaultIdBuy","amountSell","amountBuy","tokenSell","tokenBuy","feeInfo","getLimitOrderMsgHashWithFee","getLimitOrderMsgHash","sign","message","r","s","verify","signature","useCryptoCpp","BigInt","sig","BN","hashMessage","h","hash","sha256","update","digest","signMessage","verifyMessage","signTransfer","verifyTransfer","signLimitOrder","verifyLimitOrder"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AAEA;;AACA;;AAGA;;AACA;;AAUA;;AAEA;;;;AAEA,IAAMA,IAAI,GAAG,kBAAb;;AAEO,IAAMC,WAAW,GAAG,SAAdA,WAAc,CAACC,QAAD,EAAuB;AAChD,MAAMC,IAAI,GAAG,6BAAmBD,QAAQ,IAAI,4BAA/B,CAAb;;AACA,MAAME,eAAe,GAAGC,wBACrBC,cADqB,CACNH,IADM,EAErBI,UAFqB,CAEVP,IAFU,EAGrBQ,SAHqB,GAIrBC,gBAJqB,EAAxB;;AAMA,MAAMC,IAAI,GAAG,mCAAe,SAAf,EAA0B,QAA1B,EAAoCN,eAApC,EAAqD,CAArD,CAAb;AACA,SAAO,uCAAmBF,QAAnB,EAA6BQ,IAA7B,CAAP;AACD,CAVM;;;;AAYA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACC,GAAD;AAAA,qBACzBA,GAAG,CAACC,UAAJ,CAAe,KAAf,EAAsBC,QAAtB,CAA+B,EAA/B,EAAmC,GAAnC,CADyB;AAAA,CAAzB;;;;AAGA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACH,GAAD;AAAA,qBACxBA,GAAG,CAACI,SAAJ,CAAc,IAAd,EAAoB,KAApB,CADwB;AAAA,CAAxB;;;;AAGA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACL,GAAD;AAAA,qBACzBA,GAAG,CAAC;AAAD,GACLI,SADE,GAEFE,IAFE,GAGFC,QAHE,CAGO,KAHP,EAIFL,QAJE,CAIO,EAJP,EAIW,GAJX,CADyB;AAAA,CAAzB;;;;AAOA,IAAMM,cAAc,GAAG,SAAjBA,cAAiB,CAACC,UAAD;AAAA,SAC5BC,mBAAQC,cAAR,CAAuBF,UAAU,CAACG,SAAX,CAAqB,CAArB,CAAvB,EAAgD,KAAhD,CAD4B;AAAA,CAAvB;;;;AAGA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAACC,SAAD;AAAA,SAC3BJ,mBAAQK,aAAR,CAAsBD,SAAS,CAACF,SAAV,CAAoB,CAApB,CAAtB,EAA8C,KAA9C,CAD2B;AAAA,CAAtB;;;;AAGP,IAAMI,YAAY,GAAG,SAAfA,YAAe,CAACC,QAAD,EAAwB;AAC3C,MACEC,MADF,GAUID,QAVJ,CACEC,MADF;AAAA,MAEEC,KAFF,GAUIF,QAVJ,CAEEE,KAFF;AAAA,MAGEC,aAHF,GAUIH,QAVJ,CAGEG,aAHF;AAAA,MAIEC,KAJF,GAUIJ,QAVJ,CAIEI,KAJF;AAAA,MAKEC,eALF,GAUIL,QAVJ,CAKEK,eALF;AAAA,MAMEC,iBANF,GAUIN,QAVJ,CAMEM,iBANF;AAAA,MAOEC,mBAPF,GAUIP,QAVJ,CAOEO,mBAPF;AAAA,MAQEC,SARF,GAUIR,QAVJ,CAQEQ,SARF;AAAA,MASEC,WATF,GAUIT,QAVJ,CASES,WATF;AAYA,MAAMC,IAAI,GAAG,CACXT,MADW,EAEXC,KAFW,EAGXC,aAHW,EAIXC,KAJW,EAKXC,eALW,EAMXC,iBANW,EAOXC,mBAPW,EAQXC,SARW,CAAb;AAWA,MAAIC,WAAJ,EACE,OAAOE,mDACFD,IADE,SAELD,WAAW,CAACG,OAFP,EAGLH,WAAW,CAACI,aAHP,EAILJ,WAAW,CAACK,QAJP,GAAP;AAOF,SAAOC,4CAAsBL,IAAtB,CAAP;AACD,CAjCD;;AAmCA,IAAMM,cAAc,GAAG,SAAjBA,cAAiB,CAACC,UAAD,EAA4B;AACjD,MACEC,WADF,GAUID,UAVJ,CACEC,WADF;AAAA,MAEEC,UAFF,GAUIF,UAVJ,CAEEE,UAFF;AAAA,MAGEC,UAHF,GAUIH,UAVJ,CAGEG,UAHF;AAAA,MAIEC,SAJF,GAUIJ,UAVJ,CAIEI,SAJF;AAAA,MAKEC,SALF,GAUIL,UAVJ,CAKEK,SALF;AAAA,MAMEC,QANF,GAUIN,UAVJ,CAMEM,QANF;AAAA,MAOErB,KAPF,GAUIe,UAVJ,CAOEf,KAPF;AAAA,MAQEK,mBARF,GAUIU,UAVJ,CAQEV,mBARF;AAAA,MASEiB,OATF,GAUIP,UAVJ,CASEO,OATF;AAYA,MAAMd,IAAI,GAAG,CACXQ,WADW,EAEXC,UAFW,EAGXC,UAHW,EAIXC,SAJW,EAKXC,SALW,EAMXC,QANW,EAOXrB,KAPW,EAQXK,mBARW,CAAb;AAWA,MAAIiB,OAAJ,EACE,OAAOC,qDACFf,IADE,SAELc,OAAO,CAACZ,OAFH,EAGLY,OAAO,CAACX,aAHH,EAILW,OAAO,CAACV,QAJH,GAAP;AAOF,SAAOY,8CAAwBhB,IAAxB,CAAP;AACD,CAjCD;;AAmCA,IAAMiB,IAAI,GAAG,SAAPA,IAAO,CAACnC,UAAD,EAAqBoC,OAArB,EAAoD;AAC/D,MAAM7C,GAAG,GAAGQ,cAAc,CAACC,UAAD,CAA1B;;AACA,mBAAiB,qBAAUT,GAAV,EAAe6C,OAAf,CAAjB;AAAA,MAAQC,CAAR,cAAQA,CAAR;AAAA,MAAWC,CAAX,cAAWA,CAAX;;AAEA,SAAO;AACLD,IAAAA,CAAC,cAAOA,CAAC,CAACvC,QAAF,CAAW,EAAX,CAAP,CADI;AAELwC,IAAAA,CAAC,cAAOA,CAAC,CAACxC,QAAF,CAAW,EAAX,CAAP;AAFI,GAAP;AAID,CARD;;AAUA,IAAMyC,MAAM,GAAG,SAATA,MAAS,CAAClC,SAAD,EAAoB+B,OAApB,EAAqCI,SAArC,EAA8D;AAC3E,MAAIC,oBAAJ,EAAkB;AAChB,WAAO,oBACLC,MAAM,CAACrC,SAAD,CADD,EAELqC,MAAM,aAAMN,OAAN,EAFD,EAGLM,MAAM,CAACF,SAAS,CAACH,CAAX,CAHD,EAILK,MAAM,CAACF,SAAS,CAACF,CAAX,CAJD,CAAP;AAMD;;AAED,MAAM/C,GAAG,GAAGa,aAAa,CAACC,SAAD,CAAzB;AACA,MAAMsC,GAAG,GAAG;AACVN,IAAAA,CAAC,EAAE,IAAIO,WAAJ,CAAOJ,SAAS,CAACH,CAAV,CAAYlC,SAAZ,CAAsB,CAAtB,CAAP,EAAiC,EAAjC,CADO;AAEVmC,IAAAA,CAAC,EAAE,IAAIM,WAAJ,CAAOJ,SAAS,CAACF,CAAV,CAAYnC,SAAZ,CAAsB,CAAtB,CAAP,EAAiC,EAAjC;AAFO,GAAZ;AAKA,SAAO,uBAAYZ,GAAZ,EAAiB6C,OAAjB,EAA0BO,GAA1B,CAAP;AACD,CAjBD;;AAmBA,IAAME,WAAW,GAAG,SAAdA,WAAc,CAACT,OAAD,EAAqB;AACvC,MAAMU,CAAC,GAAGC,cAAKC,MAAL,GAAcC,MAAd,CAAqBb,OAArB,EAA8Bc,MAA9B,CAAqC,KAArC,CAAV;;AACA,SAAO,yBAAS,CAACJ,CAAC,CAAC3C,SAAF,CAAY,CAAZ,EAAe,EAAf,CAAD,EAAqB2C,CAAC,CAAC3C,SAAF,CAAY,EAAZ,CAArB,CAAT,CAAP;AACD,CAHD;;AAKO,IAAMgD,WAAW,GAAG,SAAdA,WAAc,CAACnD,UAAD,EAAqBoC,OAArB;AAAA,SACzBD,IAAI,CAACnC,UAAD,EAAa6C,WAAW,CAACT,OAAD,CAAxB,CADqB;AAAA,CAApB;;;;AAGA,IAAMgB,aAAa,GAAG,SAAhBA,aAAgB,CAC3B/C,SAD2B,EAE3B+B,OAF2B,EAG3BI,SAH2B;AAAA,SAIxBD,MAAM,CAAClC,SAAD,EAAYwC,WAAW,CAACT,OAAD,CAAvB,EAAkCI,SAAlC,CAJkB;AAAA,CAAtB;;;;AAMA,IAAMa,YAAY,GAAG,SAAfA,YAAe,CAC1BrD,UAD0B,EAE1BQ,QAF0B,EAGZ;AACd,MAAM4B,OAAO,GAAG7B,YAAY,CAACC,QAAD,CAA5B;AAEA,SAAO2B,IAAI,CAACnC,UAAD,EAAaoC,OAAb,CAAX;AACD,CAPM;;;;AASA,IAAMkB,cAAc,GAAG,SAAjBA,cAAiB,CAC5BjD,SAD4B,EAE5BG,QAF4B,EAG5BgC,SAH4B,EAIhB;AACZ,MAAMJ,OAAO,GAAG7B,YAAY,CAACC,QAAD,CAA5B;AAEA,SAAO+B,MAAM,CAAClC,SAAD,EAAY+B,OAAZ,EAAqBI,SAArB,CAAb;AACD,CARM;;;;AAUA,IAAMe,cAAc,GAAG,SAAjBA,cAAiB,CAC5BvD,UAD4B,EAE5ByB,UAF4B,EAGd;AACd,MAAMW,OAAO,GAAGZ,cAAc,CAACC,UAAD,CAA9B;AAEA,SAAOU,IAAI,CAACnC,UAAD,EAAaoC,OAAb,CAAX;AACD,CAPM;;;;AASA,IAAMoB,gBAAgB,GAAG,SAAnBA,gBAAmB,CAC9BnD,SAD8B,EAE9BoB,UAF8B,EAG9Be,SAH8B,EAIlB;AACZ,MAAMJ,OAAO,GAAGZ,cAAc,CAACC,UAAD,CAA9B;AAEA,SAAOc,MAAM,CAAClC,SAAD,EAAY+B,OAAZ,EAAqBI,SAArB,CAAb;AACD,CARM","sourcesContent":["import BN from 'bn.js';\nimport { generateMnemonic, mnemonicToSeedSync } from 'bip39';\nimport { ec } from 'elliptic';\nimport { hdkey } from 'ethereumjs-wallet';\nimport hash from 'hash.js';\n\nimport { LimitOrder, Transfer, Signature } from './types';\nimport { getAccountPath, getKeyPairFromPath } from './starkware/keyDerivation';\nimport {\n  starkEc,\n  pedersen,\n  sign as starkSign,\n  verify as starkVerify,\n  getTransferMsgHash,\n  getTransferMsgHashWithFee,\n  getLimitOrderMsgHash,\n  getLimitOrderMsgHashWithFee,\n} from './starkware/signature';\nimport { verify as starkVerifyCpp, useCryptoCpp } from './starkware/crypto';\n\nexport { LimitOrder, Transfer, Signature } from './types';\n\nconst 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 // force line-break (https://github.com/prettier/prettier/issues/3107)\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\nconst hashTransfer = (transfer: Transfer) => {\n  const {\n    amount,\n    nonce,\n    senderVaultId,\n    token,\n    receiverVaultId,\n    receiverPublicKey,\n    expirationTimestamp,\n    condition,\n    feeInfoUser,\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 (feeInfoUser)\n    return getTransferMsgHashWithFee(\n      ...args,\n      feeInfoUser.tokenId,\n      feeInfoUser.sourceVaultId,\n      feeInfoUser.feeLimit\n    );\n\n  return getTransferMsgHash(...args);\n};\n\nconst hashLimitOrder = (limitOrder: LimitOrder) => {\n  const {\n    vaultIdSell,\n    vaultIdBuy,\n    amountSell,\n    amountBuy,\n    tokenSell,\n    tokenBuy,\n    nonce,\n    expirationTimestamp,\n    feeInfo,\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 (feeInfo)\n    return getLimitOrderMsgHashWithFee(\n      ...args,\n      feeInfo.tokenId,\n      feeInfo.sourceVaultId,\n      feeInfo.feeLimit\n    );\n\n  return getLimitOrderMsgHash(...args);\n};\n\nconst sign = (privateKey: string, message: string): Signature => {\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\nconst verify = (publicKey: string, message: string, signature: Signature) => {\n  if (useCryptoCpp) {\n    return starkVerifyCpp(\n      BigInt(publicKey),\n      BigInt(`0x${message}`),\n      BigInt(signature.r),\n      BigInt(signature.s)\n    );\n  }\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\nconst hashMessage = (message: string) => {\n  const h = hash.sha256().update(message).digest('hex');\n  return pedersen([h.substring(0, 32), h.substring(32)]);\n};\n\nexport const signMessage = (privateKey: string, message: string): Signature =>\n  sign(privateKey, hashMessage(message));\n\nexport const verifyMessage = (\n  publicKey: string,\n  message: string,\n  signature: Signature\n) => verify(publicKey, hashMessage(message), signature);\n\nexport const signTransfer = (\n  privateKey: string,\n  transfer: Transfer\n): Signature => {\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): boolean => {\n  const message = hashTransfer(transfer);\n\n  return verify(publicKey, message, signature);\n};\n\nexport const signLimitOrder = (\n  privateKey: string,\n  limitOrder: LimitOrder\n): Signature => {\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): boolean => {\n  const message = hashLimitOrder(limitOrder);\n\n  return verify(publicKey, message, signature);\n};\n"]} |
@@ -8,1 +8,2 @@ export function pedersen(x: any, y: any): bigint; | ||
export function getPublicKey(private_key: any): bigint; | ||
export const useCryptoCpp: boolean; |
@@ -26,11 +26,18 @@ "use strict"; | ||
var ffi = require('ffi-napi'); // Native crypto bindings. | ||
var useCryptoCpp = Boolean(process.env.USE_STARKWARE_CRYPTO_CPP); | ||
var libcrypto; // Only load FFI bindings if we run in a Node environment and we asked for it | ||
if (useCryptoCpp) { | ||
// eslint-disable-next-line | ||
var ffi = require('ffi-napi'); // Native crypto bindings. | ||
var libcrypto = ffi.Library(path.join(__dirname, '..', '..', 'build', 'Release', 'crypto'), { | ||
Hash: ['int', ['string', 'string', 'string']], | ||
Verify: ['bool', ['string', 'string', 'string', 'string']], | ||
Sign: ['int', ['string', 'string', 'string', 'string']], | ||
GetPublicKey: ['int', ['string', 'string']] | ||
}); | ||
libcrypto = ffi.Library(path.join(__dirname, '..', '..', 'build', 'Release', 'crypto'), { | ||
Hash: ['int', ['string', 'string', 'string']], | ||
Verify: ['bool', ['string', 'string', 'string', 'string']], | ||
Sign: ['int', ['string', 'string', 'string', 'string']], | ||
GetPublicKey: ['int', ['string', 'string']] | ||
}); | ||
} | ||
var curveOrder = new BN('800000000000010ffffffffffffffffb781126dcae7b2321e66a241adc64d2f', 16); | ||
@@ -110,4 +117,5 @@ /* | ||
verify: verify, | ||
getPublicKey: getPublicKey | ||
getPublicKey: getPublicKey, | ||
useCryptoCpp: useCryptoCpp | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/crypto.js"],"names":["path","require","BN","BigIntBuffer","assert","ffi","libcrypto","Library","join","__dirname","Hash","Verify","Sign","GetPublicKey","curveOrder","pedersen","x","y","x_buf","toBufferLE","y_buf","res_buf","Buffer","alloc","res","strict","toString","toBigIntLE","verify","stark_key","message_hash","r","s","stark_key_buf","message_hash_buf","r_buf","bnS","w","BigInt","invm","s_buf","sign","private_key","message","k","private_key_buf","message_buf","k_buf","slice","bnW","getPublicKey","module","exports"],"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\nconst path = require('path');\nconst BN = require('bn.js');\nconst BigIntBuffer = require('bigint-buffer');\nconst assert = require('assert');\nconst ffi = require('ffi-napi');\n\n// Native crypto bindings.\nconst libcrypto = ffi.Library(\n  path.join(__dirname, '..', '..', 'build', 'Release', 'crypto'),\n  {\n    Hash: ['int', ['string', 'string', 'string']],\n    Verify: ['bool', ['string', 'string', 'string', 'string']],\n    Sign: ['int', ['string', 'string', 'string', 'string']],\n    GetPublicKey: ['int', ['string', 'string']],\n  }\n);\n\nconst curveOrder = new BN(\n  '800000000000010ffffffffffffffffb781126dcae7b2321e66a241adc64d2f',\n  16\n);\n\n/*\n Computes the StarkWare version of the Pedersen hash of x and y.\n Full specification of the hash function can be found here:\n https://docs.starkware.co/starkex-docs/crypto/pedersen-hash-function\n*/\nfunction pedersen(x, y) {\n  const x_buf = BigIntBuffer.toBufferLE(x, 32);\n  const y_buf = BigIntBuffer.toBufferLE(y, 32);\n  const res_buf = Buffer.alloc(1024);\n  const res = libcrypto.Hash(x_buf, y_buf, res_buf);\n  assert.strict(res == 0, 'Error: ' + res_buf.toString('utf-8'));\n  return BigIntBuffer.toBigIntLE(res_buf);\n}\n\n/*\n Verifies ECDSA signature of a given message hash z with a given public key.\n Returns true if public_key signs the message.\n NOTE: This function assumes that the public_key is on the curve.\n*/\nfunction verify(stark_key, message_hash, r, s) {\n  const stark_key_buf = BigIntBuffer.toBufferLE(stark_key, 32);\n  const message_hash_buf = BigIntBuffer.toBufferLE(message_hash, 32);\n  const r_buf = BigIntBuffer.toBufferLE(r, 32);\n  const bnS = new BN(s.toString(16), 16);\n  const w = BigInt('0x' + bnS.invm(curveOrder).toString(16), 16);\n  const s_buf = BigIntBuffer.toBufferLE(w, 32);\n  return libcrypto.Verify(stark_key_buf, message_hash_buf, r_buf, s_buf);\n}\n\n/*\n Signs the given message hash with the provided private_key, with randomness k.\n\n NOTE: k should be a strong cryptographical random, and not repeat.\n See: https://tools.ietf.org/html/rfc6979.\n*/\nfunction sign(private_key, message, k) {\n  const private_key_buf = BigIntBuffer.toBufferLE(private_key, 32);\n  const message_buf = BigIntBuffer.toBufferLE(message, 32);\n  const k_buf = BigIntBuffer.toBufferLE(k, 32);\n  const res_buf = Buffer.alloc(1024);\n  const res = libcrypto.Sign(private_key_buf, message_buf, k_buf, res_buf);\n  assert.strict(res == 0, 'Error: ' + res_buf.toString('utf-8'));\n  const r = BigIntBuffer.toBigIntLE(res_buf.slice(0, 32));\n  const w = BigIntBuffer.toBigIntLE(res_buf.slice(32, 64));\n  const bnW = new BN(w.toString(16), 16);\n  const s = BigInt('0x' + bnW.invm(curveOrder).toString(16), 16);\n  return { r: r, s: s };\n}\n\n/*\n Deduces the public key given a private key.\n The x coordinate of the public key is also known as the partial public key,\n and used in StarkEx to identify the user.\n*/\nfunction getPublicKey(private_key) {\n  const private_key_buf = BigIntBuffer.toBufferLE(private_key, 32);\n  const res_buf = Buffer.alloc(1024);\n  const res = libcrypto.GetPublicKey(private_key_buf, res_buf);\n  assert.strict(res == 0, 'Error: ' + res_buf.toString('utf-8'));\n  return BigIntBuffer.toBigIntLE(res_buf);\n}\n\nmodule.exports = {\n  pedersen,\n  sign,\n  verify,\n  getPublicKey,\n};\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/starkware/crypto.js"],"names":["path","require","BN","BigIntBuffer","assert","useCryptoCpp","Boolean","process","env","USE_STARKWARE_CRYPTO_CPP","libcrypto","ffi","Library","join","__dirname","Hash","Verify","Sign","GetPublicKey","curveOrder","pedersen","x","y","x_buf","toBufferLE","y_buf","res_buf","Buffer","alloc","res","strict","toString","toBigIntLE","verify","stark_key","message_hash","r","s","stark_key_buf","message_hash_buf","r_buf","bnS","w","BigInt","invm","s_buf","sign","private_key","message","k","private_key_buf","message_buf","k_buf","slice","bnW","getPublicKey","module","exports"],"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\nconst path = require('path');\nconst BN = require('bn.js');\nconst BigIntBuffer = require('bigint-buffer');\nconst assert = require('assert');\n\nconst useCryptoCpp = Boolean(process.env.USE_STARKWARE_CRYPTO_CPP);\nlet libcrypto;\n\n// Only load FFI bindings if we run in a Node environment and we asked for it\nif (useCryptoCpp) {\n  // eslint-disable-next-line\n  const ffi = require('ffi-napi');\n\n  // Native crypto bindings.\n  libcrypto = ffi.Library(\n    path.join(__dirname, '..', '..', 'build', 'Release', 'crypto'),\n    {\n      Hash: ['int', ['string', 'string', 'string']],\n      Verify: ['bool', ['string', 'string', 'string', 'string']],\n      Sign: ['int', ['string', 'string', 'string', 'string']],\n      GetPublicKey: ['int', ['string', 'string']],\n    }\n  );\n}\n\nconst curveOrder = new BN(\n  '800000000000010ffffffffffffffffb781126dcae7b2321e66a241adc64d2f',\n  16\n);\n\n/*\n Computes the StarkWare version of the Pedersen hash of x and y.\n Full specification of the hash function can be found here:\n https://docs.starkware.co/starkex-docs/crypto/pedersen-hash-function\n*/\nfunction pedersen(x, y) {\n  const x_buf = BigIntBuffer.toBufferLE(x, 32);\n  const y_buf = BigIntBuffer.toBufferLE(y, 32);\n  const res_buf = Buffer.alloc(1024);\n  const res = libcrypto.Hash(x_buf, y_buf, res_buf);\n  assert.strict(res == 0, 'Error: ' + res_buf.toString('utf-8'));\n  return BigIntBuffer.toBigIntLE(res_buf);\n}\n\n/*\n Verifies ECDSA signature of a given message hash z with a given public key.\n Returns true if public_key signs the message.\n NOTE: This function assumes that the public_key is on the curve.\n*/\nfunction verify(stark_key, message_hash, r, s) {\n  const stark_key_buf = BigIntBuffer.toBufferLE(stark_key, 32);\n  const message_hash_buf = BigIntBuffer.toBufferLE(message_hash, 32);\n  const r_buf = BigIntBuffer.toBufferLE(r, 32);\n  const bnS = new BN(s.toString(16), 16);\n  const w = BigInt('0x' + bnS.invm(curveOrder).toString(16), 16);\n  const s_buf = BigIntBuffer.toBufferLE(w, 32);\n  return libcrypto.Verify(stark_key_buf, message_hash_buf, r_buf, s_buf);\n}\n\n/*\n Signs the given message hash with the provided private_key, with randomness k.\n\n NOTE: k should be a strong cryptographical random, and not repeat.\n See: https://tools.ietf.org/html/rfc6979.\n*/\nfunction sign(private_key, message, k) {\n  const private_key_buf = BigIntBuffer.toBufferLE(private_key, 32);\n  const message_buf = BigIntBuffer.toBufferLE(message, 32);\n  const k_buf = BigIntBuffer.toBufferLE(k, 32);\n  const res_buf = Buffer.alloc(1024);\n  const res = libcrypto.Sign(private_key_buf, message_buf, k_buf, res_buf);\n  assert.strict(res == 0, 'Error: ' + res_buf.toString('utf-8'));\n  const r = BigIntBuffer.toBigIntLE(res_buf.slice(0, 32));\n  const w = BigIntBuffer.toBigIntLE(res_buf.slice(32, 64));\n  const bnW = new BN(w.toString(16), 16);\n  const s = BigInt('0x' + bnW.invm(curveOrder).toString(16), 16);\n  return { r: r, s: s };\n}\n\n/*\n Deduces the public key given a private key.\n The x coordinate of the public key is also known as the partial public key,\n and used in StarkEx to identify the user.\n*/\nfunction getPublicKey(private_key) {\n  const private_key_buf = BigIntBuffer.toBufferLE(private_key, 32);\n  const res_buf = Buffer.alloc(1024);\n  const res = libcrypto.GetPublicKey(private_key_buf, res_buf);\n  assert.strict(res == 0, 'Error: ' + res_buf.toString('utf-8'));\n  return BigIntBuffer.toBigIntLE(res_buf);\n}\n\nmodule.exports = {\n  pedersen,\n  sign,\n  verify,\n  getPublicKey,\n  useCryptoCpp,\n};\n"]} |
@@ -8,3 +8,2 @@ export function pedersen(input: any): any; | ||
export function verify(publicKey: any, msgHash: any, msgSignature: any): any; | ||
export const useCryptoCpp: boolean; | ||
export const prime: BN; | ||
@@ -11,0 +10,0 @@ export const maxEcdsaVal: BN; |
@@ -6,5 +6,4 @@ { | ||
"license": "MIT", | ||
"version": "1.3.1-beta.7", | ||
"version": "1.3.1-beta.8", | ||
"main": "lib.js", | ||
"browser": "lib-browser.js", | ||
"dependencies": { | ||
@@ -61,2 +60,3 @@ "bigint-buffer": "^1.1.5", | ||
"prepublish": "yarn run build", | ||
"install": "(test -n \"$USE_STARKWARE_CRYPTO_CPP\" && node-gyp rebuild) || true", | ||
"postinstall": "patch-package", | ||
@@ -76,5 +76,3 @@ "test": "jest ./src", | ||
"lib.js", | ||
"lib-browser.js", | ||
"lib.d.ts", | ||
"lib-browser.d.ts" | ||
"lib.d.ts" | ||
], | ||
@@ -81,0 +79,0 @@ "browserslist": [ |
@@ -44,3 +44,3 @@ <!-- logo --> | ||
Starting from v1.2.0, C++ bindings can be used for faster `verifyTransfer` and `verifyLimitOrder` operations. It uses Starkware's [crypto-cpp](https://github.com/starkware-libs/crypto-cpp) library and can be enabled by adding `USE_STARKWARE_CRYPTO_CPP=true` to your env. Please also note that `yarn install` will build C++ bindings (using [node-gyp](https://github.com/nodejs/node-gyp)) starting from this version. | ||
Starting from v1.3.2, C++ bindings can be used for faster `verifyTransfer` and `verifyLimitOrder` operations. It uses Starkware's [crypto-cpp](https://github.com/starkware-libs/crypto-cpp) library and can be enabled by adding `USE_STARKWARE_CRYPTO_CPP=true` to your env. Please note that this variable also needs to be set when `yarn install` runs in order to build the C++ bindings using [node-gyp](https://github.com/nodejs/node-gyp). | ||
@@ -47,0 +47,0 @@ # License |
Sorry, the diff of this file is too big to display
2
719319
57
1075