@mainsail/crypto-signature-ecdsa 0.0.1-evm.2 → 0.0.1-evm.21
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.
- package/distribution/index.d.ts.map +1 -1
- package/distribution/index.js +16 -12
- package/distribution/index.js.map +1 -1
- package/distribution/signature.d.ts +3 -1
- package/distribution/signature.d.ts.map +1 -1
- package/distribution/signature.js +22 -2
- package/distribution/signature.js.map +1 -1
- package/package.json +7 -7
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAI7C,qBACa,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAYtC"}
|
package/distribution/index.js
CHANGED
@@ -1,24 +1,28 @@
|
|
1
|
-
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
6
|
+
};
|
7
|
+
import { injectable, Selectors } from "@mainsail/container";
|
2
8
|
import { Identifiers } from "@mainsail/contracts";
|
3
9
|
import { Providers } from "@mainsail/kernel";
|
4
10
|
import { Signature } from "./signature.js";
|
5
|
-
|
11
|
+
let ServiceProvider = class ServiceProvider extends Providers.ServiceProvider {
|
6
12
|
async register() {
|
7
13
|
this.app
|
8
14
|
.bind(Identifiers.Cryptography.Signature.Size)
|
9
|
-
.
|
10
|
-
|
11
|
-
buffer.skip(1);
|
12
|
-
const lengthHex = buffer.readBytes(1).toString("hex");
|
13
|
-
buffer.reset();
|
14
|
-
return Number.parseInt(lengthHex, 16) + 2;
|
15
|
-
})
|
16
|
-
.when(Selectors.anyAncestorOrTargetTaggedFirst("type", "wallet"));
|
15
|
+
.toConstantValue(32 + /* r */ 32 + /* s */ +1 /* v */)
|
16
|
+
.when(Selectors.anyAncestorOrTargetTagged("type", "wallet"));
|
17
17
|
this.app
|
18
18
|
.bind(Identifiers.Cryptography.Signature.Instance)
|
19
19
|
.to(Signature)
|
20
20
|
.inSingletonScope()
|
21
|
-
.when(Selectors.
|
21
|
+
.when(Selectors.anyAncestorOrTargetTagged("type", "wallet"));
|
22
22
|
}
|
23
|
-
}
|
23
|
+
};
|
24
|
+
ServiceProvider = __decorate([
|
25
|
+
injectable()
|
26
|
+
], ServiceProvider);
|
27
|
+
export { ServiceProvider };
|
24
28
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAGpC,IAAM,eAAe,GAArB,MAAM,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,eAAe,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;aACrD,IAAI,CAAC,SAAS,CAAC,yBAAyB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QAE9D,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,yBAAyB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;IAC/D,CAAC;CACD,CAAA;AAbY,eAAe;IAD3B,UAAU,EAAE;GACA,eAAe,CAa3B"}
|
@@ -1,4 +1,3 @@
|
|
1
|
-
/// <reference types="node" resolution-mode="require"/>
|
2
1
|
import { Contracts } from "@mainsail/contracts";
|
3
2
|
import { ByteBuffer } from "@mainsail/utils";
|
4
3
|
export declare class Signature implements Contracts.Crypto.Signature {
|
@@ -8,5 +7,8 @@ export declare class Signature implements Contracts.Crypto.Signature {
|
|
8
7
|
serialize(buffer: ByteBuffer, signature: string): void;
|
9
8
|
deserialize(buffer: ByteBuffer): Buffer;
|
10
9
|
aggregate(signatures: Buffer[]): Promise<string>;
|
10
|
+
signRecoverable(message: Buffer, privateKey: Buffer): Promise<Contracts.Crypto.EcdsaSignature>;
|
11
|
+
verifyRecoverable(signature: Contracts.Crypto.EcdsaSignature, message: Buffer, publicKey: Buffer): Promise<boolean>;
|
12
|
+
recoverPublicKey(message: Buffer, signature: Contracts.Crypto.EcdsaSignature): string;
|
11
13
|
}
|
12
14
|
//# sourceMappingURL=signature.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"signature.d.ts","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":"
|
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"}
|
@@ -46,15 +46,35 @@ let Signature = class Signature {
|
|
46
46
|
buffer.writeBytes(Buffer.from(signature, "hex"));
|
47
47
|
}
|
48
48
|
deserialize(buffer) {
|
49
|
-
return buffer.readBytes(this.signatureSize
|
49
|
+
return buffer.readBytes(this.signatureSize);
|
50
50
|
}
|
51
51
|
async aggregate(signatures) {
|
52
52
|
throw new Exceptions.NotImplemented(this.constructor.name, "aggregate");
|
53
53
|
}
|
54
|
+
async signRecoverable(message, privateKey) {
|
55
|
+
const [signature, recoverId] = secp256k1.signRecoverable(message, privateKey);
|
56
|
+
return {
|
57
|
+
r: signature.slice(0, 32).toString("hex"),
|
58
|
+
s: signature.slice(32, 64).toString("hex"),
|
59
|
+
v: recoverId,
|
60
|
+
};
|
61
|
+
}
|
62
|
+
async verifyRecoverable(signature, message, publicKey) {
|
63
|
+
const signatureRS = Buffer.from(signature.r + signature.s, "hex");
|
64
|
+
if (!secp256k1.isLowS(signatureRS)) {
|
65
|
+
return false;
|
66
|
+
}
|
67
|
+
return secp256k1.verify(message, signatureRS, publicKey);
|
68
|
+
}
|
69
|
+
recoverPublicKey(message, signature) {
|
70
|
+
const v = signature.v;
|
71
|
+
const signatureRS = Buffer.from(signature.r + signature.s, "hex");
|
72
|
+
return secp256k1.recover(message, signatureRS, v, true).toString("hex");
|
73
|
+
}
|
54
74
|
};
|
55
75
|
__decorate([
|
56
76
|
inject(Identifiers.Cryptography.Signature.Size),
|
57
|
-
__metadata("design:type",
|
77
|
+
__metadata("design:type", Number)
|
58
78
|
], Signature.prototype, "signatureSize", void 0);
|
59
79
|
Signature = __decorate([
|
60
80
|
injectable()
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"signature.js","sourceRoot":"","sources":["../source/signature.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAa,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEzE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAG7B,IAAM,SAAS,GAAf,MAAM,SAAS;IAId,KAAK,CAAC,IAAI,CAAC,OAAe,EAAE,UAAkB;QACpD,OAAO,SAAS,CAAC,eAAe,CAAC,SAAS,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,SAAS,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAEzD,IAAI,CAAC,SAAS,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,SAAS,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;
|
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.
|
3
|
+
"version": "0.0.1-evm.21",
|
4
4
|
"description": "Elliptic Curve Cryptography (ECDSA) signatures for the Mainsail blockchain",
|
5
5
|
"license": "GPL-3.0-only",
|
6
6
|
"contributors": [],
|
@@ -12,13 +12,13 @@
|
|
12
12
|
],
|
13
13
|
"dependencies": {
|
14
14
|
"bcrypto": "5.5.2",
|
15
|
-
"@mainsail/
|
16
|
-
"@mainsail/
|
17
|
-
"@mainsail/container": "0.0.1-evm.
|
18
|
-
"@mainsail/utils": "0.0.1-evm.
|
15
|
+
"@mainsail/contracts": "0.0.1-evm.21",
|
16
|
+
"@mainsail/kernel": "0.0.1-evm.21",
|
17
|
+
"@mainsail/container": "0.0.1-evm.21",
|
18
|
+
"@mainsail/utils": "0.0.1-evm.21"
|
19
19
|
},
|
20
20
|
"devDependencies": {
|
21
|
-
"uvu": "
|
21
|
+
"uvu": "0.5.6"
|
22
22
|
},
|
23
23
|
"engines": {
|
24
24
|
"node": ">=20.x"
|
@@ -29,7 +29,7 @@
|
|
29
29
|
"clean": "del distribution",
|
30
30
|
"release": "pnpm publish --access public",
|
31
31
|
"test": "pnpm run uvu source .test.ts",
|
32
|
-
"test:coverage": "c8 pnpm run test",
|
32
|
+
"test:coverage": "c8 -r=text -r=lcov --all pnpm run test",
|
33
33
|
"test:coverage:html": "c8 -r html --all pnpm run test",
|
34
34
|
"test:file": "pnpm run uvu source",
|
35
35
|
"uvu": "tsx --tsconfig ../../tsconfig.test.json ./node_modules/uvu/bin.js"
|