@jjrawlins/cdk-diff-pr-github-action 0.0.72 → 1.0.0

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.
@@ -176,7 +176,7 @@ class CdkDriftDetectionWorkflow {
176
176
  }
177
177
  exports.CdkDriftDetectionWorkflow = CdkDriftDetectionWorkflow;
178
178
  _a = JSII_RTTI_SYMBOL_1;
179
- CdkDriftDetectionWorkflow[_a] = { fqn: "@jjrawlins/cdk-diff-pr-github-action.CdkDriftDetectionWorkflow", version: "0.0.72" };
179
+ CdkDriftDetectionWorkflow[_a] = { fqn: "@jjrawlins/cdk-diff-pr-github-action.CdkDriftDetectionWorkflow", version: "1.0.0" };
180
180
  CdkDriftDetectionWorkflow.scriptCreated = false;
181
181
  function issueScript(stack, region, resultsFile) {
182
182
  // Construct a plain JS script string (no template string nesting mishaps)
@@ -1,10 +1,43 @@
1
- export interface CdkDriftIamTemplateProps {
2
- readonly project: any;
1
+ /**
2
+ * Props for generating CDK Drift IAM templates (no Projen dependency)
3
+ */
4
+ export interface CdkDriftIamTemplateGeneratorProps {
5
+ /** Name for the IAM role */
3
6
  readonly roleName: string;
4
- readonly outputPath?: string;
7
+ /** ARN of the existing GitHub OIDC role that can assume this drift role */
5
8
  readonly oidcRoleArn: string;
9
+ /** Region for the OIDC trust condition */
6
10
  readonly oidcRegion: string;
7
11
  }
12
+ /**
13
+ * Pure generator class for CDK Drift IAM templates.
14
+ * No Projen dependency - can be used in any project.
15
+ */
16
+ export declare class CdkDriftIamTemplateGenerator {
17
+ /**
18
+ * Generate the CloudFormation IAM template as a YAML string.
19
+ */
20
+ static generateTemplate(props: CdkDriftIamTemplateGeneratorProps): string;
21
+ /**
22
+ * Generate the AWS CLI deploy command for the IAM template.
23
+ */
24
+ static generateDeployCommand(templatePath?: string): string;
25
+ }
26
+ /**
27
+ * Props for the Projen-integrated CDK Drift IAM template construct
28
+ */
29
+ export interface CdkDriftIamTemplateProps extends CdkDriftIamTemplateGeneratorProps {
30
+ /** Projen project instance */
31
+ readonly project: any;
32
+ /** Output path for the template file (default: 'cdk-drift-workflow-iam-template.yaml') */
33
+ readonly outputPath?: string;
34
+ }
35
+ /**
36
+ * Projen construct that emits a CloudFormation template with minimal IAM permissions
37
+ * for the CDK Drift Detection Workflow.
38
+ *
39
+ * For non-Projen projects, use `CdkDriftIamTemplateGenerator` directly.
40
+ */
8
41
  export declare class CdkDriftIamTemplate {
9
42
  constructor(props: CdkDriftIamTemplateProps);
10
43
  }
@@ -1,77 +1,106 @@
1
1
  "use strict";
2
- var _a;
2
+ var _a, _b;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.CdkDriftIamTemplate = void 0;
4
+ exports.CdkDriftIamTemplate = exports.CdkDriftIamTemplateGenerator = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const projen_1 = require("projen");
7
+ /**
8
+ * Pure generator class for CDK Drift IAM templates.
9
+ * No Projen dependency - can be used in any project.
10
+ */
11
+ class CdkDriftIamTemplateGenerator {
12
+ /**
13
+ * Generate the CloudFormation IAM template as a YAML string.
14
+ */
15
+ static generateTemplate(props) {
16
+ const lines = [
17
+ "AWSTemplateFormatVersion: '2010-09-09'",
18
+ "Description: 'IAM role for CDK Drift Detection Workflow'",
19
+ '',
20
+ 'Parameters:',
21
+ ' GitHubOIDCRoleArn:',
22
+ ' Type: String',
23
+ " Description: 'ARN of the existing GitHub OIDC role that can assume this drift role'",
24
+ ` Default: '${props.oidcRoleArn}'`,
25
+ '',
26
+ 'Resources:',
27
+ ' # CloudFormation Drift Detection Role - minimal permissions for drift detection operations',
28
+ ' CdkDriftRole:',
29
+ ' Type: AWS::IAM::Role',
30
+ ' Properties:',
31
+ " RoleName: '" + props.roleName + "'",
32
+ ' AssumeRolePolicyDocument:',
33
+ " Version: '2012-10-17'",
34
+ ' Statement:',
35
+ ' - Effect: Allow',
36
+ ' Principal:',
37
+ ' AWS: !Ref GitHubOIDCRoleArn',
38
+ ' Action: sts:AssumeRole',
39
+ ' Condition:',
40
+ ' StringEquals:',
41
+ " aws:RequestedRegion: '" + props.oidcRegion + "'",
42
+ ' Policies:',
43
+ ' - PolicyName: CloudFormationDriftAccess',
44
+ ' PolicyDocument:',
45
+ " Version: '2012-10-17'",
46
+ ' Statement:',
47
+ ' # CloudFormation drift detection operations',
48
+ ' - Effect: Allow',
49
+ ' Action:',
50
+ ' - cloudformation:DetectStackDrift',
51
+ ' - cloudformation:DescribeStackDriftDetectionStatus',
52
+ ' - cloudformation:DescribeStackResourceDrifts',
53
+ ' - cloudformation:DescribeStacks',
54
+ ' - cloudformation:ListStackResources',
55
+ ' - cloudformation:DetectStackResourceDrift',
56
+ " Resource: '*'",
57
+ '',
58
+ 'Outputs:',
59
+ ' CdkDriftRoleArn:',
60
+ " Description: 'ARN of the CDK drift detection role'",
61
+ ' Value: !GetAtt CdkDriftRole.Arn',
62
+ ' Export:',
63
+ " Name: !Sub '${AWS::StackName}-CdkDriftRoleArn'",
64
+ '',
65
+ ' CdkDriftRoleName:',
66
+ " Description: 'Name of the CDK drift detection role'",
67
+ ' Value: !Ref CdkDriftRole',
68
+ ' Export:',
69
+ " Name: !Sub '${AWS::StackName}-CdkDriftRoleName'",
70
+ ];
71
+ return lines.join('\n');
72
+ }
73
+ /**
74
+ * Generate the AWS CLI deploy command for the IAM template.
75
+ */
76
+ static generateDeployCommand(templatePath = 'cdk-drift-workflow-iam-template.yaml') {
77
+ return `aws cloudformation deploy --template-file ${templatePath} --stack-name cdk-drift-workflow-iam-role --capabilities CAPABILITY_NAMED_IAM`;
78
+ }
79
+ }
80
+ exports.CdkDriftIamTemplateGenerator = CdkDriftIamTemplateGenerator;
81
+ _a = JSII_RTTI_SYMBOL_1;
82
+ CdkDriftIamTemplateGenerator[_a] = { fqn: "@jjrawlins/cdk-diff-pr-github-action.CdkDriftIamTemplateGenerator", version: "1.0.0" };
83
+ /**
84
+ * Projen construct that emits a CloudFormation template with minimal IAM permissions
85
+ * for the CDK Drift Detection Workflow.
86
+ *
87
+ * For non-Projen projects, use `CdkDriftIamTemplateGenerator` directly.
88
+ */
7
89
  class CdkDriftIamTemplate {
8
90
  constructor(props) {
9
91
  const outputPath = props.outputPath ?? 'cdk-drift-workflow-iam-template.yaml';
92
+ // Generate template using the generator
93
+ const template = CdkDriftIamTemplateGenerator.generateTemplate(props);
94
+ new projen_1.TextFile(props.project, outputPath, { lines: template.split('\n') });
95
+ // Add deploy task
10
96
  props.project.addTask('deploy-cdkdrift-iam-template', {
11
97
  description: 'Deploy the CDK Drift Detection IAM template via CloudFormation (accepts extra AWS CLI args, e.g., --parameter-overrides Key=Value...)',
12
98
  receiveArgs: true,
13
- exec: `aws cloudformation deploy --template-file ${outputPath} --stack-name cdk-drift-workflow-iam-role --capabilities CAPABILITY_NAMED_IAM`,
14
- });
15
- new projen_1.TextFile(props.project, outputPath, {
16
- lines: [
17
- "AWSTemplateFormatVersion: '2010-09-09'",
18
- "Description: 'IAM role for CDK Drift Detection Workflow'",
19
- '',
20
- 'Parameters:',
21
- ' GitHubOIDCRoleArn:',
22
- ' Type: String',
23
- " Description: 'ARN of the existing GitHub OIDC role that can assume this drift role'",
24
- ` Default: '${props.oidcRoleArn}'`,
25
- '',
26
- 'Resources:',
27
- ' # CloudFormation Drift Detection Role - minimal permissions for drift detection operations',
28
- ' CdkDriftRole:',
29
- ' Type: AWS::IAM::Role',
30
- ' Properties:',
31
- " RoleName: '" + props.roleName + "'",
32
- ' AssumeRolePolicyDocument:',
33
- " Version: '2012-10-17'",
34
- ' Statement:',
35
- ' - Effect: Allow',
36
- ' Principal:',
37
- ' AWS: !Ref GitHubOIDCRoleArn',
38
- ' Action: sts:AssumeRole',
39
- ' Condition:',
40
- ' StringEquals:',
41
- " aws:RequestedRegion: '" + props.oidcRegion + "'",
42
- ' Policies:',
43
- ' - PolicyName: CloudFormationDriftAccess',
44
- ' PolicyDocument:',
45
- " Version: '2012-10-17'",
46
- ' Statement:',
47
- ' # CloudFormation drift detection operations',
48
- ' - Effect: Allow',
49
- ' Action:',
50
- ' - cloudformation:DetectStackDrift',
51
- ' - cloudformation:DescribeStackDriftDetectionStatus',
52
- ' - cloudformation:DescribeStackResourceDrifts',
53
- ' - cloudformation:DescribeStacks',
54
- ' - cloudformation:ListStackResources',
55
- ' - cloudformation:DetectStackResourceDrift',
56
- " Resource: '*'",
57
- '',
58
- 'Outputs:',
59
- ' CdkDriftRoleArn:',
60
- " Description: 'ARN of the CDK drift detection role'",
61
- ' Value: !GetAtt CdkDriftRole.Arn',
62
- ' Export:',
63
- " Name: !Sub '${AWS::StackName}-CdkDriftRoleArn'",
64
- '',
65
- ' CdkDriftRoleName:',
66
- " Description: 'Name of the CDK drift detection role'",
67
- ' Value: !Ref CdkDriftRole',
68
- ' Export:',
69
- " Name: !Sub '${AWS::StackName}-CdkDriftRoleName'",
70
- ],
99
+ exec: CdkDriftIamTemplateGenerator.generateDeployCommand(outputPath),
71
100
  });
72
101
  }
73
102
  }
74
103
  exports.CdkDriftIamTemplate = CdkDriftIamTemplate;
75
- _a = JSII_RTTI_SYMBOL_1;
76
- CdkDriftIamTemplate[_a] = { fqn: "@jjrawlins/cdk-diff-pr-github-action.CdkDriftIamTemplate", version: "0.0.72" };
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2RrRHJpZnRJYW1UZW1wbGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9DZGtEcmlmdElhbVRlbXBsYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQWtDO0FBVWxDLE1BQWEsbUJBQW1CO0lBQzlCLFlBQVksS0FBK0I7UUFDekMsTUFBTSxVQUFVLEdBQUcsS0FBSyxDQUFDLFVBQVUsSUFBSSxzQ0FBc0MsQ0FBQztRQUU5RSxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyw4QkFBOEIsRUFBRTtZQUNwRCxXQUFXLEVBQ1QsdUlBQXVJO1lBQ3pJLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLElBQUksRUFDRiw2Q0FBNkMsVUFBVSwrRUFBK0U7U0FDekksQ0FBQyxDQUFDO1FBRUgsSUFBSSxpQkFBUSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFO1lBQ3RDLEtBQUssRUFBRTtnQkFDTCx3Q0FBd0M7Z0JBQ3hDLDBEQUEwRDtnQkFDMUQsRUFBRTtnQkFDRixhQUFhO2dCQUNiLHNCQUFzQjtnQkFDdEIsa0JBQWtCO2dCQUNsQix5RkFBeUY7Z0JBQ3pGLGlCQUFpQixLQUFLLENBQUMsV0FBVyxHQUFHO2dCQUNyQyxFQUFFO2dCQUNGLFlBQVk7Z0JBQ1osOEZBQThGO2dCQUM5RixpQkFBaUI7Z0JBQ2pCLDBCQUEwQjtnQkFDMUIsaUJBQWlCO2dCQUNqQixtQkFBbUIsR0FBRyxLQUFLLENBQUMsUUFBUSxHQUFHLEdBQUc7Z0JBQzFDLGlDQUFpQztnQkFDakMsK0JBQStCO2dCQUMvQixvQkFBb0I7Z0JBQ3BCLDJCQUEyQjtnQkFDM0Isd0JBQXdCO2dCQUN4QiwyQ0FBMkM7Z0JBQzNDLG9DQUFvQztnQkFDcEMsd0JBQXdCO2dCQUN4Qiw2QkFBNkI7Z0JBQzdCLHdDQUF3QyxHQUFHLEtBQUssQ0FBQyxVQUFVLEdBQUcsR0FBRztnQkFDakUsaUJBQWlCO2dCQUNqQixpREFBaUQ7Z0JBQ2pELDJCQUEyQjtnQkFDM0IsbUNBQW1DO2dCQUNuQyx3QkFBd0I7Z0JBQ3hCLDJEQUEyRDtnQkFDM0QsK0JBQStCO2dCQUMvQix5QkFBeUI7Z0JBQ3pCLHFEQUFxRDtnQkFDckQsc0VBQXNFO2dCQUN0RSxnRUFBZ0U7Z0JBQ2hFLG1EQUFtRDtnQkFDbkQsdURBQXVEO2dCQUN2RCw2REFBNkQ7Z0JBQzdELCtCQUErQjtnQkFDL0IsRUFBRTtnQkFDRixVQUFVO2dCQUNWLG9CQUFvQjtnQkFDcEIsd0RBQXdEO2dCQUN4RCxxQ0FBcUM7Z0JBQ3JDLGFBQWE7Z0JBQ2Isc0RBQXNEO2dCQUN0RCxFQUFFO2dCQUNGLHFCQUFxQjtnQkFDckIseURBQXlEO2dCQUN6RCw4QkFBOEI7Z0JBQzlCLGFBQWE7Z0JBQ2IsdURBQXVEO2FBQ3hEO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFyRUgsa0RBc0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGV4dEZpbGUgfSBmcm9tICdwcm9qZW4nO1xuXG5leHBvcnQgaW50ZXJmYWNlIENka0RyaWZ0SWFtVGVtcGxhdGVQcm9wcyB7XG4gIHJlYWRvbmx5IHByb2plY3Q6IGFueTtcbiAgcmVhZG9ubHkgcm9sZU5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgb3V0cHV0UGF0aD86IHN0cmluZztcbiAgcmVhZG9ubHkgb2lkY1JvbGVBcm46IHN0cmluZztcbiAgcmVhZG9ubHkgb2lkY1JlZ2lvbjogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgQ2RrRHJpZnRJYW1UZW1wbGF0ZSB7XG4gIGNvbnN0cnVjdG9yKHByb3BzOiBDZGtEcmlmdElhbVRlbXBsYXRlUHJvcHMpIHtcbiAgICBjb25zdCBvdXRwdXRQYXRoID0gcHJvcHMub3V0cHV0UGF0aCA/PyAnY2RrLWRyaWZ0LXdvcmtmbG93LWlhbS10ZW1wbGF0ZS55YW1sJztcblxuICAgIHByb3BzLnByb2plY3QuYWRkVGFzaygnZGVwbG95LWNka2RyaWZ0LWlhbS10ZW1wbGF0ZScsIHtcbiAgICAgIGRlc2NyaXB0aW9uOlxuICAgICAgICAnRGVwbG95IHRoZSBDREsgRHJpZnQgRGV0ZWN0aW9uIElBTSB0ZW1wbGF0ZSB2aWEgQ2xvdWRGb3JtYXRpb24gKGFjY2VwdHMgZXh0cmEgQVdTIENMSSBhcmdzLCBlLmcuLCAtLXBhcmFtZXRlci1vdmVycmlkZXMgS2V5PVZhbHVlLi4uKScsXG4gICAgICByZWNlaXZlQXJnczogdHJ1ZSxcbiAgICAgIGV4ZWM6XG4gICAgICAgIGBhd3MgY2xvdWRmb3JtYXRpb24gZGVwbG95IC0tdGVtcGxhdGUtZmlsZSAke291dHB1dFBhdGh9IC0tc3RhY2stbmFtZSBjZGstZHJpZnQtd29ya2Zsb3ctaWFtLXJvbGUgLS1jYXBhYmlsaXRpZXMgQ0FQQUJJTElUWV9OQU1FRF9JQU1gLFxuICAgIH0pO1xuXG4gICAgbmV3IFRleHRGaWxlKHByb3BzLnByb2plY3QsIG91dHB1dFBhdGgsIHtcbiAgICAgIGxpbmVzOiBbXG4gICAgICAgIFwiQVdTVGVtcGxhdGVGb3JtYXRWZXJzaW9uOiAnMjAxMC0wOS0wOSdcIixcbiAgICAgICAgXCJEZXNjcmlwdGlvbjogJ0lBTSByb2xlIGZvciBDREsgRHJpZnQgRGV0ZWN0aW9uIFdvcmtmbG93J1wiLFxuICAgICAgICAnJyxcbiAgICAgICAgJ1BhcmFtZXRlcnM6JyxcbiAgICAgICAgJyAgR2l0SHViT0lEQ1JvbGVBcm46JyxcbiAgICAgICAgJyAgICBUeXBlOiBTdHJpbmcnLFxuICAgICAgICBcIiAgICBEZXNjcmlwdGlvbjogJ0FSTiBvZiB0aGUgZXhpc3RpbmcgR2l0SHViIE9JREMgcm9sZSB0aGF0IGNhbiBhc3N1bWUgdGhpcyBkcmlmdCByb2xlJ1wiLFxuICAgICAgICBgICAgIERlZmF1bHQ6ICcke3Byb3BzLm9pZGNSb2xlQXJufSdgLFxuICAgICAgICAnJyxcbiAgICAgICAgJ1Jlc291cmNlczonLFxuICAgICAgICAnICAjIENsb3VkRm9ybWF0aW9uIERyaWZ0IERldGVjdGlvbiBSb2xlIC0gbWluaW1hbCBwZXJtaXNzaW9ucyBmb3IgZHJpZnQgZGV0ZWN0aW9uIG9wZXJhdGlvbnMnLFxuICAgICAgICAnICBDZGtEcmlmdFJvbGU6JyxcbiAgICAgICAgJyAgICBUeXBlOiBBV1M6OklBTTo6Um9sZScsXG4gICAgICAgICcgICAgUHJvcGVydGllczonLFxuICAgICAgICBcIiAgICAgIFJvbGVOYW1lOiAnXCIgKyBwcm9wcy5yb2xlTmFtZSArIFwiJ1wiLFxuICAgICAgICAnICAgICAgQXNzdW1lUm9sZVBvbGljeURvY3VtZW50OicsXG4gICAgICAgIFwiICAgICAgICBWZXJzaW9uOiAnMjAxMi0xMC0xNydcIixcbiAgICAgICAgJyAgICAgICAgU3RhdGVtZW50OicsXG4gICAgICAgICcgICAgICAgICAgLSBFZmZlY3Q6IEFsbG93JyxcbiAgICAgICAgJyAgICAgICAgICAgIFByaW5jaXBhbDonLFxuICAgICAgICAnICAgICAgICAgICAgICBBV1M6ICFSZWYgR2l0SHViT0lEQ1JvbGVBcm4nLFxuICAgICAgICAnICAgICAgICAgICAgQWN0aW9uOiBzdHM6QXNzdW1lUm9sZScsXG4gICAgICAgICcgICAgICAgICAgICBDb25kaXRpb246JyxcbiAgICAgICAgJyAgICAgICAgICAgICAgU3RyaW5nRXF1YWxzOicsXG4gICAgICAgIFwiICAgICAgICAgICAgICAgIGF3czpSZXF1ZXN0ZWRSZWdpb246ICdcIiArIHByb3BzLm9pZGNSZWdpb24gKyBcIidcIixcbiAgICAgICAgJyAgICAgIFBvbGljaWVzOicsXG4gICAgICAgICcgICAgICAgIC0gUG9saWN5TmFtZTogQ2xvdWRGb3JtYXRpb25EcmlmdEFjY2VzcycsXG4gICAgICAgICcgICAgICAgICAgUG9saWN5RG9jdW1lbnQ6JyxcbiAgICAgICAgXCIgICAgICAgICAgICBWZXJzaW9uOiAnMjAxMi0xMC0xNydcIixcbiAgICAgICAgJyAgICAgICAgICAgIFN0YXRlbWVudDonLFxuICAgICAgICAnICAgICAgICAgICAgICAjIENsb3VkRm9ybWF0aW9uIGRyaWZ0IGRldGVjdGlvbiBvcGVyYXRpb25zJyxcbiAgICAgICAgJyAgICAgICAgICAgICAgLSBFZmZlY3Q6IEFsbG93JyxcbiAgICAgICAgJyAgICAgICAgICAgICAgICBBY3Rpb246JyxcbiAgICAgICAgJyAgICAgICAgICAgICAgICAgIC0gY2xvdWRmb3JtYXRpb246RGV0ZWN0U3RhY2tEcmlmdCcsXG4gICAgICAgICcgICAgICAgICAgICAgICAgICAtIGNsb3VkZm9ybWF0aW9uOkRlc2NyaWJlU3RhY2tEcmlmdERldGVjdGlvblN0YXR1cycsXG4gICAgICAgICcgICAgICAgICAgICAgICAgICAtIGNsb3VkZm9ybWF0aW9uOkRlc2NyaWJlU3RhY2tSZXNvdXJjZURyaWZ0cycsXG4gICAgICAgICcgICAgICAgICAgICAgICAgICAtIGNsb3VkZm9ybWF0aW9uOkRlc2NyaWJlU3RhY2tzJyxcbiAgICAgICAgJyAgICAgICAgICAgICAgICAgIC0gY2xvdWRmb3JtYXRpb246TGlzdFN0YWNrUmVzb3VyY2VzJyxcbiAgICAgICAgJyAgICAgICAgICAgICAgICAgIC0gY2xvdWRmb3JtYXRpb246RGV0ZWN0U3RhY2tSZXNvdXJjZURyaWZ0JyxcbiAgICAgICAgXCIgICAgICAgICAgICAgICAgUmVzb3VyY2U6ICcqJ1wiLFxuICAgICAgICAnJyxcbiAgICAgICAgJ091dHB1dHM6JyxcbiAgICAgICAgJyAgQ2RrRHJpZnRSb2xlQXJuOicsXG4gICAgICAgIFwiICAgIERlc2NyaXB0aW9uOiAnQVJOIG9mIHRoZSBDREsgZHJpZnQgZGV0ZWN0aW9uIHJvbGUnXCIsXG4gICAgICAgICcgICAgVmFsdWU6ICFHZXRBdHQgQ2RrRHJpZnRSb2xlLkFybicsXG4gICAgICAgICcgICAgRXhwb3J0OicsXG4gICAgICAgIFwiICAgICAgTmFtZTogIVN1YiAnJHtBV1M6OlN0YWNrTmFtZX0tQ2RrRHJpZnRSb2xlQXJuJ1wiLFxuICAgICAgICAnJyxcbiAgICAgICAgJyAgQ2RrRHJpZnRSb2xlTmFtZTonLFxuICAgICAgICBcIiAgICBEZXNjcmlwdGlvbjogJ05hbWUgb2YgdGhlIENESyBkcmlmdCBkZXRlY3Rpb24gcm9sZSdcIixcbiAgICAgICAgJyAgICBWYWx1ZTogIVJlZiBDZGtEcmlmdFJvbGUnLFxuICAgICAgICAnICAgIEV4cG9ydDonLFxuICAgICAgICBcIiAgICAgIE5hbWU6ICFTdWIgJyR7QVdTOjpTdGFja05hbWV9LUNka0RyaWZ0Um9sZU5hbWUnXCIsXG4gICAgICBdLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
104
+ _b = JSII_RTTI_SYMBOL_1;
105
+ CdkDriftIamTemplate[_b] = { fqn: "@jjrawlins/cdk-diff-pr-github-action.CdkDriftIamTemplate", version: "1.0.0" };
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CdkDriftIamTemplate.js","sourceRoot":"","sources":["../src/CdkDriftIamTemplate.ts"],"names":[],"mappings":";;;;;AAAA,mCAAkC;AAclC;;;GAGG;AACH,MAAa,4BAA4B;IACvC;;OAEG;IACH,MAAM,CAAC,gBAAgB,CAAC,KAAwC;QAC9D,MAAM,KAAK,GAAG;YACZ,wCAAwC;YACxC,0DAA0D;YAC1D,EAAE;YACF,aAAa;YACb,sBAAsB;YACtB,kBAAkB;YAClB,yFAAyF;YACzF,iBAAiB,KAAK,CAAC,WAAW,GAAG;YACrC,EAAE;YACF,YAAY;YACZ,8FAA8F;YAC9F,iBAAiB;YACjB,0BAA0B;YAC1B,iBAAiB;YACjB,mBAAmB,GAAG,KAAK,CAAC,QAAQ,GAAG,GAAG;YAC1C,iCAAiC;YACjC,+BAA+B;YAC/B,oBAAoB;YACpB,2BAA2B;YAC3B,wBAAwB;YACxB,2CAA2C;YAC3C,oCAAoC;YACpC,wBAAwB;YACxB,6BAA6B;YAC7B,wCAAwC,GAAG,KAAK,CAAC,UAAU,GAAG,GAAG;YACjE,iBAAiB;YACjB,iDAAiD;YACjD,2BAA2B;YAC3B,mCAAmC;YACnC,wBAAwB;YACxB,2DAA2D;YAC3D,+BAA+B;YAC/B,yBAAyB;YACzB,qDAAqD;YACrD,sEAAsE;YACtE,gEAAgE;YAChE,mDAAmD;YACnD,uDAAuD;YACvD,6DAA6D;YAC7D,+BAA+B;YAC/B,EAAE;YACF,UAAU;YACV,oBAAoB;YACpB,wDAAwD;YACxD,qCAAqC;YACrC,aAAa;YACb,sDAAsD;YACtD,EAAE;YACF,qBAAqB;YACrB,yDAAyD;YACzD,8BAA8B;YAC9B,aAAa;YACb,uDAAuD;SACxD,CAAC;QAEF,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,qBAAqB,CAAC,eAAuB,sCAAsC;QACxF,OAAO,6CAA6C,YAAY,+EAA+E,CAAC;IAClJ,CAAC;;AArEH,oEAsEC;;;AAYD;;;;;GAKG;AACH,MAAa,mBAAmB;IAC9B,YAAY,KAA+B;QACzC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,IAAI,sCAAsC,CAAC;QAE9E,wCAAwC;QACxC,MAAM,QAAQ,GAAG,4BAA4B,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACtE,IAAI,iBAAQ,CAAC,KAAK,CAAC,OAAO,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEzE,kBAAkB;QAClB,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,8BAA8B,EAAE;YACpD,WAAW,EACT,uIAAuI;YACzI,WAAW,EAAE,IAAI;YACjB,IAAI,EAAE,4BAA4B,CAAC,qBAAqB,CAAC,UAAU,CAAC;SACrE,CAAC,CAAC;IACL,CAAC;;AAfH,kDAgBC","sourcesContent":["import { TextFile } from 'projen';\n\n/**\n * Props for generating CDK Drift IAM templates (no Projen dependency)\n */\nexport interface CdkDriftIamTemplateGeneratorProps {\n  /** Name for the IAM role */\n  readonly roleName: string;\n  /** ARN of the existing GitHub OIDC role that can assume this drift role */\n  readonly oidcRoleArn: string;\n  /** Region for the OIDC trust condition */\n  readonly oidcRegion: string;\n}\n\n/**\n * Pure generator class for CDK Drift IAM templates.\n * No Projen dependency - can be used in any project.\n */\nexport class CdkDriftIamTemplateGenerator {\n  /**\n   * Generate the CloudFormation IAM template as a YAML string.\n   */\n  static generateTemplate(props: CdkDriftIamTemplateGeneratorProps): string {\n    const lines = [\n      \"AWSTemplateFormatVersion: '2010-09-09'\",\n      \"Description: 'IAM role for CDK Drift Detection Workflow'\",\n      '',\n      'Parameters:',\n      '  GitHubOIDCRoleArn:',\n      '    Type: String',\n      \"    Description: 'ARN of the existing GitHub OIDC role that can assume this drift role'\",\n      `    Default: '${props.oidcRoleArn}'`,\n      '',\n      'Resources:',\n      '  # CloudFormation Drift Detection Role - minimal permissions for drift detection operations',\n      '  CdkDriftRole:',\n      '    Type: AWS::IAM::Role',\n      '    Properties:',\n      \"      RoleName: '\" + props.roleName + \"'\",\n      '      AssumeRolePolicyDocument:',\n      \"        Version: '2012-10-17'\",\n      '        Statement:',\n      '          - Effect: Allow',\n      '            Principal:',\n      '              AWS: !Ref GitHubOIDCRoleArn',\n      '            Action: sts:AssumeRole',\n      '            Condition:',\n      '              StringEquals:',\n      \"                aws:RequestedRegion: '\" + props.oidcRegion + \"'\",\n      '      Policies:',\n      '        - PolicyName: CloudFormationDriftAccess',\n      '          PolicyDocument:',\n      \"            Version: '2012-10-17'\",\n      '            Statement:',\n      '              # CloudFormation drift detection operations',\n      '              - Effect: Allow',\n      '                Action:',\n      '                  - cloudformation:DetectStackDrift',\n      '                  - cloudformation:DescribeStackDriftDetectionStatus',\n      '                  - cloudformation:DescribeStackResourceDrifts',\n      '                  - cloudformation:DescribeStacks',\n      '                  - cloudformation:ListStackResources',\n      '                  - cloudformation:DetectStackResourceDrift',\n      \"                Resource: '*'\",\n      '',\n      'Outputs:',\n      '  CdkDriftRoleArn:',\n      \"    Description: 'ARN of the CDK drift detection role'\",\n      '    Value: !GetAtt CdkDriftRole.Arn',\n      '    Export:',\n      \"      Name: !Sub '${AWS::StackName}-CdkDriftRoleArn'\",\n      '',\n      '  CdkDriftRoleName:',\n      \"    Description: 'Name of the CDK drift detection role'\",\n      '    Value: !Ref CdkDriftRole',\n      '    Export:',\n      \"      Name: !Sub '${AWS::StackName}-CdkDriftRoleName'\",\n    ];\n\n    return lines.join('\\n');\n  }\n\n  /**\n   * Generate the AWS CLI deploy command for the IAM template.\n   */\n  static generateDeployCommand(templatePath: string = 'cdk-drift-workflow-iam-template.yaml'): string {\n    return `aws cloudformation deploy --template-file ${templatePath} --stack-name cdk-drift-workflow-iam-role --capabilities CAPABILITY_NAMED_IAM`;\n  }\n}\n\n/**\n * Props for the Projen-integrated CDK Drift IAM template construct\n */\nexport interface CdkDriftIamTemplateProps extends CdkDriftIamTemplateGeneratorProps {\n  /** Projen project instance */\n  readonly project: any;\n  /** Output path for the template file (default: 'cdk-drift-workflow-iam-template.yaml') */\n  readonly outputPath?: string;\n}\n\n/**\n * Projen construct that emits a CloudFormation template with minimal IAM permissions\n * for the CDK Drift Detection Workflow.\n *\n * For non-Projen projects, use `CdkDriftIamTemplateGenerator` directly.\n */\nexport class CdkDriftIamTemplate {\n  constructor(props: CdkDriftIamTemplateProps) {\n    const outputPath = props.outputPath ?? 'cdk-drift-workflow-iam-template.yaml';\n\n    // Generate template using the generator\n    const template = CdkDriftIamTemplateGenerator.generateTemplate(props);\n    new TextFile(props.project, outputPath, { lines: template.split('\\n') });\n\n    // Add deploy task\n    props.project.addTask('deploy-cdkdrift-iam-template', {\n      description:\n        'Deploy the CDK Drift Detection IAM template via CloudFormation (accepts extra AWS CLI args, e.g., --parameter-overrides Key=Value...)',\n      receiveArgs: true,\n      exec: CdkDriftIamTemplateGenerator.generateDeployCommand(outputPath),\n    });\n  }\n}\n"]}
package/lib/index.d.ts CHANGED
@@ -2,3 +2,4 @@ export * from './CdkDiffStackWorkflow';
2
2
  export * from './CdkDiffIamTemplate';
3
3
  export * from './CdkDriftIamTemplate';
4
4
  export * from './CdkDriftDetectionWorkflow';
5
+ export * from './CdkDiffIamTemplateStackSet';
package/lib/index.js CHANGED
@@ -18,4 +18,5 @@ __exportStar(require("./CdkDiffStackWorkflow"), exports);
18
18
  __exportStar(require("./CdkDiffIamTemplate"), exports);
19
19
  __exportStar(require("./CdkDriftIamTemplate"), exports);
20
20
  __exportStar(require("./CdkDriftDetectionWorkflow"), exports);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHlEQUF1QztBQUN2Qyx1REFBcUM7QUFDckMsd0RBQXNDO0FBQ3RDLDhEQUE0QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vQ2RrRGlmZlN0YWNrV29ya2Zsb3cnO1xuZXhwb3J0ICogZnJvbSAnLi9DZGtEaWZmSWFtVGVtcGxhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9DZGtEcmlmdElhbVRlbXBsYXRlJztcbmV4cG9ydCAqIGZyb20gJy4vQ2RrRHJpZnREZXRlY3Rpb25Xb3JrZmxvdyc7XG4iXX0=
21
+ __exportStar(require("./CdkDiffIamTemplateStackSet"), exports);
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHlEQUF1QztBQUN2Qyx1REFBcUM7QUFDckMsd0RBQXNDO0FBQ3RDLDhEQUE0QztBQUM1QywrREFBNkMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL0Nka0RpZmZTdGFja1dvcmtmbG93JztcbmV4cG9ydCAqIGZyb20gJy4vQ2RrRGlmZklhbVRlbXBsYXRlJztcbmV4cG9ydCAqIGZyb20gJy4vQ2RrRHJpZnRJYW1UZW1wbGF0ZSc7XG5leHBvcnQgKiBmcm9tICcuL0Nka0RyaWZ0RGV0ZWN0aW9uV29ya2Zsb3cnO1xuZXhwb3J0ICogZnJvbSAnLi9DZGtEaWZmSWFtVGVtcGxhdGVTdGFja1NldCc7XG4iXX0=
package/package.json CHANGED
@@ -108,7 +108,7 @@
108
108
  "publishConfig": {
109
109
  "access": "public"
110
110
  },
111
- "version": "0.0.72",
111
+ "version": "1.0.0",
112
112
  "jest": {
113
113
  "coverageProvider": "v8",
114
114
  "testMatch": [