UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

112 lines 11.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.PolicyStatementWithResources = void 0; const _3_actions_1 = require("./3-actions"); /** * Adds "resource" functionality to the Policy Statement */ class PolicyStatementWithResources extends _3_actions_1.PolicyStatementWithActions { constructor() { super(...arguments); this.useNotResource = false; this.floydResources = []; this.skipAutoResource = false; this.cdkResourcesApplied = false; } /** * Injects resources into the statement. * * Only relevant for the main package. In CDK mode this only calls super. */ toJSON() { // @ts-ignore only available after swapping 1-base if (typeof this.addResources == 'function') { this.cdkApplyResources(); return super.toJSON(); } const mode = this.useNotResource ? 'NotResource' : 'Resource'; const statement = super.toJSON(); const self = this; this.ensureResource(); if (this.floydResources.length) { const resources = this.floydResources.filter((elem, pos) => { return self.floydResources.indexOf(elem) == pos; }); statement[mode] = resources.length > 1 ? resources : resources[0]; } return statement; } toStatementJson() { this.ensureResource(); this.cdkApplyResources(); // @ts-ignore only available after swapping 1-base return super.toStatementJson(); } freeze() { // @ts-ignore only available after swapping 1-base if (!this.frozen) { this.ensureResource(); this.cdkApplyResources(); } return super.freeze(); } cdkApplyResources() { if (!this.cdkResourcesApplied) { const mode = this.useNotResource ? 'addNotResources' : 'addResources'; const self = this; const uniqueResources = this.floydResources.filter((elem, pos) => { return self.floydResources.indexOf(elem) == pos; }); // @ts-ignore only available after swapping 1-base this[mode](...uniqueResources); this.cdkResourcesApplied = true; } } /** * Switches the statement to use [`NotResource`](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notresource.html). */ notResource() { this.useNotResource = true; return this; } /** * Checks weather any resource was applied to the policy. */ hasResources() { return this.floydResources.length > 0; } /** * Limit statement to specified resources. * * To allow all resources, pass `*` */ on(...arns) { this.floydResources.push(...arns); return this; } /** * Add all resources (`*`) to the statement * * This is the default behavior, unless the statement has principals. */ onAllResources() { this.floydResources.push('*'); return this; } ensureResource() { if (this.hasResources()) return; // @ts-ignore only available after swapping 1-base if (this.hasResource) return; // @ts-ignore only available after swapping 1-base if (this.hasPrincipal) return; //assume policies may not have resources if (this.skipAutoResource) return; // a statement requires resources. if none was added, we assume the user wants all resources this.onAllResources(); } } exports.PolicyStatementWithResources = PolicyStatementWithResources; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"4-resources.js","sourceRoot":"","sources":["4-resources.ts"],"names":[],"mappings":"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","sourcesContent":["import { PolicyStatementWithActions } from './3-actions';\n\nexport type ResourceTypes = Record<string, ResourceType>;\n\nexport interface ResourceType {\n  name: string;\n  url: string;\n  arn: string;\n  conditionKeys: string[];\n}\n\n/**\n * Adds \"resource\" functionality to the Policy Statement\n */\nexport class PolicyStatementWithResources extends PolicyStatementWithActions {\n  private useNotResource = false;\n  protected floydResources: string[] = [];\n  protected skipAutoResource = false;\n  private cdkResourcesApplied = false;\n\n  /**\n   * Injects resources into the statement.\n   *\n   * Only relevant for the main package. In CDK mode this only calls super.\n   */\n  public toJSON(): any {\n    // @ts-ignore only available after swapping 1-base\n    if (typeof this.addResources == 'function') {\n      this.cdkApplyResources();\n      return super.toJSON();\n    }\n    const mode = this.useNotResource ? 'NotResource' : 'Resource';\n    const statement = super.toJSON();\n    const self = this;\n\n    this.ensureResource();\n\n    if (this.floydResources.length) {\n      const resources = this.floydResources.filter((elem, pos) => {\n        return self.floydResources.indexOf(elem) == pos;\n      });\n      statement[mode] = resources.length > 1 ? resources : resources[0];\n    }\n\n    return statement;\n  }\n\n  public toStatementJson(): any {\n    this.ensureResource();\n    this.cdkApplyResources();\n    // @ts-ignore only available after swapping 1-base\n    return super.toStatementJson();\n  }\n\n  public freeze() {\n    // @ts-ignore only available after swapping 1-base\n    if (!this.frozen) {\n      this.ensureResource();\n      this.cdkApplyResources();\n    }\n    return super.freeze();\n  }\n\n  private cdkApplyResources() {\n    if (!this.cdkResourcesApplied) {\n      const mode = this.useNotResource ? 'addNotResources' : 'addResources';\n      const self = this;\n      const uniqueResources = this.floydResources.filter((elem, pos) => {\n        return self.floydResources.indexOf(elem) == pos;\n      });\n      // @ts-ignore only available after swapping 1-base\n      this[mode](...uniqueResources);\n      this.cdkResourcesApplied = true;\n    }\n  }\n\n  /**\n   * Switches the statement to use [`NotResource`](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notresource.html).\n   */\n  public notResource() {\n    this.useNotResource = true;\n    return this;\n  }\n\n  /**\n   * Checks weather any resource was applied to the policy.\n   */\n  public hasResources(): boolean {\n    return this.floydResources.length > 0;\n  }\n\n  /**\n   * Limit statement to specified resources.\n   *\n   * To allow all resources, pass `*`\n   */\n  public on(...arns: string[]) {\n    this.floydResources.push(...arns);\n    return this;\n  }\n\n  /**\n   * Add all resources (`*`) to the statement\n   *\n   * This is the default behavior, unless the statement has principals.\n   */\n  public onAllResources() {\n    this.floydResources.push('*');\n    return this;\n  }\n\n  private ensureResource() {\n    if (this.hasResources()) return;\n    // @ts-ignore only available after swapping 1-base\n    if (this.hasResource) return;\n    // @ts-ignore only available after swapping 1-base\n    if (this.hasPrincipal) return; //assume policies may not have resources\n    if (this.skipAutoResource) return;\n\n    // a statement requires resources. if none was added, we assume the user wants all resources\n    this.onAllResources();\n  }\n}\n"]}