cdk8s-plus-31 2.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.
Files changed (114) hide show
  1. package/.backportrc.json +17 -0
  2. package/.jsii +90235 -0
  3. package/CODE_OF_CONDUCT.md +3 -0
  4. package/CONTRIBUTING.md +185 -0
  5. package/DCO +34 -0
  6. package/LICENSE +202 -0
  7. package/NOTICE +1 -0
  8. package/OWNERS.md +5 -0
  9. package/README.md +32 -0
  10. package/SECURITY.md +5 -0
  11. package/cdk8s.yaml +8 -0
  12. package/docs/java.md +23855 -0
  13. package/docs/plus/config-map.md +98 -0
  14. package/docs/plus/container.md +133 -0
  15. package/docs/plus/cronjob.md +67 -0
  16. package/docs/plus/deployment.md +232 -0
  17. package/docs/plus/horizontal-pod-autoscaler.md +226 -0
  18. package/docs/plus/ingress.md +68 -0
  19. package/docs/plus/job.md +48 -0
  20. package/docs/plus/namespace.md +58 -0
  21. package/docs/plus/network-policy.md +341 -0
  22. package/docs/plus/pod.md +455 -0
  23. package/docs/plus/pv.md +82 -0
  24. package/docs/plus/pvc.md +77 -0
  25. package/docs/plus/rbac.md +104 -0
  26. package/docs/plus/secret.md +32 -0
  27. package/docs/plus/service-account.md +35 -0
  28. package/docs/plus/service.md +41 -0
  29. package/docs/plus/volume.md +38 -0
  30. package/docs/python.md +26079 -0
  31. package/docs/typescript.md +19565 -0
  32. package/git-hooks/README.md +9 -0
  33. package/git-hooks/prepare-commit-msg +18 -0
  34. package/git-hooks/setup.sh +10 -0
  35. package/lib/_action.d.ts +21 -0
  36. package/lib/_action.js +32 -0
  37. package/lib/api-resource.d.ts +298 -0
  38. package/lib/api-resource.js +430 -0
  39. package/lib/base.d.ts +79 -0
  40. package/lib/base.js +92 -0
  41. package/lib/config-map.d.ts +126 -0
  42. package/lib/config-map.js +159 -0
  43. package/lib/container.d.ts +1057 -0
  44. package/lib/container.js +845 -0
  45. package/lib/cron-job.d.ts +138 -0
  46. package/lib/cron-job.js +103 -0
  47. package/lib/daemon-set.d.ts +45 -0
  48. package/lib/daemon-set.js +55 -0
  49. package/lib/deployment.d.ts +223 -0
  50. package/lib/deployment.js +214 -0
  51. package/lib/handler.d.ts +62 -0
  52. package/lib/handler.js +54 -0
  53. package/lib/horizontal-pod-autoscaler.d.ts +500 -0
  54. package/lib/horizontal-pod-autoscaler.js +569 -0
  55. package/lib/imports/k8s.d.ts +21534 -0
  56. package/lib/imports/k8s.js +16496 -0
  57. package/lib/index.d.ts +26 -0
  58. package/lib/index.js +39 -0
  59. package/lib/ingress.d.ts +230 -0
  60. package/lib/ingress.js +246 -0
  61. package/lib/job.d.ts +64 -0
  62. package/lib/job.js +54 -0
  63. package/lib/namespace.d.ts +128 -0
  64. package/lib/namespace.js +109 -0
  65. package/lib/network-policy.d.ts +311 -0
  66. package/lib/network-policy.js +344 -0
  67. package/lib/pod.d.ts +1080 -0
  68. package/lib/pod.js +1139 -0
  69. package/lib/probe.d.ts +141 -0
  70. package/lib/probe.js +77 -0
  71. package/lib/pv.d.ts +375 -0
  72. package/lib/pv.js +273 -0
  73. package/lib/pvc.d.ts +163 -0
  74. package/lib/pvc.js +152 -0
  75. package/lib/role-binding.d.ts +138 -0
  76. package/lib/role-binding.js +165 -0
  77. package/lib/role.d.ts +268 -0
  78. package/lib/role.js +401 -0
  79. package/lib/secret.d.ts +195 -0
  80. package/lib/secret.js +185 -0
  81. package/lib/service-account.d.ts +83 -0
  82. package/lib/service-account.js +105 -0
  83. package/lib/service.d.ts +289 -0
  84. package/lib/service.js +182 -0
  85. package/lib/stateful-set.d.ts +169 -0
  86. package/lib/stateful-set.js +174 -0
  87. package/lib/utils.d.ts +4 -0
  88. package/lib/utils.js +34 -0
  89. package/lib/volume.d.ts +573 -0
  90. package/lib/volume.js +371 -0
  91. package/lib/workload.d.ts +121 -0
  92. package/lib/workload.js +122 -0
  93. package/node_modules/balanced-match/.github/FUNDING.yml +2 -0
  94. package/node_modules/balanced-match/LICENSE.md +21 -0
  95. package/node_modules/balanced-match/README.md +97 -0
  96. package/node_modules/balanced-match/index.js +62 -0
  97. package/node_modules/balanced-match/package.json +48 -0
  98. package/node_modules/concat-map/.travis.yml +4 -0
  99. package/node_modules/concat-map/LICENSE +18 -0
  100. package/node_modules/concat-map/README.markdown +62 -0
  101. package/node_modules/concat-map/example/map.js +6 -0
  102. package/node_modules/concat-map/index.js +13 -0
  103. package/node_modules/concat-map/package.json +43 -0
  104. package/node_modules/concat-map/test/map.js +39 -0
  105. package/node_modules/minimatch/LICENSE +15 -0
  106. package/node_modules/minimatch/README.md +230 -0
  107. package/node_modules/minimatch/minimatch.js +947 -0
  108. package/node_modules/minimatch/node_modules/brace-expansion/LICENSE +21 -0
  109. package/node_modules/minimatch/node_modules/brace-expansion/README.md +129 -0
  110. package/node_modules/minimatch/node_modules/brace-expansion/index.js +201 -0
  111. package/node_modules/minimatch/node_modules/brace-expansion/package.json +47 -0
  112. package/node_modules/minimatch/package.json +33 -0
  113. package/package.json +186 -0
  114. package/rotate.md +84 -0
package/lib/pvc.js ADDED
@@ -0,0 +1,152 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.PersistentVolumeMode = exports.PersistentVolumeAccessMode = exports.PersistentVolumeClaim = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const cdk8s_1 = require("cdk8s");
7
+ const constructs_1 = require("constructs");
8
+ const base = require("./base");
9
+ const k8s = require("./imports/k8s");
10
+ class ImportedPersistentVolumeClaim extends constructs_1.Construct {
11
+ constructor(scope, id, name) {
12
+ super(scope, id);
13
+ this.resourceType = 'persistentvolumeclaims';
14
+ this._name = name;
15
+ }
16
+ get name() {
17
+ return this._name;
18
+ }
19
+ get apiVersion() {
20
+ return k8s.KubePersistentVolumeClaim.GVK.apiVersion;
21
+ }
22
+ get apiGroup() {
23
+ return '';
24
+ }
25
+ get kind() {
26
+ return k8s.KubePersistentVolumeClaim.GVK.kind;
27
+ }
28
+ get resourceName() {
29
+ return this.name;
30
+ }
31
+ }
32
+ /**
33
+ * A PersistentVolumeClaim (PVC) is a request for storage by a user.
34
+ * It is similar to a Pod. Pods consume node resources and PVCs consume PV resources.
35
+ * Pods can request specific levels of resources (CPU and Memory).
36
+ * Claims can request specific size and access modes
37
+ */
38
+ class PersistentVolumeClaim extends base.Resource {
39
+ constructor(scope, id, props = {}) {
40
+ super(scope, id);
41
+ this.resourceType = 'persistentvolumeclaims';
42
+ this.storage = props.storage;
43
+ this.volumeMode = props.volumeMode ?? PersistentVolumeMode.FILE_SYSTEM;
44
+ this.storageClassName = props.storageClassName;
45
+ this._accessModes = props.accessModes;
46
+ if (props.volume) {
47
+ this.bind(props.volume);
48
+ }
49
+ this.apiObject = new k8s.KubePersistentVolumeClaim(this, 'Resource', {
50
+ metadata: props.metadata,
51
+ spec: cdk8s_1.Lazy.any({ produce: () => this._toKube() }),
52
+ });
53
+ }
54
+ /**
55
+ * Imports a pvc from the cluster as a reference.
56
+ */
57
+ static fromClaimName(scope, id, claimName) {
58
+ return new ImportedPersistentVolumeClaim(scope, id, claimName);
59
+ }
60
+ /**
61
+ * Access modes requirement of this claim.
62
+ */
63
+ get accessModes() {
64
+ return this._accessModes ? [...this._accessModes] : undefined;
65
+ }
66
+ /**
67
+ * PV this claim is bound to. Undefined means the claim is not bound
68
+ * to any specific volume.
69
+ */
70
+ get volume() {
71
+ return this._volume;
72
+ }
73
+ /**
74
+ * Bind a claim to a specific volume.
75
+ * Note that you must also bind the volume to the claim.
76
+ *
77
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes/#binding
78
+ *
79
+ * @param vol The PV to bind to.
80
+ */
81
+ bind(vol) {
82
+ if (this._volume && this._volume.name !== vol.name) {
83
+ throw new Error(`Cannot bind claim '${this.name}' to volume '${vol.name}' since it is already bound to volume '${this._volume.name}'`);
84
+ }
85
+ this._volume = vol;
86
+ }
87
+ /**
88
+ * @internal
89
+ */
90
+ _toKube() {
91
+ const storage = this.storage ? k8s.Quantity.fromString(this.storage.toGibibytes() + 'Gi') : undefined;
92
+ return {
93
+ volumeName: this.volume ? this.volume.name : undefined,
94
+ accessModes: this.accessModes?.map(a => a.toString()),
95
+ resources: storage ? { requests: { storage } } : undefined,
96
+ volumeMode: this.volumeMode,
97
+ storageClassName: this.storageClassName,
98
+ };
99
+ }
100
+ }
101
+ exports.PersistentVolumeClaim = PersistentVolumeClaim;
102
+ _a = JSII_RTTI_SYMBOL_1;
103
+ PersistentVolumeClaim[_a] = { fqn: "cdk8s-plus-31.PersistentVolumeClaim", version: "2.0.0" };
104
+ /**
105
+ * Access Modes.
106
+ */
107
+ var PersistentVolumeAccessMode;
108
+ (function (PersistentVolumeAccessMode) {
109
+ /**
110
+ * The volume can be mounted as read-write by a single node.
111
+ * ReadWriteOnce access mode still can allow multiple pods to access
112
+ * the volume when the pods are running on the same node.
113
+ */
114
+ PersistentVolumeAccessMode["READ_WRITE_ONCE"] = "ReadWriteOnce";
115
+ /**
116
+ * The volume can be mounted as read-only by many nodes.
117
+ */
118
+ PersistentVolumeAccessMode["READ_ONLY_MANY"] = "ReadOnlyMany";
119
+ /**
120
+ * The volume can be mounted as read-write by many nodes.
121
+ */
122
+ PersistentVolumeAccessMode["READ_WRITE_MANY"] = "ReadWriteMany";
123
+ /**
124
+ * The volume can be mounted as read-write by a single Pod.
125
+ * Use ReadWriteOncePod access mode if you want to ensure that
126
+ * only one pod across whole cluster can read that PVC or write to it.
127
+ * This is only supported for CSI volumes and Kubernetes version 1.22+.
128
+ */
129
+ PersistentVolumeAccessMode["READ_WRITE_ONCE_POD"] = "ReadWriteOncePod";
130
+ })(PersistentVolumeAccessMode = exports.PersistentVolumeAccessMode || (exports.PersistentVolumeAccessMode = {}));
131
+ /**
132
+ * Volume Modes.
133
+ */
134
+ var PersistentVolumeMode;
135
+ (function (PersistentVolumeMode) {
136
+ /**
137
+ * Volume is ounted into Pods into a directory.
138
+ * If the volume is backed by a block device and the device is empty,
139
+ * Kubernetes creates a filesystem on the device before mounting it
140
+ * for the first time.
141
+ */
142
+ PersistentVolumeMode["FILE_SYSTEM"] = "Filesystem";
143
+ /**
144
+ * Use a volume as a raw block device. Such volume is presented into a Pod as a block device,
145
+ * without any filesystem on it. This mode is useful to provide a Pod the fastest possible way
146
+ * to access a volume, without any filesystem layer between the Pod
147
+ * and the volume. On the other hand, the application running in
148
+ * the Pod must know how to handle a raw block device
149
+ */
150
+ PersistentVolumeMode["BLOCK"] = "Block";
151
+ })(PersistentVolumeMode = exports.PersistentVolumeMode || (exports.PersistentVolumeMode = {}));
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pvc.js","sourceRoot":"","sources":["../src/pvc.ts"],"names":[],"mappings":"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","sourcesContent":["import { Size, ApiObject, Lazy } from 'cdk8s';\nimport { Construct } from 'constructs';\nimport * as base from './base';\nimport * as k8s from './imports/k8s';\nimport * as pv from './pv';\n\n/**\n * Contract of a `PersistentVolumeClaim`.\n */\nexport interface IPersistentVolumeClaim extends base.IResource {\n\n}\n\n/**\n * Properties for `PersistentVolumeClaim`.\n */\nexport interface PersistentVolumeClaimProps extends base.ResourceProps {\n\n  /**\n   * Contains the access modes the volume should support.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes-1\n   * @default - No access modes requirement.\n   */\n  readonly accessModes?: PersistentVolumeAccessMode[];\n\n  /**\n   * Minimum storage size the volume should have.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources\n   * @default - No storage requirement.\n   */\n  readonly storage?: Size;\n\n  /**\n   * Name of the StorageClass required by the claim.\n   * When this property is not set, the behavior is as follows:\n   *\n   * - If the admission plugin is turned on, the storage class marked as default will be used.\n   * - If the admission plugin is turned off, the pvc can only be bound to volumes without a storage class.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#class-1\n   * @default - Not set.\n   */\n  readonly storageClassName?: string;\n\n  /**\n   * Defines what type of volume is required by the claim.\n   *\n   * @default VolumeMode.FILE_SYSTEM\n   */\n  readonly volumeMode?: PersistentVolumeMode;\n\n  /**\n   * The PersistentVolume backing this claim.\n   *\n   * The control plane still checks that storage class, access modes,\n   * and requested storage size on the volume are valid.\n   *\n   * Note that in order to guarantee a proper binding, the volume should\n   * also define a `claimRef` referring to this claim. Otherwise, the volume may be\n   * claimed be other pvc's before it gets a chance to bind to this one.\n   *\n   * If the volume is managed (i.e not imported), you can use `pv.claim()` to easily\n   * create a bi-directional bounded claim.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes/#binding.\n   * @default - No specific volume binding.\n   */\n  readonly volume?: pv.IPersistentVolume;\n\n}\n\nclass ImportedPersistentVolumeClaim extends Construct implements IPersistentVolumeClaim {\n\n  private readonly _name: string;\n\n  public readonly resourceType = 'persistentvolumeclaims';\n\n  constructor(scope: Construct, id: string, name: string) {\n    super(scope, id);\n    this._name = name;\n  }\n\n  public get name(): string {\n    return this._name;\n  }\n\n  public get apiVersion(): string {\n    return k8s.KubePersistentVolumeClaim.GVK.apiVersion;\n  }\n\n  public get apiGroup(): string {\n    return '';\n  }\n\n  public get kind(): string {\n    return k8s.KubePersistentVolumeClaim.GVK.kind;\n  }\n\n  public get resourceName(): string {\n    return this.name;\n  }\n\n}\n\n/**\n * A PersistentVolumeClaim (PVC) is a request for storage by a user.\n * It is similar to a Pod. Pods consume node resources and PVCs consume PV resources.\n * Pods can request specific levels of resources (CPU and Memory).\n * Claims can request specific size and access modes\n */\nexport class PersistentVolumeClaim extends base.Resource implements IPersistentVolumeClaim {\n\n  /**\n   * Imports a pvc from the cluster as a reference.\n   */\n  public static fromClaimName(scope: Construct, id: string, claimName: string): IPersistentVolumeClaim {\n    return new ImportedPersistentVolumeClaim(scope, id, claimName);\n  }\n\n  /**\n   * @see base.Resource.apiObject\n   */\n  protected readonly apiObject: ApiObject;\n\n  public readonly resourceType = 'persistentvolumeclaims';\n\n  /**\n   * Storage requirement of this claim.\n   */\n  public readonly storage?: Size;\n\n  /**\n   * Volume mode requirement of this claim.\n   */\n  public readonly volumeMode: PersistentVolumeMode;\n\n  /**\n   * Storage class requirment of this claim.\n   */\n  public readonly storageClassName?: string;\n\n  private readonly _accessModes?: PersistentVolumeAccessMode[];\n\n  private _volume?: pv.IPersistentVolume;\n\n  public constructor(scope: Construct, id: string, props: PersistentVolumeClaimProps = { }) {\n    super(scope, id);\n\n    this.storage = props.storage;\n    this.volumeMode = props.volumeMode ?? PersistentVolumeMode.FILE_SYSTEM;\n    this.storageClassName = props.storageClassName;\n    this._accessModes = props.accessModes;\n\n    if (props.volume) {\n      this.bind(props.volume);\n    }\n\n    this.apiObject = new k8s.KubePersistentVolumeClaim(this, 'Resource', {\n      metadata: props.metadata,\n      spec: Lazy.any({ produce: () => this._toKube() }),\n    });\n  }\n\n  /**\n   * Access modes requirement of this claim.\n   */\n  public get accessModes(): PersistentVolumeAccessMode[] | undefined {\n    return this._accessModes ? [...this._accessModes] : undefined;\n  }\n\n  /**\n   * PV this claim is bound to. Undefined means the claim is not bound\n   * to any specific volume.\n   */\n  public get volume(): pv.IPersistentVolume | undefined {\n    return this._volume;\n  }\n\n  /**\n   * Bind a claim to a specific volume.\n   * Note that you must also bind the volume to the claim.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes/#binding\n   *\n   * @param vol The PV to bind to.\n   */\n  public bind(vol: pv.IPersistentVolume) {\n    if (this._volume && this._volume.name !== vol.name) {\n      throw new Error(`Cannot bind claim '${this.name}' to volume '${vol.name}' since it is already bound to volume '${this._volume.name}'`);\n    }\n    this._volume = vol;\n  }\n\n  /**\n   * @internal\n   */\n  public _toKube(): k8s.PersistentVolumeClaimSpec {\n    const storage = this.storage ? k8s.Quantity.fromString(this.storage.toGibibytes() + 'Gi') : undefined;\n    return {\n      volumeName: this.volume ? this.volume.name : undefined,\n      accessModes: this.accessModes?.map(a => a.toString()),\n      resources: storage ? { requests: { storage } } : undefined,\n      volumeMode: this.volumeMode,\n      storageClassName: this.storageClassName,\n    };\n  }\n\n}\n\n/**\n * Access Modes.\n */\nexport enum PersistentVolumeAccessMode {\n\n  /**\n   * The volume can be mounted as read-write by a single node.\n   * ReadWriteOnce access mode still can allow multiple pods to access\n   * the volume when the pods are running on the same node.\n   */\n  READ_WRITE_ONCE = 'ReadWriteOnce',\n\n  /**\n   * The volume can be mounted as read-only by many nodes.\n   */\n  READ_ONLY_MANY = 'ReadOnlyMany',\n\n  /**\n   * The volume can be mounted as read-write by many nodes.\n   */\n  READ_WRITE_MANY = 'ReadWriteMany',\n\n  /**\n   * The volume can be mounted as read-write by a single Pod.\n   * Use ReadWriteOncePod access mode if you want to ensure that\n   * only one pod across whole cluster can read that PVC or write to it.\n   * This is only supported for CSI volumes and Kubernetes version 1.22+.\n   */\n  READ_WRITE_ONCE_POD = 'ReadWriteOncePod'\n\n}\n\n/**\n * Volume Modes.\n */\nexport enum PersistentVolumeMode {\n\n  /**\n   * Volume is ounted into Pods into a directory.\n   * If the volume is backed by a block device and the device is empty,\n   * Kubernetes creates a filesystem on the device before mounting it\n   * for the first time.\n   */\n  FILE_SYSTEM = 'Filesystem',\n\n  /**\n   * Use a volume as a raw block device. Such volume is presented into a Pod as a block device,\n   * without any filesystem on it. This mode is useful to provide a Pod the fastest possible way\n   * to access a volume, without any filesystem layer between the Pod\n   * and the volume. On the other hand, the application running in\n   * the Pod must know how to handle a raw block device\n   */\n  BLOCK = 'Block'\n}\n"]}
@@ -0,0 +1,138 @@
1
+ import { ApiObject } from 'cdk8s';
2
+ import { Construct, IConstruct } from 'constructs';
3
+ import { Resource, ResourceProps } from './base';
4
+ import * as role from './role';
5
+ /**
6
+ * Subject contains a reference to the object or user identities a role binding
7
+ * applies to. This can either hold a direct API object reference, or a value
8
+ * for non-objects such as user and group names.
9
+ */
10
+ export interface SubjectConfiguration {
11
+ /**
12
+ * APIGroup holds the API group of the referenced subject. Defaults to "" for
13
+ * ServiceAccount subjects. Defaults to "rbac.authorization.k8s.io" for User
14
+ * and Group subjects.
15
+ */
16
+ readonly apiGroup?: string;
17
+ /**
18
+ * Kind of object being referenced. Values defined by this API group are
19
+ * "User", "Group", and "ServiceAccount". If the Authorizer does not
20
+ * recognized the kind value, the Authorizer should report an error.
21
+ */
22
+ readonly kind: string;
23
+ /**
24
+ * Name of the object being referenced.
25
+ */
26
+ readonly name: string;
27
+ /**
28
+ * Namespace of the referenced object. If the object kind is non-namespace,
29
+ * such as "User" or "Group", and this value is not empty the Authorizer
30
+ * should report an error.
31
+ */
32
+ readonly namespace?: string;
33
+ }
34
+ /**
35
+ * Represents an object that can be used as a role binding subject.
36
+ */
37
+ export interface ISubject extends IConstruct {
38
+ /**
39
+ * Return the subject configuration.
40
+ */
41
+ toSubjectConfiguration(): SubjectConfiguration;
42
+ }
43
+ /**
44
+ * Properties for `RoleBinding`.
45
+ */
46
+ export interface RoleBindingProps extends ResourceProps {
47
+ /**
48
+ * The role to bind to. A RoleBinding can reference a Role or a ClusterRole.
49
+ */
50
+ readonly role: role.IRole;
51
+ }
52
+ /**
53
+ * A RoleBinding grants permissions within a specific namespace to a user or
54
+ * set of users.
55
+ */
56
+ export declare class RoleBinding extends Resource {
57
+ /**
58
+ * @see base.Resource.apiObject
59
+ */
60
+ protected readonly apiObject: ApiObject;
61
+ readonly resourceType = "rolebindings";
62
+ readonly role: role.IRole;
63
+ private readonly _subjects;
64
+ constructor(scope: Construct, id: string, props: RoleBindingProps);
65
+ /**
66
+ * Adds a subject to the role.
67
+ * @param subjects The subjects to add
68
+ */
69
+ addSubjects(...subjects: ISubject[]): void;
70
+ get subjects(): ISubject[];
71
+ private synthesizeRoleRef;
72
+ private synthesizeSubjects;
73
+ }
74
+ /**
75
+ * Properties for `ClusterRoleBinding`.
76
+ */
77
+ export interface ClusterRoleBindingProps extends ResourceProps {
78
+ /**
79
+ * The role to bind to.
80
+ */
81
+ readonly role: role.IClusterRole;
82
+ }
83
+ /**
84
+ * A ClusterRoleBinding grants permissions cluster-wide to a user or
85
+ * set of users.
86
+ */
87
+ export declare class ClusterRoleBinding extends Resource {
88
+ /**
89
+ * @see base.Resource.apiObject
90
+ */
91
+ protected readonly apiObject: ApiObject;
92
+ readonly resourceType = "clusterrolebindings";
93
+ readonly role: role.IClusterRole;
94
+ private readonly _subjects;
95
+ constructor(scope: Construct, id: string, props: ClusterRoleBindingProps);
96
+ /**
97
+ * Adds a subject to the role.
98
+ * @param subjects The subjects to add
99
+ */
100
+ addSubjects(...subjects: ISubject[]): void;
101
+ get subjects(): ISubject[];
102
+ private synthesizeRoleRef;
103
+ private synthesizeSubjects;
104
+ }
105
+ /**
106
+ * Represents a user.
107
+ */
108
+ export declare class User extends Construct implements ISubject {
109
+ /**
110
+ * Reference a user in the cluster by name.
111
+ */
112
+ static fromName(scope: Construct, id: string, name: string): User;
113
+ readonly apiGroup: string | undefined;
114
+ readonly kind: string;
115
+ readonly name: string;
116
+ private constructor();
117
+ /**
118
+ * @see ISubect.toSubjectConfiguration()
119
+ */
120
+ toSubjectConfiguration(): SubjectConfiguration;
121
+ }
122
+ /**
123
+ * Represents a group.
124
+ */
125
+ export declare class Group extends Construct implements ISubject {
126
+ /**
127
+ * Reference a group by name.
128
+ */
129
+ static fromName(scope: Construct, id: string, name: string): Group;
130
+ readonly apiGroup: string | undefined;
131
+ readonly kind: string;
132
+ readonly name: string;
133
+ private constructor();
134
+ /**
135
+ * @see ISubect.toSubjectConfiguration()
136
+ */
137
+ toSubjectConfiguration(): SubjectConfiguration;
138
+ }
@@ -0,0 +1,165 @@
1
+ "use strict";
2
+ var _a, _b, _c, _d;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.Group = exports.User = exports.ClusterRoleBinding = exports.RoleBinding = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const cdk8s_1 = require("cdk8s");
7
+ const constructs_1 = require("constructs");
8
+ const base_1 = require("./base");
9
+ const k8s = require("./imports/k8s");
10
+ const utils_1 = require("./utils");
11
+ /**
12
+ * A RoleBinding grants permissions within a specific namespace to a user or
13
+ * set of users.
14
+ */
15
+ class RoleBinding extends base_1.Resource {
16
+ constructor(scope, id, props) {
17
+ super(scope, id);
18
+ this.resourceType = 'rolebindings';
19
+ this.role = props.role;
20
+ this._subjects = new Array();
21
+ this.apiObject = new k8s.KubeRoleBinding(this, 'Resource', {
22
+ metadata: props.metadata,
23
+ subjects: cdk8s_1.Lazy.any({ produce: () => this.synthesizeSubjects() }),
24
+ roleRef: cdk8s_1.Lazy.any({ produce: () => this.synthesizeRoleRef() }),
25
+ });
26
+ }
27
+ /**
28
+ * Adds a subject to the role.
29
+ * @param subjects The subjects to add
30
+ */
31
+ addSubjects(...subjects) {
32
+ for (const subject of subjects) {
33
+ this._subjects.push(subject);
34
+ }
35
+ }
36
+ get subjects() {
37
+ return [...this._subjects];
38
+ }
39
+ synthesizeRoleRef() {
40
+ return {
41
+ apiGroup: this.role.apiGroup,
42
+ kind: this.role.kind,
43
+ name: this.role.name,
44
+ };
45
+ }
46
+ synthesizeSubjects() {
47
+ return this._subjects.map(subject => subject.toSubjectConfiguration()).map((subject) => utils_1.filterUndefined({
48
+ apiGroup: subject.apiGroup === 'core' ? '' : subject.apiGroup,
49
+ kind: subject.kind,
50
+ name: subject.name,
51
+ namespace: subject.namespace,
52
+ }));
53
+ }
54
+ }
55
+ exports.RoleBinding = RoleBinding;
56
+ _a = JSII_RTTI_SYMBOL_1;
57
+ RoleBinding[_a] = { fqn: "cdk8s-plus-31.RoleBinding", version: "2.0.0" };
58
+ /**
59
+ * A ClusterRoleBinding grants permissions cluster-wide to a user or
60
+ * set of users.
61
+ */
62
+ class ClusterRoleBinding extends base_1.Resource {
63
+ constructor(scope, id, props) {
64
+ super(scope, id);
65
+ this.resourceType = 'clusterrolebindings';
66
+ this.role = props.role;
67
+ this._subjects = new Array();
68
+ this.apiObject = new k8s.KubeClusterRoleBinding(this, 'Resource', {
69
+ metadata: props.metadata,
70
+ subjects: cdk8s_1.Lazy.any({ produce: () => this.synthesizeSubjects() }),
71
+ roleRef: cdk8s_1.Lazy.any({ produce: () => this.synthesizeRoleRef() }),
72
+ });
73
+ }
74
+ /**
75
+ * Adds a subject to the role.
76
+ * @param subjects The subjects to add
77
+ */
78
+ addSubjects(...subjects) {
79
+ for (const subject of subjects) {
80
+ this._subjects.push(subject);
81
+ }
82
+ }
83
+ get subjects() {
84
+ return [...this._subjects];
85
+ }
86
+ synthesizeRoleRef() {
87
+ return {
88
+ apiGroup: this.role.apiGroup,
89
+ kind: this.role.kind,
90
+ name: this.role.name,
91
+ };
92
+ }
93
+ synthesizeSubjects() {
94
+ return this._subjects.map(subject => subject.toSubjectConfiguration()).map((subject) => utils_1.filterUndefined({
95
+ apiGroup: subject.apiGroup === 'core' ? '' : subject.apiGroup,
96
+ kind: subject.kind,
97
+ name: subject.name,
98
+ namespace: subject.namespace,
99
+ }));
100
+ }
101
+ }
102
+ exports.ClusterRoleBinding = ClusterRoleBinding;
103
+ _b = JSII_RTTI_SYMBOL_1;
104
+ ClusterRoleBinding[_b] = { fqn: "cdk8s-plus-31.ClusterRoleBinding", version: "2.0.0" };
105
+ /**
106
+ * Represents a user.
107
+ */
108
+ class User extends constructs_1.Construct {
109
+ constructor(scope, id, name) {
110
+ super(scope, id);
111
+ this.apiGroup = 'rbac.authorization.k8s.io';
112
+ this.kind = 'User';
113
+ this.name = name;
114
+ }
115
+ /**
116
+ * Reference a user in the cluster by name.
117
+ */
118
+ static fromName(scope, id, name) {
119
+ return new User(scope, id, name);
120
+ }
121
+ /**
122
+ * @see ISubect.toSubjectConfiguration()
123
+ */
124
+ toSubjectConfiguration() {
125
+ return {
126
+ kind: this.kind,
127
+ name: this.name,
128
+ apiGroup: this.apiGroup,
129
+ };
130
+ }
131
+ }
132
+ exports.User = User;
133
+ _c = JSII_RTTI_SYMBOL_1;
134
+ User[_c] = { fqn: "cdk8s-plus-31.User", version: "2.0.0" };
135
+ /**
136
+ * Represents a group.
137
+ */
138
+ class Group extends constructs_1.Construct {
139
+ constructor(scope, id, name) {
140
+ super(scope, id);
141
+ this.apiGroup = 'rbac.authorization.k8s.io';
142
+ this.kind = 'Group';
143
+ this.name = name;
144
+ }
145
+ /**
146
+ * Reference a group by name.
147
+ */
148
+ static fromName(scope, id, name) {
149
+ return new Group(scope, id, name);
150
+ }
151
+ /**
152
+ * @see ISubect.toSubjectConfiguration()
153
+ */
154
+ toSubjectConfiguration() {
155
+ return {
156
+ kind: this.kind,
157
+ name: this.name,
158
+ apiGroup: this.apiGroup,
159
+ };
160
+ }
161
+ }
162
+ exports.Group = Group;
163
+ _d = JSII_RTTI_SYMBOL_1;
164
+ Group[_d] = { fqn: "cdk8s-plus-31.Group", version: "2.0.0" };
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-binding.js","sourceRoot":"","sources":["../src/role-binding.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiObject, Lazy } from 'cdk8s';\nimport { Construct, IConstruct } from 'constructs';\nimport { Resource, ResourceProps } from './base';\nimport * as k8s from './imports/k8s';\nimport * as role from './role';\nimport { filterUndefined } from './utils';\n\n/**\n * Subject contains a reference to the object or user identities a role binding\n * applies to. This can either hold a direct API object reference, or a value\n * for non-objects such as user and group names.\n */\nexport interface SubjectConfiguration {\n\n  /**\n   * APIGroup holds the API group of the referenced subject. Defaults to \"\" for\n   * ServiceAccount subjects. Defaults to \"rbac.authorization.k8s.io\" for User\n   * and Group subjects.\n   */\n  readonly apiGroup?: string;\n\n  /**\n   * Kind of object being referenced. Values defined by this API group are\n   * \"User\", \"Group\", and \"ServiceAccount\". If the Authorizer does not\n   * recognized the kind value, the Authorizer should report an error.\n   */\n  readonly kind: string;\n\n  /**\n   * Name of the object being referenced.\n   */\n  readonly name: string;\n\n  /**\n   * Namespace of the referenced object.  If the object kind is non-namespace,\n   * such as \"User\" or \"Group\", and this value is not empty the Authorizer\n   * should report an error.\n   */\n  readonly namespace?: string;\n\n}\n\n/**\n * Represents an object that can be used as a role binding subject.\n */\nexport interface ISubject extends IConstruct {\n\n  /**\n   * Return the subject configuration.\n   */\n  toSubjectConfiguration(): SubjectConfiguration;\n\n}\n\n/**\n * Properties for `RoleBinding`.\n */\nexport interface RoleBindingProps extends ResourceProps {\n  /**\n   * The role to bind to. A RoleBinding can reference a Role or a ClusterRole.\n   */\n  readonly role: role.IRole;\n}\n\n/**\n * A RoleBinding grants permissions within a specific namespace to a user or\n * set of users.\n */\nexport class RoleBinding extends Resource {\n  /**\n   * @see base.Resource.apiObject\n   */\n  protected readonly apiObject: ApiObject;\n\n  public readonly resourceType = 'rolebindings';\n\n  public readonly role: role.IRole;\n\n  private readonly _subjects: Array<ISubject>;\n\n  constructor(scope: Construct, id: string, props: RoleBindingProps) {\n    super(scope, id);\n\n    this.role = props.role;\n\n    this._subjects = new Array<ISubject>();\n\n    this.apiObject = new k8s.KubeRoleBinding(this, 'Resource', {\n      metadata: props.metadata,\n      subjects: Lazy.any({ produce: () => this.synthesizeSubjects() }),\n      roleRef: Lazy.any({ produce: () => this.synthesizeRoleRef() }),\n    });\n  }\n\n  /**\n   * Adds a subject to the role.\n   * @param subjects The subjects to add\n   */\n  public addSubjects(...subjects: ISubject[]): void {\n    for (const subject of subjects) {\n      this._subjects.push(subject);\n    }\n  }\n\n  public get subjects() {\n    return [...this._subjects];\n  }\n\n  private synthesizeRoleRef(): k8s.RoleRef {\n    return {\n      apiGroup: this.role.apiGroup,\n      kind: this.role.kind,\n      name: this.role.name,\n    };\n  }\n\n  private synthesizeSubjects(): k8s.Subject[] {\n    return this._subjects.map(subject => subject.toSubjectConfiguration()).map((subject) => filterUndefined({\n      apiGroup: subject.apiGroup === 'core' ? '' : subject.apiGroup,\n      kind: subject.kind,\n      name: subject.name,\n      namespace: subject.namespace,\n    }));\n  }\n}\n\n/**\n * Properties for `ClusterRoleBinding`.\n */\nexport interface ClusterRoleBindingProps extends ResourceProps {\n  /**\n   * The role to bind to.\n   */\n  readonly role: role.IClusterRole;\n}\n\n/**\n * A ClusterRoleBinding grants permissions cluster-wide to a user or\n * set of users.\n */\nexport class ClusterRoleBinding extends Resource {\n  /**\n   * @see base.Resource.apiObject\n   */\n  protected readonly apiObject: ApiObject;\n\n  public readonly resourceType = 'clusterrolebindings';\n\n  public readonly role: role.IClusterRole;\n\n  private readonly _subjects: Array<ISubject>;\n\n  constructor(scope: Construct, id: string, props: ClusterRoleBindingProps) {\n    super(scope, id);\n\n    this.role = props.role;\n\n    this._subjects = new Array<ISubject>();\n\n    this.apiObject = new k8s.KubeClusterRoleBinding(this, 'Resource', {\n      metadata: props.metadata,\n      subjects: Lazy.any({ produce: () => this.synthesizeSubjects() }),\n      roleRef: Lazy.any({ produce: () => this.synthesizeRoleRef() }),\n    });\n  }\n\n  /**\n   * Adds a subject to the role.\n   * @param subjects The subjects to add\n   */\n  public addSubjects(...subjects: ISubject[]): void {\n    for (const subject of subjects) {\n      this._subjects.push(subject);\n    }\n  }\n\n  public get subjects() {\n    return [...this._subjects];\n  }\n\n  private synthesizeRoleRef(): k8s.RoleRef {\n    return {\n      apiGroup: this.role.apiGroup,\n      kind: this.role.kind,\n      name: this.role.name,\n    };\n  }\n\n  private synthesizeSubjects(): k8s.Subject[] {\n    return this._subjects.map(subject => subject.toSubjectConfiguration()).map((subject) => filterUndefined({\n      apiGroup: subject.apiGroup === 'core' ? '' : subject.apiGroup,\n      kind: subject.kind,\n      name: subject.name,\n      namespace: subject.namespace,\n    }));\n  }\n}\n\n/**\n * Represents a user.\n */\nexport class User extends Construct implements ISubject {\n\n  /**\n   * Reference a user in the cluster by name.\n   */\n  public static fromName(scope: Construct, id: string, name: string) {\n    return new User(scope, id, name);\n  }\n\n  public readonly apiGroup: string | undefined = 'rbac.authorization.k8s.io';\n  public readonly kind: string = 'User';\n  public readonly name: string;\n\n  private constructor(scope: Construct, id: string, name: string) {\n    super(scope, id);\n    this.name = name;\n  }\n\n  /**\n   * @see ISubect.toSubjectConfiguration()\n   */\n  public toSubjectConfiguration(): SubjectConfiguration {\n    return {\n      kind: this.kind,\n      name: this.name,\n      apiGroup: this.apiGroup,\n    };\n  }\n}\n\n/**\n * Represents a group.\n */\nexport class Group extends Construct implements ISubject {\n\n  /**\n   * Reference a group by name.\n   */\n  public static fromName(scope: Construct, id: string, name: string) {\n    return new Group(scope, id, name);\n  }\n\n  public readonly apiGroup: string | undefined = 'rbac.authorization.k8s.io';\n  public readonly kind: string = 'Group';\n  public readonly name: string;\n\n  private constructor(scope: Construct, id: string, name: string) {\n    super(scope, id);\n    this.name = name;\n  }\n\n  /**\n   * @see ISubect.toSubjectConfiguration()\n   */\n  public toSubjectConfiguration(): SubjectConfiguration {\n    return {\n      kind: this.kind,\n      name: this.name,\n      apiGroup: this.apiGroup,\n    };\n  }\n\n}\n"]}