@super-protocol/sdk-js 3.12.1-beta.2 → 3.13.0-beta.2
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/dist/cjs/certificates/binary-splitter.d.ts +26 -0
- package/dist/cjs/certificates/binary-splitter.js +269 -0
- package/dist/cjs/certificates/generator.d.ts +38 -0
- package/dist/cjs/certificates/generator.js +248 -0
- package/dist/cjs/certificates/helper.d.ts +8 -4
- package/dist/cjs/certificates/helper.js +45 -17
- package/dist/cjs/certificates/index.d.ts +1 -0
- package/dist/cjs/certificates/index.js +2 -1
- package/dist/cjs/certificates/ocsp.d.ts +6 -1
- package/dist/cjs/certificates/ocsp.js +179 -23
- package/dist/cjs/certificates/serializer.d.ts +5 -0
- package/dist/cjs/certificates/serializer.js +98 -2
- package/dist/cjs/certificates/setup-crypto.d.ts +3 -0
- package/dist/cjs/certificates/setup-crypto.js +51 -0
- package/dist/cjs/certificates/testing-generate.d.ts +1 -0
- package/dist/cjs/certificates/testing-generate.js +115 -0
- package/dist/cjs/certificates/types.d.ts +107 -0
- package/dist/cjs/certificates/types.js +8 -1
- package/dist/cjs/connectors/BlockchainConnector.js +11 -8
- package/dist/cjs/connectors/BlockchainEventsListener.d.ts +4 -4
- package/dist/cjs/connectors/BlockchainEventsListener.js +9 -8
- package/dist/cjs/constants.d.ts +6 -1
- package/dist/cjs/constants.js +13 -5
- package/dist/cjs/index.d.ts +0 -2
- package/dist/cjs/index.js +3 -6
- package/dist/cjs/models/Offer.d.ts +1 -1
- package/dist/cjs/models/Offer.js +10 -3
- package/dist/cjs/models/Order.d.ts +1 -1
- package/dist/cjs/models/Order.js +21 -20
- package/dist/cjs/models/TeeOffer.d.ts +2 -2
- package/dist/cjs/models/TeeOffer.js +18 -3
- package/dist/cjs/proto/OrderReport.d.ts +206 -15
- package/dist/cjs/proto/OrderReport.js +169 -3
- package/dist/cjs/staticModels/ActiveOrders.d.ts +1 -1
- package/dist/cjs/staticModels/ActiveOrders.js +1 -1
- package/dist/cjs/staticModels/OfferResources.js +3 -4
- package/dist/cjs/staticModels/Offers.d.ts +3 -4
- package/dist/cjs/staticModels/Offers.js +16 -17
- package/dist/cjs/staticModels/OffersCommon.d.ts +18 -0
- package/dist/cjs/staticModels/OffersCommon.js +79 -0
- package/dist/cjs/staticModels/Orders.d.ts +6 -5
- package/dist/cjs/staticModels/Orders.js +96 -5
- package/dist/cjs/staticModels/SecretRequests.js +2 -3
- package/dist/cjs/staticModels/StaticModel.d.ts +14 -2
- package/dist/cjs/staticModels/StaticModel.js +90 -2
- package/dist/cjs/staticModels/SuperproToken.d.ts +26 -1
- package/dist/cjs/staticModels/SuperproToken.js +40 -1
- package/dist/cjs/staticModels/TeeOffers.d.ts +4 -4
- package/dist/cjs/staticModels/TeeOffers.js +17 -16
- package/dist/cjs/tee/OrderReportService.js +4 -2
- package/dist/cjs/tee/QuoteValidator.d.ts +3 -2
- package/dist/cjs/tee/QuoteValidator.js +5 -4
- package/dist/cjs/tee/TeeCertificateService.d.ts +1 -1
- package/dist/cjs/tee/TeeCertificateService.js +11 -14
- package/dist/cjs/tee/TeeSignatureVerifier.d.ts +6 -4
- package/dist/cjs/tee/TeeSignatureVerifier.js +60 -32
- package/dist/cjs/tee/types.d.ts +1 -1
- package/dist/cjs/types/Order.d.ts +28 -2
- package/dist/cjs/types/Order.js +23 -2
- package/dist/cjs/types/index.d.ts +0 -1
- package/dist/cjs/types/index.js +1 -2
- package/dist/cjs/utils/CryptoKeysTransformer.d.ts +4 -0
- package/dist/cjs/utils/CryptoKeysTransformer.js +50 -1
- package/dist/cjs/utils/NonceTracker.d.ts +1 -0
- package/dist/cjs/utils/NonceTracker.js +6 -2
- package/dist/cjs/utils/TxManager.d.ts +3 -0
- package/dist/cjs/utils/TxManager.js +88 -35
- package/dist/cjs/utils/helper.d.ts +11 -3
- package/dist/cjs/utils/helper.js +56 -12
- package/dist/cjs/utils/helpers/getRawRpc.d.ts +2 -0
- package/dist/cjs/utils/helpers/getRawRpc.js +19 -0
- package/dist/cjs/utils/helpers/index.d.ts +1 -0
- package/dist/cjs/utils/helpers/index.js +2 -1
- package/dist/cjs/utils/types.d.ts +14 -0
- package/dist/cjs/utils/types.js +3 -0
- package/dist/mjs/certificates/binary-splitter.d.ts +26 -0
- package/dist/mjs/certificates/binary-splitter.js +265 -0
- package/dist/mjs/certificates/generator.d.ts +38 -0
- package/dist/mjs/certificates/generator.js +241 -0
- package/dist/mjs/certificates/helper.d.ts +8 -4
- package/dist/mjs/certificates/helper.js +45 -17
- package/dist/mjs/certificates/index.d.ts +1 -0
- package/dist/mjs/certificates/index.js +2 -1
- package/dist/mjs/certificates/ocsp.d.ts +6 -1
- package/dist/mjs/certificates/ocsp.js +180 -24
- package/dist/mjs/certificates/serializer.d.ts +5 -0
- package/dist/mjs/certificates/serializer.js +94 -1
- package/dist/mjs/certificates/setup-crypto.d.ts +3 -0
- package/dist/mjs/certificates/setup-crypto.js +22 -0
- package/dist/mjs/certificates/testing-generate.d.ts +1 -0
- package/dist/mjs/certificates/testing-generate.js +110 -0
- package/dist/mjs/certificates/types.d.ts +107 -0
- package/dist/mjs/certificates/types.js +7 -2
- package/dist/mjs/connectors/BlockchainConnector.js +11 -8
- package/dist/mjs/connectors/BlockchainEventsListener.d.ts +4 -4
- package/dist/mjs/connectors/BlockchainEventsListener.js +9 -8
- package/dist/mjs/constants.d.ts +6 -1
- package/dist/mjs/constants.js +12 -4
- package/dist/mjs/index.d.ts +0 -2
- package/dist/mjs/index.js +1 -3
- package/dist/mjs/models/Offer.d.ts +1 -1
- package/dist/mjs/models/Offer.js +10 -3
- package/dist/mjs/models/Order.d.ts +1 -1
- package/dist/mjs/models/Order.js +22 -21
- package/dist/mjs/models/TeeOffer.d.ts +2 -2
- package/dist/mjs/models/TeeOffer.js +18 -3
- package/dist/mjs/proto/OrderReport.d.ts +206 -15
- package/dist/mjs/proto/OrderReport.js +168 -2
- package/dist/mjs/staticModels/ActiveOrders.d.ts +1 -1
- package/dist/mjs/staticModels/ActiveOrders.js +1 -1
- package/dist/mjs/staticModels/OfferResources.js +4 -5
- package/dist/mjs/staticModels/Offers.d.ts +3 -4
- package/dist/mjs/staticModels/Offers.js +16 -17
- package/dist/mjs/staticModels/OffersCommon.d.ts +18 -0
- package/dist/mjs/staticModels/OffersCommon.js +73 -0
- package/dist/mjs/staticModels/Orders.d.ts +6 -5
- package/dist/mjs/staticModels/Orders.js +98 -7
- package/dist/mjs/staticModels/SecretRequests.js +3 -4
- package/dist/mjs/staticModels/StaticModel.d.ts +14 -2
- package/dist/mjs/staticModels/StaticModel.js +90 -2
- package/dist/mjs/staticModels/SuperproToken.d.ts +26 -1
- package/dist/mjs/staticModels/SuperproToken.js +40 -1
- package/dist/mjs/staticModels/TeeOffers.d.ts +4 -4
- package/dist/mjs/staticModels/TeeOffers.js +17 -16
- package/dist/mjs/tee/OrderReportService.js +4 -2
- package/dist/mjs/tee/QuoteValidator.d.ts +3 -2
- package/dist/mjs/tee/QuoteValidator.js +5 -4
- package/dist/mjs/tee/TeeCertificateService.d.ts +1 -1
- package/dist/mjs/tee/TeeCertificateService.js +12 -15
- package/dist/mjs/tee/TeeSignatureVerifier.d.ts +6 -4
- package/dist/mjs/tee/TeeSignatureVerifier.js +59 -31
- package/dist/mjs/tee/types.d.ts +1 -1
- package/dist/mjs/types/Order.d.ts +28 -2
- package/dist/mjs/types/Order.js +21 -1
- package/dist/mjs/types/index.d.ts +0 -1
- package/dist/mjs/types/index.js +1 -2
- package/dist/mjs/utils/CryptoKeysTransformer.d.ts +4 -0
- package/dist/mjs/utils/CryptoKeysTransformer.js +50 -1
- package/dist/mjs/utils/NonceTracker.d.ts +1 -0
- package/dist/mjs/utils/NonceTracker.js +6 -2
- package/dist/mjs/utils/TxManager.d.ts +3 -0
- package/dist/mjs/utils/TxManager.js +89 -36
- package/dist/mjs/utils/helper.d.ts +11 -3
- package/dist/mjs/utils/helper.js +54 -12
- package/dist/mjs/utils/helpers/getRawRpc.d.ts +2 -0
- package/dist/mjs/utils/helpers/getRawRpc.js +15 -0
- package/dist/mjs/utils/helpers/index.d.ts +1 -0
- package/dist/mjs/utils/helpers/index.js +2 -1
- package/dist/mjs/utils/types.d.ts +14 -0
- package/dist/mjs/utils/types.js +2 -0
- package/package.json +7 -4
- package/readme.md +11 -0
- package/dist/cjs/contracts/Campaign.d.ts +0 -1036
- package/dist/cjs/contracts/Campaign.js +0 -1347
- package/dist/cjs/staticModels/Campaign.d.ts +0 -59
- package/dist/cjs/staticModels/Campaign.js +0 -248
- package/dist/cjs/types/Campaign.d.ts +0 -57
- package/dist/cjs/types/Campaign.js +0 -11
- package/dist/mjs/contracts/Campaign.d.ts +0 -1036
- package/dist/mjs/contracts/Campaign.js +0 -1344
- package/dist/mjs/staticModels/Campaign.d.ts +0 -59
- package/dist/mjs/staticModels/Campaign.js +0 -243
- package/dist/mjs/types/Campaign.d.ts +0 -57
- package/dist/mjs/types/Campaign.js +0 -8
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getRawRpcContractCall = void 0;
|
|
4
|
+
const getRawRpcContractCall = (contractAddress, requestId, encodedData) => {
|
|
5
|
+
return {
|
|
6
|
+
jsonrpc: '2.0',
|
|
7
|
+
method: 'eth_call',
|
|
8
|
+
id: requestId,
|
|
9
|
+
params: [
|
|
10
|
+
{
|
|
11
|
+
to: contractAddress,
|
|
12
|
+
data: encodedData,
|
|
13
|
+
},
|
|
14
|
+
'latest',
|
|
15
|
+
],
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
exports.getRawRpcContractCall = getRawRpcContractCall;
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0UmF3UnBjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3V0aWxzL2hlbHBlcnMvZ2V0UmF3UnBjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVPLE1BQU0scUJBQXFCLEdBQUcsQ0FDbkMsZUFBdUIsRUFDdkIsU0FBb0IsRUFDcEIsV0FBbUIsRUFDSyxFQUFFO0lBQzFCLE9BQU87UUFDTCxPQUFPLEVBQUUsS0FBSztRQUNkLE1BQU0sRUFBRSxVQUFVO1FBQ2xCLEVBQUUsRUFBRSxTQUFTO1FBQ2IsTUFBTSxFQUFFO1lBQ047Z0JBQ0UsRUFBRSxFQUFFLGVBQWU7Z0JBQ25CLElBQUksRUFBRSxXQUFXO2FBQ2xCO1lBQ0QsUUFBUTtTQUNUO0tBQ0YsQ0FBQztBQUNKLENBQUMsQ0FBQztBQWpCVyxRQUFBLHFCQUFxQix5QkFpQmhDIn0=
|
|
@@ -19,4 +19,5 @@ __exportStar(require("./OrderArgsHelper.js"), exports);
|
|
|
19
19
|
__exportStar(require("./uploadObjectToStorage.js"), exports);
|
|
20
20
|
__exportStar(require("./promise.js"), exports);
|
|
21
21
|
__exportStar(require("./calculateObjectHash.js"), exports);
|
|
22
|
-
|
|
22
|
+
__exportStar(require("./getRawRpc.js"), exports);
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdXRpbHMvaGVscGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdURBQXFDO0FBQ3JDLHVEQUFxQztBQUNyQyw2REFBMkM7QUFDM0MsK0NBQTZCO0FBQzdCLDJEQUF5QztBQUN6QyxpREFBK0IifQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { JsonRpcId } from 'web3';
|
|
2
|
+
export type BatchResponse<T> = BatchResponseSuccess<T> | BatchResponseError;
|
|
3
|
+
export type BatchResponseSuccess<T> = {
|
|
4
|
+
requestId: JsonRpcId;
|
|
5
|
+
result: T;
|
|
6
|
+
};
|
|
7
|
+
export type BatchResponseError = {
|
|
8
|
+
requestId: JsonRpcId;
|
|
9
|
+
error: string;
|
|
10
|
+
};
|
|
11
|
+
export type ExecuteBatchOptions = {
|
|
12
|
+
timeout?: number;
|
|
13
|
+
throwOnError?: boolean;
|
|
14
|
+
};
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { CertBinaryItem } from './types.js';
|
|
2
|
+
export declare enum CertificateNonOidParts {
|
|
3
|
+
SERIAL_NUMBER = "SERIAL_NUMBER",
|
|
4
|
+
SIGNATURE_ALGORITHM = "SIGNATURE_ALGORITHM",
|
|
5
|
+
ISSUER = "ISSUER",
|
|
6
|
+
NOT_BEFORE = "NOT_BEFORE",
|
|
7
|
+
NOT_AFTER = "NOT_AFTER",
|
|
8
|
+
SUBJECT = "SUBJECT",
|
|
9
|
+
SUBJECT_PUBLIC_KEY_INFO = "SUBJECT_PUBLIC_KEY_INFO",
|
|
10
|
+
SIGNATURE = "SIGNATURE"
|
|
11
|
+
}
|
|
12
|
+
export declare class CertificateBinarySplitter {
|
|
13
|
+
private parts;
|
|
14
|
+
private readonly certBinary;
|
|
15
|
+
private lastPosition;
|
|
16
|
+
constructor(certDer: ArrayBuffer);
|
|
17
|
+
split(nonOidParts: CertificateNonOidParts[], oids: string[]): Array<Uint8Array | CertBinaryItem>;
|
|
18
|
+
private processExtensions;
|
|
19
|
+
private getElementPositionInParent;
|
|
20
|
+
private addElement;
|
|
21
|
+
private addPublicKeyElement;
|
|
22
|
+
private addSignatureElement;
|
|
23
|
+
private getElementValueAndPosition;
|
|
24
|
+
private getValueHex;
|
|
25
|
+
private addPart;
|
|
26
|
+
}
|
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
import { fromBER } from 'asn1js';
|
|
2
|
+
export var CertificateNonOidParts;
|
|
3
|
+
(function (CertificateNonOidParts) {
|
|
4
|
+
CertificateNonOidParts["SERIAL_NUMBER"] = "SERIAL_NUMBER";
|
|
5
|
+
CertificateNonOidParts["SIGNATURE_ALGORITHM"] = "SIGNATURE_ALGORITHM";
|
|
6
|
+
CertificateNonOidParts["ISSUER"] = "ISSUER";
|
|
7
|
+
CertificateNonOidParts["NOT_BEFORE"] = "NOT_BEFORE";
|
|
8
|
+
CertificateNonOidParts["NOT_AFTER"] = "NOT_AFTER";
|
|
9
|
+
CertificateNonOidParts["SUBJECT"] = "SUBJECT";
|
|
10
|
+
CertificateNonOidParts["SUBJECT_PUBLIC_KEY_INFO"] = "SUBJECT_PUBLIC_KEY_INFO";
|
|
11
|
+
CertificateNonOidParts["SIGNATURE"] = "SIGNATURE";
|
|
12
|
+
})(CertificateNonOidParts || (CertificateNonOidParts = {}));
|
|
13
|
+
export class CertificateBinarySplitter {
|
|
14
|
+
parts = [];
|
|
15
|
+
certBinary;
|
|
16
|
+
lastPosition = 0;
|
|
17
|
+
constructor(certDer) {
|
|
18
|
+
this.certBinary = new Uint8Array(certDer);
|
|
19
|
+
}
|
|
20
|
+
split(nonOidParts, oids) {
|
|
21
|
+
this.parts = [];
|
|
22
|
+
this.lastPosition = 0;
|
|
23
|
+
try {
|
|
24
|
+
const asn1 = fromBER(this.certBinary);
|
|
25
|
+
if (asn1.offset === -1) {
|
|
26
|
+
throw new Error('Error parsing ASN.1 structure');
|
|
27
|
+
}
|
|
28
|
+
const certificate = asn1.result;
|
|
29
|
+
// certificate.valueBlock.value[0] = TBSCertificate
|
|
30
|
+
// certificate.valueBlock.value[1] = signatureAlgorithm
|
|
31
|
+
// certificate.valueBlock.value[2] = signature
|
|
32
|
+
const tbsCertificate = certificate.valueBlock.value[0];
|
|
33
|
+
const tbsStartPosition = this.getElementPositionInParent(tbsCertificate.toBER());
|
|
34
|
+
this.addPart(new Uint8Array(this.certBinary.slice(0, tbsStartPosition)));
|
|
35
|
+
this.lastPosition = tbsStartPosition;
|
|
36
|
+
const tbsValues = tbsCertificate.valueBlock.value;
|
|
37
|
+
let tbsIndex = 0;
|
|
38
|
+
// 1. Version [0] EXPLICIT (optional, default v1)
|
|
39
|
+
if (tbsValues[tbsIndex].idBlock.tagClass === 3 &&
|
|
40
|
+
tbsValues[tbsIndex].idBlock.tagNumber === 0) {
|
|
41
|
+
tbsIndex++; // skip version
|
|
42
|
+
}
|
|
43
|
+
// 2. Serial Number (mandatory)
|
|
44
|
+
const serialNumber = tbsValues[tbsIndex++];
|
|
45
|
+
if (serialNumber.idBlock.tagNumber !== 2) {
|
|
46
|
+
throw new Error('Expected serial number (INTEGER)');
|
|
47
|
+
}
|
|
48
|
+
if (nonOidParts.includes(CertificateNonOidParts.SERIAL_NUMBER)) {
|
|
49
|
+
this.addElement({
|
|
50
|
+
name: 'serialNumber',
|
|
51
|
+
element: serialNumber,
|
|
52
|
+
forcePushPrefix: true,
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
// 3. Signature Algorithm (mandatory)
|
|
56
|
+
const signatureAlgorithm = tbsValues[tbsIndex++];
|
|
57
|
+
if (nonOidParts.includes(CertificateNonOidParts.SIGNATURE_ALGORITHM)) {
|
|
58
|
+
this.addElement({ name: 'signatureAlgorithm', element: signatureAlgorithm });
|
|
59
|
+
}
|
|
60
|
+
// 4. Issuer (mandatory)
|
|
61
|
+
const issuer = tbsValues[tbsIndex++];
|
|
62
|
+
if (nonOidParts.includes(CertificateNonOidParts.ISSUER)) {
|
|
63
|
+
this.addElement({ name: 'issuer', element: issuer });
|
|
64
|
+
}
|
|
65
|
+
// 5. Validity (mandatory)
|
|
66
|
+
const validity = tbsValues[tbsIndex++];
|
|
67
|
+
const notBefore = validity.valueBlock.value[0];
|
|
68
|
+
const notAfter = validity.valueBlock.value[1];
|
|
69
|
+
if (nonOidParts.includes(CertificateNonOidParts.NOT_BEFORE)) {
|
|
70
|
+
this.addElement({ name: 'notBefore', element: notBefore });
|
|
71
|
+
}
|
|
72
|
+
if (nonOidParts.includes(CertificateNonOidParts.NOT_AFTER)) {
|
|
73
|
+
this.addElement({ name: 'notAfter', element: notAfter });
|
|
74
|
+
}
|
|
75
|
+
// 6. Subject
|
|
76
|
+
const subject = tbsValues[tbsIndex++];
|
|
77
|
+
if (nonOidParts.includes(CertificateNonOidParts.SUBJECT)) {
|
|
78
|
+
this.addElement({ name: 'subject', element: subject });
|
|
79
|
+
}
|
|
80
|
+
// 7.subjectPublicKeyInfo
|
|
81
|
+
const subjectPublicKeyInfo = tbsValues[tbsIndex++];
|
|
82
|
+
const publicKeyBitString = subjectPublicKeyInfo.valueBlock.value[1]; // BIT STRING with public key
|
|
83
|
+
if (nonOidParts.includes(CertificateNonOidParts.SUBJECT_PUBLIC_KEY_INFO)) {
|
|
84
|
+
this.addPublicKeyElement(publicKeyBitString);
|
|
85
|
+
}
|
|
86
|
+
// 8. issuerUniqueID [1] IMPLICIT (optional, only in v2+)
|
|
87
|
+
if (tbsIndex < tbsValues.length &&
|
|
88
|
+
tbsValues[tbsIndex].idBlock.tagClass === 3 &&
|
|
89
|
+
tbsValues[tbsIndex].idBlock.tagNumber === 1) {
|
|
90
|
+
tbsIndex++; // skip issuerUniqueID
|
|
91
|
+
}
|
|
92
|
+
// 9. subjectUniqueID [2] IMPLICIT (optional, only in v2+)
|
|
93
|
+
if (tbsIndex < tbsValues.length &&
|
|
94
|
+
tbsValues[tbsIndex].idBlock.tagClass === 3 &&
|
|
95
|
+
tbsValues[tbsIndex].idBlock.tagNumber === 2) {
|
|
96
|
+
tbsIndex++; // skip subjectUniqueID
|
|
97
|
+
}
|
|
98
|
+
// 10. Extensions
|
|
99
|
+
if (tbsIndex < tbsValues.length) {
|
|
100
|
+
const extensions = tbsValues[tbsIndex];
|
|
101
|
+
if (extensions.idBlock.tagClass === 3 && extensions.idBlock.tagNumber === 3) {
|
|
102
|
+
const extensionsSequence = extensions.valueBlock.value[0];
|
|
103
|
+
this.processExtensions(extensionsSequence, oids);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
// 11. signature
|
|
107
|
+
if (nonOidParts.includes(CertificateNonOidParts.SIGNATURE)) {
|
|
108
|
+
const signatureAlgorithmId = certificate.valueBlock.value[1];
|
|
109
|
+
this.addElement({
|
|
110
|
+
element: signatureAlgorithmId,
|
|
111
|
+
forcePushPrefix: true,
|
|
112
|
+
forcePushHeader: true,
|
|
113
|
+
});
|
|
114
|
+
const signature = certificate.valueBlock.value[2];
|
|
115
|
+
this.addSignatureElement(signature);
|
|
116
|
+
}
|
|
117
|
+
// Add any remaining part after the last processed element
|
|
118
|
+
if (this.lastPosition < this.certBinary.length) {
|
|
119
|
+
this.addPart(new Uint8Array(this.certBinary.slice(this.lastPosition)));
|
|
120
|
+
}
|
|
121
|
+
return this.parts;
|
|
122
|
+
}
|
|
123
|
+
catch (error) {
|
|
124
|
+
throw new Error(`Failed to split certificate: ${error instanceof Error ? error.message : 'Unknown error'}`);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
processExtensions(extensionsSequence, targetOids) {
|
|
128
|
+
for (const extension of extensionsSequence.valueBlock.value) {
|
|
129
|
+
const extValues = extension.valueBlock.value;
|
|
130
|
+
const oid = extValues[0].valueBlock.toString(); // OID as string
|
|
131
|
+
if (!targetOids.includes(oid)) {
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
// Find OCTET STRING with extension value
|
|
135
|
+
let octetString;
|
|
136
|
+
if (extValues.length === 3) {
|
|
137
|
+
// OID + critical + OCTET STRING
|
|
138
|
+
octetString = extValues[2];
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
// OID + OCTET STRING
|
|
142
|
+
octetString = extValues[1];
|
|
143
|
+
}
|
|
144
|
+
this.addElement({ name: 'extension', element: octetString, oid });
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
getElementPositionInParent(element, parent) {
|
|
148
|
+
const elementBytes = new Uint8Array(element);
|
|
149
|
+
const parentToSearch = parent || this.certBinary;
|
|
150
|
+
const startPosition = parent ? 0 : this.lastPosition;
|
|
151
|
+
for (let i = startPosition; i <= parentToSearch.length - elementBytes.length; i++) {
|
|
152
|
+
let match = true;
|
|
153
|
+
for (let j = 0; j < elementBytes.length; j++) {
|
|
154
|
+
if (parentToSearch[i + j] !== elementBytes[j]) {
|
|
155
|
+
match = false;
|
|
156
|
+
break;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
if (match) {
|
|
160
|
+
return i;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
throw new Error('Some element not found in certificate binary');
|
|
164
|
+
}
|
|
165
|
+
addElement({ name, element, oid, forcePushPrefix, forcePushHeader, }) {
|
|
166
|
+
const { value, position } = this.getElementValueAndPosition({
|
|
167
|
+
element,
|
|
168
|
+
forcePushPrefix,
|
|
169
|
+
forcePushHeader,
|
|
170
|
+
});
|
|
171
|
+
name ? this.addPart({ name, value, oid }) : this.addPart(new Uint8Array(value));
|
|
172
|
+
this.lastPosition = position + value.byteLength;
|
|
173
|
+
}
|
|
174
|
+
addPublicKeyElement(element) {
|
|
175
|
+
const { value, position } = this.getElementValueAndPosition({ element });
|
|
176
|
+
// extract first byte 0x04 - uncompressed public key
|
|
177
|
+
this.addPart(new Uint8Array(value.slice(0, 1)));
|
|
178
|
+
this.addPart({ name: 'publicKey', value: value.slice(1) });
|
|
179
|
+
this.lastPosition = position + value.byteLength;
|
|
180
|
+
}
|
|
181
|
+
addSignatureElement(element) {
|
|
182
|
+
const { value, position } = this.getElementValueAndPosition({ element });
|
|
183
|
+
// Parse the signature as ASN.1 SEQUENCE containing R and S values
|
|
184
|
+
const signatureAsn1 = fromBER(value);
|
|
185
|
+
const sequence = signatureAsn1.result;
|
|
186
|
+
const rElement = sequence.valueBlock.value[0];
|
|
187
|
+
const sElement = sequence.valueBlock.value[1];
|
|
188
|
+
const rBer = rElement.toBER();
|
|
189
|
+
const sBer = sElement.toBER();
|
|
190
|
+
// R value
|
|
191
|
+
const rPosition = this.getElementPositionInParent(rBer, value);
|
|
192
|
+
this.addPart(new Uint8Array(value.slice(0, rPosition)));
|
|
193
|
+
let rValue = this.getValueHex(rElement);
|
|
194
|
+
if (rValue.byteLength > 32) {
|
|
195
|
+
rValue = rValue.slice(rValue.byteLength - 32);
|
|
196
|
+
}
|
|
197
|
+
const rHeaderLength = rBer.byteLength - rValue.byteLength;
|
|
198
|
+
if (rHeaderLength > 0) {
|
|
199
|
+
this.addPart(new Uint8Array(value.slice(rPosition, rPosition + rHeaderLength)));
|
|
200
|
+
}
|
|
201
|
+
const rEndPos = rPosition + rBer.byteLength;
|
|
202
|
+
// S value
|
|
203
|
+
const sPosition = this.getElementPositionInParent(sBer, value);
|
|
204
|
+
if (sPosition > rEndPos) {
|
|
205
|
+
this.addPart(new Uint8Array(value.slice(rEndPos, sPosition)));
|
|
206
|
+
}
|
|
207
|
+
let sValue = this.getValueHex(sElement);
|
|
208
|
+
if (sValue.byteLength > 32) {
|
|
209
|
+
sValue = sValue.slice(sValue.byteLength - 32);
|
|
210
|
+
}
|
|
211
|
+
const sHeaderLength = sBer.byteLength - sValue.byteLength;
|
|
212
|
+
if (sHeaderLength > 0) {
|
|
213
|
+
this.addPart(new Uint8Array(value.slice(sPosition, sPosition + sHeaderLength)), true);
|
|
214
|
+
}
|
|
215
|
+
const fullSignature = Buffer.concat([Buffer.from(rValue), Buffer.from(sValue)]);
|
|
216
|
+
this.addPart({ name: 'signature', value: new Uint8Array(fullSignature) });
|
|
217
|
+
const sEndPos = sPosition + sBer.byteLength;
|
|
218
|
+
if (sEndPos < value.byteLength) {
|
|
219
|
+
this.addPart(new Uint8Array(value.slice(sEndPos)));
|
|
220
|
+
}
|
|
221
|
+
this.lastPosition = position + value.byteLength;
|
|
222
|
+
}
|
|
223
|
+
getElementValueAndPosition({ element, forcePushPrefix = false, forcePushHeader = false, }) {
|
|
224
|
+
const elementBer = element.toBER();
|
|
225
|
+
const elementValue = this.getValueHex(element);
|
|
226
|
+
const elementPosition = this.getElementPositionInParent(elementBer);
|
|
227
|
+
const valueOffsetInElement = elementBer.byteLength - elementValue.byteLength;
|
|
228
|
+
const valuePosition = elementPosition + valueOffsetInElement;
|
|
229
|
+
// Part before element
|
|
230
|
+
if (this.lastPosition < elementPosition) {
|
|
231
|
+
this.addPart(new Uint8Array(this.certBinary.slice(this.lastPosition, elementPosition)), forcePushPrefix);
|
|
232
|
+
}
|
|
233
|
+
// Element header
|
|
234
|
+
if (valueOffsetInElement > 0) {
|
|
235
|
+
this.addPart(new Uint8Array(this.certBinary.slice(elementPosition, valuePosition)), forcePushHeader);
|
|
236
|
+
}
|
|
237
|
+
return {
|
|
238
|
+
value: new Uint8Array(elementValue),
|
|
239
|
+
position: valuePosition,
|
|
240
|
+
};
|
|
241
|
+
}
|
|
242
|
+
getValueHex(element) {
|
|
243
|
+
if ('valueHex' in element.valueBlock) {
|
|
244
|
+
return element.valueBlock.valueHex;
|
|
245
|
+
}
|
|
246
|
+
if ('value' in element.valueBlock && Array.isArray(element.valueBlock.value)) {
|
|
247
|
+
const arrayBuffers = element.valueBlock.value.map((valueItem) => valueItem.toBER());
|
|
248
|
+
const concatenatedBuffer = arrayBuffers.reduce((acc, current) => Buffer.concat([acc, Buffer.from(current)]), Buffer.alloc(0));
|
|
249
|
+
return new Uint8Array(concatenatedBuffer).buffer;
|
|
250
|
+
}
|
|
251
|
+
throw new Error('Cannot extract valueHex from element');
|
|
252
|
+
}
|
|
253
|
+
addPart(part, forcePush = false) {
|
|
254
|
+
const lastPart = this.parts[this.parts.length - 1];
|
|
255
|
+
if (part instanceof Uint8Array && lastPart instanceof Uint8Array && !forcePush) {
|
|
256
|
+
const merged = new Uint8Array(lastPart.length + part.length);
|
|
257
|
+
merged.set(lastPart, 0);
|
|
258
|
+
merged.set(part, lastPart.length);
|
|
259
|
+
this.parts[this.parts.length - 1] = merged;
|
|
260
|
+
return;
|
|
261
|
+
}
|
|
262
|
+
this.parts.push(part);
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmluYXJ5LXNwbGl0dGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NlcnRpZmljYXRlcy9iaW5hcnktc3BsaXR0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFlLE9BQU8sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUc5QyxNQUFNLENBQU4sSUFBWSxzQkFTWDtBQVRELFdBQVksc0JBQXNCO0lBQ2hDLHlEQUErQixDQUFBO0lBQy9CLHFFQUEyQyxDQUFBO0lBQzNDLDJDQUFpQixDQUFBO0lBQ2pCLG1EQUF5QixDQUFBO0lBQ3pCLGlEQUF1QixDQUFBO0lBQ3ZCLDZDQUFtQixDQUFBO0lBQ25CLDZFQUFtRCxDQUFBO0lBQ25ELGlEQUF1QixDQUFBO0FBQ3pCLENBQUMsRUFUVyxzQkFBc0IsS0FBdEIsc0JBQXNCLFFBU2pDO0FBRUQsTUFBTSxPQUFPLHlCQUF5QjtJQUM1QixLQUFLLEdBQXVDLEVBQUUsQ0FBQztJQUN0QyxVQUFVLENBQWE7SUFDaEMsWUFBWSxHQUFHLENBQUMsQ0FBQztJQUV6QixZQUFZLE9BQW9CO1FBQzlCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVELEtBQUssQ0FBQyxXQUFxQyxFQUFFLElBQWM7UUFDekQsSUFBSSxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUM7UUFDaEIsSUFBSSxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUM7UUFFdEIsSUFBSSxDQUFDO1lBQ0gsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUN0QyxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDdkIsTUFBTSxJQUFJLEtBQUssQ0FBQywrQkFBK0IsQ0FBQyxDQUFDO1lBQ25ELENBQUM7WUFFRCxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsTUFBcUIs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
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { GenerateCertParams, GenerateCsrParams, ParsedCert, ParsedCsr, SignatureAlgorithm } from './types.js';
|
|
2
|
+
export declare class CertificateGenerator {
|
|
3
|
+
/**
|
|
4
|
+
* Generates certificate based on the provided parameters.
|
|
5
|
+
* @param params - Parameters for generating the certificate.
|
|
6
|
+
* @returns The generated certificate in PEM format.
|
|
7
|
+
*/
|
|
8
|
+
static generateCert(params: GenerateCertParams): Promise<string>;
|
|
9
|
+
/**
|
|
10
|
+
* Generates a pair of cryptographic keys based on the specified signature algorithm.
|
|
11
|
+
* @param signatureAlgorithm - The algorithm to use for key generation.
|
|
12
|
+
* @returns A promise that resolves to a CryptoKeyPair containing the public and private keys.
|
|
13
|
+
*/
|
|
14
|
+
static generateKeys(signatureAlgorithm: SignatureAlgorithm): Promise<CryptoKeyPair>;
|
|
15
|
+
/**
|
|
16
|
+
* Generates a Certificate Signing Request (CSR) based on the provided parameters.
|
|
17
|
+
* @param params - Parameters for generating the CSR.
|
|
18
|
+
* @returns The generated CSR in PEM format.
|
|
19
|
+
*/
|
|
20
|
+
static generateCsr(params: GenerateCsrParams): Promise<string>;
|
|
21
|
+
/**
|
|
22
|
+
* Checks and parses a certificate in PEM format.
|
|
23
|
+
* @param certPem - The certificate in PEM format.
|
|
24
|
+
* @returns An object containing the parsed certificate details.
|
|
25
|
+
*/
|
|
26
|
+
static checkAndParseCert(certPem: string): Promise<ParsedCert>;
|
|
27
|
+
/**
|
|
28
|
+
* Checks and parses a Certificate Signing Request (CSR) in PEM format.
|
|
29
|
+
* @param csrPem - The CSR in PEM format.
|
|
30
|
+
* @returns An object containing the parsed CSR details.
|
|
31
|
+
*/
|
|
32
|
+
static checkAndParseCsr(csrPem: string): Promise<ParsedCsr>;
|
|
33
|
+
private static getCryptoKeys;
|
|
34
|
+
private static generateSerialNumber;
|
|
35
|
+
private static getPrincipalInfo;
|
|
36
|
+
private static getAlgorithm;
|
|
37
|
+
private static extractDnsNamesFromExtensions;
|
|
38
|
+
}
|