@scloud/cdk-patterns
Version:
Serverless CDK patterns for common infrastructure needs
88 lines • 12 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.addGhaSecret = addGhaSecret;
exports.addGhaVariable = addGhaVariable;
exports.addGhaLambda = addGhaLambda;
exports.addGhaBucket = addGhaBucket;
exports.addGhaDistribution = addGhaDistribution;
exports.addGhaRepository = addGhaRepository;
exports.saveGhaValues = saveGhaValues;
exports.ghaPolicy = ghaPolicy;
exports.ghaOidcProvider = ghaOidcProvider;
exports.ghaOidcRole = ghaOidcRole;
exports.ghaUser = ghaUser;
const GithubActions_1 = require("../GithubActions");
// const ghaInfo = {
// resources: {
// repositories: <IRepository[]>[],
// buckets: <IBucket[]>[],
// lambdas: <IFunction[]>[],
// services: <IFargateService[]>[],
// distributions: <IDistribution[]>[],
// },
// secrets: <string[]>[],
// variables: <string[]>[],
// };
// @deprecated - Use GithubActions instead
function addGhaSecret(construct, name, value) {
(0, GithubActions_1.githubActions)(construct).addGhaSecret(name, value);
}
// @deprecated - Use GithubActions instead
function addGhaVariable(construct, name, type, value) {
(0, GithubActions_1.githubActions)(construct).addGhaVariable(name, type, value);
}
// @deprecated - Use GithubActions instead
function addGhaLambda(construct, name, lambda) {
(0, GithubActions_1.githubActions)(construct).addGhaLambda(name, lambda);
}
// @deprecated - Use GithubActions instead
function addGhaBucket(construct, name, bucket) {
(0, GithubActions_1.githubActions)(construct).addGhaBucket(name, bucket);
}
// @deprecated - Use GithubActions instead
function addGhaDistribution(construct, name, distribution) {
(0, GithubActions_1.githubActions)(construct).addGhaDistribution(name, distribution);
}
// @deprecated - Use GithubActions instead
function addGhaRepository(construct, name, repository) {
(0, GithubActions_1.githubActions)(construct).addGhaRepository(name, repository);
}
// @deprecated - Use GithubActions instead
function saveGhaValues(stack) {
(0, GithubActions_1.githubActions)(stack).saveGhaValues();
}
// @deprecated - Use GithubActions instead
function ghaPolicy(stack) {
return (0, GithubActions_1.githubActions)(stack).ghaPolicy();
}
/**
* @deprecated - Use GithubActions instead
*
* Create an account-wide OIDC connection fo Guthub Actions.
* NB only one OIDC provider for GitHub can be created per AWS account (because the provider URL must be unique).
* To provide access to resources, you can create multiple roles that trust the provider so you'll probably want to call ghaOidcRole() instead.
* See: https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services
* @param repo What to grant access to. This is a minimum of a GitHub owner (user or org), optionally a repository name, and you can also specify a filter to limit access to e.g. a branch.
*/
function ghaOidcProvider(stack) {
return (0, GithubActions_1.githubActions)(stack).ghaOidcProvider();
}
/**
* @deprecated - Use GithubActions instead
*
* Add permissions to the GitHub OIDC role that allow workflows to access the AWS resources in this stack that need to be updated at build time.
* See: https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services
* @param repo The repository to grant access to (owner and name). You can also specify a filter to limit access e.g. to a branch.
*/
function ghaOidcRole(stack, repo, openIdConnectProvider) {
return (0, GithubActions_1.githubActions)(stack).ghaOidcRole(repo, openIdConnectProvider);
}
/**
* @deprecated - Use GithubActions instead
*
* A user for Gihud Actions CI/CD.
*/
function ghaUser(stack, username) {
return (0, GithubActions_1.githubActions)(stack).ghaUser(username);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ghaUserDeprecated.js","sourceRoot":"","sources":["../../src/deprecated/ghaUserDeprecated.ts"],"names":[],"mappings":";;AAyBA,oCAMC;AAGD,wCAOC;AAGD,oCAMC;AAGD,oCAMC;AAGD,gDAMC;AAGD,4CAMC;AAGD,sCAEC;AAID,8BAEC;AAWD,0CAEC;AASD,kCAEC;AAOD,0BAEC;AA/GD,oDAAiD;AAEjD,oBAAoB;AACpB,iBAAiB;AACjB,uCAAuC;AACvC,8BAA8B;AAC9B,gCAAgC;AAChC,uCAAuC;AACvC,0CAA0C;AAC1C,OAAO;AACP,2BAA2B;AAC3B,6BAA6B;AAC7B,KAAK;AAEL,0CAA0C;AAC1C,SAAgB,YAAY,CAC1B,SAAoB,EACpB,IAAY,EACZ,KAAa;IAEb,IAAA,6BAAa,EAAC,SAAS,CAAC,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AACrD,CAAC;AAED,0CAA0C;AAC1C,SAAgB,cAAc,CAC5B,SAAoB,EACpB,IAAY,EACZ,IAAY,EACZ,KAAa;IAEb,IAAA,6BAAa,EAAC,SAAS,CAAC,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;AAC7D,CAAC;AAED,0CAA0C;AAC1C,SAAgB,YAAY,CAC1B,SAAoB,EACpB,IAAY,EACZ,MAAiB;IAEjB,IAAA,6BAAa,EAAC,SAAS,CAAC,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AACtD,CAAC;AAED,0CAA0C;AAC1C,SAAgB,YAAY,CAC1B,SAAoB,EACpB,IAAY,EACZ,MAAe;IAEf,IAAA,6BAAa,EAAC,SAAS,CAAC,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AACtD,CAAC;AAED,0CAA0C;AAC1C,SAAgB,kBAAkB,CAChC,SAAoB,EACpB,IAAY,EACZ,YAA2B;IAE3B,IAAA,6BAAa,EAAC,SAAS,CAAC,CAAC,kBAAkB,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;AAClE,CAAC;AAED,0CAA0C;AAC1C,SAAgB,gBAAgB,CAC9B,SAAoB,EACpB,IAAY,EACZ,UAAuB;IAEvB,IAAA,6BAAa,EAAC,SAAS,CAAC,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;AAC9D,CAAC;AAED,0CAA0C;AAC1C,SAAgB,aAAa,CAAC,KAAY;IACxC,IAAA,6BAAa,EAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC;AACvC,CAAC;AAED,0CAA0C;AAE1C,SAAgB,SAAS,CAAC,KAAY;IACpC,OAAO,IAAA,6BAAa,EAAC,KAAK,CAAC,CAAC,SAAS,EAAE,CAAC;AAC1C,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,eAAe,CAAC,KAAY;IAC1C,OAAO,IAAA,6BAAa,EAAC,KAAK,CAAC,CAAC,eAAe,EAAE,CAAC;AAChD,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,WAAW,CAAC,KAAY,EAAE,IAAwD,EAAE,qBAA6C;IAC/I,OAAO,IAAA,6BAAa,EAAC,KAAK,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC;AACvE,CAAC;AAED;;;;GAIG;AACH,SAAgB,OAAO,CAAC,KAAY,EAAE,QAAiB;IACrD,OAAO,IAAA,6BAAa,EAAC,KAAK,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;AAChD,CAAC","sourcesContent":["\nimport {\n  CfnAccessKey, OpenIdConnectProvider, Role, User,\n} from 'aws-cdk-lib/aws-iam';\nimport { Stack } from 'aws-cdk-lib';\nimport { IRepository } from 'aws-cdk-lib/aws-ecr';\nimport { IFunction } from 'aws-cdk-lib/aws-lambda';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport { IDistribution } from 'aws-cdk-lib/aws-cloudfront';\nimport { Construct } from 'constructs';\nimport { githubActions } from '../GithubActions';\n\n// const ghaInfo = {\n//   resources: {\n//     repositories: <IRepository[]>[],\n//     buckets: <IBucket[]>[],\n//     lambdas: <IFunction[]>[],\n//     services: <IFargateService[]>[],\n//     distributions: <IDistribution[]>[],\n//   },\n//   secrets: <string[]>[],\n//   variables: <string[]>[],\n// };\n\n// @deprecated - Use GithubActions instead\nexport function addGhaSecret(\n  construct: Construct,\n  name: string,\n  value: string,\n) {\n  githubActions(construct).addGhaSecret(name, value);\n}\n\n// @deprecated - Use GithubActions instead\nexport function addGhaVariable(\n  construct: Construct,\n  name: string,\n  type: string,\n  value: string,\n) {\n  githubActions(construct).addGhaVariable(name, type, value);\n}\n\n// @deprecated - Use GithubActions instead\nexport function addGhaLambda(\n  construct: Construct,\n  name: string,\n  lambda: IFunction,\n) {\n  githubActions(construct).addGhaLambda(name, lambda);\n}\n\n// @deprecated - Use GithubActions instead\nexport function addGhaBucket(\n  construct: Construct,\n  name: string,\n  bucket: IBucket,\n) {\n  githubActions(construct).addGhaBucket(name, bucket);\n}\n\n// @deprecated - Use GithubActions instead\nexport function addGhaDistribution(\n  construct: Construct,\n  name: string,\n  distribution: IDistribution,\n) {\n  githubActions(construct).addGhaDistribution(name, distribution);\n}\n\n// @deprecated - Use GithubActions instead\nexport function addGhaRepository(\n  construct: Construct,\n  name: string,\n  repository: IRepository,\n) {\n  githubActions(construct).addGhaRepository(name, repository);\n}\n\n// @deprecated - Use GithubActions instead\nexport function saveGhaValues(stack: Stack) {\n  githubActions(stack).saveGhaValues();\n}\n\n// @deprecated - Use GithubActions instead\n\nexport function ghaPolicy(stack: Stack) {\n  return githubActions(stack).ghaPolicy();\n}\n\n/**\n * @deprecated - Use GithubActions instead\n *\n * Create an account-wide OIDC connection fo Guthub Actions.\n * NB only one OIDC provider for GitHub can be created per AWS account (because the provider URL must be unique).\n * To provide access to resources, you can create multiple roles that trust the provider so you'll probably want to call ghaOidcRole() instead.\n * See: https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services\n * @param repo What to grant access to. This is a minimum of a GitHub owner (user or org), optionally a repository name, and you can also specify a filter to limit access to e.g. a branch.\n */\nexport function ghaOidcProvider(stack: Stack): OpenIdConnectProvider {\n  return githubActions(stack).ghaOidcProvider();\n}\n\n/**\n * @deprecated - Use GithubActions instead\n *\n * Add permissions to the GitHub OIDC role that allow workflows to access the AWS resources in this stack that need to be updated at build time.\n * See: https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services\n * @param repo The repository to grant access to (owner and name). You can also specify a filter to limit access e.g. to a branch.\n */\nexport function ghaOidcRole(stack: Stack, repo: { owner: string, repo?: string; filter?: string; }, openIdConnectProvider?: OpenIdConnectProvider): Role {\n  return githubActions(stack).ghaOidcRole(repo, openIdConnectProvider);\n}\n\n/**\n * @deprecated - Use GithubActions instead\n *\n * A user for Gihud Actions CI/CD.\n */\nexport function ghaUser(stack: Stack, username?: string): { user: User, accessKey: CfnAccessKey | undefined; } {\n  return githubActions(stack).ghaUser(username);\n}\n"]}