@mainsail/crypto-key-pair-bls12-381 0.0.1-alpha.13 → 0.0.1-alpha.15

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.
@@ -0,0 +1,3 @@
1
+ import { IBls } from "@chainsafe/bls/types";
2
+ export declare const getBls: () => Promise<IBls>;
3
+ //# sourceMappingURL=get-bls.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-bls.d.ts","sourceRoot":"","sources":["../source/get-bls.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAG5C,eAAO,MAAM,MAAM,QAAa,QAAQ,IAAI,CAW3C,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { getImplementation } from "@chainsafe/bls/getImplementation";
2
+ let _bls;
3
+ export const getBls = async () => {
4
+ if (!_bls) {
5
+ const runtime = globalThis.process?.release?.name ?? "browser";
6
+ if (runtime === "node") {
7
+ _bls = await getImplementation("blst-native");
8
+ }
9
+ else {
10
+ _bls = await getImplementation("herumi");
11
+ }
12
+ }
13
+ return _bls;
14
+ };
15
+ //# sourceMappingURL=get-bls.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-bls.js","sourceRoot":"","sources":["../source/get-bls.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAGrE,IAAI,IAAsB,CAAC;AAC3B,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,IAAmB,EAAE;IAC/C,IAAI,CAAC,IAAI,EAAE,CAAC;QACX,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,IAAI,SAAS,CAAC;QAC/D,IAAI,OAAO,KAAK,MAAM,EAAE,CAAC;YACxB,IAAI,GAAG,MAAM,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAC/C,CAAC;aAAM,CAAC;YACP,IAAI,GAAG,MAAM,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAC1C,CAAC;IACF,CAAC;IAED,OAAO,IAAI,CAAC;AACb,CAAC,CAAC"}
@@ -1,4 +1,5 @@
1
1
  import { Providers } from "@mainsail/kernel";
2
+ export * from "./get-bls.js";
2
3
  export * from "./pair.js";
3
4
  export * from "./private.js";
4
5
  export * from "./public.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAQ7C,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAEhC,qBAAa,eAAgB,SAAQ,SAAS,CAAC,eAAe;;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IA8B/B,gBAAgB,IAAI,OAAO;CASlC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAQ7C,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAEhC,qBAAa,eAAgB,SAAQ,SAAS,CAAC,eAAe;;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IA8B/B,gBAAgB,IAAI,OAAO;CASlC"}
@@ -12,6 +12,7 @@ import { PrivateKeyFactory } from "./private.js";
12
12
  import { PublicKeyFactory } from "./public.js";
13
13
  import { schemas } from "./schemas.js";
14
14
  import { PublicKeySerializer } from "./serializer.js";
15
+ export * from "./get-bls.js";
15
16
  export * from "./pair.js";
16
17
  export * from "./private.js";
17
18
  export * from "./public.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAa,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEtD,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAEhC,MAAM,OAAO,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAA9D;;;IAwCA,CAAC;IAvCO,KAAK,CAAC,QAAQ;QACpB,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC;aACtD,eAAe,CAAC,EAAE,CAAC;aACnB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC;aACvD,EAAE,CAAC,cAAc,CAAC;aAClB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC;aAC1D,EAAE,CAAC,iBAAiB,CAAC;aACrB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC;aACzD,EAAE,CAAC,gBAAgB,CAAC;aACpB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,UAAU,CAAC;aAC5D,EAAE,CAAC,mBAAmB,CAAC;aACvB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEnE,uBAAA,IAAI,oEAAiB,MAArB,IAAI,CAAmB,CAAC;IACzB,CAAC;IAEM,gBAAgB;QACtB,OAAO,IAAI,CAAC;IACb,CAAC;CAOD;;IAJC,KAAK,MAAM,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAC7C,IAAI,CAAC,GAAG,CAAC,GAAG,CAA6B,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAChG,CAAC;AACF,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAa,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEtD,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAEhC,MAAM,OAAO,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAA9D;;;IAwCA,CAAC;IAvCO,KAAK,CAAC,QAAQ;QACpB,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC;aACtD,eAAe,CAAC,EAAE,CAAC;aACnB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC;aACvD,EAAE,CAAC,cAAc,CAAC;aAClB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC;aAC1D,EAAE,CAAC,iBAAiB,CAAC;aACrB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC;aACzD,EAAE,CAAC,gBAAgB,CAAC;aACpB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,GAAG;aACN,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,UAAU,CAAC;aAC5D,EAAE,CAAC,mBAAmB,CAAC;aACvB,gBAAgB,EAAE;aAClB,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEnE,uBAAA,IAAI,oEAAiB,MAArB,IAAI,CAAmB,CAAC;IACzB,CAAC;IAEM,gBAAgB;QACtB,OAAO,IAAI,CAAC;IACb,CAAC;CAOD;;IAJC,KAAK,MAAM,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAC7C,IAAI,CAAC,GAAG,CAAC,GAAG,CAA6B,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAChG,CAAC;AACF,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"pair.d.ts","sourceRoot":"","sources":["../source/pair.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAK7D,qBACa,cAAe,YAAW,SAAS,CAAC,MAAM,CAAC,cAAc;;IAErE,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAEnD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC;IAIjE,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC;IAIrE,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC;CAmBpE"}
1
+ {"version":3,"file":"pair.d.ts","sourceRoot":"","sources":["../source/pair.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAO7D,qBACa,cAAe,YAAW,SAAS,CAAC,MAAM,CAAC,cAAc;;IAErE,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAkC;IAEnD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC;IAIjE,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC;IAIrE,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC;CAsBpE"}
@@ -13,12 +13,12 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
13
13
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
14
14
  };
15
15
  var _KeyPairFactory_instances, _KeyPairFactory_fromPrivateKey;
16
- import { SecretKey } from "@chainsafe/blst";
17
16
  import { inject, injectable } from "@mainsail/container";
18
17
  import { Contracts, Identifiers } from "@mainsail/contracts";
19
18
  import { mnemonicToSeedSync } from "@scure/bip39";
20
19
  import { deriveChild, deriveMaster } from "bls12-381-keygen";
21
20
  import WIF from "wif";
21
+ import { getBls } from "./get-bls.js";
22
22
  let KeyPairFactory = class KeyPairFactory {
23
23
  constructor() {
24
24
  _KeyPairFactory_instances.add(this);
@@ -30,18 +30,20 @@ let KeyPairFactory = class KeyPairFactory {
30
30
  return __classPrivateFieldGet(this, _KeyPairFactory_instances, "m", _KeyPairFactory_fromPrivateKey).call(this, privateKey);
31
31
  }
32
32
  async fromWIF(wif) {
33
+ const bls = await getBls();
33
34
  const decoded = WIF.decode(wif, this.configuration.get("network.wif"));
34
35
  const privateKey = Buffer.from(decoded.privateKey);
35
36
  return {
36
37
  compressed: decoded.compressed,
37
38
  privateKey: privateKey.toString("hex"),
38
- publicKey: Buffer.from(SecretKey.fromBytes(decoded.privateKey).toPublicKey().toBytes()).toString("hex"),
39
+ publicKey: Buffer.from(bls.SecretKey.fromBytes(decoded.privateKey).toPublicKey().toBytes()).toString("hex"),
39
40
  };
40
41
  }
41
42
  };
42
43
  _KeyPairFactory_instances = new WeakSet();
43
- _KeyPairFactory_fromPrivateKey = function _KeyPairFactory_fromPrivateKey(privateKey) {
44
- const secretKey = SecretKey.fromBytes(privateKey);
44
+ _KeyPairFactory_fromPrivateKey = async function _KeyPairFactory_fromPrivateKey(privateKey) {
45
+ const bls = await getBls();
46
+ const secretKey = bls.SecretKey.fromBytes(privateKey);
45
47
  return {
46
48
  compressed: true,
47
49
  privateKey: Buffer.from(privateKey).toString("hex"),
@@ -1 +1 @@
1
- {"version":3,"file":"pair.js","sourceRoot":"","sources":["../source/pair.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,GAAG,MAAM,KAAK,CAAC;AAGf,IAAM,cAAc,GAApB,MAAM,cAAc;IAApB;;IA+BP,CAAC;IA3BO,KAAK,CAAC,YAAY,CAAC,QAAgB;QACzC,OAAO,uBAAA,IAAI,iEAAgB,MAApB,IAAI,EAAiB,WAAW,CAAC,YAAY,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACzF,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,UAAkB;QAC7C,OAAO,uBAAA,IAAI,iEAAgB,MAApB,IAAI,EAAiB,UAAU,CAAC,CAAC;IACzC,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,GAAW;QAC/B,MAAM,OAAO,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC;QACvE,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAEnD,OAAO;YACN,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,UAAU,EAAE,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC;YACtC,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;SACvG,CAAC;IACH,CAAC;CAUD,CAAA;;yEARgB,UAAsB;IACrC,MAAM,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IAClD,OAAO;QACN,UAAU,EAAE,IAAI;QAChB,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;QACnD,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KACzE,CAAC;AACH,CAAC;AA5BgB;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;qDACiB;AAFpD,cAAc;IAD1B,UAAU,EAAE;GACA,cAAc,CA+B1B"}
1
+ {"version":3,"file":"pair.js","sourceRoot":"","sources":["../source/pair.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,GAAG,MAAM,KAAK,CAAC;AAEtB,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAG/B,IAAM,cAAc,GAApB,MAAM,cAAc;IAApB;;IAkCP,CAAC;IA9BO,KAAK,CAAC,YAAY,CAAC,QAAgB;QACzC,OAAO,uBAAA,IAAI,iEAAgB,MAApB,IAAI,EAAiB,WAAW,CAAC,YAAY,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACzF,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,UAAkB;QAC7C,OAAO,uBAAA,IAAI,iEAAgB,MAApB,IAAI,EAAiB,UAAU,CAAC,CAAC;IACzC,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,GAAW;QAC/B,MAAM,GAAG,GAAG,MAAM,MAAM,EAAE,CAAC;QAC3B,MAAM,OAAO,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC;QACvE,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAEnD,OAAO;YACN,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,UAAU,EAAE,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC;YACtC,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;SAC3G,CAAC;IACH,CAAC;CAYD,CAAA;;iCAVA,KAAK,yCAAiB,UAAsB;IAC3C,MAAM,GAAG,GAAG,MAAM,MAAM,EAAE,CAAC;IAE3B,MAAM,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACtD,OAAO;QACN,UAAU,EAAE,IAAI;QAChB,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;QACnD,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KACzE,CAAC;AACH,CAAC;AA/BgB;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC;;qDACiB;AAFpD,cAAc;IAD1B,UAAU,EAAE;GACA,cAAc,CAkC1B"}
@@ -1 +1 @@
1
- {"version":3,"file":"public.d.ts","sourceRoot":"","sources":["../source/public.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAE7D,qBACa,gBAAiB,YAAW,SAAS,CAAC,MAAM,CAAC,gBAAgB;IAEzE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAmC;IAErD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAI/C,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAIrC,uBAAuB,CAAC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC;IAMrF,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAU3C,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;CAK7D"}
1
+ {"version":3,"file":"public.d.ts","sourceRoot":"","sources":["../source/public.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAA2B,MAAM,qBAAqB,CAAC;AAIzE,qBACa,gBAAiB,YAAW,SAAS,CAAC,MAAM,CAAC,gBAAgB;IAEzE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAmC;IAErD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAI/C,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAIrC,uBAAuB,CAAC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC;IAIrF,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAY3C,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;CAM7D"}
@@ -7,9 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
7
7
  var __metadata = (this && this.__metadata) || function (k, v) {
8
8
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
9
  };
10
- import { aggregatePubkeys, PublicKey } from "@chainsafe/blst";
11
10
  import { inject, injectable } from "@mainsail/container";
12
- import { Contracts, Identifiers } from "@mainsail/contracts";
11
+ import { Contracts, Exceptions, Identifiers } from "@mainsail/contracts";
12
+ import { getBls } from "./get-bls.js";
13
13
  let PublicKeyFactory = class PublicKeyFactory {
14
14
  async fromMnemonic(mnemonic) {
15
15
  return (await this.keyPairFactory.fromMnemonic(mnemonic)).publicKey;
@@ -18,11 +18,12 @@ let PublicKeyFactory = class PublicKeyFactory {
18
18
  return (await this.keyPairFactory.fromWIF(wif)).publicKey;
19
19
  }
20
20
  async fromMultiSignatureAsset(asset) {
21
- return Buffer.from(aggregatePubkeys(asset.publicKeys.map((pub) => PublicKey.fromBytes(Buffer.from(pub, "hex")))).toBytes()).toString("hex");
21
+ throw new Exceptions.NotImplemented(this.constructor.name, "fromMultiSignatureAsset");
22
22
  }
23
23
  async verify(publicKey) {
24
+ const bls = await getBls();
24
25
  try {
25
- PublicKey.fromBytes(Buffer.from(publicKey, "hex")).keyValidate();
26
+ bls.PublicKey.fromBytes(Buffer.from(publicKey, "hex"), undefined, true);
26
27
  }
27
28
  catch {
28
29
  return false;
@@ -30,7 +31,8 @@ let PublicKeyFactory = class PublicKeyFactory {
30
31
  return true;
31
32
  }
32
33
  async aggregate(publicKeys) {
33
- return Buffer.from(aggregatePubkeys(publicKeys.map((pub) => PublicKey.fromBytes(pub))).toBytes()).toString("hex");
34
+ const bls = await getBls();
35
+ return Buffer.from(bls.aggregatePublicKeys(publicKeys.map((pub) => bls.PublicKey.fromBytes(pub).toBytes()))).toString("hex");
34
36
  }
35
37
  };
36
38
  __decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"public.js","sourceRoot":"","sources":["../source/public.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGtD,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAIrB,KAAK,CAAC,YAAY,CAAC,QAAgB;QACzC,OAAO,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IACrE,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,GAAW;QAC/B,OAAO,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC;IAC3D,CAAC;IAEM,KAAK,CAAC,uBAAuB,CAAC,KAA2C;QAC/E,OAAO,MAAM,CAAC,IAAI,CACjB,gBAAgB,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CACvG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACnB,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,SAAiB;QACpC,IAAI,CAAC;YACJ,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAClE,CAAC;QAAC,MAAM,CAAC;YACR,OAAO,KAAK,CAAC;QACd,CAAC;QAED,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,UAAoB;QAC1C,OAAO,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CACzG,KAAK,CACL,CAAC;IACH,CAAC;CACD,CAAA;AA/BiB;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC;;wDACQ;AAFtD,gBAAgB;IAD5B,UAAU,EAAE;GACA,gBAAgB,CAiC5B"}
1
+ {"version":3,"file":"public.js","sourceRoot":"","sources":["../source/public.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEzE,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAG/B,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAIrB,KAAK,CAAC,YAAY,CAAC,QAAgB;QACzC,OAAO,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IACrE,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,GAAW;QAC/B,OAAO,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC;IAC3D,CAAC;IAEM,KAAK,CAAC,uBAAuB,CAAC,KAA2C;QAC/E,MAAM,IAAI,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,yBAAyB,CAAC,CAAC;IACvF,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,SAAiB;QACpC,MAAM,GAAG,GAAG,MAAM,MAAM,EAAE,CAAC;QAE3B,IAAI,CAAC;YACJ,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QACzE,CAAC;QAAC,MAAM,CAAC;YACR,OAAO,KAAK,CAAC;QACd,CAAC;QAED,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,UAAoB;QAC1C,MAAM,GAAG,GAAG,MAAM,MAAM,EAAE,CAAC;QAC3B,OAAO,MAAM,CAAC,IAAI,CACjB,GAAG,CAAC,mBAAmB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CACxF,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACnB,CAAC;CACD,CAAA;AAhCiB;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC;;wDACQ;AAFtD,gBAAgB;IAD5B,UAAU,EAAE;GACA,gBAAgB,CAkC5B"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mainsail/crypto-key-pair-bls12-381",
3
- "version": "0.0.1-alpha.13",
3
+ "version": "0.0.1-alpha.15",
4
4
  "description": "BLS12-381 key derivation for the Mainsail blockchain",
5
5
  "license": "GPL-3.0-only",
6
6
  "contributors": [],
@@ -11,22 +11,23 @@
11
11
  "distribution"
12
12
  ],
13
13
  "dependencies": {
14
+ "@chainsafe/bls": "^7.1.3",
14
15
  "@chainsafe/blst": "^0.2.10",
15
16
  "@scure/bip39": "^1.2.2",
16
17
  "bls12-381-keygen": "^0.2.3",
17
18
  "wif": "^4.0.0",
18
- "@mainsail/container": "0.0.1-alpha.13",
19
- "@mainsail/contracts": "0.0.1-alpha.13",
20
- "@mainsail/kernel": "0.0.1-alpha.13",
21
- "@mainsail/utils": "0.0.1-alpha.13"
19
+ "@mainsail/container": "0.0.1-alpha.15",
20
+ "@mainsail/kernel": "0.0.1-alpha.15",
21
+ "@mainsail/contracts": "0.0.1-alpha.15",
22
+ "@mainsail/utils": "0.0.1-alpha.15"
22
23
  },
23
24
  "devDependencies": {
24
25
  "@types/wif": "^2.0.5",
25
26
  "bip39": "3.1.0",
26
27
  "uvu": "^0.5.6",
27
- "@mainsail/crypto-config": "0.0.1-alpha.13",
28
- "@mainsail/validation": "0.0.1-alpha.13",
29
- "@mainsail/crypto-validation": "0.0.1-alpha.13"
28
+ "@mainsail/crypto-config": "0.0.1-alpha.15",
29
+ "@mainsail/crypto-validation": "0.0.1-alpha.15",
30
+ "@mainsail/validation": "0.0.1-alpha.15"
30
31
  },
31
32
  "engines": {
32
33
  "node": ">=20.x"
@@ -36,9 +37,10 @@
36
37
  "build:watch": "pnpm run clean && tsc -w",
37
38
  "clean": "del distribution",
38
39
  "release": "pnpm publish --access public",
39
- "test": "uvu -r tsm source .test.ts",
40
+ "test": "pnpm run uvu source .test.ts",
40
41
  "test:coverage": "c8 pnpm run test",
41
42
  "test:coverage:html": "c8 -r html --all pnpm run test",
42
- "test:file": "uvu -r tsm source"
43
+ "test:file": "pnpm run uvu source",
44
+ "uvu": "tsx --tsconfig ../../tsconfig.test.json ./node_modules/uvu/bin.js"
43
45
  }
44
46
  }