@lindorm/rsa 0.1.0
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/CHANGELOG.md +10 -0
- package/README.md +1 -0
- package/dist/classes/RsaKit.d.ts +11 -0
- package/dist/classes/RsaKit.d.ts.map +1 -0
- package/dist/classes/RsaKit.js +42 -0
- package/dist/classes/RsaKit.js.map +1 -0
- package/dist/classes/index.d.ts +2 -0
- package/dist/classes/index.d.ts.map +1 -0
- package/dist/classes/index.js +18 -0
- package/dist/classes/index.js.map +1 -0
- package/dist/enums/RsaAlgorithm.d.ts +9 -0
- package/dist/enums/RsaAlgorithm.d.ts.map +1 -0
- package/dist/enums/RsaAlgorithm.js +13 -0
- package/dist/enums/RsaAlgorithm.js.map +1 -0
- package/dist/enums/RsaFormat.d.ts +6 -0
- package/dist/enums/RsaFormat.d.ts.map +1 -0
- package/dist/enums/RsaFormat.js +10 -0
- package/dist/enums/RsaFormat.js.map +1 -0
- package/dist/enums/index.d.ts +3 -0
- package/dist/enums/index.d.ts.map +1 -0
- package/dist/enums/index.js +19 -0
- package/dist/enums/index.js.map +1 -0
- package/dist/errors/RsaError.d.ts +4 -0
- package/dist/errors/RsaError.d.ts.map +1 -0
- package/dist/errors/RsaError.js +8 -0
- package/dist/errors/RsaError.js.map +1 -0
- package/dist/errors/index.d.ts +2 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +18 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +20 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/rsa-signature-class.d.ts +8 -0
- package/dist/types/rsa-signature-class.d.ts.map +1 -0
- package/dist/types/rsa-signature-class.js +3 -0
- package/dist/types/rsa-signature-class.js.map +1 -0
- package/dist/types/rsa-signature.d.ts +16 -0
- package/dist/types/rsa-signature.d.ts.map +1 -0
- package/dist/types/rsa-signature.js +3 -0
- package/dist/types/rsa-signature.js.map +1 -0
- package/dist/types/types.d.ts +3 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/types.js +3 -0
- package/dist/types/types.js.map +1 -0
- package/dist/utils/private/rsa-signature.d.ts +5 -0
- package/dist/utils/private/rsa-signature.d.ts.map +1 -0
- package/dist/utils/private/rsa-signature.js +39 -0
- package/dist/utils/private/rsa-signature.js.map +1 -0
- package/package.json +33 -0
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
# Change Log
|
|
2
|
+
|
|
3
|
+
All notable changes to this project will be documented in this file.
|
|
4
|
+
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
|
+
|
|
6
|
+
# 0.1.0 (2024-05-11)
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
- initialise rsa package ([e16e47b](https://github.com/lindorm-io/monorepo/commit/e16e47b7263ee4b5392f2219df9f20355eb7fd45))
|
package/README.md
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
# @lindorm/rsa
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { RsaKitOptions } from "../types";
|
|
2
|
+
export declare class RsaKit {
|
|
3
|
+
private readonly algorithm;
|
|
4
|
+
private readonly format;
|
|
5
|
+
private readonly kryptos;
|
|
6
|
+
constructor(options: RsaKitOptions);
|
|
7
|
+
sign(data: string): string;
|
|
8
|
+
verify(data: string, signature: string): boolean;
|
|
9
|
+
assert(data: string, signature: string): void;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=RsaKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaKit.d.ts","sourceRoot":"","sources":["../../src/classes/RsaKit.ts"],"names":[],"mappings":"AACA,OAAO,EAAgB,aAAa,EAAsB,MAAM,UAAU,CAAC;AAO3E,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAqB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAe;IACtC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAU;gBAEf,OAAO,EAAE,aAAa;IAMlC,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAS1B,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO;IAUhD,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;CASrD"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RsaKit = void 0;
|
|
4
|
+
const rsa_signature_1 = require("../utils/private/rsa-signature");
|
|
5
|
+
class RsaKit {
|
|
6
|
+
algorithm;
|
|
7
|
+
format;
|
|
8
|
+
kryptos;
|
|
9
|
+
constructor(options) {
|
|
10
|
+
this.algorithm = options.algorithm || "RSA-SHA256";
|
|
11
|
+
this.format = options.format || "base64url";
|
|
12
|
+
this.kryptos = options.kryptos;
|
|
13
|
+
}
|
|
14
|
+
sign(data) {
|
|
15
|
+
return (0, rsa_signature_1.createRsaSignature)({
|
|
16
|
+
algorithm: this.algorithm,
|
|
17
|
+
data,
|
|
18
|
+
format: this.format,
|
|
19
|
+
kryptos: this.kryptos,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
verify(data, signature) {
|
|
23
|
+
return (0, rsa_signature_1.verifyRsaSignature)({
|
|
24
|
+
algorithm: this.algorithm,
|
|
25
|
+
data,
|
|
26
|
+
format: this.format,
|
|
27
|
+
kryptos: this.kryptos,
|
|
28
|
+
signature,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
assert(data, signature) {
|
|
32
|
+
return (0, rsa_signature_1.assertRsaSignature)({
|
|
33
|
+
algorithm: this.algorithm,
|
|
34
|
+
data,
|
|
35
|
+
format: this.format,
|
|
36
|
+
kryptos: this.kryptos,
|
|
37
|
+
signature,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.RsaKit = RsaKit;
|
|
42
|
+
//# sourceMappingURL=RsaKit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaKit.js","sourceRoot":"","sources":["../../src/classes/RsaKit.ts"],"names":[],"mappings":";;;AAEA,kEAIwC;AAExC,MAAa,MAAM;IACA,SAAS,CAAqB;IAC9B,MAAM,CAAe;IACrB,OAAO,CAAU;IAElC,YAAmB,OAAsB;QACvC,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,YAAY,CAAC;QACnD,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,WAAW,CAAC;QAC5C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IACjC,CAAC;IAEM,IAAI,CAAC,IAAY;QACtB,OAAO,IAAA,kCAAkB,EAAC;YACxB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,IAAI;YACJ,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,IAAY,EAAE,SAAiB;QAC3C,OAAO,IAAA,kCAAkB,EAAC;YACxB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,IAAI;YACJ,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS;SACV,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,IAAY,EAAE,SAAiB;QAC3C,OAAO,IAAA,kCAAkB,EAAC;YACxB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,IAAI;YACJ,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS;SACV,CAAC,CAAC;IACL,CAAC;CACF;AAvCD,wBAuCC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/classes/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./RsaKit"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/classes/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaAlgorithm.d.ts","sourceRoot":"","sources":["../../src/enums/RsaAlgorithm.ts"],"names":[],"mappings":"AAAA,oBAAY,YAAY;IACtB,UAAU,eAAe;IACzB,UAAU,eAAe;IACzB,UAAU,eAAe;IACzB,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,MAAM,WAAW;CAClB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RsaAlgorithm = void 0;
|
|
4
|
+
var RsaAlgorithm;
|
|
5
|
+
(function (RsaAlgorithm) {
|
|
6
|
+
RsaAlgorithm["RSA_SHA256"] = "RSA-SHA256";
|
|
7
|
+
RsaAlgorithm["RSA_SHA384"] = "RSA-SHA384";
|
|
8
|
+
RsaAlgorithm["RSA_SHA512"] = "RSA-SHA512";
|
|
9
|
+
RsaAlgorithm["SHA256"] = "sha256";
|
|
10
|
+
RsaAlgorithm["SHA384"] = "sha384";
|
|
11
|
+
RsaAlgorithm["SHA512"] = "sha512";
|
|
12
|
+
})(RsaAlgorithm || (exports.RsaAlgorithm = RsaAlgorithm = {}));
|
|
13
|
+
//# sourceMappingURL=RsaAlgorithm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaAlgorithm.js","sourceRoot":"","sources":["../../src/enums/RsaAlgorithm.ts"],"names":[],"mappings":";;;AAAA,IAAY,YAOX;AAPD,WAAY,YAAY;IACtB,yCAAyB,CAAA;IACzB,yCAAyB,CAAA;IACzB,yCAAyB,CAAA;IACzB,iCAAiB,CAAA;IACjB,iCAAiB,CAAA;IACjB,iCAAiB,CAAA;AACnB,CAAC,EAPW,YAAY,4BAAZ,YAAY,QAOvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaFormat.d.ts","sourceRoot":"","sources":["../../src/enums/RsaFormat.ts"],"names":[],"mappings":"AAAA,oBAAY,SAAS;IACnB,MAAM,WAAW;IACjB,UAAU,cAAc;IACxB,GAAG,QAAQ;CACZ"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RsaFormat = void 0;
|
|
4
|
+
var RsaFormat;
|
|
5
|
+
(function (RsaFormat) {
|
|
6
|
+
RsaFormat["BASE64"] = "base64";
|
|
7
|
+
RsaFormat["BASE64_URL"] = "base64url";
|
|
8
|
+
RsaFormat["HEX"] = "hex";
|
|
9
|
+
})(RsaFormat || (exports.RsaFormat = RsaFormat = {}));
|
|
10
|
+
//# sourceMappingURL=RsaFormat.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaFormat.js","sourceRoot":"","sources":["../../src/enums/RsaFormat.ts"],"names":[],"mappings":";;;AAAA,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,qCAAwB,CAAA;IACxB,wBAAW,CAAA;AACb,CAAC,EAJW,SAAS,yBAAT,SAAS,QAIpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/enums/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./RsaAlgorithm"), exports);
|
|
18
|
+
__exportStar(require("./RsaFormat"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/enums/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,8CAA4B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaError.d.ts","sourceRoot":"","sources":["../../src/errors/RsaError.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,qBAAa,QAAS,SAAQ,YAAY;CAAG"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RsaError = void 0;
|
|
4
|
+
const errors_1 = require("@lindorm/errors");
|
|
5
|
+
class RsaError extends errors_1.LindormError {
|
|
6
|
+
}
|
|
7
|
+
exports.RsaError = RsaError;
|
|
8
|
+
//# sourceMappingURL=RsaError.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RsaError.js","sourceRoot":"","sources":["../../src/errors/RsaError.ts"],"names":[],"mappings":";;;AAAA,4CAA+C;AAE/C,MAAa,QAAS,SAAQ,qBAAY;CAAG;AAA7C,4BAA6C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/errors/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./RsaError"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/errors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./classes"), exports);
|
|
18
|
+
__exportStar(require("./enums"), exports);
|
|
19
|
+
__exportStar(require("./errors"), exports);
|
|
20
|
+
__exportStar(require("./types"), exports);
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4CAA0B;AAC1B,0CAAwB;AACxB,2CAAyB;AACzB,0CAAwB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./rsa-signature"), exports);
|
|
18
|
+
__exportStar(require("./rsa-signature-class"), exports);
|
|
19
|
+
__exportStar(require("./types"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,wDAAsC;AACtC,0CAAwB"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Kryptos } from "@lindorm/kryptos";
|
|
2
|
+
import { BufferFormat, SignatureAlgorithm } from "./types";
|
|
3
|
+
export type RsaKitOptions = {
|
|
4
|
+
algorithm?: SignatureAlgorithm;
|
|
5
|
+
format?: BufferFormat;
|
|
6
|
+
kryptos: Kryptos;
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=rsa-signature-class.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rsa-signature-class.d.ts","sourceRoot":"","sources":["../../src/types/rsa-signature-class.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAE3D,MAAM,MAAM,aAAa,GAAG;IAC1B,SAAS,CAAC,EAAE,kBAAkB,CAAC;IAC/B,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;CAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rsa-signature-class.js","sourceRoot":"","sources":["../../src/types/rsa-signature-class.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Kryptos } from "@lindorm/kryptos";
|
|
2
|
+
import { BufferFormat, SignatureAlgorithm } from "./types";
|
|
3
|
+
export type CreateRsaSignatureOptions = {
|
|
4
|
+
algorithm?: SignatureAlgorithm;
|
|
5
|
+
data: string;
|
|
6
|
+
format?: BufferFormat;
|
|
7
|
+
kryptos: Kryptos;
|
|
8
|
+
};
|
|
9
|
+
export type VerifyRsaSignatureOptions = {
|
|
10
|
+
algorithm?: SignatureAlgorithm;
|
|
11
|
+
data: string;
|
|
12
|
+
format?: BufferFormat;
|
|
13
|
+
kryptos: Kryptos;
|
|
14
|
+
signature: string;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=rsa-signature.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rsa-signature.d.ts","sourceRoot":"","sources":["../../src/types/rsa-signature.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAE3D,MAAM,MAAM,yBAAyB,GAAG;IACtC,SAAS,CAAC,EAAE,kBAAkB,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,SAAS,CAAC,EAAE,kBAAkB,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rsa-signature.js","sourceRoot":"","sources":["../../src/types/rsa-signature.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,WAAW,GAAG,KAAK,CAAC;AAE1D,MAAM,MAAM,kBAAkB,GAC1B,YAAY,GACZ,YAAY,GACZ,YAAY,GACZ,QAAQ,GACR,QAAQ,GACR,QAAQ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { CreateRsaSignatureOptions, VerifyRsaSignatureOptions } from "../../types";
|
|
2
|
+
export declare const createRsaSignature: (options: CreateRsaSignatureOptions) => string;
|
|
3
|
+
export declare const verifyRsaSignature: (options: VerifyRsaSignatureOptions) => boolean;
|
|
4
|
+
export declare const assertRsaSignature: (options: VerifyRsaSignatureOptions) => void;
|
|
5
|
+
//# sourceMappingURL=rsa-signature.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rsa-signature.d.ts","sourceRoot":"","sources":["../../../src/utils/private/rsa-signature.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,yBAAyB,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAEnF,eAAO,MAAM,kBAAkB,YAAa,yBAAyB,KAAG,MAgBvE,CAAC;AAEF,eAAO,MAAM,kBAAkB,YAAa,yBAAyB,KAAG,OAgBvE,CAAC;AAEF,eAAO,MAAM,kBAAkB,YAAa,yBAAyB,KAAG,IAGvE,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.assertRsaSignature = exports.verifyRsaSignature = exports.createRsaSignature = void 0;
|
|
4
|
+
const kryptos_1 = require("@lindorm/kryptos");
|
|
5
|
+
const crypto_1 = require("crypto");
|
|
6
|
+
const errors_1 = require("../../errors");
|
|
7
|
+
const createRsaSignature = (options) => {
|
|
8
|
+
const { algorithm = "RSA-SHA256", data, format = "base64url", kryptos } = options;
|
|
9
|
+
if (!kryptos_1.Kryptos.isRsa(kryptos)) {
|
|
10
|
+
throw new errors_1.RsaError("Invalid kryptos type");
|
|
11
|
+
}
|
|
12
|
+
const { privateKey } = kryptos.export("pem");
|
|
13
|
+
if (!privateKey) {
|
|
14
|
+
throw new errors_1.RsaError("Private key not found in key set");
|
|
15
|
+
}
|
|
16
|
+
const sign = (0, crypto_1.createSign)(algorithm).update(data).end();
|
|
17
|
+
return sign.sign(privateKey, format);
|
|
18
|
+
};
|
|
19
|
+
exports.createRsaSignature = createRsaSignature;
|
|
20
|
+
const verifyRsaSignature = (options) => {
|
|
21
|
+
const { algorithm = "RSA-SHA256", data, format = "base64url", kryptos, signature } = options;
|
|
22
|
+
if (!kryptos_1.Kryptos.isRsa(kryptos)) {
|
|
23
|
+
throw new errors_1.RsaError("Invalid kryptos type");
|
|
24
|
+
}
|
|
25
|
+
const { publicKey } = kryptos.export("pem");
|
|
26
|
+
if (!publicKey) {
|
|
27
|
+
throw new errors_1.RsaError("Public key not found in key set");
|
|
28
|
+
}
|
|
29
|
+
const verifier = (0, crypto_1.createVerify)(algorithm).update(data).end();
|
|
30
|
+
return verifier.verify(publicKey, signature, format);
|
|
31
|
+
};
|
|
32
|
+
exports.verifyRsaSignature = verifyRsaSignature;
|
|
33
|
+
const assertRsaSignature = (options) => {
|
|
34
|
+
if ((0, exports.verifyRsaSignature)(options))
|
|
35
|
+
return;
|
|
36
|
+
throw new errors_1.RsaError("Invalid signature");
|
|
37
|
+
};
|
|
38
|
+
exports.assertRsaSignature = assertRsaSignature;
|
|
39
|
+
//# sourceMappingURL=rsa-signature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rsa-signature.js","sourceRoot":"","sources":["../../../src/utils/private/rsa-signature.ts"],"names":[],"mappings":";;;AAAA,8CAA2C;AAC3C,mCAAkD;AAClD,yCAAwC;AAGjC,MAAM,kBAAkB,GAAG,CAAC,OAAkC,EAAU,EAAE;IAC/E,MAAM,EAAE,SAAS,GAAG,YAAY,EAAE,IAAI,EAAE,MAAM,GAAG,WAAW,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAElF,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,sBAAsB,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAE7C,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,MAAM,IAAI,iBAAQ,CAAC,kCAAkC,CAAC,CAAC;IACzD,CAAC;IAED,MAAM,IAAI,GAAG,IAAA,mBAAU,EAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC;IAEtD,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;AACvC,CAAC,CAAC;AAhBW,QAAA,kBAAkB,sBAgB7B;AAEK,MAAM,kBAAkB,GAAG,CAAC,OAAkC,EAAW,EAAE;IAChF,MAAM,EAAE,SAAS,GAAG,YAAY,EAAE,IAAI,EAAE,MAAM,GAAG,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC;IAE7F,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,sBAAsB,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAE5C,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,iBAAQ,CAAC,iCAAiC,CAAC,CAAC;IACxD,CAAC;IAED,MAAM,QAAQ,GAAG,IAAA,qBAAY,EAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC;IAE5D,OAAO,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;AACvD,CAAC,CAAC;AAhBW,QAAA,kBAAkB,sBAgB7B;AAEK,MAAM,kBAAkB,GAAG,CAAC,OAAkC,EAAQ,EAAE;IAC7E,IAAI,IAAA,0BAAkB,EAAC,OAAO,CAAC;QAAE,OAAO;IACxC,MAAM,IAAI,iBAAQ,CAAC,mBAAmB,CAAC,CAAC;AAC1C,CAAC,CAAC;AAHW,QAAA,kBAAkB,sBAG7B"}
|
package/package.json
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@lindorm/rsa",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"license": "AGPL-3.0-or-later",
|
|
5
|
+
"author": "Jonn Nilsson",
|
|
6
|
+
"repository": {
|
|
7
|
+
"url": "https://github.com/lindorm-io/monorepo",
|
|
8
|
+
"directory": "packages/rsa"
|
|
9
|
+
},
|
|
10
|
+
"bugs": "https://github.com/lindorm-io/monorepo/issues",
|
|
11
|
+
"publishConfig": {
|
|
12
|
+
"access": "public"
|
|
13
|
+
},
|
|
14
|
+
"main": "dist/index.js",
|
|
15
|
+
"typings": "dist/index.d.ts",
|
|
16
|
+
"scripts": {
|
|
17
|
+
"build": "rimraf dist && tsc -b ./tsconfig.build.json",
|
|
18
|
+
"example": "ts-node example",
|
|
19
|
+
"integration": "compd --file docker-compose.yml jest --config jest.config.integration.js --watch --",
|
|
20
|
+
"test:ci": "npm run test:unit",
|
|
21
|
+
"test:integration": "jest --config jest.config.integration.js --",
|
|
22
|
+
"test:unit": "jest --config jest.config.js --",
|
|
23
|
+
"test": "jest --watch --",
|
|
24
|
+
"typecheck:ci": "tsc",
|
|
25
|
+
"typecheck": "tsc --watch",
|
|
26
|
+
"update": "ncu -u"
|
|
27
|
+
},
|
|
28
|
+
"dependencies": {
|
|
29
|
+
"@lindorm/errors": "^0.1.4",
|
|
30
|
+
"@lindorm/kryptos": "^0.2.0"
|
|
31
|
+
},
|
|
32
|
+
"gitHead": "a17ffe98c4fd9ef81d3b251f84fbff66ae133722"
|
|
33
|
+
}
|