@super-protocol/pki-common 1.0.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.
@@ -0,0 +1,6 @@
1
+ /// <reference types="node" />
2
+ import { ChallengeType, KeyPairPem } from './types';
3
+ export declare const generateDomain: (baseDomain: string, challengeType: ChallengeType, id: string) => string;
4
+ export declare const getPublicKeyFromPrivate: (privateKeyPem: string) => string;
5
+ export declare const getPublicKeyHash: (publicKeyPem: string) => Buffer;
6
+ export declare const generateKeyPair: () => KeyPairPem;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.generateKeyPair = exports.getPublicKeyHash = exports.getPublicKeyFromPrivate = exports.generateDomain = void 0;
7
+ const node_forge_1 = __importDefault(require("node-forge"));
8
+ const node_crypto_1 = require("node:crypto");
9
+ const crypto_1 = require("crypto");
10
+ const generateDomain = (baseDomain, challengeType, id) => `*.${id}.${challengeType}.${baseDomain}`;
11
+ exports.generateDomain = generateDomain;
12
+ const getPublicKeyFromPrivate = (privateKeyPem) => {
13
+ const privateKey = node_forge_1.default.pki.privateKeyFromPem(privateKeyPem);
14
+ const publicKey = node_forge_1.default.pki.rsa.setPublicKey(privateKey.n, privateKey.e);
15
+ return node_forge_1.default.pki.publicKeyToPem(publicKey);
16
+ };
17
+ exports.getPublicKeyFromPrivate = getPublicKeyFromPrivate;
18
+ const getPublicKeyHash = (publicKeyPem) => {
19
+ const publicKey = node_forge_1.default.pki.publicKeyFromPem(publicKeyPem);
20
+ const asn1 = node_forge_1.default.pki.publicKeyToAsn1(publicKey);
21
+ const der = node_forge_1.default.asn1.toDer(asn1).getBytes();
22
+ const keyBuffer = Buffer.from(der, 'binary');
23
+ const hash = (0, node_crypto_1.createHash)('md5');
24
+ hash.update(keyBuffer);
25
+ return hash.digest();
26
+ };
27
+ exports.getPublicKeyHash = getPublicKeyHash;
28
+ const generateKeyPair = () => {
29
+ const keys = (0, crypto_1.generateKeyPairSync)('rsa', {
30
+ modulusLength: 2048,
31
+ publicKeyEncoding: {
32
+ type: 'spki',
33
+ format: 'pem',
34
+ },
35
+ privateKeyEncoding: {
36
+ type: 'pkcs8',
37
+ format: 'pem',
38
+ },
39
+ });
40
+ return {
41
+ publicKeyPem: keys.publicKey,
42
+ privateKeyPem: keys.privateKey,
43
+ };
44
+ };
45
+ exports.generateKeyPair = generateKeyPair;
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLDREQUErQjtBQUMvQiw2Q0FBeUM7QUFDekMsbUNBQTZDO0FBRXRDLE1BQU0sY0FBYyxHQUFHLENBQzFCLFVBQWtCLEVBQ2xCLGFBQTRCLEVBQzVCLEVBQVUsRUFDWixFQUFFLENBQUMsS0FBSyxFQUFFLElBQUksYUFBYSxJQUFJLFVBQVUsRUFBRSxDQUFDO0FBSmpDLFFBQUEsY0FBYyxrQkFJbUI7QUFFdkMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLGFBQXFCLEVBQUUsRUFBRTtJQUM3RCxNQUFNLFVBQVUsR0FBRyxvQkFBSyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUM5RCxNQUFNLFNBQVMsR0FBRyxvQkFBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3pFLE9BQU8sb0JBQUssQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQy9DLENBQUMsQ0FBQztBQUpXLFFBQUEsdUJBQXVCLDJCQUlsQztBQUVLLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxZQUFvQixFQUFFLEVBQUU7SUFDckQsTUFBTSxTQUFTLEdBQUcsb0JBQUssQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDM0QsTUFBTSxJQUFJLEdBQUcsb0JBQUssQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2xELE1BQU0sR0FBRyxHQUFHLG9CQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUM5QyxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUM3QyxNQUFNLElBQUksR0FBRyxJQUFBLHdCQUFVLEVBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN2QixPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztBQUN6QixDQUFDLENBQUM7QUFSVyxRQUFBLGdCQUFnQixvQkFRM0I7QUFFSyxNQUFNLGVBQWUsR0FBRyxHQUFlLEVBQUU7SUFDNUMsTUFBTSxJQUFJLEdBQUcsSUFBQSw0QkFBbUIsRUFBQyxLQUFLLEVBQUU7UUFDcEMsYUFBYSxFQUFFLElBQUk7UUFDbkIsaUJBQWlCLEVBQUU7WUFDZixJQUFJLEVBQUUsTUFBTTtZQUNaLE1BQU0sRUFBRSxLQUFLO1NBQ2hCO1FBQ0Qsa0JBQWtCLEVBQUU7WUFDaEIsSUFBSSxFQUFFLE9BQU87WUFDYixNQUFNLEVBQUUsS0FBSztTQUNoQjtLQUNKLENBQUMsQ0FBQztJQUNILE9BQU87UUFDSCxZQUFZLEVBQUUsSUFBSSxDQUFDLFNBQVM7UUFDNUIsYUFBYSxFQUFFLElBQUksQ0FBQyxVQUFVO0tBQ2pDLENBQUM7QUFDTixDQUFDLENBQUM7QUFoQlcsUUFBQSxlQUFlLG1CQWdCMUIifQ==
@@ -0,0 +1,2 @@
1
+ export * from './types';
2
+ export * from './helpers';
package/dist/index.js ADDED
@@ -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("./types"), exports);
18
+ __exportStar(require("./helpers"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDBDQUF3QjtBQUN4Qiw0Q0FBMEIifQ==
@@ -0,0 +1,58 @@
1
+ export declare enum ChallengeType {
2
+ Untrusted = "untrusted",
3
+ SGXDCAP = "sgx-dcap",
4
+ SGXIAS = "sgx-ias",
5
+ TDX = "tdx",
6
+ AMDSEV = "amd-sev",
7
+ TDXSuperLoader = "tdx-super-loader"
8
+ }
9
+ export interface UntrustedChallenge {
10
+ type: ChallengeType.Untrusted;
11
+ userData: string;
12
+ id: string;
13
+ }
14
+ export interface SGXDCAPChallenge {
15
+ type: ChallengeType.SGXDCAP;
16
+ quoteBase64: string;
17
+ }
18
+ export type Challenge = UntrustedChallenge | SGXDCAPChallenge;
19
+ export interface PkiCertParams {
20
+ serialNumber: string;
21
+ notBefore: string;
22
+ notAfter: string;
23
+ commonName: string;
24
+ countryName: string;
25
+ stateName: string;
26
+ localityName: string;
27
+ organizationName: string;
28
+ organizationUnitName: string;
29
+ }
30
+ export interface PkiUntrustedStaticKeyStorage {
31
+ type: 'untrusted-static';
32
+ publicKeyPem: string;
33
+ privateKeyPem: string;
34
+ }
35
+ export interface PkiInMemoryKeyStorage {
36
+ type: 'in-memory';
37
+ }
38
+ export interface PkiSuperDecentralizedSecretKeyStorage {
39
+ type: 'super';
40
+ }
41
+ export interface PkiTrustedKeyStorage {
42
+ type: 'trusted';
43
+ storage: PkiInMemoryKeyStorage | PkiSuperDecentralizedSecretKeyStorage;
44
+ }
45
+ export declare enum PkiRole {
46
+ root = "root",
47
+ subroot = "subroot"
48
+ }
49
+ export interface KeyPairPem {
50
+ publicKeyPem: string;
51
+ privateKeyPem: string;
52
+ }
53
+ export interface TeeSslCertificate {
54
+ certPem: string;
55
+ caBundle: string;
56
+ baseDomain: string;
57
+ keyPair: KeyPairPem;
58
+ }
package/dist/types.js ADDED
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PkiRole = exports.ChallengeType = void 0;
4
+ var ChallengeType;
5
+ (function (ChallengeType) {
6
+ ChallengeType["Untrusted"] = "untrusted";
7
+ ChallengeType["SGXDCAP"] = "sgx-dcap";
8
+ ChallengeType["SGXIAS"] = "sgx-ias";
9
+ ChallengeType["TDX"] = "tdx";
10
+ ChallengeType["AMDSEV"] = "amd-sev";
11
+ ChallengeType["TDXSuperLoader"] = "tdx-super-loader";
12
+ })(ChallengeType || (exports.ChallengeType = ChallengeType = {}));
13
+ var PkiRole;
14
+ (function (PkiRole) {
15
+ PkiRole["root"] = "root";
16
+ PkiRole["subroot"] = "subroot";
17
+ })(PkiRole || (exports.PkiRole = PkiRole = {}));
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBWSxhQU9YO0FBUEQsV0FBWSxhQUFhO0lBQ3JCLHdDQUF1QixDQUFBO0lBQ3ZCLHFDQUFvQixDQUFBO0lBQ3BCLG1DQUFrQixDQUFBO0lBQ2xCLDRCQUFXLENBQUE7SUFDWCxtQ0FBa0IsQ0FBQTtJQUNsQixvREFBbUMsQ0FBQTtBQUN2QyxDQUFDLEVBUFcsYUFBYSw2QkFBYixhQUFhLFFBT3hCO0FBOENELElBQVksT0FHWDtBQUhELFdBQVksT0FBTztJQUNmLHdCQUFhLENBQUE7SUFDYiw4QkFBbUIsQ0FBQTtBQUN2QixDQUFDLEVBSFcsT0FBTyx1QkFBUCxPQUFPLFFBR2xCIn0=
package/package.json ADDED
@@ -0,0 +1,24 @@
1
+ {
2
+ "name": "@super-protocol/pki-common",
3
+ "version": "1.0.0",
4
+ "description": "",
5
+ "main": "dist/index.js",
6
+ "module": "dist/index.js",
7
+ "types": "dist/index.d.ts",
8
+ "files": [
9
+ "dist"
10
+ ],
11
+ "directories": {
12
+ "lib": "dist"
13
+ },
14
+ "scripts": {
15
+ "build": "tsc -b",
16
+ "lint": "eslint --max-warnings=0 src",
17
+ "lint:fix": "eslint --fix src"
18
+ },
19
+ "author": "Super Protocol",
20
+ "license": "ISC",
21
+ "dependencies": {
22
+ "node-forge": "^1.3.1"
23
+ }
24
+ }