aws-delivlib 14.1.97 → 14.1.98

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.
@@ -1,3 +1,4 @@
1
+ import { aws_s3 as s3 } from 'aws-cdk-lib';
1
2
  import { Construct } from 'constructs';
2
3
  import { RsaPrivateKeySecret } from './private-key';
3
4
  export interface CertificateSigningRequestProps {
@@ -39,6 +40,10 @@ export declare class CertificateSigningRequest extends Construct {
39
40
  * The S3 URL to a self-signed certificate that corresponds with this CSR.
40
41
  */
41
42
  readonly selfSignedPemCertificate: string;
43
+ /**
44
+ * The S3 bucket where the self-signed certificate is stored.
45
+ */
46
+ readonly outputBucket: s3.IBucket;
42
47
  constructor(parent: Construct, id: string, props: CertificateSigningRequestProps);
43
48
  }
44
49
  /**
@@ -61,6 +61,7 @@ class CertificateSigningRequest extends constructs_1.Construct {
61
61
  enforceSSL: true,
62
62
  });
63
63
  outputBucket.grantReadWrite(customResource);
64
+ this.outputBucket = outputBucket;
64
65
  const csr = new aws_cdk_lib_1.CustomResource(this, 'Resource', {
65
66
  serviceToken: customResource.functionArn,
66
67
  resourceType: 'Custom::CertificateSigningRequest',
@@ -94,4 +95,4 @@ class CertificateSigningRequest extends constructs_1.Construct {
94
95
  }
95
96
  }
96
97
  exports.CertificateSigningRequest = CertificateSigningRequest;
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"certificate-signing-request.js","sourceRoot":"","sources":["certificate-signing-request.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Duration,\n  CustomResource,\n  aws_lambda as lambda,\n  aws_s3 as s3,\n  RemovalPolicy,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { RsaPrivateKeySecret } from './private-key';\nimport { hashFileOrDirectory } from '../util';\n\n\nexport interface CertificateSigningRequestProps {\n  /**\n   * The RSA Private Key to use for this CSR.\n   */\n  privateKey: RsaPrivateKeySecret;\n  /**\n   * The Distinguished Name for this CSR.\n   */\n  dn: DistinguishedName;\n  /**\n   * The key usage requests for this CSR.\n   *\n   * @example critical,digitalSignature\n   */\n  keyUsage: string;\n  /**\n   * The extended key usage requests for this CSR.\n   *\n   * @example critical,codeSigning\n   */\n  extendedKeyUsage?: string;\n}\n\n/**\n * Creates a Certificate Signing Request (CSR), which will allow a Certificate Authority to provide a signed certificate\n * that uses the specified RSA Private Key. A CSR document can usually be shared publicly, however it must be noted that\n * the information provided in the ``dn`` fields, information about the public key and the intended ley usage will be\n * readable by anyone who can access the CSR.\n *\n * @see https://www.openssl.org/docs/manmaster/man1/req.html\n */\nexport class CertificateSigningRequest extends Construct {\n  /**\n   * The S3 URL to the CSR document.\n   */\n  public readonly pemRequest: string;\n\n  /**\n   * The S3 URL to a self-signed certificate that corresponds with this CSR.\n   */\n  public readonly selfSignedPemCertificate: string;\n\n  constructor(parent: Construct, id: string, props: CertificateSigningRequestProps) {\n    super(parent, id);\n\n    const codeLocation = path.resolve(__dirname, '..', 'custom-resource-handlers', 'bin', 'certificate-signing-request');\n    const customResource = new lambda.SingletonFunction(this, 'ResourceHandler', {\n      uuid: '541F6782-6DCF-49A7-8C5A-67715ADD9E4C',\n      lambdaPurpose: 'CreateCSR',\n      description: 'Creates a Certificate Signing Request document for an x509 certificate',\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: new lambda.AssetCode(codeLocation),\n      timeout: Duration.seconds(300),\n      // add the layer that contains the OpenSSL CLI binary\n      layers: [new lambda.LayerVersion(this, 'OpenSslCliLayer', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '..', 'custom-resource-handlers', 'layers', 'openssl-cli-layer.zip')),\n      })],\n    });\n\n    const outputBucket = new s3.Bucket(this, 'Bucket', {\n      // CSRs can be easily re-created if lost or corrupt, so we can let those get to a black hole, no worries.\n      autoDeleteObjects: true,\n      removalPolicy: RemovalPolicy.DESTROY,\n      encryption: s3.BucketEncryption.S3_MANAGED,\n      enforceSSL: true,\n    });\n    outputBucket.grantReadWrite(customResource);\n\n    const csr = new CustomResource(this, 'Resource', {\n      serviceToken: customResource.functionArn,\n      resourceType: 'Custom::CertificateSigningRequest',\n      pascalCaseProperties: true,\n      properties: {\n        resourceVersion: hashFileOrDirectory(codeLocation),\n        // Private key\n        privateKeySecretId: props.privateKey.secretArn,\n        // Distinguished name\n        dnCommonName: props.dn.commonName,\n        dnCountry: props.dn.country,\n        dnStateOrProvince: props.dn.stateOrProvince,\n        dnLocality: props.dn.locality,\n        dnOrganizationName: props.dn.organizationName,\n        dnOrganizationalUnitName: props.dn.organizationalUnitName,\n        dnEmailAddress: props.dn.emailAddress,\n        // Key Usage\n        extendedKeyUsage: props.extendedKeyUsage || '',\n        keyUsage: props.keyUsage,\n        // Ouput location\n        outputBucket: outputBucket.bucketName,\n      },\n    });\n    if (customResource.role) {\n      // Make sure the permissions are all good before proceeding\n      csr.node.addDependency(customResource.role);\n      props.privateKey.grantGetSecretValue(customResource.role);\n    }\n\n    this.pemRequest = csr.getAtt('CSR').toString();\n    this.selfSignedPemCertificate = csr.getAtt('SelfSignedCertificate').toString();\n  }\n}\n\n/**\n * Fields that compose the distinguished name of a certificate\n */\nexport interface DistinguishedName {\n  /** The Common Name (CN) */\n  commonName: string;\n  /** The email address (emailAddress) */\n  emailAddress: string;\n\n  /** The Country (C) */\n  country: string;\n  /** The State or Province (ST) */\n  stateOrProvince: string;\n  /** The locality (L) */\n  locality: string;\n\n  /** The organization name (O) */\n  organizationName: string;\n  /** The organizational unit name (OU) */\n  organizationalUnitName: string;\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"certificate-signing-request.js","sourceRoot":"","sources":["certificate-signing-request.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Duration,\n  CustomResource,\n  aws_lambda as lambda,\n  aws_s3 as s3,\n  RemovalPolicy,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { RsaPrivateKeySecret } from './private-key';\nimport { hashFileOrDirectory } from '../util';\n\n\nexport interface CertificateSigningRequestProps {\n  /**\n   * The RSA Private Key to use for this CSR.\n   */\n  privateKey: RsaPrivateKeySecret;\n  /**\n   * The Distinguished Name for this CSR.\n   */\n  dn: DistinguishedName;\n  /**\n   * The key usage requests for this CSR.\n   *\n   * @example critical,digitalSignature\n   */\n  keyUsage: string;\n  /**\n   * The extended key usage requests for this CSR.\n   *\n   * @example critical,codeSigning\n   */\n  extendedKeyUsage?: string;\n}\n\n/**\n * Creates a Certificate Signing Request (CSR), which will allow a Certificate Authority to provide a signed certificate\n * that uses the specified RSA Private Key. A CSR document can usually be shared publicly, however it must be noted that\n * the information provided in the ``dn`` fields, information about the public key and the intended ley usage will be\n * readable by anyone who can access the CSR.\n *\n * @see https://www.openssl.org/docs/manmaster/man1/req.html\n */\nexport class CertificateSigningRequest extends Construct {\n  /**\n   * The S3 URL to the CSR document.\n   */\n  public readonly pemRequest: string;\n\n  /**\n   * The S3 URL to a self-signed certificate that corresponds with this CSR.\n   */\n  public readonly selfSignedPemCertificate: string;\n\n  /**\n   * The S3 bucket where the self-signed certificate is stored.\n   */\n  public readonly outputBucket: s3.IBucket;\n\n  constructor(parent: Construct, id: string, props: CertificateSigningRequestProps) {\n    super(parent, id);\n\n    const codeLocation = path.resolve(__dirname, '..', 'custom-resource-handlers', 'bin', 'certificate-signing-request');\n    const customResource = new lambda.SingletonFunction(this, 'ResourceHandler', {\n      uuid: '541F6782-6DCF-49A7-8C5A-67715ADD9E4C',\n      lambdaPurpose: 'CreateCSR',\n      description: 'Creates a Certificate Signing Request document for an x509 certificate',\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: new lambda.AssetCode(codeLocation),\n      timeout: Duration.seconds(300),\n      // add the layer that contains the OpenSSL CLI binary\n      layers: [new lambda.LayerVersion(this, 'OpenSslCliLayer', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '..', 'custom-resource-handlers', 'layers', 'openssl-cli-layer.zip')),\n      })],\n    });\n\n    const outputBucket = new s3.Bucket(this, 'Bucket', {\n      // CSRs can be easily re-created if lost or corrupt, so we can let those get to a black hole, no worries.\n      autoDeleteObjects: true,\n      removalPolicy: RemovalPolicy.DESTROY,\n      encryption: s3.BucketEncryption.S3_MANAGED,\n      enforceSSL: true,\n    });\n    outputBucket.grantReadWrite(customResource);\n    this.outputBucket = outputBucket;\n\n    const csr = new CustomResource(this, 'Resource', {\n      serviceToken: customResource.functionArn,\n      resourceType: 'Custom::CertificateSigningRequest',\n      pascalCaseProperties: true,\n      properties: {\n        resourceVersion: hashFileOrDirectory(codeLocation),\n        // Private key\n        privateKeySecretId: props.privateKey.secretArn,\n        // Distinguished name\n        dnCommonName: props.dn.commonName,\n        dnCountry: props.dn.country,\n        dnStateOrProvince: props.dn.stateOrProvince,\n        dnLocality: props.dn.locality,\n        dnOrganizationName: props.dn.organizationName,\n        dnOrganizationalUnitName: props.dn.organizationalUnitName,\n        dnEmailAddress: props.dn.emailAddress,\n        // Key Usage\n        extendedKeyUsage: props.extendedKeyUsage || '',\n        keyUsage: props.keyUsage,\n        // Ouput location\n        outputBucket: outputBucket.bucketName,\n      },\n    });\n    if (customResource.role) {\n      // Make sure the permissions are all good before proceeding\n      csr.node.addDependency(customResource.role);\n      props.privateKey.grantGetSecretValue(customResource.role);\n    }\n\n    this.pemRequest = csr.getAtt('CSR').toString();\n    this.selfSignedPemCertificate = csr.getAtt('SelfSignedCertificate').toString();\n  }\n}\n\n/**\n * Fields that compose the distinguished name of a certificate\n */\nexport interface DistinguishedName {\n  /** The Common Name (CN) */\n  commonName: string;\n  /** The email address (emailAddress) */\n  emailAddress: string;\n\n  /** The Country (C) */\n  country: string;\n  /** The State or Province (ST) */\n  stateOrProvince: string;\n  /** The locality (L) */\n  locality: string;\n\n  /** The organization name (O) */\n  organizationName: string;\n  /** The organizational unit name (OU) */\n  organizationalUnitName: string;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { aws_iam as iam, aws_kms as kms, aws_secretsmanager as secretsManager, aws_ssm as ssm } from 'aws-cdk-lib';
1
+ import { aws_iam as iam, aws_kms as kms, aws_s3 as s3, aws_secretsmanager as secretsManager, aws_ssm as ssm } from 'aws-cdk-lib';
2
2
  import { Construct, IConstruct } from 'constructs';
3
3
  import { DistinguishedName } from './certificate-signing-request';
4
4
  import { ICredentialPair } from '../credential-pair';
@@ -51,6 +51,10 @@ interface CodeSigningCertificateProps {
51
51
  readonly baseName?: string;
52
52
  }
53
53
  export interface ICodeSigningCertificate extends IConstruct, ICredentialPair {
54
+ /**
55
+ * The S3 bucket where the self-signed certificate is stored.
56
+ */
57
+ readonly certificateBucket?: s3.IBucket;
54
58
  /**
55
59
  * Grant the IAM principal permissions to read the private key and
56
60
  * certificate.
@@ -81,6 +85,10 @@ export declare class CodeSigningCertificate extends Construct implements ICodeSi
81
85
  * The AWS SSM Parameter that holds the certificate for this CSC.
82
86
  */
83
87
  readonly principal: ssm.IStringParameter;
88
+ /**
89
+ * The S3 bucket where the self-signed certificate is stored.
90
+ */
91
+ readonly certificateBucket?: s3.IBucket;
84
92
  constructor(parent: Construct, id: string, props: CodeSigningCertificateProps);
85
93
  /**
86
94
  * Grant the IAM principal permissions to read the private key and
@@ -64,6 +64,7 @@ class CodeSigningCertificate extends constructs_1.Construct {
64
64
  let certificate = props.pemCertificate;
65
65
  if (!certificate || props.forceCertificateSigningRequest) {
66
66
  const csr = privateKey.newCertificateSigningRequest('CertificateSigningRequest', props.distinguishedName, 'critical,digitalSignature', 'critical,codeSigning');
67
+ this.certificateBucket = csr.outputBucket;
67
68
  new aws_cdk_lib_1.CfnOutput(this, 'CSR', {
68
69
  description: 'A PEM-encoded Certificate Signing Request for a Code-Signing Certificate',
69
70
  value: csr.pemRequest,
@@ -101,4 +102,4 @@ class CodeSigningCertificate extends constructs_1.Construct {
101
102
  }
102
103
  }
103
104
  exports.CodeSigningCertificate = CodeSigningCertificate;
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-signing-certificate.js","sourceRoot":"","sources":["code-signing-certificate.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CfnOutput, RemovalPolicy, Stack,\n  aws_iam as iam,\n  aws_kms as kms,\n  aws_secretsmanager as secretsManager,\n  aws_ssm as ssm,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\nimport { DistinguishedName } from './certificate-signing-request';\nimport { RsaPrivateKeySecret } from './private-key';\nimport { ICredentialPair } from '../credential-pair';\nimport * as permissions from '../permissions';\n\n\nexport { DistinguishedName } from './certificate-signing-request';\n\ninterface CodeSigningCertificateProps {\n  /**\n   * The number of bits to compose the modulus of the generated private key for this certificate.\n   *\n   * @default 2048\n   */\n  rsaKeySize?: number;\n\n  /**\n   * The KMS CMK to use for encrypting the Private Key secret.\n   * @default A new KMS key will be allocated for you\n   */\n  secretEncryptionKey?: kms.IKey;\n\n  /**\n   * The PEM-encoded certificate that was signed by the relevant authority.\n   *\n   * @default If a certificate is not provided, a self-signed certificate will\n   * be generated and a CSR (certificate signing request) will by available in\n   * the stack output.\n   */\n  pemCertificate?: string;\n\n  /**\n   * Whether a CSR should be generated, even if the certificate is provided.\n   * This can be useful if one wants to renew a certificate that is close to\n   * expiry without generating a new private key (for example, to avoid breaking\n   * clients that make use of certificate pinning).\n   *\n   * @default false\n   */\n  forceCertificateSigningRequest?: boolean;\n\n  /**\n   * When enabled, the Private Key secret will have a DeletionPolicy of\n   * \"RETAIN\", making sure the Private Key is not inadvertently destroyed.\n   *\n   * @default true\n   */\n  retainPrivateKey?: boolean;\n\n  /**\n   * The Distinguished Name for this CSR.\n   */\n  distinguishedName: DistinguishedName;\n\n  /**\n   * Base names for the private key and output SSM parameter\n   *\n   * @default - Automatically generated\n   */\n  readonly baseName?: string;\n}\n\nexport interface ICodeSigningCertificate extends IConstruct, ICredentialPair {\n  /**\n   * Grant the IAM principal permissions to read the private key and\n   * certificate.\n   */\n  grantDecrypt(principal?: iam.IPrincipal): void;\n}\n\n/**\n * A Code-Signing certificate, that will use a private key that is generated by a Lambda function. The Certificate will\n * not be usable until the ``pemCertificate`` value has been provided. A typical workflow to use this Construct would be:\n *\n * 1. Add an instance of the construct to your app, without providing the ``pemCertificate`` property\n * 2. Deploy the stack to provision a Private Key and obtain the CSR (you can surface it using a Output, for example)\n * 3. Submit the CSR to your Certificate Authority of choice.\n * 4. Populate the ``pemCertificate`` property with the PEM-encoded certificate provided by your CA of coice.\n * 5. Re-deploy the stack so make the certificate usable\n *\n * In order to renew the certificate, if you do not wish to retain the same private key (your clients do not rely on\n * public key pinning), simply add a new instance of the construct to your app and follow the process listed above. If\n * you wish to retain the private key, you can set ``forceCertificateSigningRequest`` to ``true`` in order to obtain a\n * new CSR document.\n */\nexport class CodeSigningCertificate extends Construct implements ICodeSigningCertificate {\n  /**\n   * The AWS Secrets Manager secret that holds the private key for this CSC\n   */\n  public readonly credential: secretsManager.ISecret;\n\n  /**\n   * The AWS SSM Parameter that holds the certificate for this CSC.\n   */\n  public readonly principal: ssm.IStringParameter;\n\n  constructor(parent: Construct, id: string, props: CodeSigningCertificateProps) {\n    super(parent, id);\n\n    // The construct path of this construct with respect to the containing stack, without any leading /\n    const stack = Stack.of(this);\n    const baseName = props.baseName ?? `${stack.stackName}${this.node.path.substr(stack.node.path.length)}`;\n\n    const privateKey = new RsaPrivateKeySecret(this, 'RSAPrivateKey', {\n      removalPolicy: props.retainPrivateKey === false ? RemovalPolicy.DESTROY : RemovalPolicy.RETAIN,\n      description: 'The PEM-encoded private key of the x509 Code-Signing Certificate',\n      keySize: props.rsaKeySize || 2048,\n      secretEncryptionKey: props.secretEncryptionKey,\n      secretName: `${baseName}/RSAPrivateKey`,\n    });\n\n    this.credential = secretsManager.Secret.fromSecretAttributes(this, 'Credential', {\n      encryptionKey: props.secretEncryptionKey,\n      secretCompleteArn: privateKey.secretArn,\n    });\n\n    let certificate = props.pemCertificate;\n\n    if (!certificate || props.forceCertificateSigningRequest) {\n      const csr = privateKey.newCertificateSigningRequest('CertificateSigningRequest',\n        props.distinguishedName,\n        'critical,digitalSignature',\n        'critical,codeSigning');\n\n      new CfnOutput(this, 'CSR', {\n        description: 'A PEM-encoded Certificate Signing Request for a Code-Signing Certificate',\n        value: csr.pemRequest,\n      });\n\n      if (!certificate) {\n        certificate = csr.selfSignedPemCertificate;\n      }\n    }\n\n    this.principal = new ssm.StringParameter(this, 'Resource', {\n      description: `A PEM-encoded Code-Signing Certificate (private key in ${privateKey.secretArn})`,\n      parameterName: `/${baseName}/Certificate`,\n      stringValue: certificate!,\n    });\n  }\n\n  /**\n   * Grant the IAM principal permissions to read the private key and\n   * certificate.\n   */\n  public grantDecrypt(principal?: iam.IPrincipal) {\n    if (!principal) { return; }\n\n    permissions.grantSecretRead({\n      keyArn: this.credential.encryptionKey && this.credential.encryptionKey.keyArn,\n      secretArn: this.credential.secretArn,\n    }, principal);\n\n    principal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ssm:GetParameter'],\n      resources: [Stack.of(this).formatArn({\n        // TODO: This is a workaround until https://github.com/awslabs/aws-cdk/pull/1726 is released\n        service: 'ssm',\n        resource: `parameter${this.principal.parameterName}`,\n      })],\n    }));\n  }\n}\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-signing-certificate.js","sourceRoot":"","sources":["code-signing-certificate.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CfnOutput, RemovalPolicy, Stack,\n  aws_iam as iam,\n  aws_kms as kms,\n  aws_s3 as s3,\n  aws_secretsmanager as secretsManager,\n  aws_ssm as ssm,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\nimport { CertificateSigningRequest, DistinguishedName } from './certificate-signing-request';\nimport { RsaPrivateKeySecret } from './private-key';\nimport { ICredentialPair } from '../credential-pair';\nimport * as permissions from '../permissions';\n\n\nexport { DistinguishedName } from './certificate-signing-request';\n\ninterface CodeSigningCertificateProps {\n  /**\n   * The number of bits to compose the modulus of the generated private key for this certificate.\n   *\n   * @default 2048\n   */\n  rsaKeySize?: number;\n\n  /**\n   * The KMS CMK to use for encrypting the Private Key secret.\n   * @default A new KMS key will be allocated for you\n   */\n  secretEncryptionKey?: kms.IKey;\n\n  /**\n   * The PEM-encoded certificate that was signed by the relevant authority.\n   *\n   * @default If a certificate is not provided, a self-signed certificate will\n   * be generated and a CSR (certificate signing request) will by available in\n   * the stack output.\n   */\n  pemCertificate?: string;\n\n  /**\n   * Whether a CSR should be generated, even if the certificate is provided.\n   * This can be useful if one wants to renew a certificate that is close to\n   * expiry without generating a new private key (for example, to avoid breaking\n   * clients that make use of certificate pinning).\n   *\n   * @default false\n   */\n  forceCertificateSigningRequest?: boolean;\n\n  /**\n   * When enabled, the Private Key secret will have a DeletionPolicy of\n   * \"RETAIN\", making sure the Private Key is not inadvertently destroyed.\n   *\n   * @default true\n   */\n  retainPrivateKey?: boolean;\n\n  /**\n   * The Distinguished Name for this CSR.\n   */\n  distinguishedName: DistinguishedName;\n\n  /**\n   * Base names for the private key and output SSM parameter\n   *\n   * @default - Automatically generated\n   */\n  readonly baseName?: string;\n}\n\nexport interface ICodeSigningCertificate extends IConstruct, ICredentialPair {\n  /**\n   * The S3 bucket where the self-signed certificate is stored.\n   */\n  readonly certificateBucket?: s3.IBucket;\n\n  /**\n   * Grant the IAM principal permissions to read the private key and\n   * certificate.\n   */\n  grantDecrypt(principal?: iam.IPrincipal): void;\n}\n\n/**\n * A Code-Signing certificate, that will use a private key that is generated by a Lambda function. The Certificate will\n * not be usable until the ``pemCertificate`` value has been provided. A typical workflow to use this Construct would be:\n *\n * 1. Add an instance of the construct to your app, without providing the ``pemCertificate`` property\n * 2. Deploy the stack to provision a Private Key and obtain the CSR (you can surface it using a Output, for example)\n * 3. Submit the CSR to your Certificate Authority of choice.\n * 4. Populate the ``pemCertificate`` property with the PEM-encoded certificate provided by your CA of coice.\n * 5. Re-deploy the stack so make the certificate usable\n *\n * In order to renew the certificate, if you do not wish to retain the same private key (your clients do not rely on\n * public key pinning), simply add a new instance of the construct to your app and follow the process listed above. If\n * you wish to retain the private key, you can set ``forceCertificateSigningRequest`` to ``true`` in order to obtain a\n * new CSR document.\n */\nexport class CodeSigningCertificate extends Construct implements ICodeSigningCertificate {\n  /**\n   * The AWS Secrets Manager secret that holds the private key for this CSC\n   */\n  public readonly credential: secretsManager.ISecret;\n\n  /**\n   * The AWS SSM Parameter that holds the certificate for this CSC.\n   */\n  public readonly principal: ssm.IStringParameter;\n\n  /**\n   * The S3 bucket where the self-signed certificate is stored.\n   */\n  public readonly certificateBucket?: s3.IBucket;\n\n  constructor(parent: Construct, id: string, props: CodeSigningCertificateProps) {\n    super(parent, id);\n\n    // The construct path of this construct with respect to the containing stack, without any leading /\n    const stack = Stack.of(this);\n    const baseName = props.baseName ?? `${stack.stackName}${this.node.path.substr(stack.node.path.length)}`;\n\n    const privateKey = new RsaPrivateKeySecret(this, 'RSAPrivateKey', {\n      removalPolicy: props.retainPrivateKey === false ? RemovalPolicy.DESTROY : RemovalPolicy.RETAIN,\n      description: 'The PEM-encoded private key of the x509 Code-Signing Certificate',\n      keySize: props.rsaKeySize || 2048,\n      secretEncryptionKey: props.secretEncryptionKey,\n      secretName: `${baseName}/RSAPrivateKey`,\n    });\n\n    this.credential = secretsManager.Secret.fromSecretAttributes(this, 'Credential', {\n      encryptionKey: props.secretEncryptionKey,\n      secretCompleteArn: privateKey.secretArn,\n    });\n\n    let certificate = props.pemCertificate;\n\n    if (!certificate || props.forceCertificateSigningRequest) {\n      const csr: CertificateSigningRequest = privateKey.newCertificateSigningRequest('CertificateSigningRequest',\n        props.distinguishedName,\n        'critical,digitalSignature',\n        'critical,codeSigning');\n\n      this.certificateBucket = csr.outputBucket;\n\n      new CfnOutput(this, 'CSR', {\n        description: 'A PEM-encoded Certificate Signing Request for a Code-Signing Certificate',\n        value: csr.pemRequest,\n      });\n\n      if (!certificate) {\n        certificate = csr.selfSignedPemCertificate;\n      }\n    }\n\n    this.principal = new ssm.StringParameter(this, 'Resource', {\n      description: `A PEM-encoded Code-Signing Certificate (private key in ${privateKey.secretArn})`,\n      parameterName: `/${baseName}/Certificate`,\n      stringValue: certificate!,\n    });\n  }\n\n  /**\n   * Grant the IAM principal permissions to read the private key and\n   * certificate.\n   */\n  public grantDecrypt(principal?: iam.IPrincipal) {\n    if (!principal) { return; }\n\n    permissions.grantSecretRead({\n      keyArn: this.credential.encryptionKey && this.credential.encryptionKey.keyArn,\n      secretArn: this.credential.secretArn,\n    }, principal);\n\n    principal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ssm:GetParameter'],\n      resources: [Stack.of(this).formatArn({\n        // TODO: This is a workaround until https://github.com/awslabs/aws-cdk/pull/1726 is released\n        service: 'ssm',\n        resource: `parameter${this.principal.parameterName}`,\n      })],\n    }));\n  }\n}\n"]}
@@ -39,7 +39,8 @@ if [ -n "${CODE_SIGNING_SECRET_ID:-}" ]; then
39
39
  # Prepare the PEM encoded certificate for sign.sh to use
40
40
  echo "Reading certificate from SSM parameter: ${CODE_SIGNING_PARAMETER_NAME}"
41
41
  signcode_spc="${cert}/certificate.spc"
42
- aws ssm get-parameter --name "${CODE_SIGNING_PARAMETER_NAME}" | jq -r '.Parameter.Value' > "${signcode_spc}.pem"
42
+ CERTIFICATE_LOCATION=$(aws ssm get-parameter --name "/delivlib-test/X509CodeSigningKey/Certificate" | jq -r '.Parameter.Value')
43
+ aws s3 cp "${CERTIFICATE_LOCATION}" "${signcode_spc}.pem"
43
44
  openssl crl2pkcs7 -nocrl -certfile "${signcode_spc}.pem" -outform DER -out "${signcode_spc}"
44
45
  echo "Successfully converted certificate from PEM to DER (.spc)"
45
46
 
package/lib/publishing.js CHANGED
@@ -122,7 +122,7 @@ exports.PublishToNpmProject = PublishToNpmProject;
122
122
  */
123
123
  class PublishToNuGetProject extends constructs_1.Construct {
124
124
  constructor(parent, id, props) {
125
- var _a;
125
+ var _a, _b;
126
126
  super(parent, id);
127
127
  const environment = {};
128
128
  environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();
@@ -136,16 +136,17 @@ class PublishToNuGetProject extends constructs_1.Construct {
136
136
  environment.NUGET_SECRET_REGION = aws_cdk_lib_1.Stack.of(this).region;
137
137
  }
138
138
  environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;
139
- if (props.codeSign) {
140
- environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;
141
- environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;
142
- }
143
139
  const shellable = new shellable_1.Shellable(this, 'Default', {
144
140
  platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('jsii/superchain:1-buster-slim')),
145
141
  scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),
146
142
  entrypoint: 'publish.sh',
147
143
  environment,
148
144
  });
145
+ if (props.codeSign) {
146
+ environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;
147
+ environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;
148
+ (_b = props.codeSign.certificateBucket) === null || _b === void 0 ? void 0 : _b.grantRead(shellable.role);
149
+ }
149
150
  if (shellable.role) {
150
151
  if (props.nugetApiKeySecret.assumeRoleArn) {
151
152
  permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);
@@ -353,4 +354,4 @@ class PublishToGolang extends constructs_1.Construct {
353
354
  }
354
355
  }
355
356
  exports.PublishToGolang = PublishToGolang;
356
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Stack,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam,\n  aws_s3 as s3,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ICodeSigningCertificate } from './code-signing';\nimport { OpenPGPKeyPair } from './open-pgp-key-pair';\nimport * as permissions from './permissions';\nimport { AddToPipelineOptions, IPublisher } from './pipeline';\nimport { WritableGitHubRepo } from './repo';\nimport { LinuxPlatform, Shellable } from './shellable';\nimport { noUndefined } from './util';\n\n/**\n * Type of access permissions to request from npmjs.\n */\nexport enum NpmAccess {\n  /**\n   * No access restriction. Note that unscoped packages must always be public.\n   */\n  PUBLIC = 'public',\n\n  /**\n   * Limit access to whitelisted npmjs users.\n   */\n  RESTRICTED = 'restricted',\n}\n\nexport interface PublishToMavenProjectProps {\n  /**\n   * The signing key itself\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The ID of the sonatype staging profile (e.g. \"68a05363083174\").\n   */\n  stagingProfileId: string;\n\n  /**\n   * Identifier of the secret that contains the Maven login\n   */\n  mavenLoginSecret: permissions.ExternalSecret;\n\n  /**\n   * If true (default) performs a dry-run only instead of actually publishing.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The Maven publishing endpoint to be used.\n   *\n   * @default \"https://oss.sonatype.org\"\n   */\n  mavenEndpoint?: string;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have Maven preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to Maven\n */\nexport class PublishToMavenProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToMavenProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('jsii/superchain:1-buster-slim')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: {\n        STAGING_PROFILE_ID: props.stagingProfileId,\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        FOR_REAL: forReal,\n        MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,\n        MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNpmProjectProps {\n  /**\n   * Identifier of the secret that contains the NPM token\n   */\n  npmTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * npm dist-tag to use when publishing artifacts.\n   *\n   * @default - npm default behavior (\"latest\" unless dist tag is specified in package.json)\n   */\n  distTag?: string;\n\n  /**\n   * npm --access public|restricted\n   *\n   * See https://docs.npmjs.com/cli-commands/publish#:~:text=Tells%20the\n   *\n   * Tells the registry whether this package should be published as public or restricted.\n   * Only applies to scoped packages, which default to restricted.\n   * If you don’t have a paid account, you must publish with --access public to publish scoped packages.\n   *\n   * @default NpmAccess.PUBLIC\n   */\n  access?: NpmAccess;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NPM\n */\nexport class PublishToNpmProject extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNpmProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const access = props.access ?? NpmAccess.PUBLIC;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'npm'),\n      entrypoint: 'publish.sh',\n      environment: {\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNuGetProjectProps {\n  /**\n   * The SecretsManager secret which stores the Nuget API key.\n   */\n  nugetApiKeySecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * A code signing certificate to use to sign assemblies.\n   * @default No signing\n   */\n  codeSign?: ICodeSigningCertificate;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have NuGet preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishToNuGetProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNuGetProjectProps) {\n    super(parent, id);\n\n    const environment: { [key: string]: string } = {};\n\n    environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    if (props.nugetApiKeySecret.assumeRoleArn) {\n      environment.NUGET_ROLE_ARN = props.nugetApiKeySecret.assumeRoleArn;\n    }\n\n    if (props.nugetApiKeySecret.region) {\n      environment.NUGET_SECRET_REGION = props.nugetApiKeySecret.region;\n    } else {\n      environment.NUGET_SECRET_REGION = Stack.of(this).region;\n    }\n\n    environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;\n\n    if (props.codeSign) {\n      environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;\n      environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('jsii/superchain:1-buster-slim')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),\n      entrypoint: 'publish.sh',\n      environment,\n    });\n\n    if (shellable.role) {\n      if (props.nugetApiKeySecret.assumeRoleArn) {\n        permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);\n      } else {\n        permissions.grantSecretRead(props.nugetApiKeySecret, shellable.role);\n      }\n\n      if (props.codeSign) {\n        props.codeSign.grantDecrypt(shellable.role);\n      }\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishDocsToGitHubProjectProps {\n  /**\n   * The repository to publish to\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * GitHub Pages branch to push to.\n   * @default gh-pages\n   */\n  branch?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishDocsToGitHubProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishDocsToGitHubProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'docs'),\n      entrypoint: 'publish.sh',\n      environment: {\n        // Must be SSH because we use an SSH key to authenticate\n        GITHUB_REPO: props.githubRepo.repositoryUrlSsh,\n        GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',\n        SSH_KEY_SECRET: props.githubRepo.sshKeySecret.secretArn,\n        FOR_REAL: forReal,\n        COMMIT_USERNAME: props.githubRepo.commitUsername,\n        COMMIT_EMAIL: props.githubRepo.commitEmail,\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToGitHubProps {\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The repository to create a release in.\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * The signign key to use to create a GPG signature of the artifact.\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * The name of the changelog markdown file, used to create release notes.\n   * Relative to the artifacts root.\n   * @default \"./CHANGELOG.md\"\n   */\n  changelogFileName?: string;\n\n  /**\n   * The name of the release notes file, containing the completed release notes\n   * for the current release.\n   * Relative to the artifacts root.\n   * NOTE - If this value is set and points to a valid file, the file in its entirety\n   * will be read and used for the release notes. The value of `changelogFileName` will\n   * be ignored.\n   * @default \"./RELEASE_NOTES.md\"\n   */\n  releaseNotesFileName?: string;\n\n  /**\n   * Additional input artifacts to publish binaries from to GitHub release\n   */\n  additionalInputArtifacts?: cpipeline.Artifact[];\n\n  /**\n   * Whether to sign the additional artifacts\n   *\n   * @default true\n   */\n  signAdditionalArtifacts?: boolean;\n}\n\nexport class PublishToGitHub extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n  private readonly additionalInputArtifacts?: cpipeline.Artifact[];\n\n  constructor(parent: Construct, id: string, props: PublishToGitHubProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n    this.additionalInputArtifacts = props.additionalInputArtifacts;\n\n    // The release notes, if set and a valid file, overrides any usages of the changelog.\n    if (props.changelogFileName && props.releaseNotesFileName) {\n      throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'github'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        CHANGELOG: props.changelogFileName || './CHANGELOG.md',\n        RELEASE_NOTES: props.releaseNotesFileName || './RELEASE_NOTES.md',\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        GITHUB_OWNER: props.githubRepo.owner,\n        GITHUB_REPO: props.githubRepo.repo,\n        FOR_REAL: forReal,\n        // Transmit the names of the secondary sources to the shell script (for easier iteration)\n        SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,\n        SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,\n      }),\n      environmentSecrets: {\n        GITHUB_TOKEN: props.githubRepo.tokenSecretArn,\n      },\n    });\n\n    // allow script to read the signing key\n    if (shellable.role) {\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      extraInputs: this.additionalInputArtifacts,\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToS3Props {\n  bucket: s3.IBucket;\n\n  /**\n   * Make files publicly readable\n   *\n   * @default false\n   */\n  public?: boolean;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n}\n\nexport class PublishToS3 extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(scope: Construct, id: string, props: PublishToS3Props) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 's3'),\n      entrypoint: 'publish.sh',\n      environment: {\n        BUCKET_URL: `s3://${props.bucket.bucketName}`,\n        CHANGELOG: props.public ? 'true' : 'false',\n        FOR_REAL: forReal,\n      },\n    });\n\n    // Allow script to write to bucket\n    if (shellable.role) {\n      props.bucket.grantReadWrite(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToPyPiProps {\n  /**\n   * Identifier of the secret that contains the PyPI credentials under\n   * \"username\" and \"password\" keys.\n   */\n  loginSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n}\n\nexport class PublishToPyPi extends Construct {\n\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToPyPiProps) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),\n      entrypoint: 'publish.sh',\n      environment: {\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\n/**\n * Props for Go publishing.\n */\nexport interface PublishToGolangProps {\n  /**\n   * Identifier of the secret that contains the GitHub personal access token\n   * used to push the go code to the github repository defined by it's name.\n   *\n   * @see https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token\n   */\n  readonly githubTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * Username to perform the commit with.\n   */\n  readonly gitUserName: string;\n\n  /**\n   * Email to perform the commit with.\n   */\n  readonly gitUserEmail: string;\n\n  /**\n   * Set to \"true\" for a dry run.\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Module version.\n   *\n   * @default - Defaults to the value in the 'version' file of the module\n   * directory. Fails if it doesn't exist.\n   */\n  readonly version?: string;\n\n  /**\n   * Branch to push to.\n   *\n   * @default \"main\"\n   */\n  readonly gitBranch?: string;\n\n  /**\n   * The commit message.\n   *\n   * @default \"chore(release): $VERSION\"\n   */\n  readonly gitCommitMessage?: string;\n}\n\n/**\n * Pushes a directory of golang modules to a GitHub repository.\n */\nexport class PublishToGolang extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToGolangProps) {\n    super(scope, id);\n\n    const dryRun = props.dryRun ?? false;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'golang'),\n      entrypoint: 'publish.sh',\n      environment: {\n        DRYRUN: dryRun ? 'true' : undefined,\n        GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,\n        VERSION: props.version,\n        GIT_BRANCH: props.gitBranch,\n        GIT_USER_NAME: props.gitUserName,\n        GIT_USER_EMAIL: props.gitUserEmail,\n        GIT_COMMIT_MESSAGE: props.gitCommitMessage,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n"]}
357
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Stack,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam,\n  aws_s3 as s3,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ICodeSigningCertificate } from './code-signing';\nimport { OpenPGPKeyPair } from './open-pgp-key-pair';\nimport * as permissions from './permissions';\nimport { AddToPipelineOptions, IPublisher } from './pipeline';\nimport { WritableGitHubRepo } from './repo';\nimport { LinuxPlatform, Shellable } from './shellable';\nimport { noUndefined } from './util';\n\n/**\n * Type of access permissions to request from npmjs.\n */\nexport enum NpmAccess {\n  /**\n   * No access restriction. Note that unscoped packages must always be public.\n   */\n  PUBLIC = 'public',\n\n  /**\n   * Limit access to whitelisted npmjs users.\n   */\n  RESTRICTED = 'restricted',\n}\n\nexport interface PublishToMavenProjectProps {\n  /**\n   * The signing key itself\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The ID of the sonatype staging profile (e.g. \"68a05363083174\").\n   */\n  stagingProfileId: string;\n\n  /**\n   * Identifier of the secret that contains the Maven login\n   */\n  mavenLoginSecret: permissions.ExternalSecret;\n\n  /**\n   * If true (default) performs a dry-run only instead of actually publishing.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The Maven publishing endpoint to be used.\n   *\n   * @default \"https://oss.sonatype.org\"\n   */\n  mavenEndpoint?: string;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have Maven preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to Maven\n */\nexport class PublishToMavenProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToMavenProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('jsii/superchain:1-buster-slim')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: {\n        STAGING_PROFILE_ID: props.stagingProfileId,\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        FOR_REAL: forReal,\n        MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,\n        MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNpmProjectProps {\n  /**\n   * Identifier of the secret that contains the NPM token\n   */\n  npmTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * npm dist-tag to use when publishing artifacts.\n   *\n   * @default - npm default behavior (\"latest\" unless dist tag is specified in package.json)\n   */\n  distTag?: string;\n\n  /**\n   * npm --access public|restricted\n   *\n   * See https://docs.npmjs.com/cli-commands/publish#:~:text=Tells%20the\n   *\n   * Tells the registry whether this package should be published as public or restricted.\n   * Only applies to scoped packages, which default to restricted.\n   * If you don’t have a paid account, you must publish with --access public to publish scoped packages.\n   *\n   * @default NpmAccess.PUBLIC\n   */\n  access?: NpmAccess;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NPM\n */\nexport class PublishToNpmProject extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNpmProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const access = props.access ?? NpmAccess.PUBLIC;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'npm'),\n      entrypoint: 'publish.sh',\n      environment: {\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNuGetProjectProps {\n  /**\n   * The SecretsManager secret which stores the Nuget API key.\n   */\n  nugetApiKeySecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * A code signing certificate to use to sign assemblies.\n   * @default No signing\n   */\n  codeSign?: ICodeSigningCertificate;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have NuGet preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishToNuGetProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNuGetProjectProps) {\n    super(parent, id);\n\n    const environment: { [key: string]: string } = {};\n\n    environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    if (props.nugetApiKeySecret.assumeRoleArn) {\n      environment.NUGET_ROLE_ARN = props.nugetApiKeySecret.assumeRoleArn;\n    }\n\n    if (props.nugetApiKeySecret.region) {\n      environment.NUGET_SECRET_REGION = props.nugetApiKeySecret.region;\n    } else {\n      environment.NUGET_SECRET_REGION = Stack.of(this).region;\n    }\n\n    environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('jsii/superchain:1-buster-slim')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),\n      entrypoint: 'publish.sh',\n      environment,\n    });\n\n    if (props.codeSign) {\n      environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;\n      environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;\n      props.codeSign.certificateBucket?.grantRead(shellable.role);\n    }\n\n    if (shellable.role) {\n      if (props.nugetApiKeySecret.assumeRoleArn) {\n        permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);\n      } else {\n        permissions.grantSecretRead(props.nugetApiKeySecret, shellable.role);\n      }\n\n      if (props.codeSign) {\n        props.codeSign.grantDecrypt(shellable.role);\n      }\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishDocsToGitHubProjectProps {\n  /**\n   * The repository to publish to\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * GitHub Pages branch to push to.\n   * @default gh-pages\n   */\n  branch?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishDocsToGitHubProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishDocsToGitHubProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'docs'),\n      entrypoint: 'publish.sh',\n      environment: {\n        // Must be SSH because we use an SSH key to authenticate\n        GITHUB_REPO: props.githubRepo.repositoryUrlSsh,\n        GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',\n        SSH_KEY_SECRET: props.githubRepo.sshKeySecret.secretArn,\n        FOR_REAL: forReal,\n        COMMIT_USERNAME: props.githubRepo.commitUsername,\n        COMMIT_EMAIL: props.githubRepo.commitEmail,\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToGitHubProps {\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The repository to create a release in.\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * The signign key to use to create a GPG signature of the artifact.\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * The name of the changelog markdown file, used to create release notes.\n   * Relative to the artifacts root.\n   * @default \"./CHANGELOG.md\"\n   */\n  changelogFileName?: string;\n\n  /**\n   * The name of the release notes file, containing the completed release notes\n   * for the current release.\n   * Relative to the artifacts root.\n   * NOTE - If this value is set and points to a valid file, the file in its entirety\n   * will be read and used for the release notes. The value of `changelogFileName` will\n   * be ignored.\n   * @default \"./RELEASE_NOTES.md\"\n   */\n  releaseNotesFileName?: string;\n\n  /**\n   * Additional input artifacts to publish binaries from to GitHub release\n   */\n  additionalInputArtifacts?: cpipeline.Artifact[];\n\n  /**\n   * Whether to sign the additional artifacts\n   *\n   * @default true\n   */\n  signAdditionalArtifacts?: boolean;\n}\n\nexport class PublishToGitHub extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n  private readonly additionalInputArtifacts?: cpipeline.Artifact[];\n\n  constructor(parent: Construct, id: string, props: PublishToGitHubProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n    this.additionalInputArtifacts = props.additionalInputArtifacts;\n\n    // The release notes, if set and a valid file, overrides any usages of the changelog.\n    if (props.changelogFileName && props.releaseNotesFileName) {\n      throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'github'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        CHANGELOG: props.changelogFileName || './CHANGELOG.md',\n        RELEASE_NOTES: props.releaseNotesFileName || './RELEASE_NOTES.md',\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        GITHUB_OWNER: props.githubRepo.owner,\n        GITHUB_REPO: props.githubRepo.repo,\n        FOR_REAL: forReal,\n        // Transmit the names of the secondary sources to the shell script (for easier iteration)\n        SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,\n        SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,\n      }),\n      environmentSecrets: {\n        GITHUB_TOKEN: props.githubRepo.tokenSecretArn,\n      },\n    });\n\n    // allow script to read the signing key\n    if (shellable.role) {\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      extraInputs: this.additionalInputArtifacts,\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToS3Props {\n  bucket: s3.IBucket;\n\n  /**\n   * Make files publicly readable\n   *\n   * @default false\n   */\n  public?: boolean;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n}\n\nexport class PublishToS3 extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(scope: Construct, id: string, props: PublishToS3Props) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 's3'),\n      entrypoint: 'publish.sh',\n      environment: {\n        BUCKET_URL: `s3://${props.bucket.bucketName}`,\n        CHANGELOG: props.public ? 'true' : 'false',\n        FOR_REAL: forReal,\n      },\n    });\n\n    // Allow script to write to bucket\n    if (shellable.role) {\n      props.bucket.grantReadWrite(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToPyPiProps {\n  /**\n   * Identifier of the secret that contains the PyPI credentials under\n   * \"username\" and \"password\" keys.\n   */\n  loginSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n}\n\nexport class PublishToPyPi extends Construct {\n\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToPyPiProps) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),\n      entrypoint: 'publish.sh',\n      environment: {\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\n/**\n * Props for Go publishing.\n */\nexport interface PublishToGolangProps {\n  /**\n   * Identifier of the secret that contains the GitHub personal access token\n   * used to push the go code to the github repository defined by it's name.\n   *\n   * @see https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token\n   */\n  readonly githubTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * Username to perform the commit with.\n   */\n  readonly gitUserName: string;\n\n  /**\n   * Email to perform the commit with.\n   */\n  readonly gitUserEmail: string;\n\n  /**\n   * Set to \"true\" for a dry run.\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Module version.\n   *\n   * @default - Defaults to the value in the 'version' file of the module\n   * directory. Fails if it doesn't exist.\n   */\n  readonly version?: string;\n\n  /**\n   * Branch to push to.\n   *\n   * @default \"main\"\n   */\n  readonly gitBranch?: string;\n\n  /**\n   * The commit message.\n   *\n   * @default \"chore(release): $VERSION\"\n   */\n  readonly gitCommitMessage?: string;\n}\n\n/**\n * Pushes a directory of golang modules to a GitHub repository.\n */\nexport class PublishToGolang extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToGolangProps) {\n    super(scope, id);\n\n    const dryRun = props.dryRun ?? false;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_5_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'golang'),\n      entrypoint: 'publish.sh',\n      environment: {\n        DRYRUN: dryRun ? 'true' : undefined,\n        GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,\n        VERSION: props.version,\n        GIT_BRANCH: props.gitBranch,\n        GIT_USER_NAME: props.gitUserName,\n        GIT_USER_EMAIL: props.gitUserEmail,\n        GIT_COMMIT_MESSAGE: props.gitCommitMessage,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n"]}
package/package.json CHANGED
@@ -91,7 +91,7 @@
91
91
  },
92
92
  "main": "lib/index.js",
93
93
  "license": "Apache-2.0",
94
- "version": "14.1.97",
94
+ "version": "14.1.98",
95
95
  "jest": {
96
96
  "testMatch": [
97
97
  "**/lib/__tests__/**/?(*.)+(spec|test).js?(x)"