@super-protocol/sdk-js 2.2.0-beta.59 → 2.2.0-beta.60
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/index.d.ts +1 -1
- package/dist/cjs/index.js +5 -2
- package/dist/cjs/tee/QuoteParser.d.ts +59 -5
- package/dist/cjs/tee/QuoteParser.js +219 -27
- package/dist/cjs/tee/QuoteValidator.d.ts +1 -0
- package/dist/cjs/tee/QuoteValidator.js +53 -28
- package/dist/cjs/tee/types.d.ts +49 -9
- package/dist/cjs/tee/types.js +32 -1
- package/dist/mjs/index.d.ts +1 -1
- package/dist/mjs/index.js +2 -2
- package/dist/mjs/tee/QuoteParser.d.ts +59 -5
- package/dist/mjs/tee/QuoteParser.js +216 -26
- package/dist/mjs/tee/QuoteValidator.d.ts +1 -0
- package/dist/mjs/tee/QuoteValidator.js +54 -29
- package/dist/mjs/tee/types.d.ts +49 -9
- package/dist/mjs/tee/types.js +28 -2
- package/package.json +1 -1
package/dist/cjs/index.d.ts
CHANGED
|
@@ -71,7 +71,7 @@ export * as helpers from './utils/helpers/index.js';
|
|
|
71
71
|
export * as constants from './constants.js';
|
|
72
72
|
export { Web3TransactionRevertedByEvmError } from './utils/TxManager.js';
|
|
73
73
|
import './polyfills.js';
|
|
74
|
-
export { TeeSgxParser } from './tee/QuoteParser.js';
|
|
74
|
+
export { TeeSgxParser, TeeTdxParser, TeeParser } from './tee/QuoteParser.js';
|
|
75
75
|
export { QuoteValidator } from './tee/QuoteValidator.js';
|
|
76
76
|
export * from './tee/statuses.js';
|
|
77
77
|
export { TeeBlockVerifier } from './tee/TeeBlockVerifier.js';
|
package/dist/cjs/index.js
CHANGED
|
@@ -29,7 +29,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
29
29
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
30
30
|
};
|
|
31
31
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
32
|
-
exports.
|
|
32
|
+
exports.BrowserEventProvider = exports.NodeEventProvider = exports.Analytics = exports.TeeBlockVerifier = exports.QuoteValidator = exports.TeeParser = exports.TeeTdxParser = exports.TeeSgxParser = exports.Web3TransactionRevertedByEvmError = exports.constants = exports.helpers = exports.StorjCredentialsManager = exports.CredentialsPermissions = exports.parseStorageCredentials = exports.getStorageProvider = exports.ContentWriterType = exports.StorageContentWriter = exports.CacheEvents = exports.StorageAdapter = exports.StorageKeyValueAdapter = exports.StorageMetadataReader = exports.StorjAdapter = exports.ChunkedStorageProvider = exports.TCB = exports.Offer = exports.TeeOffer = exports.Provider = exports.Order = exports.SecretRequests = exports.OffersStorageRequests = exports.OffersStorageAllocated = exports.OfferResources = exports.LoaderSecretsPublicKeys = exports.LoaderSessions = exports.Deposits = exports.Marks = exports.Superpro = exports.SuperproToken = exports.ProviderRegistry = exports.TeeOffers = exports.Offers = exports.ActiveOffers = exports.ActiveOrders = exports.Orders = exports.Consensus = exports.RIGenerator = exports.TIIGenerator = exports.Crypto = exports.BlockchainEventsListener = exports.BlockchainConnector = void 0;
|
|
33
|
+
exports.FetchTransport = exports.AxiosTransport = void 0;
|
|
33
34
|
var BlockchainConnector_js_1 = require("./connectors/BlockchainConnector.js");
|
|
34
35
|
Object.defineProperty(exports, "BlockchainConnector", { enumerable: true, get: function () { return __importDefault(BlockchainConnector_js_1).default; } });
|
|
35
36
|
__exportStar(require("./connectors/BlockchainConnector.js"), exports);
|
|
@@ -139,6 +140,8 @@ Object.defineProperty(exports, "Web3TransactionRevertedByEvmError", { enumerable
|
|
|
139
140
|
require("./polyfills.js");
|
|
140
141
|
var QuoteParser_js_1 = require("./tee/QuoteParser.js");
|
|
141
142
|
Object.defineProperty(exports, "TeeSgxParser", { enumerable: true, get: function () { return QuoteParser_js_1.TeeSgxParser; } });
|
|
143
|
+
Object.defineProperty(exports, "TeeTdxParser", { enumerable: true, get: function () { return QuoteParser_js_1.TeeTdxParser; } });
|
|
144
|
+
Object.defineProperty(exports, "TeeParser", { enumerable: true, get: function () { return QuoteParser_js_1.TeeParser; } });
|
|
142
145
|
var QuoteValidator_js_1 = require("./tee/QuoteValidator.js");
|
|
143
146
|
Object.defineProperty(exports, "QuoteValidator", { enumerable: true, get: function () { return QuoteValidator_js_1.QuoteValidator; } });
|
|
144
147
|
__exportStar(require("./tee/statuses.js"), exports);
|
|
@@ -156,4 +159,4 @@ Object.defineProperty(exports, "AxiosTransport", { enumerable: true, get: functi
|
|
|
156
159
|
var FetchTransport_js_1 = require("./analytics/transports/FetchTransport.js");
|
|
157
160
|
Object.defineProperty(exports, "FetchTransport", { enumerable: true, get: function () { return __importDefault(FetchTransport_js_1).default; } });
|
|
158
161
|
__exportStar(require("./utils/cache/index.js"), exports);
|
|
159
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsOEVBQXFGO0FBQTVFLDhJQUFBLE9BQU8sT0FBdUI7QUFFdkMsc0VBQW9EO0FBSXBELHdGQUErRjtBQUF0Rix3SkFBQSxPQUFPLE9BQTRCO0FBRTVDLDhDQUFzRDtBQUE3QyxtSEFBQSxPQUFPLE9BQVU7QUFDMUIsb0RBQWtDO0FBRWxDLHFEQUE0RDtBQUFuRCxnSUFBQSxPQUFPLE9BQWdCO0FBQ2hDLG9EQUFrQztBQUVsQyxtREFBMEQ7QUFBakQsOEhBQUEsT0FBTyxPQUFlO0FBQy9CLG9EQUFrQztBQUVsQyw0REFBbUU7QUFBMUQsMEhBQUEsT0FBTyxPQUFhO0FBQzdCLDhEQUE0QztBQUU1QyxzREFBNkQ7QUFBcEQsb0hBQUEsT0FBTyxPQUFVO0FBQzFCLDJEQUF5QztBQUV6QyxrRUFBeUU7QUFBaEUsZ0lBQUEsT0FBTyxPQUFnQjtBQUNoQyxpRUFBK0M7QUFFL0Msa0VBQXlFO0FBQWhFLGdJQUFBLE9BQU8sT0FBZ0I7QUFDaEMsaUVBQStDO0FBRS9DLHNEQUE2RDtBQUFwRCxvSEFBQSxPQUFPLE9BQVU7QUFDMUIsMkRBQXlDO0FBRXpDLDREQUFtRTtBQUExRCwwSEFBQSxPQUFPLE9BQWE7QUFDN0IsOERBQTRDO0FBRTVDLDBFQUFpRjtBQUF4RSx3SUFBQSxPQUFPLE9BQW9CO0FBQ3BDLHFFQUFtRDtBQUVuRCxvRUFBMkU7QUFBbEUsa0lBQUEsT0FBTyxPQUFpQjtBQUNqQyxrRUFBZ0Q7QUFFaEQsMERBQWlFO0FBQXhELHdIQUFBLE9BQU8sT0FBWTtBQUM1Qiw2REFBMkM7QUFFM0Msb0RBQTJEO0FBQWxELGtIQUFBLE9BQU8sT0FBUztBQUN6QiwwREFBd0M7QUFFeEMsMERBQWlFO0FBQXhELHdIQUFBLE9BQU8sT0FBWTtBQUM1Qiw2REFBMkM7QUFFM0Msc0VBQTZFO0FBQXBFLG9JQUFBLE9BQU8sT0FBa0I7QUFDbEMsbUVBQWlEO0FBRWpELHdGQUErRjtBQUF0RixzSkFBQSxPQUFPLE9BQTJCO0FBQzNDLDRFQUEwRDtBQUUxRCxzRUFBNkU7QUFBcEUsb0lBQUEsT0FBTyxPQUFrQjtBQUNsQyxtRUFBaUQ7QUFFakQsc0ZBQTZGO0FBQXBGLG9KQUFBLE9BQU8sT0FBMEI7QUFDMUMsMkVBQXlEO0FBRXpELG9GQUEyRjtBQUFsRixrSkFBQSxPQUFPLE9BQXlCO0FBQ3pDLDBFQUF3RDtBQUV4RCxzRUFBNkU7QUFBcEUsb0lBQUEsT0FBTyxPQUFrQjtBQUNsQyxtRUFBaUQ7QUFFakQsOENBQXFEO0FBQTVDLGtIQUFBLE9BQU8sT0FBUztBQUN6QixvREFBa0M7QUFFbEMsb0RBQTJEO0FBQWxELHdIQUFBLE9BQU8sT0FBWTtBQUM1Qix1REFBcUM7QUFFckMsb0RBQTJEO0FBQWxELHdIQUFBLE9BQU8sT0FBWTtBQUM1Qix1REFBcUM7QUFFckMsOENBQXFEO0FBQTVDLGtIQUFBLE9BQU8sT0FBUztBQUN6QixvREFBa0M7QUFFbEMsMENBQWlEO0FBQXhDLDhHQUFBLE9BQU8sT0FBTztBQUN2QixrREFBZ0M7QUFFaEMsbURBQWlDO0FBRWpDLHlHQUF5RjtBQUN6Rix1RUFBMkY7QUFBbEYsZ0lBQUEsT0FBTyxPQUFnQjtBQUNoQyx5RkFHc0Q7QUFGcEQsa0pBQUEsT0FBTyxPQUF5QjtBQUdsQywyRkFBa0c7QUFBekYsb0pBQUEsT0FBTyxPQUEwQjtBQUMxQywyRUFJK0M7QUFIN0Msb0lBQUEsT0FBTyxPQUFrQjtBQUN6QixnSEFBQSxXQUFXLE9BQUE7QUFHYix1RkFJcUQ7QUFIbkQsZ0pBQUEsT0FBTyxPQUF3QjtBQUUvQiw0SEFBQSxpQkFBaUIsT0FBQTtBQU1uQixtRkFBMEY7QUFBakYsNElBQUEsT0FBTyxPQUFzQjtBQUV0Qyw2RkFBeUY7QUFBaEYscUlBQUEsdUJBQXVCLE9BQUE7QUFDaEMsNkZBR3dEO0FBRnRELG9JQUFBLHNCQUFzQixPQUFBO0FBQ3RCLHFJQUFBLHVCQUF1QixPQUFBO0FBR3pCLG1FQUFpRDtBQUNqRCxvRUFBb0Q7QUFDcEQsNERBQTRDO0FBRTVDLHFEQUF5RTtBQUFoRSxpSUFBQSxpQ0FBaUMsT0FBQTtBQUUxQywwQkFBd0I7QUFFeEIsdURBQTZFO0FBQXBFLDhHQUFBLFlBQVksT0FBQTtBQUFFLDhHQUFBLFlBQVksT0FBQTtBQUFFLDJHQUFBLFNBQVMsT0FBQTtBQUM5Qyw2REFBeUQ7QUFBaEQsbUhBQUEsY0FBYyxPQUFBO0FBQ3ZCLG9EQUFrQztBQUNsQyxpRUFBNkQ7QUFBcEQsdUhBQUEsZ0JBQWdCLE9BQUE7QUFFekIsdURBQXFDO0FBQ3JDLHlEQUFnRTtBQUF2RCwwSEFBQSxPQUFPLE9BQWE7QUFDN0Isd0ZBQStGO0FBQXRGLDBJQUFBLE9BQU8sT0FBcUI7QUFDckMsOEZBQXFHO0FBQTVGLGdKQUFBLE9BQU8sT0FBd0I7QUFDeEMsOEVBQXFGO0FBQTVFLG9JQUFBLE9BQU8sT0FBa0I7QUFDbEMsOEVBQXFGO0FBQTVFLG9JQUFBLE9BQU8sT0FBa0I7QUFDbEMseURBQXVDIn0=
|
|
@@ -1,5 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import * as pkijs from 'pkijs';
|
|
3
|
+
import { Buffer as Blob } from 'buffer';
|
|
4
|
+
import { BinaryType, TeeSgxQuoteDataType, TeeSgxReportDataType, ChunkedX509Cert, TeeTdxQuoteDataType, TeeTdxBodyType, TeeTdxHeaderData, QuoteType } from './types.js';
|
|
5
|
+
export declare abstract class TeeParser {
|
|
6
|
+
protected extractRS(cert: pkijs.Certificate): {
|
|
7
|
+
r: string;
|
|
8
|
+
s: string;
|
|
9
|
+
derSignature: string;
|
|
10
|
+
};
|
|
11
|
+
protected parsePem(pem: string): ChunkedX509Cert;
|
|
12
|
+
protected getDataAndAdvance(blob: {
|
|
13
|
+
data: Blob;
|
|
14
|
+
}, size: number): Blob;
|
|
15
|
+
static determineQuoteType(quote: BinaryType): {
|
|
16
|
+
type: QuoteType;
|
|
17
|
+
version: number;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export declare class TeeSgxParser extends TeeParser {
|
|
3
21
|
static readonly quoteHeaderSize = 48;
|
|
4
22
|
static readonly pceSvnOffset = 10;
|
|
5
23
|
static readonly reportSize = 384;
|
|
@@ -19,9 +37,45 @@ export declare class TeeSgxParser {
|
|
|
19
37
|
static readonly reportUserDataSHA256Size = 32;
|
|
20
38
|
static readonly ecdsaP256SignatureSize = 64;
|
|
21
39
|
static readonly ecdsaP256PublicKeySize = 64;
|
|
22
|
-
private getDataAndAdvance;
|
|
23
|
-
private extractRS;
|
|
24
|
-
private parsePem;
|
|
25
40
|
parseQuote(data: BinaryType): TeeSgxQuoteDataType;
|
|
26
41
|
parseReport(data: BinaryType): TeeSgxReportDataType;
|
|
27
42
|
}
|
|
43
|
+
export declare class TeeTdxParser extends TeeParser {
|
|
44
|
+
static readonly quoteHeaderSize = 48;
|
|
45
|
+
static readonly tdQuoteBodySize = 584;
|
|
46
|
+
static readonly quoteSignatureDataLen = 4;
|
|
47
|
+
static readonly headerVersionSize = 2;
|
|
48
|
+
static readonly headerAttestationKeyTypeSize = 2;
|
|
49
|
+
static readonly headerTeeTypeSize = 4;
|
|
50
|
+
static readonly headerReserved1Size = 2;
|
|
51
|
+
static readonly headerReserved2Size = 2;
|
|
52
|
+
static readonly headerQeVendorIdSize = 16;
|
|
53
|
+
static readonly headerUserDataSize = 20;
|
|
54
|
+
static readonly bodyTeeTcbSvnSize = 16;
|
|
55
|
+
static readonly bodyMrSeamSize = 48;
|
|
56
|
+
static readonly bodyMrSignerSeamSize = 48;
|
|
57
|
+
static readonly bodySeamAttributesSize = 8;
|
|
58
|
+
static readonly bodyTdAttributesSize = 8;
|
|
59
|
+
static readonly bodyXfamSize = 8;
|
|
60
|
+
static readonly bodyMrTdSize = 48;
|
|
61
|
+
static readonly bodyMrConfigIdSize = 48;
|
|
62
|
+
static readonly bodyMrOwnerSize = 48;
|
|
63
|
+
static readonly bodyMrOwnerConfigSize = 48;
|
|
64
|
+
static readonly bodyRtmr0Size = 48;
|
|
65
|
+
static readonly bodyRtmr1Size = 48;
|
|
66
|
+
static readonly bodyRtmr2Size = 48;
|
|
67
|
+
static readonly bodyRtmr3Size = 48;
|
|
68
|
+
static readonly bodyReportDataSize = 64;
|
|
69
|
+
static readonly sigQuoteSignatureSize = 64;
|
|
70
|
+
static readonly sigAttestationKeySize = 64;
|
|
71
|
+
static readonly sigCertDataTypeSize = 2;
|
|
72
|
+
static readonly sigCertDataSzSize = 4;
|
|
73
|
+
static readonly sigQeReportSize = 384;
|
|
74
|
+
static readonly sigQeReportSignatureSize = 64;
|
|
75
|
+
static readonly sigQeAuthenticationDataSzSize = 2;
|
|
76
|
+
static readonly sigSignatureTypeSize = 2;
|
|
77
|
+
static readonly sigSignatureSzSize = 4;
|
|
78
|
+
parseQuote(data: BinaryType): TeeTdxQuoteDataType;
|
|
79
|
+
parseHeader(data: BinaryType): TeeTdxHeaderData;
|
|
80
|
+
parseBody(data: BinaryType): TeeTdxBodyType;
|
|
81
|
+
}
|
|
@@ -23,38 +23,15 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.TeeSgxParser = void 0;
|
|
26
|
+
exports.TeeTdxParser = exports.TeeSgxParser = exports.TeeParser = void 0;
|
|
27
27
|
const x509_1 = require("@fidm/x509");
|
|
28
28
|
const asn1js = __importStar(require("asn1js"));
|
|
29
29
|
const pkijs = __importStar(require("pkijs"));
|
|
30
30
|
const buffer_1 = require("buffer");
|
|
31
31
|
const errors_js_1 = require("./errors.js");
|
|
32
|
+
const types_js_1 = require("./types.js");
|
|
32
33
|
const helpers_js_1 = require("./helpers.js");
|
|
33
|
-
class
|
|
34
|
-
static quoteHeaderSize = 48;
|
|
35
|
-
static pceSvnOffset = 10;
|
|
36
|
-
static reportSize = 384;
|
|
37
|
-
static userDataOffset = 28;
|
|
38
|
-
static userDataSize = 20;
|
|
39
|
-
static cpuSvnSize = 16;
|
|
40
|
-
static reportMrEnclaveOffset = 64;
|
|
41
|
-
static reportMrEnclaveSize = 32;
|
|
42
|
-
static reportMrSignerOffset = TeeSgxParser.reportMrEnclaveOffset + TeeSgxParser.reportMrEnclaveSize + /* reserved */ 32;
|
|
43
|
-
static reportMrSignerSize = 32;
|
|
44
|
-
static reportIsvProdIdOffset = TeeSgxParser.reportMrSignerOffset + TeeSgxParser.reportMrSignerSize + /* reserved */ 96;
|
|
45
|
-
static reportIsvProdIdSize = 2;
|
|
46
|
-
static reportIsvSvnOffset = TeeSgxParser.reportIsvProdIdOffset + TeeSgxParser.reportIsvProdIdSize;
|
|
47
|
-
static reportIsvSvnSize = 2;
|
|
48
|
-
static reportDataOffset = TeeSgxParser.reportIsvSvnOffset + TeeSgxParser.reportIsvSvnSize + /* reserved */ 60;
|
|
49
|
-
static reportUserDataSize = 64;
|
|
50
|
-
static reportUserDataSHA256Size = 32; /* 64 in report, but we need 32 only for sha256 hash */
|
|
51
|
-
static ecdsaP256SignatureSize = 64;
|
|
52
|
-
static ecdsaP256PublicKeySize = 64;
|
|
53
|
-
getDataAndAdvance(blob, size) {
|
|
54
|
-
const buf = buffer_1.Buffer.from(blob.data.subarray(0, size));
|
|
55
|
-
blob.data = buffer_1.Buffer.from(blob.data.subarray(size));
|
|
56
|
-
return buf;
|
|
57
|
-
}
|
|
34
|
+
class TeeParser {
|
|
58
35
|
extractRS(cert) {
|
|
59
36
|
const derSignature = Buffer.from(cert.signatureValue.valueBlock.valueHexView).toString('hex');
|
|
60
37
|
const parsedSignature = helpers_js_1.Signature.importFromDER(derSignature);
|
|
@@ -81,6 +58,53 @@ class TeeSgxParser {
|
|
|
81
58
|
signature: x509Signature,
|
|
82
59
|
};
|
|
83
60
|
}
|
|
61
|
+
getDataAndAdvance(blob, size) {
|
|
62
|
+
const buf = buffer_1.Buffer.from(blob.data.subarray(0, size));
|
|
63
|
+
blob.data = buffer_1.Buffer.from(blob.data.subarray(size));
|
|
64
|
+
return buf;
|
|
65
|
+
}
|
|
66
|
+
static determineQuoteType(quote) {
|
|
67
|
+
let type = types_js_1.QuoteType.SGX;
|
|
68
|
+
if (quote.length < 48) {
|
|
69
|
+
throw new errors_js_1.TeeQuoteParserError('data has invalid length');
|
|
70
|
+
}
|
|
71
|
+
const version = Buffer.from(quote).readUInt16LE(0);
|
|
72
|
+
if (version === 4) {
|
|
73
|
+
const quoteType = Buffer.from(quote).readUInt32LE(4);
|
|
74
|
+
if (quoteType === 0x00000081) {
|
|
75
|
+
type = types_js_1.QuoteType.TDX;
|
|
76
|
+
}
|
|
77
|
+
else if (quoteType !== 0x00000000) {
|
|
78
|
+
throw new errors_js_1.TeeQuoteParserError(`Unknown quote type ${quoteType}`);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
else if (version !== 3) {
|
|
82
|
+
throw new errors_js_1.TeeQuoteParserError(`Unknown quote version ${version}`);
|
|
83
|
+
}
|
|
84
|
+
return { type, version };
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
exports.TeeParser = TeeParser;
|
|
88
|
+
class TeeSgxParser extends TeeParser {
|
|
89
|
+
static quoteHeaderSize = 48;
|
|
90
|
+
static pceSvnOffset = 10;
|
|
91
|
+
static reportSize = 384;
|
|
92
|
+
static userDataOffset = 28;
|
|
93
|
+
static userDataSize = 20;
|
|
94
|
+
static cpuSvnSize = 16;
|
|
95
|
+
static reportMrEnclaveOffset = 64;
|
|
96
|
+
static reportMrEnclaveSize = 32;
|
|
97
|
+
static reportMrSignerOffset = TeeSgxParser.reportMrEnclaveOffset + TeeSgxParser.reportMrEnclaveSize + /* reserved */ 32;
|
|
98
|
+
static reportMrSignerSize = 32;
|
|
99
|
+
static reportIsvProdIdOffset = TeeSgxParser.reportMrSignerOffset + TeeSgxParser.reportMrSignerSize + /* reserved */ 96;
|
|
100
|
+
static reportIsvProdIdSize = 2;
|
|
101
|
+
static reportIsvSvnOffset = TeeSgxParser.reportIsvProdIdOffset + TeeSgxParser.reportIsvProdIdSize;
|
|
102
|
+
static reportIsvSvnSize = 2;
|
|
103
|
+
static reportDataOffset = TeeSgxParser.reportIsvSvnOffset + TeeSgxParser.reportIsvSvnSize + /* reserved */ 60;
|
|
104
|
+
static reportUserDataSize = 64;
|
|
105
|
+
static reportUserDataSHA256Size = 32; /* 64 in report, but we need 32 only for sha256 hash */
|
|
106
|
+
static ecdsaP256SignatureSize = 64;
|
|
107
|
+
static ecdsaP256PublicKeySize = 64;
|
|
84
108
|
parseQuote(data) {
|
|
85
109
|
const { quoteHeaderSize, pceSvnOffset, reportSize, userDataOffset, userDataSize, ecdsaP256SignatureSize, ecdsaP256PublicKeySize, } = TeeSgxParser;
|
|
86
110
|
if (data.length < quoteHeaderSize + reportSize) {
|
|
@@ -126,6 +150,7 @@ class TeeSgxParser {
|
|
|
126
150
|
const certsPems = (0, helpers_js_1.splitChain)(qeCertificationData.toString()); // [device, platform, root]
|
|
127
151
|
const certsData = certsPems.map((pem) => this.parsePem(pem));
|
|
128
152
|
return {
|
|
153
|
+
quoteType: types_js_1.QuoteType.SGX,
|
|
129
154
|
rawHeader: quoteHeader,
|
|
130
155
|
header: {
|
|
131
156
|
version,
|
|
@@ -186,4 +211,171 @@ class TeeSgxParser {
|
|
|
186
211
|
}
|
|
187
212
|
}
|
|
188
213
|
exports.TeeSgxParser = TeeSgxParser;
|
|
189
|
-
|
|
214
|
+
class TeeTdxParser extends TeeParser {
|
|
215
|
+
//High-level quote structure
|
|
216
|
+
static quoteHeaderSize = 48;
|
|
217
|
+
static tdQuoteBodySize = 584;
|
|
218
|
+
static quoteSignatureDataLen = 4;
|
|
219
|
+
// Header fields
|
|
220
|
+
static headerVersionSize = 2;
|
|
221
|
+
static headerAttestationKeyTypeSize = 2;
|
|
222
|
+
static headerTeeTypeSize = 4;
|
|
223
|
+
static headerReserved1Size = 2;
|
|
224
|
+
static headerReserved2Size = 2;
|
|
225
|
+
static headerQeVendorIdSize = 16;
|
|
226
|
+
static headerUserDataSize = 20;
|
|
227
|
+
// Body fiedls
|
|
228
|
+
static bodyTeeTcbSvnSize = 16;
|
|
229
|
+
static bodyMrSeamSize = 48;
|
|
230
|
+
static bodyMrSignerSeamSize = 48;
|
|
231
|
+
static bodySeamAttributesSize = 8;
|
|
232
|
+
static bodyTdAttributesSize = 8;
|
|
233
|
+
static bodyXfamSize = 8;
|
|
234
|
+
static bodyMrTdSize = 48;
|
|
235
|
+
static bodyMrConfigIdSize = 48;
|
|
236
|
+
static bodyMrOwnerSize = 48;
|
|
237
|
+
static bodyMrOwnerConfigSize = 48;
|
|
238
|
+
static bodyRtmr0Size = 48;
|
|
239
|
+
static bodyRtmr1Size = 48;
|
|
240
|
+
static bodyRtmr2Size = 48;
|
|
241
|
+
static bodyRtmr3Size = 48;
|
|
242
|
+
static bodyReportDataSize = 64;
|
|
243
|
+
// Signature fields
|
|
244
|
+
static sigQuoteSignatureSize = 64;
|
|
245
|
+
static sigAttestationKeySize = 64;
|
|
246
|
+
static sigCertDataTypeSize = 2;
|
|
247
|
+
static sigCertDataSzSize = 4;
|
|
248
|
+
static sigQeReportSize = 384;
|
|
249
|
+
static sigQeReportSignatureSize = 64;
|
|
250
|
+
static sigQeAuthenticationDataSzSize = 2;
|
|
251
|
+
static sigSignatureTypeSize = 2;
|
|
252
|
+
static sigSignatureSzSize = 4;
|
|
253
|
+
parseQuote(data) {
|
|
254
|
+
const { quoteHeaderSize, tdQuoteBodySize, quoteSignatureDataLen, sigQuoteSignatureSize, sigAttestationKeySize, sigCertDataTypeSize, sigCertDataSzSize, sigQeReportSize, sigQeReportSignatureSize, sigQeAuthenticationDataSzSize, sigSignatureTypeSize, sigSignatureSzSize, } = TeeTdxParser;
|
|
255
|
+
const expectedSize = quoteHeaderSize + tdQuoteBodySize + quoteSignatureDataLen;
|
|
256
|
+
if (data.length < expectedSize) {
|
|
257
|
+
throw new errors_js_1.TeeQuoteParserError(`quote has invalid length ${data.length}, expected not less than ${expectedSize}`);
|
|
258
|
+
}
|
|
259
|
+
const quoteRemainder = { data: buffer_1.Buffer.from(data) };
|
|
260
|
+
const rawHeader = this.getDataAndAdvance(quoteRemainder, quoteHeaderSize);
|
|
261
|
+
const tdQuoteBody = this.getDataAndAdvance(quoteRemainder, tdQuoteBodySize);
|
|
262
|
+
const signatureLen = this.getDataAndAdvance(quoteRemainder, quoteSignatureDataLen);
|
|
263
|
+
const certificationDataSize = signatureLen.readUInt32LE(0);
|
|
264
|
+
const expectedQuoteLen = quoteHeaderSize + tdQuoteBodySize + quoteSignatureDataLen + certificationDataSize;
|
|
265
|
+
if (data.length < expectedQuoteLen) {
|
|
266
|
+
throw new errors_js_1.TeeQuoteParserError(`quote has invalid length ${data.length}, expected not less than ${expectedQuoteLen}`);
|
|
267
|
+
}
|
|
268
|
+
const signature = { data: this.getDataAndAdvance(quoteRemainder, certificationDataSize) };
|
|
269
|
+
const quoteSignature = this.getDataAndAdvance(signature, sigQuoteSignatureSize);
|
|
270
|
+
const ecdsaAttestationKey = this.getDataAndAdvance(signature, sigAttestationKeySize);
|
|
271
|
+
const certDataType = this.getDataAndAdvance(signature, sigCertDataTypeSize).readUint16LE(); //expected 6
|
|
272
|
+
if (certDataType !== 6)
|
|
273
|
+
throw new errors_js_1.TeeQuoteParserError(`certDataType has invalid value ${certDataType}, expected 6`);
|
|
274
|
+
const certDataSize = this.getDataAndAdvance(signature, sigCertDataSzSize).readUint32LE();
|
|
275
|
+
if (signature.data.length < certDataSize)
|
|
276
|
+
throw new errors_js_1.TeeQuoteParserError(`certData has invalid length ${data.length}, expected not less than ${certDataSize}`);
|
|
277
|
+
const qeReport = this.getDataAndAdvance(signature, sigQeReportSize);
|
|
278
|
+
const qeReportSignature = this.getDataAndAdvance(signature, sigQeReportSignatureSize);
|
|
279
|
+
const qeAuthenticationDataSize = this.getDataAndAdvance(signature, sigQeAuthenticationDataSzSize).readUint16LE();
|
|
280
|
+
if (signature.data.length < qeAuthenticationDataSize)
|
|
281
|
+
throw new errors_js_1.TeeQuoteParserError(`qeAuthenticationData has invalid length ${data.length}, expected not less than ${qeAuthenticationDataSize}`);
|
|
282
|
+
const qeAuthenticationData = this.getDataAndAdvance(signature, qeAuthenticationDataSize);
|
|
283
|
+
const qeCertificationDataType = this.getDataAndAdvance(signature, sigSignatureTypeSize).readUint16LE(); //expected 5
|
|
284
|
+
if (qeCertificationDataType !== 5)
|
|
285
|
+
throw new errors_js_1.TeeQuoteParserError(`signatureType has invalid value ${qeCertificationDataType}, expected 5`);
|
|
286
|
+
const signatureSize = this.getDataAndAdvance(signature, sigSignatureSzSize).readUint32LE();
|
|
287
|
+
if (signature.data.length < signatureSize)
|
|
288
|
+
throw new errors_js_1.TeeQuoteParserError(`certChain has invalid length ${data.length}, expected not less than ${signatureSize}`);
|
|
289
|
+
const qeCertificationData = this.getDataAndAdvance(signature, signatureSize);
|
|
290
|
+
const certsPems = (0, helpers_js_1.splitChain)(qeCertificationData.toString()); // [device, platform, root]
|
|
291
|
+
const certsData = certsPems.map((pem) => this.parsePem(pem));
|
|
292
|
+
return {
|
|
293
|
+
quoteType: types_js_1.QuoteType.TDX,
|
|
294
|
+
rawHeader,
|
|
295
|
+
header: this.parseHeader(rawHeader),
|
|
296
|
+
tdQuoteBody,
|
|
297
|
+
quoteSignature,
|
|
298
|
+
ecdsaAttestationKey,
|
|
299
|
+
certDataType,
|
|
300
|
+
qeReport,
|
|
301
|
+
qeReportSignature,
|
|
302
|
+
qeAuthenticationData,
|
|
303
|
+
qeCertificationDataType,
|
|
304
|
+
qeCertificationData,
|
|
305
|
+
certificates: {
|
|
306
|
+
device: {
|
|
307
|
+
pem: certsPems[0],
|
|
308
|
+
x509Data: certsData[0],
|
|
309
|
+
},
|
|
310
|
+
platform: {
|
|
311
|
+
pem: certsPems[1],
|
|
312
|
+
x509Data: certsData[1],
|
|
313
|
+
},
|
|
314
|
+
root: {
|
|
315
|
+
pem: certsPems[2],
|
|
316
|
+
x509Data: certsData[2],
|
|
317
|
+
},
|
|
318
|
+
},
|
|
319
|
+
};
|
|
320
|
+
}
|
|
321
|
+
parseHeader(data) {
|
|
322
|
+
const { headerVersionSize, headerAttestationKeyTypeSize, headerTeeTypeSize, headerReserved1Size, headerReserved2Size, headerQeVendorIdSize, headerUserDataSize, } = TeeTdxParser;
|
|
323
|
+
const headerRemainder = { data: buffer_1.Buffer.from(data) };
|
|
324
|
+
const version = this.getDataAndAdvance(headerRemainder, headerVersionSize).readUInt16LE();
|
|
325
|
+
const attestationKeyType = this.getDataAndAdvance(headerRemainder, headerAttestationKeyTypeSize).readUInt16LE();
|
|
326
|
+
const teeType = this.getDataAndAdvance(headerRemainder, headerTeeTypeSize).readUInt32LE();
|
|
327
|
+
const reserved1 = this.getDataAndAdvance(headerRemainder, headerReserved1Size);
|
|
328
|
+
const reserved2 = this.getDataAndAdvance(headerRemainder, headerReserved2Size);
|
|
329
|
+
const qeVendorId = this.getDataAndAdvance(headerRemainder, headerQeVendorIdSize);
|
|
330
|
+
const userData = this.getDataAndAdvance(headerRemainder, headerUserDataSize);
|
|
331
|
+
return {
|
|
332
|
+
version,
|
|
333
|
+
attestationKeyType,
|
|
334
|
+
teeType,
|
|
335
|
+
reserved1,
|
|
336
|
+
reserved2,
|
|
337
|
+
qeVendorId,
|
|
338
|
+
userData,
|
|
339
|
+
};
|
|
340
|
+
}
|
|
341
|
+
parseBody(data) {
|
|
342
|
+
const { bodyTeeTcbSvnSize, bodyMrSeamSize, bodyMrSignerSeamSize, bodySeamAttributesSize, bodyTdAttributesSize, bodyXfamSize, bodyMrTdSize, bodyMrConfigIdSize, bodyMrOwnerSize, bodyMrOwnerConfigSize, bodyRtmr0Size, bodyRtmr1Size, bodyRtmr2Size, bodyRtmr3Size, bodyReportDataSize, } = TeeTdxParser;
|
|
343
|
+
const bodyRemainder = { data: buffer_1.Buffer.from(data) };
|
|
344
|
+
if (bodyRemainder.data.length !== TeeTdxParser.tdQuoteBodySize)
|
|
345
|
+
throw new errors_js_1.TeeQuoteParserError(`body has invalid length ${bodyRemainder.data.length}, expected ${TeeTdxParser.tdQuoteBodySize}`);
|
|
346
|
+
const teeTcbSvn = this.getDataAndAdvance(bodyRemainder, bodyTeeTcbSvnSize);
|
|
347
|
+
const mrSeam = this.getDataAndAdvance(bodyRemainder, bodyMrSeamSize);
|
|
348
|
+
const mrSignerSeam = this.getDataAndAdvance(bodyRemainder, bodyMrSignerSeamSize);
|
|
349
|
+
const seamAttributes = this.getDataAndAdvance(bodyRemainder, bodySeamAttributesSize);
|
|
350
|
+
const tdAttributes = this.getDataAndAdvance(bodyRemainder, bodyTdAttributesSize);
|
|
351
|
+
const xfam = this.getDataAndAdvance(bodyRemainder, bodyXfamSize);
|
|
352
|
+
const mrTd = this.getDataAndAdvance(bodyRemainder, bodyMrTdSize);
|
|
353
|
+
const mrConfigId = this.getDataAndAdvance(bodyRemainder, bodyMrConfigIdSize);
|
|
354
|
+
const mrOwner = this.getDataAndAdvance(bodyRemainder, bodyMrOwnerSize);
|
|
355
|
+
const mrOwnerConfig = this.getDataAndAdvance(bodyRemainder, bodyMrOwnerConfigSize);
|
|
356
|
+
const rtmr0 = this.getDataAndAdvance(bodyRemainder, bodyRtmr0Size);
|
|
357
|
+
const rtmr1 = this.getDataAndAdvance(bodyRemainder, bodyRtmr1Size);
|
|
358
|
+
const rtmr2 = this.getDataAndAdvance(bodyRemainder, bodyRtmr2Size);
|
|
359
|
+
const rtmr3 = this.getDataAndAdvance(bodyRemainder, bodyRtmr3Size);
|
|
360
|
+
const reportData = this.getDataAndAdvance(bodyRemainder, bodyReportDataSize);
|
|
361
|
+
return {
|
|
362
|
+
teeTcbSvn,
|
|
363
|
+
mrSeam,
|
|
364
|
+
mrSignerSeam,
|
|
365
|
+
seamAttributes,
|
|
366
|
+
tdAttributes,
|
|
367
|
+
xfam,
|
|
368
|
+
mrTd,
|
|
369
|
+
mrConfigId,
|
|
370
|
+
mrOwner,
|
|
371
|
+
mrOwnerConfig,
|
|
372
|
+
rtmr0,
|
|
373
|
+
rtmr1,
|
|
374
|
+
rtmr2,
|
|
375
|
+
rtmr3,
|
|
376
|
+
reportData,
|
|
377
|
+
};
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
exports.TeeTdxParser = TeeTdxParser;
|
|
381
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"QuoteParser.js","sourceRoot":"","sources":["../../../src/tee/QuoteParser.ts"],"names":[],"mappings":"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"}
|