@super-protocol/addons-tee 1.0.0 → 1.1.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.
Files changed (27) hide show
  1. package/bindings/amd-sev-snp-napi-rs/amd-sev-snp-napi-rs.linux-x64-gnu.node +0 -0
  2. package/bindings/go-tdx-attest-wrapper/.gitignore +8 -0
  3. package/bindings/go-tdx-attest-wrapper/go.mod +18 -0
  4. package/bindings/go-tdx-attest-wrapper/go.sum +29 -0
  5. package/bindings/go-tdx-attest-wrapper/main.go +244 -0
  6. package/bindings/sgx-native/build/Release/libmbedcrypto_gramine.so.15 +0 -0
  7. package/bindings/sgx-native/build/Release/libmbedx509_gramine.so.6 +0 -0
  8. package/bindings/sgx-native/build/Release/libsgx_dcap_quoteverify.so.1 +0 -0
  9. package/bindings/sgx-native/build/Release/libtdx_attest.so.1 +0 -0
  10. package/bindings/sgx-native/build/Release/sgx_native.node +0 -0
  11. package/bindings/utils/virtee/libsev.so +0 -0
  12. package/bindings/utils/virtee/snpguest +0 -0
  13. package/dist/sgx-native-module/dcap-quote-verify.service.d.ts +7 -0
  14. package/dist/sgx-native-module/dcap-quote-verify.service.js +189 -1
  15. package/dist/sgx-native-module/index.d.ts +2 -0
  16. package/dist/sgx-native-module/index.js +3 -1
  17. package/dist/sgx-native-module/tdx-parsed-quote-schema.d.ts +10 -0
  18. package/dist/sgx-native-module/tdx-parsed-quote-schema.js +13 -0
  19. package/dist/sgx-native-module/tdx-quote-with-event-log-schema.d.ts +19 -0
  20. package/dist/sgx-native-module/tdx-quote-with-event-log-schema.js +13 -0
  21. package/package.json +3 -5
  22. package/dto/src/AmdSevSnp.proto +0 -31
  23. package/dto/src/Compression.proto +0 -11
  24. package/dto/src/Hash.proto +0 -6
  25. package/dto/src/OrderReport.proto +0 -21
  26. package/dto/src/TRI.proto +0 -22
  27. package/dto/src/TeeDeviceInfo.proto +0 -46
@@ -0,0 +1,8 @@
1
+ .gocache/
2
+ .gomodcache/
3
+ /go-tdx-attest-wrapper
4
+ /tdx-attest-wrapper
5
+ !go.mod
6
+ !go.sum
7
+ !main.go
8
+ !.gitignore
@@ -0,0 +1,18 @@
1
+ module github.com/super-protocol/sp-nodejs-addons/tee-addon/bindings/go-tdx-attest-wrapper
2
+
3
+ go 1.22
4
+
5
+ require (
6
+ github.com/google/go-eventlog v0.0.2
7
+ github.com/google/go-tdx-guest v0.3.1
8
+ )
9
+
10
+ require (
11
+ github.com/google/go-configfs-tsm v0.2.2 // indirect
12
+ github.com/google/go-tpm v0.9.0 // indirect
13
+ github.com/google/logger v1.1.1 // indirect
14
+ go.uber.org/multierr v1.11.0 // indirect
15
+ golang.org/x/crypto v0.17.0 // indirect
16
+ golang.org/x/sys v0.19.0 // indirect
17
+ google.golang.org/protobuf v1.34.2 // indirect
18
+ )
@@ -0,0 +1,29 @@
1
+ github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
2
+ github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
3
+ github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI=
4
+ github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
5
+ github.com/google/go-configfs-tsm v0.2.2 h1:YnJ9rXIOj5BYD7/0DNnzs8AOp7UcvjfTvt215EWcs98=
6
+ github.com/google/go-configfs-tsm v0.2.2/go.mod h1:EL1GTDFMb5PZQWDviGfZV9n87WeGTR/JUg13RfwkgRo=
7
+ github.com/google/go-eventlog v0.0.2 h1:Q3XESKw1xuO7+U37PmFGmteQqprL8U5/linAiuy3oIY=
8
+ github.com/google/go-eventlog v0.0.2/go.mod h1:7huE5P8w2NTObSwSJjboHmB7ioBNblkijdzoVa2skfQ=
9
+ github.com/google/go-tdx-guest v0.3.1 h1:gl0KvjdsD4RrJzyLefDOvFOUH3NAJri/3qvaL5m83Iw=
10
+ github.com/google/go-tdx-guest v0.3.1/go.mod h1:/rc3d7rnPykOPuY8U9saMyEps0PZDThLk/RygXm04nE=
11
+ github.com/google/go-tpm v0.9.0 h1:sQF6YqWMi+SCXpsmS3fd21oPy/vSddwZry4JnmltHVk=
12
+ github.com/google/go-tpm v0.9.0/go.mod h1:FkNVkc6C+IsvDI9Jw1OveJmxGZUUaKxtrpOS47QWKfU=
13
+ github.com/google/logger v1.1.1 h1:+6Z2geNxc9G+4D4oDO9njjjn2d0wN5d7uOo0vOIW1NQ=
14
+ github.com/google/logger v1.1.1/go.mod h1:BkeJZ+1FhQ+/d087r4dzojEg1u2ZX+ZqG1jTUrLM+zQ=
15
+ github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
16
+ github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
17
+ github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY=
18
+ github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
19
+ go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0=
20
+ go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y=
21
+ golang.org/x/crypto v0.17.0 h1:r8bRNjWL3GshPW3gkd+RpvzWrZAwPS49OmTGZ/uhM4k=
22
+ golang.org/x/crypto v0.17.0/go.mod h1:gCAAfMLgwOJRpTjQ2zCCt2OcSfYMTeZVSRtQlPC7Nq4=
23
+ golang.org/x/sys v0.0.0-20210426230700-d19ff857e887/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
24
+ golang.org/x/sys v0.19.0 h1:q5f1RH2jigJ1MoAWp2KTp3gm5zAGFUTarQZ5U386+4o=
25
+ golang.org/x/sys v0.19.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
26
+ google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg=
27
+ google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw=
28
+ gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
29
+ gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
@@ -0,0 +1,244 @@
1
+ package main
2
+
3
+ import (
4
+ "encoding/base64"
5
+ "encoding/hex"
6
+ "encoding/json"
7
+ "errors"
8
+ "flag"
9
+ "fmt"
10
+ "io"
11
+ "os"
12
+ "strings"
13
+
14
+ "github.com/google/go-tdx-guest/abi"
15
+ "github.com/google/go-eventlog/register"
16
+ "github.com/google/go-eventlog/tcg"
17
+ "github.com/google/go-tdx-guest/client"
18
+ pb "github.com/google/go-tdx-guest/proto/tdx"
19
+ )
20
+
21
+ const (
22
+ defaultCCELEventLogPath = "/sys/firmware/acpi/tables/data/CCEL"
23
+ rtmr0MRIndex = 1
24
+ )
25
+
26
+ type eventRecord struct {
27
+ Type string `json:"type"`
28
+ Digest string `json:"digest"`
29
+ }
30
+
31
+ type outputPayload struct {
32
+ Quote string `json:"quote"`
33
+ EventLog []eventRecord `json:"eventLog"`
34
+ }
35
+
36
+ type parsedQuotePayload struct {
37
+ TDAttributes string `json:"tdattributes"`
38
+ MRTD string `json:"mrtd"`
39
+ RTMR0 string `json:"rtmr0"`
40
+ RTMR1 string `json:"rtmr1"`
41
+ RTMR2 string `json:"rtmr2"`
42
+ RTMR3 string `json:"rtmr3"`
43
+ }
44
+
45
+ func main() {
46
+ if err := run(); err != nil {
47
+ fmt.Fprintf(os.Stderr, "error: %v\n", err)
48
+ os.Exit(1)
49
+ }
50
+ }
51
+
52
+ func run() error {
53
+ if len(os.Args) < 2 {
54
+ return usageError("missing subcommand: expected 'attest' or 'parse-quote'")
55
+ }
56
+
57
+ switch os.Args[1] {
58
+ case "attest":
59
+ return runAttest(os.Args[2:])
60
+ case "parse-quote":
61
+ return runParseQuote(os.Args[2:])
62
+ default:
63
+ return usageError(fmt.Sprintf("unknown subcommand %q: expected 'attest' or 'parse-quote'", os.Args[1]))
64
+ }
65
+ }
66
+
67
+ func runAttest(args []string) error {
68
+ fs := newFlagSet("attest")
69
+ reportDataHex := fs.String("report-data", "", "hex-encoded report data, up to 64 bytes")
70
+ outputPath := fs.String("output", "", "write JSON output to file")
71
+ ccelEventLogPath := fs.String("ccel-event-log", defaultCCELEventLogPath, "path to CCEL event log data")
72
+ if err := fs.Parse(args); err != nil {
73
+ return err
74
+ }
75
+
76
+ if *reportDataHex == "" {
77
+ return errors.New("missing required flag --report-data")
78
+ }
79
+ if *outputPath == "" {
80
+ return errors.New("missing required flag --output")
81
+ }
82
+
83
+ reportData, err := decodeReportData(*reportDataHex)
84
+ if err != nil {
85
+ return fmt.Errorf("decode report data: %w", err)
86
+ }
87
+
88
+ quoteProvider, err := client.GetQuoteProvider()
89
+ if err != nil {
90
+ return fmt.Errorf("get quote provider: %w", err)
91
+ }
92
+
93
+ rawQuote, err := client.GetRawQuote(quoteProvider, reportData)
94
+ if err != nil {
95
+ return fmt.Errorf("get TDX quote: %w", err)
96
+ }
97
+
98
+ events, err := readRTMR0Events(*ccelEventLogPath)
99
+ if err != nil {
100
+ return err
101
+ }
102
+
103
+ payload := outputPayload{
104
+ Quote: base64.StdEncoding.EncodeToString(rawQuote),
105
+ EventLog: events,
106
+ }
107
+
108
+ return writeJSON(*outputPath, payload)
109
+ }
110
+
111
+ func runParseQuote(args []string) error {
112
+ fs := newFlagSet("parse-quote")
113
+ quotePath := fs.String("quote-file", "", "path to a raw TDX quote file")
114
+ outputPath := fs.String("output", "", "write JSON output to file")
115
+ if err := fs.Parse(args); err != nil {
116
+ return err
117
+ }
118
+
119
+ if *quotePath == "" {
120
+ return errors.New("missing required flag --quote-file")
121
+ }
122
+ if *outputPath == "" {
123
+ return errors.New("missing required flag --output")
124
+ }
125
+
126
+ rawQuote, err := os.ReadFile(*quotePath)
127
+ if err != nil {
128
+ return fmt.Errorf("read quote file %q: %w", *quotePath, err)
129
+ }
130
+
131
+ payload, err := parseQuote(rawQuote)
132
+ if err != nil {
133
+ return err
134
+ }
135
+
136
+ return writeJSON(*outputPath, payload)
137
+ }
138
+
139
+ func newFlagSet(name string) *flag.FlagSet {
140
+ fs := flag.NewFlagSet(name, flag.ContinueOnError)
141
+ fs.SetOutput(io.Discard)
142
+ return fs
143
+ }
144
+
145
+ func writeJSON(outputPath string, payload any) error {
146
+ jsonData, err := json.MarshalIndent(payload, "", " ")
147
+ if err != nil {
148
+ return fmt.Errorf("marshal JSON: %w", err)
149
+ }
150
+
151
+ if err := os.WriteFile(outputPath, append(jsonData, '\n'), 0o644); err != nil {
152
+ return fmt.Errorf("write output file %q: %w", outputPath, err)
153
+ }
154
+
155
+ return nil
156
+ }
157
+
158
+ func parseQuote(rawQuote []byte) (parsedQuotePayload, error) {
159
+ anyQuote, err := abi.QuoteToProto(rawQuote)
160
+ if err != nil {
161
+ return parsedQuotePayload{}, fmt.Errorf("parse quote: %w", err)
162
+ }
163
+
164
+ switch quote := anyQuote.(type) {
165
+ case *pb.QuoteV4:
166
+ tdQuoteBody := quote.GetTdQuoteBody()
167
+ if tdQuoteBody == nil {
168
+ return parsedQuotePayload{}, errors.New("parse quote: missing TD quote body")
169
+ }
170
+
171
+ rtmrs := tdQuoteBody.GetRtmrs()
172
+ if len(rtmrs) < 4 {
173
+ return parsedQuotePayload{}, fmt.Errorf("parse quote: expected at least 4 RTMRs, got %d", len(rtmrs))
174
+ }
175
+
176
+ return parsedQuotePayload{
177
+ TDAttributes: hex.EncodeToString(tdQuoteBody.GetTdAttributes()),
178
+ MRTD: hex.EncodeToString(tdQuoteBody.GetMrTd()),
179
+ RTMR0: hex.EncodeToString(rtmrs[0]),
180
+ RTMR1: hex.EncodeToString(rtmrs[1]),
181
+ RTMR2: hex.EncodeToString(rtmrs[2]),
182
+ RTMR3: hex.EncodeToString(rtmrs[3]),
183
+ }, nil
184
+ default:
185
+ return parsedQuotePayload{}, fmt.Errorf("parse quote: unsupported quote type %T", anyQuote)
186
+ }
187
+ }
188
+
189
+ func usageError(message string) error {
190
+ return fmt.Errorf("%s\nusage:\n %s attest --report-data <hex> --output <file> [--ccel-event-log <path>]\n %s parse-quote --quote-file <path> --output <file>", message, os.Args[0], os.Args[0])
191
+ }
192
+
193
+ func decodeReportData(raw string) ([64]byte, error) {
194
+ var reportData [64]byte
195
+
196
+ normalized := strings.TrimSpace(raw)
197
+ normalized = strings.TrimPrefix(normalized, "0x")
198
+ normalized = strings.TrimPrefix(normalized, "0X")
199
+
200
+ decoded, err := hex.DecodeString(normalized)
201
+ if err != nil {
202
+ return reportData, err
203
+ }
204
+ if len(decoded) > len(reportData) {
205
+ return reportData, fmt.Errorf("report data is %d bytes, exceeds 64 bytes", len(decoded))
206
+ }
207
+
208
+ copy(reportData[:], decoded)
209
+ return reportData, nil
210
+ }
211
+
212
+ func readRTMR0Events(eventLogPath string) ([]eventRecord, error) {
213
+ eventLogData, err := os.ReadFile(eventLogPath)
214
+ if err != nil {
215
+ return nil, fmt.Errorf("read CCEL event log %q: %w", eventLogPath, err)
216
+ }
217
+
218
+ eventLog, err := tcg.ParseEventLog(eventLogData, tcg.ParseOpts{AllowPadding: true})
219
+ if err != nil {
220
+ return nil, fmt.Errorf("parse CCEL event log %q: %w", eventLogPath, err)
221
+ }
222
+
223
+ records := make([]eventRecord, 0)
224
+ for _, event := range eventLog.Events(register.HashSHA384) {
225
+ if event.MRIndex() != rtmr0MRIndex {
226
+ continue
227
+ }
228
+
229
+ records = append(records, eventRecord{
230
+ Type: eventTypeTCGString(event.UntrustedType()),
231
+ Digest: hex.EncodeToString(event.ReplayedDigest()),
232
+ })
233
+ }
234
+
235
+ return records, nil
236
+ }
237
+
238
+ func eventTypeTCGString(eventType any) string {
239
+ if typed, ok := eventType.(interface{ TCGString() string }); ok {
240
+ return typed.TCGString()
241
+ }
242
+
243
+ return fmt.Sprintf("%v", eventType)
244
+ }
Binary file
Binary file
@@ -1,4 +1,6 @@
1
1
  /// <reference types="node" />
2
+ import { TdxEventLogEntry, TdxQuoteWithEventLog } from "./tdx-quote-with-event-log-schema";
3
+ import { TdxParseQuote } from "./tdx-parsed-quote-schema";
2
4
  export declare class DcapQuoteVerifyService {
3
5
  private readonly quoteVerifier;
4
6
  private static isInGramineMode;
@@ -7,6 +9,11 @@ export declare class DcapQuoteVerifyService {
7
9
  extractQuoteFromCert(pemOrDerCert: Buffer): Promise<Buffer>;
8
10
  validateQuoteVerifierEnclave(quote: Buffer, checkSecurity?: boolean): Promise<void>;
9
11
  generateTDXQuote(userData: Buffer): Promise<Buffer>;
12
+ validateRtmrEventLogIntegrity(eventLog: TdxEventLogEntry[], rtmr: string | Buffer): Promise<void>;
13
+ parseTDXQuote(quote: Buffer): Promise<TdxParseQuote>;
14
+ generateTDXQuoteWithEventLog(userData: Buffer): Promise<TdxQuoteWithEventLog>;
15
+ private static formatSubprocessError;
16
+ private normalizeRtmr;
10
17
  private validateMode;
11
18
  generateSGXQuote(userData: Buffer): Promise<Buffer>;
12
19
  }
@@ -1,4 +1,27 @@
1
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
+ };
2
25
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
27
  };
@@ -9,6 +32,17 @@ const consts_1 = require("./consts");
9
32
  const errors_1 = require("./errors");
10
33
  const p_queue_1 = __importDefault(require("p-queue"));
11
34
  const fs_1 = require("fs");
35
+ const child_process_1 = require("child_process");
36
+ const crypto_1 = require("crypto");
37
+ const os = __importStar(require("os"));
38
+ const path = __importStar(require("path"));
39
+ const util_1 = require("util");
40
+ const value_1 = require("@sinclair/typebox/value");
41
+ const helpers_1 = require("./helpers");
42
+ const tdx_quote_with_event_log_schema_1 = require("./tdx-quote-with-event-log-schema");
43
+ const tdx_parsed_quote_schema_1 = require("./tdx-parsed-quote-schema");
44
+ const execFileAsync = (0, util_1.promisify)(child_process_1.execFile);
45
+ const TDX_ATTEST_WRAPPER_PATH = path.resolve(__dirname, "../../bindings/go-tdx-attest-wrapper/go-tdx-attest-wrapper");
12
46
  class DcapQuoteVerifyService {
13
47
  constructor() {
14
48
  this.quoteVerifier = new SgxAttestationVerifier();
@@ -35,6 +69,160 @@ class DcapQuoteVerifyService {
35
69
  async generateTDXQuote(userData) {
36
70
  return this.quoteVerifier.generateTDXQuote(userData);
37
71
  }
72
+ async validateRtmrEventLogIntegrity(eventLog, rtmr) {
73
+ if (!Array.isArray(eventLog)) {
74
+ throw new Error("eventLog must be an array");
75
+ }
76
+ let current = Buffer.alloc(48);
77
+ for (const [i, event] of eventLog.entries()) {
78
+ if (!event || typeof event.digest !== "string") {
79
+ throw new Error(`event ${i}: digest must be a string`);
80
+ }
81
+ if (!/^[0-9a-fA-F]+$/.test(event.digest) || event.digest.length % 2 !== 0) {
82
+ throw new Error(`event ${i}: decode sha384: encoding/hex: invalid byte`);
83
+ }
84
+ const measurement = Buffer.from(event.digest, "hex");
85
+ if (measurement.length !== 48) {
86
+ throw new Error(`event ${i}: sha384 length is ${measurement.length} bytes, want 48`);
87
+ }
88
+ current = (0, crypto_1.createHash)("sha384")
89
+ .update(Buffer.concat([current, measurement]))
90
+ .digest();
91
+ }
92
+ const expectedRtmr = this.normalizeRtmr(rtmr);
93
+ if (!current.equals(expectedRtmr)) {
94
+ throw new Error("RTMR does not match event log");
95
+ }
96
+ }
97
+ async parseTDXQuote(quote) {
98
+ if (!Buffer.isBuffer(quote)) {
99
+ throw new Error("quote must be a Buffer");
100
+ }
101
+ if (quote.length === 0) {
102
+ throw new Error("quote cannot be empty");
103
+ }
104
+ let tempDir = "";
105
+ try {
106
+ await fs_1.promises.access(TDX_ATTEST_WRAPPER_PATH, fs_1.constants.X_OK);
107
+ tempDir = await fs_1.promises.mkdtemp(path.join(os.tmpdir(), "tdx-parsed-quote-"));
108
+ const quotePath = path.join(tempDir, "quote.bin");
109
+ const outputPath = path.join(tempDir, "parsed-quote.json");
110
+ await fs_1.promises.writeFile(quotePath, quote);
111
+ try {
112
+ await execFileAsync(TDX_ATTEST_WRAPPER_PATH, [
113
+ "parse-quote",
114
+ "--quote-file",
115
+ quotePath,
116
+ "--output",
117
+ outputPath,
118
+ ]);
119
+ }
120
+ catch (error) {
121
+ throw new Error(`Failed to parse quote: ${DcapQuoteVerifyService.formatSubprocessError(error)}`);
122
+ }
123
+ const rawJson = await fs_1.promises.readFile(outputPath, "utf8");
124
+ const parsed = JSON.parse(rawJson);
125
+ if (!value_1.Value.Check(tdx_parsed_quote_schema_1.TdxParsedQuoteJsonSchema, parsed)) {
126
+ const [firstError] = [...value_1.Value.Errors(tdx_parsed_quote_schema_1.TdxParsedQuoteJsonSchema, parsed)];
127
+ const errorMessage = firstError ? `${firstError.path} ${firstError.message}`.trim() : "unknown error";
128
+ throw new Error(`Failed to validate parsed quote JSON: ${errorMessage}`);
129
+ }
130
+ return parsed;
131
+ }
132
+ catch (error) {
133
+ if (error instanceof Error) {
134
+ throw new Error(`Failed to parse quote: ${error.message}`);
135
+ }
136
+ throw new Error("Failed to parse quote: unknown error");
137
+ }
138
+ finally {
139
+ if (tempDir) {
140
+ await (0, helpers_1.gramineCompatibleRmDir)(tempDir);
141
+ }
142
+ }
143
+ }
144
+ async generateTDXQuoteWithEventLog(userData) {
145
+ if (!Buffer.isBuffer(userData)) {
146
+ throw new Error("userData must be a Buffer");
147
+ }
148
+ if (userData.length === 0) {
149
+ throw new Error("userData cannot be empty");
150
+ }
151
+ let tempDir = "";
152
+ try {
153
+ await fs_1.promises.access(TDX_ATTEST_WRAPPER_PATH, fs_1.constants.X_OK);
154
+ tempDir = await fs_1.promises.mkdtemp(path.join(os.tmpdir(), "tdx-quote-with-event-log-"));
155
+ const outputPath = path.join(tempDir, "quote-with-event-log.json");
156
+ await DcapQuoteVerifyService.executeLikeWithMutex.add(async () => {
157
+ try {
158
+ await execFileAsync(TDX_ATTEST_WRAPPER_PATH, [
159
+ "attest",
160
+ "--report-data",
161
+ userData.toString("hex"),
162
+ "--output",
163
+ outputPath,
164
+ ]);
165
+ }
166
+ catch (error) {
167
+ throw new errors_1.QuoteGenerationError(`Failed to generate quote with event log: ${DcapQuoteVerifyService.formatSubprocessError(error)}`);
168
+ }
169
+ });
170
+ const rawJson = await fs_1.promises.readFile(outputPath, "utf8");
171
+ const parsed = JSON.parse(rawJson);
172
+ if (!value_1.Value.Check(tdx_quote_with_event_log_schema_1.TdxQuoteWithEventLogJsonSchema, parsed)) {
173
+ const [firstError] = [...value_1.Value.Errors(tdx_quote_with_event_log_schema_1.TdxQuoteWithEventLogJsonSchema, parsed)];
174
+ const errorMessage = firstError ? `${firstError.path} ${firstError.message}`.trim() : "unknown error";
175
+ throw new errors_1.QuoteGenerationError(`Failed to validate quote with event log JSON: ${errorMessage}`);
176
+ }
177
+ const result = parsed;
178
+ return {
179
+ quote: Buffer.from(result.quote, "base64"),
180
+ eventLog: result.eventLog,
181
+ };
182
+ }
183
+ catch (error) {
184
+ if (error instanceof errors_1.QuoteGenerationError) {
185
+ throw error;
186
+ }
187
+ if (error instanceof Error) {
188
+ throw new errors_1.QuoteGenerationError(`Failed to generate quote with event log: ${error.message}`);
189
+ }
190
+ throw new errors_1.QuoteGenerationError("Failed to generate quote with event log: unknown error");
191
+ }
192
+ finally {
193
+ if (tempDir) {
194
+ await (0, helpers_1.gramineCompatibleRmDir)(tempDir);
195
+ }
196
+ }
197
+ }
198
+ static formatSubprocessError(error) {
199
+ if (!(error instanceof Error)) {
200
+ return "unknown error";
201
+ }
202
+ const processError = error;
203
+ const output = [processError.stdout, processError.stderr].filter(Boolean).join("\n").trim();
204
+ return output ? `${processError.message}\n${output}` : processError.message;
205
+ }
206
+ normalizeRtmr(rtmr) {
207
+ if (Buffer.isBuffer(rtmr)) {
208
+ if (rtmr.length !== 48) {
209
+ throw new Error("rtmr must be a 48-byte Buffer or SHA-384 hex string");
210
+ }
211
+ return rtmr;
212
+ }
213
+ if (typeof rtmr !== "string") {
214
+ throw new Error("rtmr must be a 48-byte Buffer or SHA-384 hex string");
215
+ }
216
+ const normalized = rtmr.trim().replace(/^0x/i, "");
217
+ if (!/^[0-9a-fA-F]+$/.test(normalized) || normalized.length % 2 !== 0) {
218
+ throw new Error("rtmr must be a 48-byte Buffer or SHA-384 hex string");
219
+ }
220
+ const decoded = Buffer.from(normalized, "hex");
221
+ if (decoded.length !== 48) {
222
+ throw new Error("rtmr must be a 48-byte Buffer or SHA-384 hex string");
223
+ }
224
+ return decoded;
225
+ }
38
226
  async validateMode() {
39
227
  if (DcapQuoteVerifyService.isInGramineMode) {
40
228
  return;
@@ -81,4 +269,4 @@ class DcapQuoteVerifyService {
81
269
  exports.DcapQuoteVerifyService = DcapQuoteVerifyService;
82
270
  DcapQuoteVerifyService.isInGramineMode = false;
83
271
  DcapQuoteVerifyService.executeLikeWithMutex = new p_queue_1.default({ concurrency: 1 });
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGNhcC1xdW90ZS12ZXJpZnkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZ3gtbmF0aXZlLW1vZHVsZS9kY2FwLXF1b3RlLXZlcmlmeS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE1BQU0sRUFBRSxzQkFBc0IsRUFBRSxHQUFHLE9BQU8sQ0FBQyx5REFBeUQsQ0FBQyxDQUFDO0FBQ3RHLHFDQUFnRTtBQUNoRSxxQ0FLa0I7QUFDbEIsc0RBQTRCO0FBQzVCLDJCQUE4QjtBQVE5QixNQUFhLHNCQUFzQjtJQUsvQjtRQUNJLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxzQkFBc0IsRUFBRSxDQUFDO0lBQ3RELENBQUM7SUFFRCxLQUFLLENBQUMsb0JBQW9CLENBQUMsWUFBb0I7UUFDM0MsSUFBSSxDQUFDLFlBQVksRUFBRSxNQUFNLEVBQUUsQ0FBQztZQUN4QixNQUFNLElBQUksK0NBQXNDLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUMxRSxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLG9CQUFvQixDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2pFLENBQUM7SUFFRCxLQUFLLENBQUMsNEJBQTRCLENBQUMsS0FBYSxFQUFFLGFBQXVCO1FBQ3JFLGFBQWEsR0FBRyxhQUFhLElBQUksS0FBSyxDQUFDO1FBRXZDLElBQUksQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDakIsTUFBTSxJQUFJLCtDQUFzQyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3BFLENBQUM7UUFFRCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvRCxJQUFJLGFBQWEsSUFBSSxZQUFZLENBQUMsVUFBVSxLQUFLLGdCQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDckUsTUFBTSxJQUFJLHFDQUE0QixDQUFDLFlBQVksQ0FB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
272
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dcap-quote-verify.service.js","sourceRoot":"","sources":["../../src/sgx-native-module/dcap-quote-verify.service.ts"],"names":[],"mappings":"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"}
@@ -6,4 +6,6 @@ export * from "./pki.service";
6
6
  export * from "./sev-snp";
7
7
  export * from "./sev-snp-mrenclave";
8
8
  export * from "./sev-snp-schema";
9
+ export * from "./tdx-parsed-quote-schema";
10
+ export * from "./tdx-quote-with-event-log-schema";
9
11
  export * from "../proto/AmdSevSnp";
@@ -22,5 +22,7 @@ __exportStar(require("./pki.service"), exports);
22
22
  __exportStar(require("./sev-snp"), exports);
23
23
  __exportStar(require("./sev-snp-mrenclave"), exports);
24
24
  __exportStar(require("./sev-snp-schema"), exports);
25
+ __exportStar(require("./tdx-parsed-quote-schema"), exports);
26
+ __exportStar(require("./tdx-quote-with-event-log-schema"), exports);
25
27
  __exportStar(require("../proto/AmdSevSnp"), exports);
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2d4LW5hdGl2ZS1tb2R1bGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsb0RBQWtDO0FBQ2xDLDhEQUE0QztBQUM1QyxnREFBOEI7QUFDOUIsNENBQTBCO0FBQzFCLHNEQUFvQztBQUNwQyxtREFBaUM7QUFDakMscURBQW1DIn0=
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2d4LW5hdGl2ZS1tb2R1bGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsb0RBQWtDO0FBQ2xDLDhEQUE0QztBQUM1QyxnREFBOEI7QUFDOUIsNENBQTBCO0FBQzFCLHNEQUFvQztBQUNwQyxtREFBaUM7QUFDakMsNERBQTBDO0FBQzFDLG9FQUFrRDtBQUNsRCxxREFBbUMifQ==
@@ -0,0 +1,10 @@
1
+ import { Static } from "@sinclair/typebox";
2
+ export declare const TdxParsedQuoteJsonSchema: import("@sinclair/typebox").TObject<{
3
+ tdattributes: import("@sinclair/typebox").TString;
4
+ mrtd: import("@sinclair/typebox").TString;
5
+ rtmr0: import("@sinclair/typebox").TString;
6
+ rtmr1: import("@sinclair/typebox").TString;
7
+ rtmr2: import("@sinclair/typebox").TString;
8
+ rtmr3: import("@sinclair/typebox").TString;
9
+ }>;
10
+ export type TdxParseQuote = Static<typeof TdxParsedQuoteJsonSchema>;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TdxParsedQuoteJsonSchema = void 0;
4
+ const typebox_1 = require("@sinclair/typebox");
5
+ exports.TdxParsedQuoteJsonSchema = typebox_1.Type.Object({
6
+ tdattributes: typebox_1.Type.String(),
7
+ mrtd: typebox_1.Type.String(),
8
+ rtmr0: typebox_1.Type.String(),
9
+ rtmr1: typebox_1.Type.String(),
10
+ rtmr2: typebox_1.Type.String(),
11
+ rtmr3: typebox_1.Type.String(),
12
+ });
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGR4LXBhcnNlZC1xdW90ZS1zY2hlbWEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2d4LW5hdGl2ZS1tb2R1bGUvdGR4LXBhcnNlZC1xdW90ZS1zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQWlEO0FBRXBDLFFBQUEsd0JBQXdCLEdBQUcsY0FBSSxDQUFDLE1BQU0sQ0FBQztJQUNoRCxZQUFZLEVBQUUsY0FBSSxDQUFDLE1BQU0sRUFBRTtJQUMzQixJQUFJLEVBQUUsY0FBSSxDQUFDLE1BQU0sRUFBRTtJQUNuQixLQUFLLEVBQUUsY0FBSSxDQUFDLE1BQU0sRUFBRTtJQUNwQixLQUFLLEVBQUUsY0FBSSxDQUFDLE1BQU0sRUFBRTtJQUNwQixLQUFLLEVBQUUsY0FBSSxDQUFDLE1BQU0sRUFBRTtJQUNwQixLQUFLLEVBQUUsY0FBSSxDQUFDLE1BQU0sRUFBRTtDQUN2QixDQUFDLENBQUMifQ==
@@ -0,0 +1,19 @@
1
+ /// <reference types="node" />
2
+ import { Static } from "@sinclair/typebox";
3
+ export declare const TdxEventLogEntrySchema: import("@sinclair/typebox").TObject<{
4
+ type: import("@sinclair/typebox").TString;
5
+ digest: import("@sinclair/typebox").TString;
6
+ }>;
7
+ export declare const TdxQuoteWithEventLogJsonSchema: import("@sinclair/typebox").TObject<{
8
+ quote: import("@sinclair/typebox").TString;
9
+ eventLog: import("@sinclair/typebox").TArray<import("@sinclair/typebox").TObject<{
10
+ type: import("@sinclair/typebox").TString;
11
+ digest: import("@sinclair/typebox").TString;
12
+ }>>;
13
+ }>;
14
+ export type TdxEventLogEntry = Static<typeof TdxEventLogEntrySchema>;
15
+ export type TdxQuoteWithEventLogJson = Static<typeof TdxQuoteWithEventLogJsonSchema>;
16
+ export interface TdxQuoteWithEventLog {
17
+ quote: Buffer;
18
+ eventLog: TdxEventLogEntry[];
19
+ }
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TdxQuoteWithEventLogJsonSchema = exports.TdxEventLogEntrySchema = void 0;
4
+ const typebox_1 = require("@sinclair/typebox");
5
+ exports.TdxEventLogEntrySchema = typebox_1.Type.Object({
6
+ type: typebox_1.Type.String(),
7
+ digest: typebox_1.Type.String(),
8
+ });
9
+ exports.TdxQuoteWithEventLogJsonSchema = typebox_1.Type.Object({
10
+ quote: typebox_1.Type.String(),
11
+ eventLog: typebox_1.Type.Array(exports.TdxEventLogEntrySchema),
12
+ });
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGR4LXF1b3RlLXdpdGgtZXZlbnQtbG9nLXNjaGVtYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZ3gtbmF0aXZlLW1vZHVsZS90ZHgtcXVvdGUtd2l0aC1ldmVudC1sb2ctc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLCtDQUFpRDtBQUVwQyxRQUFBLHNCQUFzQixHQUFHLGNBQUksQ0FBQyxNQUFNLENBQUM7SUFDOUMsSUFBSSxFQUFFLGNBQUksQ0FBQyxNQUFNLEVBQUU7SUFDbkIsTUFBTSxFQUFFLGNBQUksQ0FBQyxNQUFNLEVBQUU7Q0FDeEIsQ0FBQyxDQUFDO0FBRVUsUUFBQSw4QkFBOEIsR0FBRyxjQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3RELEtBQUssRUFBRSxjQUFJLENBQUMsTUFBTSxFQUFFO0lBQ3BCLFFBQVEsRUFBRSxjQUFJLENBQUMsS0FBSyxDQUFDLDhCQUFzQixDQUFDO0NBQy9DLENBQUMsQ0FBQyJ9
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@super-protocol/addons-tee",
3
- "version": "1.0.0",
3
+ "version": "1.1.1",
4
4
  "description": "The TEE trusted loader addons",
5
5
  "tags": [
6
6
  "tee"
@@ -15,8 +15,8 @@
15
15
  "author": "Super Protocol",
16
16
  "license": "ISC",
17
17
  "engines": {
18
- "node": ">=14.0",
19
- "npm": ">=6.0"
18
+ "node": ">=20.0",
19
+ "npm": ">=10.0"
20
20
  },
21
21
  "main": "dist/index.js",
22
22
  "module": "dist/index.js",
@@ -43,7 +43,6 @@
43
43
  "dependencies": {
44
44
  "@super-protocol/eslint-config-typescript": "2.0.1",
45
45
  "asn1-tree": "^0.1.1",
46
- "msgpack5": "^6.0.2",
47
46
  "node-forge": "^1.3.1",
48
47
  "p-queue": "^6.6.2",
49
48
  "@sinclair/typebox": "0.33.17"
@@ -57,7 +56,6 @@
57
56
  "@peculiar/x509": "^1.9.3",
58
57
  "@types/jest": "^27.5.2",
59
58
  "@types/lodash": "^4.17.5",
60
- "@types/msgpack5": "^3.4.6",
61
59
  "@types/node": "^17.0.0",
62
60
  "@types/node-forge": "^1.3.1",
63
61
  "jest": "^29.7.0",
@@ -1,31 +0,0 @@
1
- syntax = "proto3";
2
-
3
- enum SevSNPCertType {
4
- ARK = 0;
5
- ASK = 1;
6
- VCEK = 2;
7
- }
8
-
9
- enum SevSnpCertificateFormat {
10
- PEM = 0;
11
- DER = 1;
12
- }
13
-
14
- message SnpCert {
15
- SevSNPCertType type = 1;
16
- bytes cert = 2;
17
- SevSnpCertificateFormat format = 3;
18
- }
19
-
20
- message SNPReport {
21
- bytes rawReport = 1;
22
- uint32 cpuSig = 2;
23
- uint32 cores = 3;
24
- bytes cmdLineHash = 4;
25
- string build = 5;
26
- }
27
-
28
- message SNPReportWithChain {
29
- SNPReport snpReport = 1;
30
- repeated SnpCert certs = 2;
31
- }
@@ -1,11 +0,0 @@
1
- syntax = "proto3";
2
-
3
- message Compression {
4
- enum TYPE {
5
- Uncompressed = 0;
6
- GZIP = 1;
7
- }
8
-
9
- TYPE type = 1;
10
- bytes data = 2;
11
- }
@@ -1,6 +0,0 @@
1
- syntax = "proto3";
2
-
3
- message Hash {
4
- string algo = 1;
5
- bytes hash = 2;
6
- }
@@ -1,21 +0,0 @@
1
- syntax = "proto3";
2
-
3
- import "Hash.proto";
4
-
5
- message OrderReportProto {
6
- repeated bytes certificates = 1;
7
- WorkloadInfo workloadInfo = 2;
8
- }
9
-
10
- message WorkloadInfo {
11
- repeated RuntimeInfo runtimeInfo = 1;
12
- int64 created = 2;
13
- }
14
-
15
- message RuntimeInfo {
16
- string type = 1;
17
- int64 size = 2;
18
- Hash hash = 3;
19
- optional Hash signatureKeyHash = 4;
20
- optional Hash argsHash = 5;
21
- }
package/dto/src/TRI.proto DELETED
@@ -1,22 +0,0 @@
1
- syntax = "proto3";
2
-
3
- import "Hash.proto";
4
-
5
- message Encryption {
6
- string algo = 1;
7
- optional bytes key = 2;
8
- optional string cipher = 3;
9
- optional bytes ciphertext = 4;
10
- optional bytes iv = 6;
11
- optional bytes mac = 7;
12
- string encoding = 8;
13
- }
14
-
15
- message TRI {
16
- repeated Hash solutionHashes = 1;
17
- bytes mrenclave = 2;
18
- string args = 3;
19
- Encryption encryption = 4;
20
- bytes mrsigner = 5;
21
- repeated Hash imageHashes = 6;
22
- }
@@ -1,46 +0,0 @@
1
- syntax = "proto3";
2
-
3
- message TeeDeviceInfo {
4
- CpuInfo cpu = 1;
5
- MemoryInfo memory = 2;
6
- DiskInfo disk = 3;
7
- GpuInfo gpu = 4;
8
- }
9
-
10
- message CpuInfo {
11
- string vendor_id = 1;
12
- int32 cpu_family = 2;
13
- int32 model = 3;
14
- string model_name = 4;
15
- int32 total_physical_cores = 5;
16
- int32 total_logical_cores = 6;
17
- int32 base_freq = 7;
18
- int32 max_freq = 8;
19
- }
20
-
21
- message MemoryInfo {
22
- string type = 1;
23
- int64 size = 2;
24
- }
25
-
26
- message DiskInfo {
27
- string type = 1;
28
- int64 size = 2;
29
- }
30
-
31
- message GpuInfo {
32
- string type = 1;
33
- int32 count = 2;
34
- int64 memory_size = 3;
35
- }
36
-
37
- message NvtrustGPUInfo {
38
- string model = 1;
39
- string driverVersion = 2;
40
- string vbios = 3;
41
- bool dbgStat = 4;
42
- }
43
-
44
- message NvtrustGPUList {
45
- repeated NvtrustGPUInfo gpus = 1;
46
- }