sign.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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. Object.defineProperty(exports, "__esModule", { value: true });
  26. exports.Signer = void 0;
  27. const sigstore = __importStar(require("./types/sigstore"));
  28. const util_1 = require("./util");
  29. class Signer {
  30. constructor(options) {
  31. this.identityProviders = [];
  32. this.ca = options.ca;
  33. this.tlog = options.tlog;
  34. this.tsa = options.tsa;
  35. this.identityProviders = options.identityProviders;
  36. this.tlogUpload = options.tlogUpload ?? true;
  37. this.signer = options.signer || this.signWithEphemeralKey.bind(this);
  38. }
  39. async signBlob(payload) {
  40. // Get signature and verification material for payload
  41. const sigMaterial = await this.signer(payload);
  42. // Calculate artifact digest
  43. const digest = util_1.crypto.hash(payload);
  44. // Create a Rekor entry (if tlogUpload is enabled)
  45. const entry = this.tlogUpload
  46. ? await this.tlog.createMessageSignatureEntry(digest, sigMaterial)
  47. : undefined;
  48. return sigstore.toMessageSignatureBundle({
  49. digest,
  50. signature: sigMaterial,
  51. tlogEntry: entry,
  52. timestamp: this.tsa
  53. ? await this.tsa.createTimestamp(sigMaterial.signature)
  54. : undefined,
  55. });
  56. }
  57. async signAttestation(payload, payloadType) {
  58. // Pre-authentication encoding to be signed
  59. const paeBuffer = util_1.dsse.preAuthEncoding(payloadType, payload);
  60. // Get signature and verification material for pae
  61. const sigMaterial = await this.signer(paeBuffer);
  62. const envelope = {
  63. payloadType,
  64. payload: payload,
  65. signatures: [
  66. {
  67. keyid: sigMaterial.key?.id || '',
  68. sig: sigMaterial.signature,
  69. },
  70. ],
  71. };
  72. // Create a Rekor entry (if tlogUpload is enabled)
  73. const entry = this.tlogUpload
  74. ? await this.tlog.createDSSEEntry(envelope, sigMaterial)
  75. : undefined;
  76. return sigstore.toDSSEBundle({
  77. envelope,
  78. signature: sigMaterial,
  79. tlogEntry: entry,
  80. timestamp: this.tsa
  81. ? await this.tsa.createTimestamp(sigMaterial.signature)
  82. : undefined,
  83. });
  84. }
  85. async signWithEphemeralKey(payload) {
  86. // Create emphemeral key pair
  87. const keypair = util_1.crypto.generateKeyPair();
  88. // Retrieve identity token from one of the supplied identity providers
  89. const identityToken = await this.getIdentityToken();
  90. // Extract challenge claim from OIDC token
  91. const subject = util_1.oidc.extractJWTSubject(identityToken);
  92. // Construct challenge value by encrypting subject with private key
  93. const challenge = util_1.crypto.signBlob(Buffer.from(subject), keypair.privateKey);
  94. // Create signing certificate
  95. const certificates = await this.ca.createSigningCertificate(identityToken, keypair.publicKey, challenge);
  96. // Generate artifact signature
  97. const signature = util_1.crypto.signBlob(payload, keypair.privateKey);
  98. return {
  99. signature,
  100. certificates,
  101. key: undefined,
  102. };
  103. }
  104. async getIdentityToken() {
  105. const aggErrs = [];
  106. for (const provider of this.identityProviders) {
  107. try {
  108. const token = await provider.getToken();
  109. if (token) {
  110. return token;
  111. }
  112. }
  113. catch (err) {
  114. aggErrs.push(err);
  115. }
  116. }
  117. throw new Error(`Identity token providers failed: ${aggErrs}`);
  118. }
  119. }
  120. exports.Signer = Signer;