@super-protocol/addons-tee 0.8.16 → 0.8.17-beta.1
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/README.md +1 -1
- package/bindings/amd-sev-snp-napi-rs/amd-sev-snp-napi-rs.linux-x64-gnu.node +0 -0
- package/bindings/amd-sev-snp-napi-rs/index.d.ts +24 -0
- package/bindings/amd-sev-snp-napi-rs/index.js +328 -0
- package/bindings/amd-sev-snp-napi-rs/package-lock.json +40 -0
- package/bindings/amd-sev-snp-napi-rs/package.json +31 -0
- package/bindings/sgx-native/build/Release/sgx_native.node +0 -0
- package/bindings/utils/virtee/LICENSE +201 -0
- package/bindings/utils/virtee/libsev.so +0 -0
- package/bindings/utils/virtee/snpguest +0 -0
- package/dist/sgx-native-module/consts.d.ts +1 -1
- package/dist/sgx-native-module/consts.js +4 -4
- package/dist/sgx-native-module/dcap-quote-verify.service.js +1 -1
- package/dist/sgx-native-module/enclave.service.d.ts +5 -4
- package/dist/sgx-native-module/enclave.service.js +1 -1
- package/dist/sgx-native-module/errors.js +1 -1
- package/dist/sgx-native-module/index.d.ts +2 -0
- package/dist/sgx-native-module/index.js +3 -1
- package/dist/sgx-native-module/pki.service.d.ts +2 -2
- package/dist/sgx-native-module/pki.service.js +4 -4
- package/dist/sgx-native-module/sev-snp-mrenclave.d.ts +63 -0
- package/dist/sgx-native-module/sev-snp-mrenclave.js +290 -0
- package/dist/sgx-native-module/sev-snp.d.ts +133 -0
- package/dist/sgx-native-module/sev-snp.js +533 -0
- package/package.json +21 -14
- package/dist/sgx-native-module/sgx-tests.d.ts +0 -1
- package/dist/sgx-native-module/sgx-tests.js +0 -114
- package/dist/sgx-native-module/tdx-tests.d.ts +0 -1
- package/dist/sgx-native-module/tdx-tests.js +0 -64
|
@@ -32,4 +32,4 @@ class DcapQuoteVerifyService {
|
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
34
|
exports.DcapQuoteVerifyService = DcapQuoteVerifyService;
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGNhcC1xdW90ZS12ZXJpZnkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZ3gtbmF0aXZlLW1vZHVsZS9kY2FwLXF1b3RlLXZlcmlmeS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLE1BQU0sRUFBRSxzQkFBc0IsRUFBRSxHQUFHLE9BQU8sQ0FBQyx5REFBeUQsQ0FBQyxDQUFDO0FBQ3RHLHFDQUFnRTtBQUNoRSxxQ0FBc0g7QUFRdEgsTUFBYSxzQkFBc0I7SUFHL0I7UUFDSSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksc0JBQXNCLEVBQUUsQ0FBQztJQUN0RCxDQUFDO0lBRUQsS0FBSyxDQUFDLG9CQUFvQixDQUFDLFlBQW9CO1FBQzNDLElBQUksQ0FBQyxZQUFZLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDeEIsTUFBTSxJQUFJLCtDQUFzQyxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFDMUUsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxvQkFBb0IsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRUQsS0FBSyxDQUFDLDRCQUE0QixDQUFDLEtBQWEsRUFBRSxhQUF1QjtRQUNyRSxhQUFhLEdBQUcsYUFBYSxJQUFJLEtBQUssQ0FBQztRQUV2QyxJQUFJLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSwrQ0FBc0MsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNwRSxDQUFDO1FBRUQsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0QsSUFBSSxhQUFhLElBQUksWUFBWSxDQUFDLFVBQVUsS0FBSyxnQkFBTyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3JFLE1BQU0sSUFBSSxxQ0FBNEIsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN6RCxDQUFDO1FBQ0QsSUFBSSxZQUFZLENBQUMsa0JBQWtCLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDeEMsTUFBTSxJQUFJLDZCQUFvQixDQUFDLFlBQVksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3BFLENBQUM7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLGdCQUFnQixDQUFDLFFBQWdCO1FBQ25DLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN6RCxDQUFDO0NBQ0o7QUFsQ0Qsd0RBa0NDIn0=
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
2
3
|
import { Readable } from "stream";
|
|
3
4
|
import { KeyType, KeyPolicy } from "./consts";
|
|
4
|
-
export
|
|
5
|
+
export type TeeDeviceInfoType = {
|
|
5
6
|
cpus: Array<{
|
|
6
7
|
vendorId: string;
|
|
7
8
|
cpuFamily: number;
|
|
@@ -16,16 +17,16 @@ export declare type TeeDeviceInfoType = {
|
|
|
16
17
|
totalPhysicalCores: number;
|
|
17
18
|
totalLogicalCores: number;
|
|
18
19
|
};
|
|
19
|
-
export
|
|
20
|
+
export type TeeRunCpuBenchmarkType = {
|
|
20
21
|
cpuScore: number;
|
|
21
22
|
cpuBenchmark: string;
|
|
22
23
|
cpuCoresCount: number;
|
|
23
24
|
};
|
|
24
|
-
export
|
|
25
|
+
export type TeeRunMemoryBenchmarkType = {
|
|
25
26
|
memBandwidth: number;
|
|
26
27
|
memСonfirmedSize: number;
|
|
27
28
|
};
|
|
28
|
-
export
|
|
29
|
+
export type TeeGetKeyResult = {
|
|
29
30
|
key: Buffer;
|
|
30
31
|
request: Buffer;
|
|
31
32
|
};
|
|
@@ -208,4 +208,4 @@ class EnclaveService {
|
|
|
208
208
|
}
|
|
209
209
|
}
|
|
210
210
|
exports.EnclaveService = EnclaveService;
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enclave.service.js","sourceRoot":"","sources":["../../src/sgx-native-module/enclave.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -59,4 +59,4 @@ class PkiServiceError extends Error {
|
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
61
|
exports.PkiServiceError = PkiServiceError;
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NneC1uYXRpdmUtbW9kdWxlL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBZ0U7QUFFaEUsTUFBYSxzQ0FBdUMsU0FBUSxLQUFLO0lBQzdELFlBQVksR0FBWTtRQUNwQixLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDWCxJQUFJLENBQUMsSUFBSSxHQUFHLHNDQUFzQyxDQUFDLElBQUksQ0FBQztJQUM1RCxDQUFDO0NBQ0o7QUFMRCx3RkFLQztBQUVELE1BQWEsb0JBQXFCLFNBQVEsc0NBQXNDO0lBRTVFLFlBQTRCLFlBQW9CO1FBQzVDLEtBQUssRUFBRSxDQUFDO1FBRGdCLGlCQUFZLEdBQVosWUFBWSxDQUFRO1FBRHpDLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBR3pCLElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO1FBRTNCLFFBQVEsWUFBWSxFQUFFLENBQUM7WUFDbkIsS0FBSyxNQUFNO2dCQUNQLElBQUksQ0FBQyxPQUFPLEdBQUc7NEZBQzZELENBQUM7Z0JBQzdFLE1BQU07WUFDVixLQUFLLE1BQU0sQ0FBQztZQUNaLEtBQUssTUFBTSxDQUFDO1lBQ1osS0FBSyxNQUFNO2dCQUNQLElBQUksQ0FBQyxPQUFPLEdBQUc7b0ZBQ3FELENBQUM7Z0JBQ3JFLE1BQU07WUFDVixLQUFLLE1BQU0sQ0FBQztZQUNaLEtBQUssTUFBTTtnQkFDUCxJQUFJLENBQUMsT0FBTyxHQUFHOzZIQUM4RixDQUFDO2dCQUM5RyxNQUFNO1lBQ1Y7Z0JBQ0ksSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7Z0JBQzFCLElBQUksQ0FBQyxPQUFPLEdBQUcscURBQXFELE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztnQkFDeEcsTUFBTTtRQUNkLENBQUM7SUFDTCxDQUFDO0NBQ0o7QUE3QkQsb0RBNkJDO0FBRUQsTUFBYSw0QkFBNkIsU0FBUSxzQ0FBc0M7SUFDcEYsWUFBNEIsWUFBeUM7UUFDakUsS0FBSyxFQUFFLENBQUM7UUFEZ0IsaUJBQVksR0FBWixZQUFZLENBQTZCO1FBRWpFLElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxPQUFPLEdBQUcsc0NBQXNDLENBQUM7UUFDdEQsSUFBSSxZQUFZLENBQUMsVUFBVSxLQUFLLGdCQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDcEQsSUFBSSxDQUFDLE9BQU8sR0FBRyw4REFBOEQsQ0FBQztRQUNsRixDQUFDO0lBQ0wsQ0FBQztDQUNKO0FBVEQsb0VBU0M7QUFFRCxNQUFhLGVBQWdCLFNBQVEsS0FBSztJQUN0QyxZQUFZLEdBQVk7UUFDcEIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ1gsSUFBSSxDQUFDLElBQUksR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDO0lBQ3JDLENBQUM7Q0FDSjtBQUxELDBDQUtDIn0=
|
|
@@ -19,4 +19,6 @@ __exportStar(require("./errors"), exports);
|
|
|
19
19
|
__exportStar(require("./enclave.service"), exports);
|
|
20
20
|
__exportStar(require("./dcap-quote-verify.service"), exports);
|
|
21
21
|
__exportStar(require("./pki.service"), exports);
|
|
22
|
-
|
|
22
|
+
__exportStar(require("./sev-snp"), exports);
|
|
23
|
+
__exportStar(require("./sev-snp-mrenclave"), exports);
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2d4LW5hdGl2ZS1tb2R1bGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsb0RBQWtDO0FBQ2xDLDhEQUE0QztBQUM1QyxnREFBOEI7QUFDOUIsNENBQTBCO0FBQzFCLHNEQUFvQyJ9
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
-
export
|
|
2
|
+
export type TlsCertResult = {
|
|
3
3
|
key: Buffer;
|
|
4
4
|
cert: Buffer;
|
|
5
5
|
};
|
|
@@ -24,7 +24,7 @@ export declare enum ECPCurve {
|
|
|
24
24
|
SECP224K1 = "SECP224K1" /*!< Domain parameters for 224-bit "Koblitz" curve. */,
|
|
25
25
|
SECP256K1 = "SECP256K1" /*!< Domain parameters for 256-bit "Koblitz" curve. */
|
|
26
26
|
}
|
|
27
|
-
export
|
|
27
|
+
export type TLSCertParams = {
|
|
28
28
|
format?: CertificateFormat;
|
|
29
29
|
subject?: {
|
|
30
30
|
commonName?: string;
|
|
@@ -6,12 +6,12 @@ var CertificateKeyType;
|
|
|
6
6
|
(function (CertificateKeyType) {
|
|
7
7
|
CertificateKeyType["RSA"] = "RSA";
|
|
8
8
|
CertificateKeyType["ECP"] = "ECP";
|
|
9
|
-
})(CertificateKeyType
|
|
9
|
+
})(CertificateKeyType || (exports.CertificateKeyType = CertificateKeyType = {}));
|
|
10
10
|
var CertificateFormat;
|
|
11
11
|
(function (CertificateFormat) {
|
|
12
12
|
CertificateFormat["PEM"] = "PEM";
|
|
13
13
|
CertificateFormat["DER"] = "DER";
|
|
14
|
-
})(CertificateFormat
|
|
14
|
+
})(CertificateFormat || (exports.CertificateFormat = CertificateFormat = {}));
|
|
15
15
|
var ECPCurve;
|
|
16
16
|
(function (ECPCurve) {
|
|
17
17
|
ECPCurve["SECP192R1"] = "SECP192R1"; /*!< Domain parameters for the 192-bit curve defined by FIPS 186-4 and SEC1. */
|
|
@@ -27,7 +27,7 @@ var ECPCurve;
|
|
|
27
27
|
ECPCurve["SECP224K1"] = "SECP224K1"; /*!< Domain parameters for 224-bit "Koblitz" curve. */
|
|
28
28
|
ECPCurve["SECP256K1"] = "SECP256K1"; /*!< Domain parameters for 256-bit "Koblitz" curve. */
|
|
29
29
|
// @TODO: MBEDTLS NOT SUPPORT EXRPORT CURVE448 = "CURVE448", /*!< Domain parameters for Curve448. */
|
|
30
|
-
})(ECPCurve
|
|
30
|
+
})(ECPCurve || (exports.ECPCurve = ECPCurve = {}));
|
|
31
31
|
class PkiService {
|
|
32
32
|
constructor() {
|
|
33
33
|
this.cryptoPrimitives = new CryptoPrimitives();
|
|
@@ -86,4 +86,4 @@ class PkiService {
|
|
|
86
86
|
}
|
|
87
87
|
}
|
|
88
88
|
exports.PkiService = PkiService;
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGtpLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2d4LW5hdGl2ZS1tb2R1bGUvcGtpLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsTUFBTSxFQUFFLGdCQUFnQixFQUFFLEdBQUcsT0FBTyxDQUFDLHlEQUF5RCxDQUFDLENBQUM7QUFPaEcsSUFBWSxrQkFHWDtBQUhELFdBQVksa0JBQWtCO0lBQzFCLGlDQUFXLENBQUE7SUFDWCxpQ0FBVyxDQUFBO0FBQ2YsQ0FBQyxFQUhXLGtCQUFrQixrQ0FBbEIsa0JBQWtCLFFBRzdCO0FBRUQsSUFBWSxpQkFHWDtBQUhELFdBQVksaUJBQWlCO0lBQ3pCLGdDQUFXLENBQUE7SUFDWCxnQ0FBVyxDQUFBO0FBQ2YsQ0FBQyxFQUhXLGlCQUFpQixpQ0FBakIsaUJBQWlCLFFBRzVCO0FBRUQsSUFBWSxRQWNYO0FBZEQsV0FBWSxRQUFRO0lBQ2hCLG1DQUF1QixDQUFBLENBQUMsK0VBQStFO0lBQ3ZHLG1DQUF1QixDQUFBLENBQUMsK0VBQStFO0lBQ3ZHLG1DQUF1QixDQUFBLENBQUMsK0VBQStFO0lBQ3ZHLG1DQUF1QixDQUFBLENBQUMsK0VBQStFO0lBQ3ZHLG1DQUF1QixDQUFBLENBQUMsK0VBQStFO0lBQ3ZHLCtCQUFtQixDQUFBLENBQUMsc0RBQXNEO0lBQzFFLCtCQUFtQixDQUFBLENBQUMsc0RBQXNEO0lBQzFFLCtCQUFtQixDQUFBLENBQUMsc0RBQXNEO0lBQzFFLDBHQUEwRztJQUMxRyxtQ0FBdUIsQ0FBQSxDQUFDLHNEQUFzRDtJQUM5RSxtQ0FBdUIsQ0FBQSxDQUFDLHNEQUFzRDtJQUM5RSxtQ0FBdUIsQ0FBQSxDQUFDLHNEQUFzRDtJQUM5RSwyR0FBMkc7QUFDL0csQ0FBQyxFQWRXLFFBQVEsd0JBQVIsUUFBUSxRQWNuQjtBQTRCRCxNQUFhLFVBQVU7SUFHbkI7UUFDSSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxnQkFBZ0IsRUFB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
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import { SNPReport } from "./sev-snp";
|
|
4
|
+
import { StorageType, StorageAccessCredentials } from "@super-protocol/dto-js";
|
|
5
|
+
import { Transform } from "stream";
|
|
6
|
+
interface VMCommon {
|
|
7
|
+
kernelHash: Buffer;
|
|
8
|
+
initrdHash: Buffer | undefined;
|
|
9
|
+
}
|
|
10
|
+
interface VMConfig extends VMCommon {
|
|
11
|
+
ovmfHash: Buffer;
|
|
12
|
+
ovmfBucket: string;
|
|
13
|
+
ovmfPrefix: string;
|
|
14
|
+
ovmfFilename: string;
|
|
15
|
+
}
|
|
16
|
+
interface VMMeasure extends VMCommon {
|
|
17
|
+
ovmfFilePath: string;
|
|
18
|
+
}
|
|
19
|
+
export type StorageAccessCredentialsInput = Omit<StorageAccessCredentials, "bucket" | "prefix">;
|
|
20
|
+
export interface SNPMrEnclaveCalculatorArgs {
|
|
21
|
+
cacheFolder?: string;
|
|
22
|
+
rmPrevCache?: boolean;
|
|
23
|
+
vmRepoOwner?: string;
|
|
24
|
+
vmRepo?: string;
|
|
25
|
+
releaseAsset?: string;
|
|
26
|
+
downloadAssetRetryInterval?: number;
|
|
27
|
+
downloadAssetRetryMax?: number;
|
|
28
|
+
storageCredentials?: StorageAccessCredentialsInput;
|
|
29
|
+
storageType?: StorageType;
|
|
30
|
+
cacheRecordsTTL?: number;
|
|
31
|
+
}
|
|
32
|
+
export declare class SNPMrEnclaveCalculator {
|
|
33
|
+
private readonly cacheFolder;
|
|
34
|
+
private readonly vmRepoOwner;
|
|
35
|
+
private readonly vmRepo;
|
|
36
|
+
private readonly releaseAsset;
|
|
37
|
+
private readonly axiosInstance;
|
|
38
|
+
private readonly retryInterval;
|
|
39
|
+
private readonly retryMax;
|
|
40
|
+
private readonly storageCredentials;
|
|
41
|
+
private readonly storageType;
|
|
42
|
+
private readonly vmInfoCache;
|
|
43
|
+
private readonly defaultCredentials;
|
|
44
|
+
constructor(config: SNPMrEnclaveCalculatorArgs);
|
|
45
|
+
private clearFileCache;
|
|
46
|
+
/**
|
|
47
|
+
* The method allows to obtain expected mrenclave if the virtual machine for which the report is
|
|
48
|
+
* submitted was running on one core and a Milan processor
|
|
49
|
+
* @param report - @see CalcSnpMrEnclaveParams
|
|
50
|
+
*/
|
|
51
|
+
getSingleCoreMrEnclave(report: SNPReport): Promise<Buffer>;
|
|
52
|
+
protected downloadAsset(assetUrl: string): Promise<Buffer>;
|
|
53
|
+
protected extractVMData(data: Buffer): VMConfig;
|
|
54
|
+
protected static calcHashStream(alg?: string): {
|
|
55
|
+
process: Transform;
|
|
56
|
+
get: () => Buffer;
|
|
57
|
+
};
|
|
58
|
+
protected static fileExist(filePath: string): Promise<boolean>;
|
|
59
|
+
protected getAssetUrl(build: string): Promise<string>;
|
|
60
|
+
protected downloadVM(build: string): Promise<VMMeasure>;
|
|
61
|
+
protected downloadOvmf(vmFiles: VMConfig, ovmfPath: string): Promise<void>;
|
|
62
|
+
}
|
|
63
|
+
export {};
|
|
@@ -0,0 +1,290 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.SNPMrEnclaveCalculator = void 0;
|
|
30
|
+
const fs = __importStar(require("fs"));
|
|
31
|
+
const fsAsync = __importStar(require("fs/promises"));
|
|
32
|
+
const path = __importStar(require("path"));
|
|
33
|
+
const os = __importStar(require("os"));
|
|
34
|
+
const sev_snp_1 = require("./sev-snp");
|
|
35
|
+
const axios_1 = __importDefault(require("axios"));
|
|
36
|
+
const sdk_js_1 = require("@super-protocol/sdk-js");
|
|
37
|
+
const dto_js_1 = require("@super-protocol/dto-js");
|
|
38
|
+
const crypto_1 = require("crypto");
|
|
39
|
+
const stream_1 = require("stream");
|
|
40
|
+
class VMConfigCache {
|
|
41
|
+
constructor(ttl = 5 * 60 * 1000) {
|
|
42
|
+
this.cache = {};
|
|
43
|
+
this.ttl = ttl;
|
|
44
|
+
}
|
|
45
|
+
set(key, value) {
|
|
46
|
+
const timestamp = Date.now();
|
|
47
|
+
this.cache[key] = {
|
|
48
|
+
value,
|
|
49
|
+
timestamp,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
get(key, force = false) {
|
|
53
|
+
const record = this.cache[key];
|
|
54
|
+
if (record) {
|
|
55
|
+
if (force === false) {
|
|
56
|
+
const now = Date.now();
|
|
57
|
+
if (now - record.timestamp > this.ttl) {
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return record.value;
|
|
62
|
+
}
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
clear() {
|
|
66
|
+
this.cache = {};
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
class SNPMrEnclaveCalculator {
|
|
70
|
+
constructor(config) {
|
|
71
|
+
this.axiosInstance = axios_1.default.create();
|
|
72
|
+
this.defaultCredentials = {
|
|
73
|
+
token: "1UXqNMwov41q9TgHmyopNg5q2giQ8aTdh1gjKWKjfbWPFrcrnhenp6QZfd5ukyVnYXDx9Cok6RtnQMMnXmoZPrSUMNGZGF9KuLCzvRNmQYHowX14C2xAxtJeH6VCuNX39ist4bRE9L5VT3k41frDVh3cG1gZvsqh4EaDeaJyV6U4xVaqXqULnSb9PozqU97VVLWhfwdnj6XgUM59Wzq7yo7vn8RxwSyn8H74TEiLNGUPPA3frsYZuoqWQkNzbiYev5ByWeLro1TXo7DogD4WALCKfEmpwHs9j9rsX5WZvvZ13ourTiuZp5vTTZkByB2ibxUJqkSoZSpCNVtmDToNVKkMREVySe",
|
|
74
|
+
};
|
|
75
|
+
this.cacheFolder = config.cacheFolder || fs.mkdtempSync(path.join(os.tmpdir(), "snp-mrenclave-cache-"));
|
|
76
|
+
const rmPrevCache = config.rmPrevCache ?? false;
|
|
77
|
+
this.vmRepoOwner = config.vmRepoOwner || "Super-Protocol";
|
|
78
|
+
this.vmRepo = config.vmRepo || "sp-vm";
|
|
79
|
+
this.releaseAsset = config.releaseAsset || "vm.json";
|
|
80
|
+
this.retryInterval = config.downloadAssetRetryInterval ?? 1000;
|
|
81
|
+
this.retryMax = config.downloadAssetRetryMax ?? 3;
|
|
82
|
+
if ((config.storageCredentials && !config.storageType) || (!config.storageCredentials && config.storageType)) {
|
|
83
|
+
throw new Error("Both the StorageCredentials and StorageType parameters must either be passed or not passed");
|
|
84
|
+
}
|
|
85
|
+
this.storageCredentials = config.storageCredentials ?? this.defaultCredentials;
|
|
86
|
+
this.storageType = config.storageType ?? dto_js_1.StorageType.StorJ;
|
|
87
|
+
const cacheRecordsTTL = config.cacheRecordsTTL ?? 5 * 60 * 1000;
|
|
88
|
+
if (rmPrevCache && fs.existsSync(this.cacheFolder)) {
|
|
89
|
+
this.clearFileCache();
|
|
90
|
+
}
|
|
91
|
+
if (!fs.existsSync(this.cacheFolder)) {
|
|
92
|
+
fs.mkdirSync(this.cacheFolder, { recursive: true });
|
|
93
|
+
}
|
|
94
|
+
this.vmInfoCache = new VMConfigCache(cacheRecordsTTL);
|
|
95
|
+
}
|
|
96
|
+
clearFileCache() {
|
|
97
|
+
fs.rmSync(this.cacheFolder, {
|
|
98
|
+
recursive: true,
|
|
99
|
+
force: true,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* The method allows to obtain expected mrenclave if the virtual machine for which the report is
|
|
104
|
+
* submitted was running on one core and a Milan processor
|
|
105
|
+
* @param report - @see CalcSnpMrEnclaveParams
|
|
106
|
+
*/
|
|
107
|
+
async getSingleCoreMrEnclave(report) {
|
|
108
|
+
const mrEnclave = await sev_snp_1.SevSNP.getMrEnclave(report.report);
|
|
109
|
+
const vmMeasure = await this.downloadVM(report.build);
|
|
110
|
+
const expectedMrEnclave = await sev_snp_1.SevSNP.calcSnpMrEnclave({
|
|
111
|
+
ovmfPath: vmMeasure.ovmfFilePath,
|
|
112
|
+
kernelHash: vmMeasure.kernelHash,
|
|
113
|
+
initrdHash: vmMeasure.initrdHash,
|
|
114
|
+
cmdLineHash: report.cmdLineHash,
|
|
115
|
+
vcpuSig: report.cpuSig,
|
|
116
|
+
vcpuCount: report.cores,
|
|
117
|
+
});
|
|
118
|
+
if (!mrEnclave.equals(expectedMrEnclave))
|
|
119
|
+
throw new Error("Expected mrEnclave does not match the calculated one");
|
|
120
|
+
const singleCoreMrEnclave = await sev_snp_1.SevSNP.calcSnpMrEnclave({
|
|
121
|
+
ovmfPath: vmMeasure.ovmfFilePath,
|
|
122
|
+
kernelHash: vmMeasure.kernelHash,
|
|
123
|
+
initrdHash: vmMeasure.initrdHash,
|
|
124
|
+
cmdLineHash: report.cmdLineHash,
|
|
125
|
+
vcpuSig: sev_snp_1.SevSNP.getCpuSig(sev_snp_1.AMD_EPYC_MILAN_CPUINFO),
|
|
126
|
+
vcpuCount: 1,
|
|
127
|
+
});
|
|
128
|
+
return singleCoreMrEnclave;
|
|
129
|
+
}
|
|
130
|
+
async downloadAsset(assetUrl) {
|
|
131
|
+
const { retryInterval, retryMax } = this;
|
|
132
|
+
const response = await sdk_js_1.helpers.tryWithInterval({
|
|
133
|
+
checkResult(response) {
|
|
134
|
+
return { isResultOk: response.status === 200 };
|
|
135
|
+
},
|
|
136
|
+
handler: async () => {
|
|
137
|
+
return this.axiosInstance.get(assetUrl, {
|
|
138
|
+
responseType: "arraybuffer",
|
|
139
|
+
});
|
|
140
|
+
},
|
|
141
|
+
checkError(err) {
|
|
142
|
+
if (axios_1.default.isAxiosError(err) && err.response) {
|
|
143
|
+
const status = err.response.status;
|
|
144
|
+
return { retryable: status < 400 || status >= 500 || status === 429 };
|
|
145
|
+
}
|
|
146
|
+
return { retryable: axios_1.default.isAxiosError(err) };
|
|
147
|
+
},
|
|
148
|
+
retryInterval,
|
|
149
|
+
retryMax,
|
|
150
|
+
});
|
|
151
|
+
return response.data;
|
|
152
|
+
}
|
|
153
|
+
extractVMData(data) {
|
|
154
|
+
const vm = JSON.parse(data.toString("utf-8"));
|
|
155
|
+
const kernelHash = vm.kernel?.sha256;
|
|
156
|
+
if (!kernelHash) {
|
|
157
|
+
throw new Error("kernel hash is missing");
|
|
158
|
+
}
|
|
159
|
+
const initrdHash = vm.initrd?.sha256;
|
|
160
|
+
const OVMF = vm.bios_amd || vm.bios;
|
|
161
|
+
if (!OVMF) {
|
|
162
|
+
throw new Error("Neither bios_amd nor bios is available");
|
|
163
|
+
}
|
|
164
|
+
const { sha256, bucket, prefix, filename } = OVMF;
|
|
165
|
+
if (!sha256 || !bucket || !prefix || !filename) {
|
|
166
|
+
throw new Error("Missing one or more required fields in OVMF");
|
|
167
|
+
}
|
|
168
|
+
return {
|
|
169
|
+
kernelHash: Buffer.from(kernelHash, "hex"),
|
|
170
|
+
initrdHash: initrdHash ? Buffer.from(initrdHash, "hex") : undefined,
|
|
171
|
+
ovmfHash: Buffer.from(sha256, "hex"),
|
|
172
|
+
ovmfBucket: bucket,
|
|
173
|
+
ovmfPrefix: prefix,
|
|
174
|
+
ovmfFilename: filename,
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
static calcHashStream(alg = "sha256") {
|
|
178
|
+
const hash = (0, crypto_1.createHash)(alg);
|
|
179
|
+
return {
|
|
180
|
+
process: new stream_1.Transform({
|
|
181
|
+
transform: (data, encoding, done) => {
|
|
182
|
+
hash.update(data);
|
|
183
|
+
done(null, data);
|
|
184
|
+
},
|
|
185
|
+
}),
|
|
186
|
+
get: () => hash.digest(),
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
static async fileExist(filePath) {
|
|
190
|
+
try {
|
|
191
|
+
await fsAsync.access(filePath);
|
|
192
|
+
return true;
|
|
193
|
+
}
|
|
194
|
+
catch (err) {
|
|
195
|
+
return false;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
async getAssetUrl(build) {
|
|
199
|
+
const { retryInterval, retryMax } = this;
|
|
200
|
+
const response = await sdk_js_1.helpers.tryWithInterval({
|
|
201
|
+
checkResult(response) {
|
|
202
|
+
return { isResultOk: response.status === 200 };
|
|
203
|
+
},
|
|
204
|
+
handler: async () => {
|
|
205
|
+
return this.axiosInstance.get(`https://api.github.com/repos/${this.vmRepoOwner}/${this.vmRepo}/releases/tags/${build}`);
|
|
206
|
+
},
|
|
207
|
+
checkError(err) {
|
|
208
|
+
if (axios_1.default.isAxiosError(err) && err.response) {
|
|
209
|
+
const status = err.response.status;
|
|
210
|
+
return { retryable: status < 400 || status >= 500 || status === 429 };
|
|
211
|
+
}
|
|
212
|
+
return { retryable: axios_1.default.isAxiosError(err) };
|
|
213
|
+
},
|
|
214
|
+
retryInterval,
|
|
215
|
+
retryMax,
|
|
216
|
+
});
|
|
217
|
+
const { data } = response;
|
|
218
|
+
const asset = data.assets.find((asset) => asset.name === this.releaseAsset);
|
|
219
|
+
return asset.browser_download_url;
|
|
220
|
+
}
|
|
221
|
+
async downloadVM(build) {
|
|
222
|
+
let fromCache = false;
|
|
223
|
+
let vmFiles;
|
|
224
|
+
const vmInfo = this.vmInfoCache.get(build);
|
|
225
|
+
if (vmInfo) {
|
|
226
|
+
fromCache = true;
|
|
227
|
+
vmFiles = vmInfo;
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
try {
|
|
231
|
+
const assetUrl = await this.getAssetUrl(build);
|
|
232
|
+
const vm = await this.downloadAsset(assetUrl);
|
|
233
|
+
vmFiles = this.extractVMData(vm);
|
|
234
|
+
}
|
|
235
|
+
catch (error) {
|
|
236
|
+
const vmInfo = this.vmInfoCache.get(build, true);
|
|
237
|
+
if (vmInfo) {
|
|
238
|
+
fromCache = true;
|
|
239
|
+
vmFiles = vmInfo;
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
throw error;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
const ovmfPath = path.join(this.cacheFolder, `${vmFiles.ovmfHash.toString("hex")}_OVMF.fd`);
|
|
247
|
+
let fileExistAndCorrect = false;
|
|
248
|
+
if (await SNPMrEnclaveCalculator.fileExist(ovmfPath)) {
|
|
249
|
+
const fileStream = fs.createReadStream(ovmfPath);
|
|
250
|
+
const hash = await sdk_js_1.Crypto.createHash(fileStream, {
|
|
251
|
+
algo: dto_js_1.HashAlgorithm.SHA256,
|
|
252
|
+
encoding: dto_js_1.Encoding.hex,
|
|
253
|
+
});
|
|
254
|
+
if (vmFiles.ovmfHash.toString("hex") === hash.hash) {
|
|
255
|
+
fileExistAndCorrect = true;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
if (fileExistAndCorrect !== true) {
|
|
259
|
+
await this.downloadOvmf(vmFiles, ovmfPath);
|
|
260
|
+
}
|
|
261
|
+
if (fromCache !== true) {
|
|
262
|
+
this.vmInfoCache.set(build, vmFiles);
|
|
263
|
+
}
|
|
264
|
+
return {
|
|
265
|
+
initrdHash: vmFiles.initrdHash,
|
|
266
|
+
kernelHash: vmFiles.kernelHash,
|
|
267
|
+
ovmfFilePath: ovmfPath,
|
|
268
|
+
};
|
|
269
|
+
}
|
|
270
|
+
async downloadOvmf(vmFiles, ovmfPath) {
|
|
271
|
+
const credentials = {
|
|
272
|
+
...this.storageCredentials,
|
|
273
|
+
bucket: vmFiles.ovmfBucket,
|
|
274
|
+
prefix: vmFiles.ovmfPrefix.endsWith("/") ? vmFiles.ovmfPrefix : `${vmFiles.ovmfPrefix}/`,
|
|
275
|
+
};
|
|
276
|
+
const access = {
|
|
277
|
+
storageType: this.storageType,
|
|
278
|
+
credentials,
|
|
279
|
+
};
|
|
280
|
+
const storageProvider = (0, sdk_js_1.getStorageProvider)(access);
|
|
281
|
+
const downloaderStream = await storageProvider.downloadFile(vmFiles.ovmfFilename, {});
|
|
282
|
+
const { process: hashStream, get: getStreamHash } = SNPMrEnclaveCalculator.calcHashStream("sha256");
|
|
283
|
+
await stream_1.promises.pipeline(downloaderStream, hashStream, fs.createWriteStream(ovmfPath));
|
|
284
|
+
if (!vmFiles.ovmfHash.equals(getStreamHash())) {
|
|
285
|
+
throw new Error("The downloaded OVMF-file does not match the expected checksum");
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
exports.SNPMrEnclaveCalculator = SNPMrEnclaveCalculator;
|
|
290
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sev-snp-mrenclave.js","sourceRoot":"","sources":["../../src/sgx-native-module/sev-snp-mrenclave.ts"],"names":[],"mappings":"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"}
|