@mainsail/crypto-signature-ecdsa 0.0.1-evm.11 → 0.0.1-evm.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -8,8 +8,8 @@ export declare class Signature implements Contracts.Crypto.Signature {
8
8
  serialize(buffer: ByteBuffer, signature: string): void;
9
9
  deserialize(buffer: ByteBuffer): Buffer;
10
10
  aggregate(signatures: Buffer[]): Promise<string>;
11
- signRecoverable(message: Buffer, privateKey: Buffer): Promise<string>;
12
- verifyRecoverable(signature: Buffer, message: Buffer, publicKey: Buffer): Promise<boolean>;
13
- recoverPublicKey(message: Buffer, signature: Buffer): string;
11
+ signRecoverable(message: Buffer, privateKey: Buffer): Promise<Contracts.Crypto.EcdsaSignature>;
12
+ verifyRecoverable(signature: Contracts.Crypto.EcdsaSignature, message: Buffer, publicKey: Buffer): Promise<boolean>;
13
+ recoverPublicKey(message: Buffer, signature: Contracts.Crypto.EcdsaSignature): string;
14
14
  }
15
15
  //# sourceMappingURL=signature.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signature.d.ts","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAG7C,qBACa,SAAU,YAAW,SAAS,CAAC,MAAM,CAAC,SAAS;IAE3D,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAU;IAE3B,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAI1D,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAsCrF,SAAS,CAAC,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAItD,WAAW,CAAC,MAAM,EAAE,UAAU,GAAG,MAAM;IAIjC,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAIhD,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAKrE,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAShG,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;CAInE"}
1
+ {"version":3,"file":"signature.d.ts","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAG7C,qBACa,SAAU,YAAW,SAAS,CAAC,MAAM,CAAC,SAAS;IAE3D,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAU;IAE3B,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAI1D,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAsCrF,SAAS,CAAC,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAItD,WAAW,CAAC,MAAM,EAAE,UAAU,GAAG,MAAM;IAIjC,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAIhD,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC;IAU9F,iBAAiB,CAC7B,SAAS,EAAE,SAAS,CAAC,MAAM,CAAC,cAAc,EAC1C,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,GACf,OAAO,CAAC,OAAO,CAAC;IASZ,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,CAAC,MAAM,CAAC,cAAc,GAAG,MAAM;CAK5F"}
@@ -53,18 +53,23 @@ let Signature = class Signature {
53
53
  }
54
54
  async signRecoverable(message, privateKey) {
55
55
  const [signature, recoverId] = secp256k1.signRecoverable(message, privateKey);
56
- return Buffer.concat([signature, Buffer.from([recoverId])]).toString("hex");
56
+ return {
57
+ r: signature.slice(0, 32).toString("hex"),
58
+ s: signature.slice(32, 64).toString("hex"),
59
+ v: recoverId + 27,
60
+ };
57
61
  }
58
62
  async verifyRecoverable(signature, message, publicKey) {
59
- const signatureRS = signature.subarray(0, 64);
63
+ const signatureRS = Buffer.from(signature.r + signature.s, "hex");
60
64
  if (!secp256k1.isLowS(signatureRS)) {
61
65
  return false;
62
66
  }
63
67
  return secp256k1.verify(message, signatureRS, publicKey);
64
68
  }
65
69
  recoverPublicKey(message, signature) {
66
- const v = signature.readUint8(64);
67
- return secp256k1.recover(message, signature.subarray(0, 64), v, true).toString("hex");
70
+ const v = signature.v - 27;
71
+ const signatureRS = Buffer.from(signature.r + signature.s, "hex");
72
+ return secp256k1.recover(message, signatureRS, v, true).toString("hex");
68
73
  }
69
74
  };
70
75
  __decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"signature.js","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"signature.js","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mainsail/crypto-signature-ecdsa",
3
- "version": "0.0.1-evm.11",
3
+ "version": "0.0.1-evm.13",
4
4
  "description": "Elliptic Curve Cryptography (ECDSA) signatures for the Mainsail blockchain",
5
5
  "license": "GPL-3.0-only",
6
6
  "contributors": [],
@@ -12,10 +12,10 @@
12
12
  ],
13
13
  "dependencies": {
14
14
  "bcrypto": "5.5.2",
15
- "@mainsail/container": "0.0.1-evm.11",
16
- "@mainsail/kernel": "0.0.1-evm.11",
17
- "@mainsail/utils": "0.0.1-evm.11",
18
- "@mainsail/contracts": "0.0.1-evm.11"
15
+ "@mainsail/container": "0.0.1-evm.13",
16
+ "@mainsail/contracts": "0.0.1-evm.13",
17
+ "@mainsail/utils": "0.0.1-evm.13",
18
+ "@mainsail/kernel": "0.0.1-evm.13"
19
19
  },
20
20
  "devDependencies": {
21
21
  "uvu": "^0.5.6"