@mainsail/crypto-signature-ecdsa 0.0.1-alpha.8 → 0.0.1-evm.1

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.
@@ -1,6 +1,5 @@
1
1
  import { Providers } from "@mainsail/kernel";
2
2
  export declare class ServiceProvider extends Providers.ServiceProvider {
3
3
  register(): Promise<void>;
4
- requiredByWorker(): boolean;
5
4
  }
6
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAK7C,qBAAa,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAsB/B,gBAAgB,IAAI,OAAO;CAGlC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAK7C,qBAAa,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAqBtC"}
@@ -1,14 +1,11 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ServiceProvider = void 0;
4
- const container_1 = require("@mainsail/container");
5
- const contracts_1 = require("@mainsail/contracts");
6
- const kernel_1 = require("@mainsail/kernel");
7
- const signature_1 = require("./signature");
8
- class ServiceProvider extends kernel_1.Providers.ServiceProvider {
1
+ import { Selectors } from "@mainsail/container";
2
+ import { Identifiers } from "@mainsail/contracts";
3
+ import { Providers } from "@mainsail/kernel";
4
+ import { Signature } from "./signature.js";
5
+ export class ServiceProvider extends Providers.ServiceProvider {
9
6
  async register() {
10
7
  this.app
11
- .bind(contracts_1.Identifiers.Cryptography.Signature.Size)
8
+ .bind(Identifiers.Cryptography.Signature.Size)
12
9
  .toFunction((buffer) => {
13
10
  buffer.mark();
14
11
  buffer.skip(1);
@@ -16,16 +13,12 @@ class ServiceProvider extends kernel_1.Providers.ServiceProvider {
16
13
  buffer.reset();
17
14
  return Number.parseInt(lengthHex, 16) + 2;
18
15
  })
19
- .when(container_1.Selectors.anyAncestorOrTargetTaggedFirst("type", "wallet"));
16
+ .when(Selectors.anyAncestorOrTargetTaggedFirst("type", "wallet"));
20
17
  this.app
21
- .bind(contracts_1.Identifiers.Cryptography.Signature.Instance)
22
- .to(signature_1.Signature)
18
+ .bind(Identifiers.Cryptography.Signature.Instance)
19
+ .to(Signature)
23
20
  .inSingletonScope()
24
- .when(container_1.Selectors.anyAncestorOrTargetTaggedFirst("type", "wallet"));
25
- }
26
- requiredByWorker() {
27
- return true;
21
+ .when(Selectors.anyAncestorOrTargetTaggedFirst("type", "wallet"));
28
22
  }
29
23
  }
30
- exports.ServiceProvider = ServiceProvider;
31
24
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":";;;AAAA,mDAAgD;AAChD,mDAAkD;AAClD,6CAA6C;AAG7C,2CAAwC;AAExC,MAAa,eAAgB,SAAQ,kBAAS,CAAC,eAAe;IACtD,KAAK,CAAC,QAAQ;QACpB,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,uBAAW,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC;aAC7C,UAAU,CAAC,CAAC,MAAkB,EAAE,EAAE;YAClC,MAAM,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAEf,MAAM,SAAS,GAAW,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAE9D,MAAM,CAAC,KAAK,EAAE,CAAC;YAEf,OAAO,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;QAC3C,CAAC,CAAC;aACD,IAAI,CAAC,qBAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,uBAAW,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC;aACjD,EAAE,CAAC,qBAAS,CAAC;aACb,gBAAgB,EAAE;aAClB,IAAI,CAAC,qBAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;IACpE,CAAC;IAEM,gBAAgB;QACtB,OAAO,IAAI,CAAC;IACb,CAAC;CACD;AA1BD,0CA0BC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAG7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,MAAM,OAAO,eAAgB,SAAQ,SAAS,CAAC,eAAe;IACtD,KAAK,CAAC,QAAQ;QACpB,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC;aAC7C,UAAU,CAAC,CAAC,MAAkB,EAAE,EAAE;YAClC,MAAM,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAEf,MAAM,SAAS,GAAW,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAE9D,MAAM,CAAC,KAAK,EAAE,CAAC;YAEf,OAAO,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;QAC3C,CAAC,CAAC;aACD,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC;aACjD,EAAE,CAAC,SAAS,CAAC;aACb,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;IACpE,CAAC;CACD"}
@@ -1,4 +1,4 @@
1
- /// <reference types="node" />
1
+ /// <reference types="node" resolution-mode="require"/>
2
2
  import { Contracts } from "@mainsail/contracts";
3
3
  import { ByteBuffer } from "@mainsail/utils";
4
4
  export declare class Signature implements Contracts.Crypto.Signature {
@@ -1,4 +1,3 @@
1
- "use strict";
2
1
  var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
2
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
3
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
@@ -8,18 +7,16 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
8
7
  var __metadata = (this && this.__metadata) || function (k, v) {
9
8
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
9
  };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.Signature = void 0;
13
- const container_1 = require("@mainsail/container");
14
- const contracts_1 = require("@mainsail/contracts");
15
- const bcrypto_1 = require("bcrypto");
10
+ import { inject, injectable } from "@mainsail/container";
11
+ import { Exceptions, Identifiers } from "@mainsail/contracts";
12
+ import { secp256k1 } from "bcrypto";
16
13
  let Signature = class Signature {
17
14
  async sign(message, privateKey) {
18
- return bcrypto_1.secp256k1.signatureExport(bcrypto_1.secp256k1.sign(message, privateKey)).toString("hex");
15
+ return secp256k1.signatureExport(secp256k1.sign(message, privateKey)).toString("hex");
19
16
  }
20
17
  async verify(signature, message, publicKey) {
21
- const signatureRS = bcrypto_1.secp256k1.signatureImport(signature);
22
- if (!bcrypto_1.secp256k1.isLowS(signatureRS)) {
18
+ const signatureRS = secp256k1.signatureImport(signature);
19
+ if (!secp256k1.isLowS(signatureRS)) {
23
20
  return false;
24
21
  }
25
22
  // check that global signature length matches R and S length, see DER format :
@@ -43,7 +40,7 @@ let Signature = class Signature {
43
40
  (sFirstByte === 0 && signature.readInt8(4 + rLength + 2 + 1) >= 0)) {
44
41
  return false;
45
42
  }
46
- return bcrypto_1.secp256k1.verify(message, signatureRS, publicKey);
43
+ return secp256k1.verify(message, signatureRS, publicKey);
47
44
  }
48
45
  serialize(buffer, signature) {
49
46
  buffer.writeBytes(Buffer.from(signature, "hex"));
@@ -52,15 +49,15 @@ let Signature = class Signature {
52
49
  return buffer.readBytes(this.signatureSize(buffer));
53
50
  }
54
51
  async aggregate(signatures) {
55
- throw new contracts_1.Exceptions.NotImplemented(this.constructor.name, "aggregate");
52
+ throw new Exceptions.NotImplemented(this.constructor.name, "aggregate");
56
53
  }
57
54
  };
58
- exports.Signature = Signature;
59
55
  __decorate([
60
- (0, container_1.inject)(contracts_1.Identifiers.Cryptography.Signature.Size),
56
+ inject(Identifiers.Cryptography.Signature.Size),
61
57
  __metadata("design:type", Function)
62
58
  ], Signature.prototype, "signatureSize", void 0);
63
- exports.Signature = Signature = __decorate([
64
- (0, container_1.injectable)()
59
+ Signature = __decorate([
60
+ injectable()
65
61
  ], Signature);
62
+ export { Signature };
66
63
  //# sourceMappingURL=signature.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"signature.js","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAyD;AACzD,mDAAyE;AAEzE,qCAAoC;AAG7B,IAAM,SAAS,GAAf,MAAM,SAAS;IAId,KAAK,CAAC,IAAI,CAAC,OAAe,EAAE,UAAkB;QACpD,OAAO,mBAAS,CAAC,eAAe,CAAC,mBAAS,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvF,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,SAAiB,EAAE,OAAe,EAAE,SAAiB;QACxE,MAAM,WAAW,GAAG,mBAAS,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAEzD,IAAI,CAAC,mBAAS,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;YACpC,OAAO,KAAK,CAAC;QACd,CAAC;QAED,8EAA8E;QAC9E,4FAA4F;QAC5F,MAAM,eAAe,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,OAAO,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,OAAO,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC;QACrD,IACC,SAAS,CAAC,MAAM,KAAK,CAAC,GAAG,OAAO,GAAG,CAAC,GAAG,OAAO;YAC9C,eAAe,KAAK,CAAC,GAAG,OAAO,GAAG,CAAC,GAAG,OAAO;YAC7C,eAAe,GAAG,GAAG,EACpB,CAAC;YACF,OAAO,KAAK,CAAC;QACd,CAAC;QAED,gGAAgG;QAChG,MAAM,UAAU,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,UAAU,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC;QACvD,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,GAAG,IAAI,UAAU,GAAG,GAAG,EAAE,CAAC;YAC9E,OAAO,KAAK,CAAC;QACd,CAAC;QAED,sFAAsF;QACtF,IACC,CAAC,UAAU,KAAK,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YACpD,CAAC,UAAU,KAAK,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAC,GAAG,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,EACjE,CAAC;YACF,OAAO,KAAK,CAAC;QACd,CAAC;QAED,OAAO,mBAAS,CAAC,MAAM,CAAC,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;IAC1D,CAAC;IAEM,SAAS,CAAC,MAAkB,EAAE,SAAiB;QACrD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;IAClD,CAAC;IAEM,WAAW,CAAC,MAAkB;QACpC,OAAO,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,UAAoB;QAC1C,MAAM,IAAI,sBAAU,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IACzE,CAAC;CACD,CAAA;AAzDY,8BAAS;AAEJ;IADhB,IAAA,kBAAM,EAAC,uBAAW,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC;8BACf,QAAQ;gDAAC;oBAF9B,SAAS;IADrB,IAAA,sBAAU,GAAE;GACA,SAAS,CAyDrB"}
1
+ {"version":3,"file":"signature.js","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,9 +1,10 @@
1
1
  {
2
2
  "name": "@mainsail/crypto-signature-ecdsa",
3
- "version": "0.0.1-alpha.8",
3
+ "version": "0.0.1-evm.1",
4
4
  "description": "Elliptic Curve Cryptography (ECDSA) signatures for the Mainsail blockchain",
5
5
  "license": "GPL-3.0-only",
6
6
  "contributors": [],
7
+ "type": "module",
7
8
  "main": "distribution/index.js",
8
9
  "types": "distribution/index.d.ts",
9
10
  "files": [
@@ -11,10 +12,10 @@
11
12
  ],
12
13
  "dependencies": {
13
14
  "bcrypto": "5.5.2",
14
- "@mainsail/container": "0.0.1-alpha.8",
15
- "@mainsail/contracts": "0.0.1-alpha.8",
16
- "@mainsail/kernel": "0.0.1-alpha.8",
17
- "@mainsail/utils": "0.0.1-alpha.8"
15
+ "@mainsail/contracts": "0.0.1-evm.1",
16
+ "@mainsail/container": "0.0.1-evm.1",
17
+ "@mainsail/kernel": "0.0.1-evm.1",
18
+ "@mainsail/utils": "0.0.1-evm.1"
18
19
  },
19
20
  "devDependencies": {
20
21
  "uvu": "^0.5.6"
@@ -27,9 +28,10 @@
27
28
  "build:watch": "pnpm run clean && tsc -w",
28
29
  "clean": "del distribution",
29
30
  "release": "pnpm publish --access public",
30
- "test": "uvu -r tsm source .test.ts",
31
+ "test": "pnpm run uvu source .test.ts",
31
32
  "test:coverage": "c8 pnpm run test",
32
33
  "test:coverage:html": "c8 -r html --all pnpm run test",
33
- "test:file": "uvu -r tsm source"
34
+ "test:file": "pnpm run uvu source",
35
+ "uvu": "tsx --tsconfig ../../tsconfig.test.json ./node_modules/uvu/bin.js"
34
36
  }
35
37
  }