1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.EventBus = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const iam = require("@aws-cdk/aws-iam");
|
8 | const core_1 = require("@aws-cdk/core");
|
9 | const archive_1 = require("./archive");
|
10 | const events_generated_1 = require("./events.generated");
|
11 | class EventBusBase extends core_1.Resource {
|
12 | archive(id, props) {
|
13 | return new archive_1.Archive(this, id, {
|
14 | sourceEventBus: this,
|
15 | description: props.description || `Event Archive for ${this.eventBusName} Event Bus`,
|
16 | eventPattern: props.eventPattern,
|
17 | retention: props.retention,
|
18 | archiveName: props.archiveName,
|
19 | });
|
20 | }
|
21 | grantPutEventsTo(grantee) {
|
22 | return iam.Grant.addToPrincipal({
|
23 | grantee,
|
24 | actions: ['events:PutEvents'],
|
25 | resourceArns: [this.eventBusArn],
|
26 | });
|
27 | }
|
28 | }
|
29 | /**
|
30 | * Define an EventBridge EventBus
|
31 | *
|
32 | * @resource AWS::Events::EventBus
|
33 | */
|
34 | class EventBus extends EventBusBase {
|
35 | constructor(scope, id, props) {
|
36 | try {
|
37 | jsiiDeprecationWarnings._aws_cdk_aws_events_EventBusProps(props);
|
38 | }
|
39 | catch (error) {
|
40 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
41 | Error.captureStackTrace(error, this.constructor);
|
42 | }
|
43 | throw error;
|
44 | }
|
45 | const { eventBusName, eventSourceName } = EventBus.eventBusProps(core_1.Lazy.string({ produce: () => core_1.Names.uniqueId(this) }), props);
|
46 | super(scope, id, { physicalName: eventBusName });
|
47 | const eventBus = new events_generated_1.CfnEventBus(this, 'Resource', {
|
48 | name: this.physicalName,
|
49 | eventSourceName,
|
50 | });
|
51 | this.eventBusArn = this.getResourceArnAttribute(eventBus.attrArn, {
|
52 | service: 'events',
|
53 | resource: 'event-bus',
|
54 | resourceName: eventBus.name,
|
55 | });
|
56 | this.eventBusName = this.getResourceNameAttribute(eventBus.ref);
|
57 | this.eventBusPolicy = eventBus.attrPolicy;
|
58 | this.eventSourceName = eventBus.eventSourceName;
|
59 | }
|
60 | /**
|
61 | * Import an existing event bus resource
|
62 | * @param scope Parent construct
|
63 | * @param id Construct ID
|
64 | * @param eventBusArn ARN of imported event bus
|
65 | */
|
66 | static fromEventBusArn(scope, id, eventBusArn) {
|
67 | const parts = core_1.Stack.of(scope).splitArn(eventBusArn, core_1.ArnFormat.SLASH_RESOURCE_NAME);
|
68 | return new ImportedEventBus(scope, id, {
|
69 | eventBusArn: eventBusArn,
|
70 | eventBusName: parts.resourceName || '',
|
71 | eventBusPolicy: '',
|
72 | });
|
73 | }
|
74 | /**
|
75 | * Import an existing event bus resource
|
76 | * @param scope Parent construct
|
77 | * @param id Construct ID
|
78 | * @param eventBusName Name of imported event bus
|
79 | */
|
80 | static fromEventBusName(scope, id, eventBusName) {
|
81 | const eventBusArn = core_1.Stack.of(scope).formatArn({
|
82 | resource: 'event-bus',
|
83 | service: 'events',
|
84 | resourceName: eventBusName,
|
85 | });
|
86 | return EventBus.fromEventBusAttributes(scope, id, {
|
87 | eventBusName: eventBusName,
|
88 | eventBusArn: eventBusArn,
|
89 | eventBusPolicy: '',
|
90 | });
|
91 | }
|
92 | /**
|
93 | * Import an existing event bus resource
|
94 | * @param scope Parent construct
|
95 | * @param id Construct ID
|
96 | * @param attrs Imported event bus properties
|
97 | */
|
98 | static fromEventBusAttributes(scope, id, attrs) {
|
99 | try {
|
100 | jsiiDeprecationWarnings._aws_cdk_aws_events_EventBusAttributes(attrs);
|
101 | }
|
102 | catch (error) {
|
103 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
104 | Error.captureStackTrace(error, this.fromEventBusAttributes);
|
105 | }
|
106 | throw error;
|
107 | }
|
108 | return new ImportedEventBus(scope, id, attrs);
|
109 | }
|
110 | /**
|
111 | * Permits an IAM Principal to send custom events to EventBridge
|
112 | * so that they can be matched to rules.
|
113 | *
|
114 | * @param grantee The principal (no-op if undefined)
|
115 | * @deprecated use grantAllPutEvents instead
|
116 | */
|
117 | static grantPutEvents(grantee) {
|
118 | try {
|
119 | jsiiDeprecationWarnings.print("@aws-cdk/aws-events.EventBus#grantPutEvents", "use grantAllPutEvents instead");
|
120 | }
|
121 | catch (error) {
|
122 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
123 | Error.captureStackTrace(error, this.grantPutEvents);
|
124 | }
|
125 | throw error;
|
126 | }
|
127 | // It's currently not possible to restrict PutEvents to specific resources.
|
128 | // See https://docs.aws.amazon.com/eventbridge/latest/userguide/permissions-reference-eventbridge.html
|
129 | return iam.Grant.addToPrincipal({
|
130 | grantee,
|
131 | actions: ['events:PutEvents'],
|
132 | resourceArns: ['*'],
|
133 | });
|
134 | }
|
135 | /**
|
136 | * Permits an IAM Principal to send custom events to EventBridge
|
137 | * so that they can be matched to rules.
|
138 | *
|
139 | * @param grantee The principal (no-op if undefined)
|
140 | */
|
141 | static grantAllPutEvents(grantee) {
|
142 | return iam.Grant.addToPrincipal({
|
143 | grantee,
|
144 | actions: ['events:PutEvents'],
|
145 | resourceArns: ['*'],
|
146 | });
|
147 | }
|
148 | static eventBusProps(defaultEventBusName, props = {}) {
|
149 | const { eventBusName, eventSourceName } = props;
|
150 | const eventBusNameRegex = /^[\/\.\-_A-Za-z0-9]{1,256}$/;
|
151 | if (eventBusName !== undefined && eventSourceName !== undefined) {
|
152 | throw new Error('\'eventBusName\' and \'eventSourceName\' cannot both be provided');
|
153 | }
|
154 | if (eventBusName !== undefined) {
|
155 | if (!core_1.Token.isUnresolved(eventBusName)) {
|
156 | if (eventBusName === 'default') {
|
157 | throw new Error('\'eventBusName\' must not be \'default\'');
|
158 | }
|
159 | else if (eventBusName.indexOf('/') > -1) {
|
160 | throw new Error('\'eventBusName\' must not contain \'/\'');
|
161 | }
|
162 | else if (!eventBusNameRegex.test(eventBusName)) {
|
163 | throw new Error(`'eventBusName' must satisfy: ${eventBusNameRegex}`);
|
164 | }
|
165 | }
|
166 | return { eventBusName };
|
167 | }
|
168 | if (eventSourceName !== undefined) {
|
169 | // Ex: aws.partner/PartnerName/acct1/repo1
|
170 | const eventSourceNameRegex = /^aws\.partner(\/[\.\-_A-Za-z0-9]+){2,}$/;
|
171 | if (!eventSourceNameRegex.test(eventSourceName)) {
|
172 | throw new Error(`'eventSourceName' must satisfy: ${eventSourceNameRegex}`);
|
173 | }
|
174 | else if (!eventBusNameRegex.test(eventSourceName)) {
|
175 | throw new Error(`'eventSourceName' must satisfy: ${eventBusNameRegex}`);
|
176 | }
|
177 | return { eventBusName: eventSourceName, eventSourceName };
|
178 | }
|
179 | return { eventBusName: defaultEventBusName };
|
180 | }
|
181 | }
|
182 | exports.EventBus = EventBus;
|
183 | _a = JSII_RTTI_SYMBOL_1;
|
184 | EventBus[_a] = { fqn: "@aws-cdk/aws-events.EventBus", version: "1.155.0" };
|
185 | class ImportedEventBus extends EventBusBase {
|
186 | constructor(scope, id, attrs) {
|
187 | const arnParts = core_1.Stack.of(scope).splitArn(attrs.eventBusArn, core_1.ArnFormat.SLASH_RESOURCE_NAME);
|
188 | super(scope, id, {
|
189 | account: arnParts.account,
|
190 | region: arnParts.region,
|
191 | });
|
192 | this.eventBusArn = attrs.eventBusArn;
|
193 | this.eventBusName = attrs.eventBusName;
|
194 | this.eventBusPolicy = attrs.eventBusPolicy;
|
195 | this.eventSourceName = attrs.eventSourceName;
|
196 | }
|
197 | }
|
198 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-bus.js","sourceRoot":"","sources":["event-bus.ts"],"names":[],"mappings":";;;;;;AAAA,wCAAwC;AACxC,wCAA0F;AAE1F,uCAAsD;AACtD,yDAAiD;AAgHjD,MAAe,YAAa,SAAQ,eAAQ;IAsBnC,OAAO,CAAC,EAAU,EAAE,KAAuB;QAChD,OAAO,IAAI,iBAAO,CAAC,IAAI,EAAE,EAAE,EAAE;YAC3B,cAAc,EAAE,IAAI;YACpB,WAAW,EAAE,KAAK,CAAC,WAAW,IAAI,qBAAqB,IAAI,CAAC,YAAY,YAAY;YACpF,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,WAAW,EAAE,KAAK,CAAC,WAAW;SAC/B,CAAC,CAAC;KACJ;IAEM,gBAAgB,CAAC,OAAuB;QAC7C,OAAO,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC;YAC9B,OAAO;YACP,OAAO,EAAE,CAAC,kBAAkB,CAAC;YAC7B,YAAY,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC;SACjC,CAAC,CAAC;KACJ;CACF;AAED;;;;GAIG;AACH,MAAa,QAAS,SAAQ,YAAY;IAmJxC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAqB;;;;;;;;;;QAC7D,MAAM,EAAE,YAAY,EAAE,eAAe,EAAE,GAAG,QAAQ,CAAC,aAAa,CAC9D,WAAI,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,EACpD,KAAK,CACN,CAAC;QAEF,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC,CAAC;QAEjD,MAAM,QAAQ,GAAG,IAAI,8BAAW,CAAC,IAAI,EAAE,UAAU,EAAE;YACjD,IAAI,EAAE,IAAI,CAAC,YAAY;YACvB,eAAe;SAChB,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,OAAO,EAAE;YAChE,OAAO,EAAE,QAAQ;YACjB,QAAQ,EAAE,WAAW;YACrB,YAAY,EAAE,QAAQ,CAAC,IAAI;SAC5B,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAChE,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,UAAU,CAAC;QAC1C,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,eAAe,CAAC;KACjD;IAvKD;;;;;OAKG;IACI,MAAM,CAAC,eAAe,CAAC,KAAgB,EAAE,EAAU,EAAE,WAAmB;QAC7E,MAAM,KAAK,GAAG,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,gBAAS,CAAC,mBAAmB,CAAC,CAAC;QAEnF,OAAO,IAAI,gBAAgB,CAAC,KAAK,EAAE,EAAE,EAAE;YACrC,WAAW,EAAE,WAAW;YACxB,YAAY,EAAE,KAAK,CAAC,YAAY,IAAI,EAAE;YACtC,cAAc,EAAE,EAAE;SACnB,CAAC,CAAC;KACJ;IAED;;;;;OAKG;IACI,MAAM,CAAC,gBAAgB,CAAC,KAAgB,EAAE,EAAU,EAAE,YAAoB;QAC/E,MAAM,WAAW,GAAG,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC;YAC5C,QAAQ,EAAE,WAAW;YACrB,OAAO,EAAE,QAAQ;YACjB,YAAY,EAAE,YAAY;SAC3B,CAAC,CAAC;QAEH,OAAO,QAAQ,CAAC,sBAAsB,CAAC,KAAK,EAAE,EAAE,EAAE;YAChD,YAAY,EAAE,YAAY;YAC1B,WAAW,EAAE,WAAW;YACxB,cAAc,EAAE,EAAE;SACnB,CAAC,CAAC;KACJ;IAED;;;;;OAKG;IACI,MAAM,CAAC,sBAAsB,CAAC,KAAgB,EAAE,EAAU,EAAE,KAAyB;;;;;;;;;;QAC1F,OAAO,IAAI,gBAAgB,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;KAC/C;IAED;;;;;;OAMG;IACI,MAAM,CAAC,cAAc,CAAC,OAAuB;;;;;;;;;;QAClD,2EAA2E;QAC3E,sGAAsG;QACtG,OAAO,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC;YAC9B,OAAO;YACP,OAAO,EAAE,CAAC,kBAAkB,CAAC;YAC7B,YAAY,EAAE,CAAC,GAAG,CAAC;SACpB,CAAC,CAAC;KACJ;IAED;;;;;OAKG;IACI,MAAM,CAAC,iBAAiB,CAAC,OAAuB;QACrD,OAAO,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC;YAC9B,OAAO;YACP,OAAO,EAAE,CAAC,kBAAkB,CAAC;YAC7B,YAAY,EAAE,CAAC,GAAG,CAAC;SACpB,CAAC,CAAC;KACJ;IAEO,MAAM,CAAC,aAAa,CAAC,mBAA2B,EAAE,QAAuB,EAAE;QACjF,MAAM,EAAE,YAAY,EAAE,eAAe,EAAE,GAAG,KAAK,CAAC;QAChD,MAAM,iBAAiB,GAAG,6BAA6B,CAAC;QAExD,IAAI,YAAY,KAAK,SAAS,IAAI,eAAe,KAAK,SAAS,EAAE;YAC/D,MAAM,IAAI,KAAK,CACb,kEAAkE,CACnE,CAAC;SACH;QAED,IAAI,YAAY,KAAK,SAAS,EAAE;YAC9B,IAAI,CAAC,YAAK,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE;gBACrC,IAAI,YAAY,KAAK,SAAS,EAAE;oBAC9B,MAAM,IAAI,KAAK,CACb,0CAA0C,CAC3C,CAAC;iBACH;qBAAM,IAAI,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE;oBACzC,MAAM,IAAI,KAAK,CACb,yCAAyC,CAC1C,CAAC;iBACH;qBAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;oBAChD,MAAM,IAAI,KAAK,CACb,gCAAgC,iBAAiB,EAAE,CACpD,CAAC;iBACH;aACF;YACD,OAAO,EAAE,YAAY,EAAE,CAAC;SACzB;QAED,IAAI,eAAe,KAAK,SAAS,EAAE;YACjC,0CAA0C;YAC1C,MAAM,oBAAoB,GAAG,yCAAyC,CAAC;YACvE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE;gBAC/C,MAAM,IAAI,KAAK,CACb,mCAAmC,oBAAoB,EAAE,CAC1D,CAAC;aACH;iBAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE;gBACnD,MAAM,IAAI,KAAK,CACb,mCAAmC,iBAAiB,EAAE,CACvD,CAAC;aACH;YACD,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,eAAe,EAAE,CAAC;SAC3D;QAED,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,CAAC;KAC9C;;AA5HH,4BA0KC;;;AAED,MAAM,gBAAiB,SAAQ,YAAY;IAKzC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAyB;QACjE,MAAM,QAAQ,GAAG,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,EAAE,gBAAS,CAAC,mBAAmB,CAAC,CAAC;QAC5F,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,OAAO,EAAE,QAAQ,CAAC,OAAO;YACzB,MAAM,EAAE,QAAQ,CAAC,MAAM;SACxB,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,eAAe,CAAC;KAC9C;CACF","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport { ArnFormat, IResource, Lazy, Names, Resource, Stack, Token } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { Archive, BaseArchiveProps } from './archive';\nimport { CfnEventBus } from './events.generated';\n\n/**\n * Interface which all EventBus based classes MUST implement\n */\nexport interface IEventBus extends IResource {\n  /**\n   * The physical ID of this event bus resource\n   *\n   * @attribute\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#cfn-events-eventbus-name\n   */\n  readonly eventBusName: string;\n\n  /**\n   * The ARN of this event bus resource\n   *\n   * @attribute\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#Arn-fn::getatt\n   */\n  readonly eventBusArn: string;\n\n  /**\n   * The JSON policy of this event bus resource\n   *\n   * @attribute\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#Policy-fn::getatt\n   */\n  readonly eventBusPolicy: string;\n\n  /**\n   * The partner event source to associate with this event bus resource\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#cfn-events-eventbus-eventsourcename\n   */\n  readonly eventSourceName?: string;\n\n  /**\n   * Create an EventBridge archive to send events to.\n   * When you create an archive, incoming events might not immediately start being sent to the archive.\n   * Allow a short period of time for changes to take effect.\n   *\n   * @param props Properties of the archive\n   */\n  archive(id: string, props: BaseArchiveProps): Archive;\n\n  /**\n   * Grants an IAM Principal to send custom events to the eventBus\n   * so that they can be matched to rules.\n   *\n   * @param grantee The principal (no-op if undefined)\n   */\n  grantPutEventsTo(grantee: iam.IGrantable): iam.Grant;\n}\n\n/**\n * Properties to define an event bus\n */\nexport interface EventBusProps {\n  /**\n   * The name of the event bus you are creating\n   * Note: If 'eventSourceName' is passed in, you cannot set this\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#cfn-events-eventbus-name\n   * @default - automatically generated name\n   */\n  readonly eventBusName?: string;\n\n  /**\n   * The partner event source to associate with this event bus resource\n   * Note: If 'eventBusName' is passed in, you cannot set this\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#cfn-events-eventbus-eventsourcename\n   * @default - no partner event source\n   */\n  readonly eventSourceName?: string;\n}\n\n/**\n * Interface with properties necessary to import a reusable EventBus\n */\nexport interface EventBusAttributes {\n  /**\n   * The physical ID of this event bus resource\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#cfn-events-eventbus-name\n   */\n  readonly eventBusName: string;\n\n  /**\n   * The ARN of this event bus resource\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#Arn-fn::getatt\n   */\n  readonly eventBusArn: string;\n\n  /**\n   * The JSON policy of this event bus resource\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#Policy-fn::getatt\n   */\n  readonly eventBusPolicy: string;\n\n  /**\n   * The partner event source to associate with this event bus resource\n   *\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-events-eventbus.html#cfn-events-eventbus-eventsourcename\n   * @default - no partner event source\n   */\n  readonly eventSourceName?: string;\n}\n\nabstract class EventBusBase extends Resource implements IEventBus {\n  /**\n   * The physical ID of this event bus resource\n   */\n  public abstract readonly eventBusName: string;\n\n  /**\n   * The ARN of the event bus, such as:\n   * arn:aws:events:us-east-2:123456789012:event-bus/aws.partner/PartnerName/acct1/repo1.\n   */\n  public abstract readonly eventBusArn: string;\n\n  /**\n   * The policy for the event bus in JSON form.\n   */\n  public abstract readonly eventBusPolicy: string;\n\n  /**\n   * The name of the partner event source\n   */\n  public abstract readonly eventSourceName?: string;\n\n  public archive(id: string, props: BaseArchiveProps): Archive {\n    return new Archive(this, id, {\n      sourceEventBus: this,\n      description: props.description || `Event Archive for ${this.eventBusName} Event Bus`,\n      eventPattern: props.eventPattern,\n      retention: props.retention,\n      archiveName: props.archiveName,\n    });\n  }\n\n  public grantPutEventsTo(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['events:PutEvents'],\n      resourceArns: [this.eventBusArn],\n    });\n  }\n}\n\n/**\n * Define an EventBridge EventBus\n *\n * @resource AWS::Events::EventBus\n */\nexport class EventBus extends EventBusBase {\n\n  /**\n   * Import an existing event bus resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param eventBusArn ARN of imported event bus\n   */\n  public static fromEventBusArn(scope: Construct, id: string, eventBusArn: string): IEventBus {\n    const parts = Stack.of(scope).splitArn(eventBusArn, ArnFormat.SLASH_RESOURCE_NAME);\n\n    return new ImportedEventBus(scope, id, {\n      eventBusArn: eventBusArn,\n      eventBusName: parts.resourceName || '',\n      eventBusPolicy: '',\n    });\n  }\n\n  /**\n   * Import an existing event bus resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param eventBusName Name of imported event bus\n   */\n  public static fromEventBusName(scope: Construct, id: string, eventBusName: string): IEventBus {\n    const eventBusArn = Stack.of(scope).formatArn({\n      resource: 'event-bus',\n      service: 'events',\n      resourceName: eventBusName,\n    });\n\n    return EventBus.fromEventBusAttributes(scope, id, {\n      eventBusName: eventBusName,\n      eventBusArn: eventBusArn,\n      eventBusPolicy: '',\n    });\n  }\n\n  /**\n   * Import an existing event bus resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param attrs Imported event bus properties\n   */\n  public static fromEventBusAttributes(scope: Construct, id: string, attrs: EventBusAttributes): IEventBus {\n    return new ImportedEventBus(scope, id, attrs);\n  }\n\n  /**\n   * Permits an IAM Principal to send custom events to EventBridge\n   * so that they can be matched to rules.\n   *\n   * @param grantee The principal (no-op if undefined)\n   * @deprecated use grantAllPutEvents instead\n   */\n  public static grantPutEvents(grantee: iam.IGrantable): iam.Grant {\n    // It's currently not possible to restrict PutEvents to specific resources.\n    // See https://docs.aws.amazon.com/eventbridge/latest/userguide/permissions-reference-eventbridge.html\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['events:PutEvents'],\n      resourceArns: ['*'],\n    });\n  }\n\n  /**\n   * Permits an IAM Principal to send custom events to EventBridge\n   * so that they can be matched to rules.\n   *\n   * @param grantee The principal (no-op if undefined)\n   */\n  public static grantAllPutEvents(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['events:PutEvents'],\n      resourceArns: ['*'],\n    });\n  }\n\n  private static eventBusProps(defaultEventBusName: string, props: EventBusProps = {}) {\n    const { eventBusName, eventSourceName } = props;\n    const eventBusNameRegex = /^[\\/\\.\\-_A-Za-z0-9]{1,256}$/;\n\n    if (eventBusName !== undefined && eventSourceName !== undefined) {\n      throw new Error(\n        '\\'eventBusName\\' and \\'eventSourceName\\' cannot both be provided',\n      );\n    }\n\n    if (eventBusName !== undefined) {\n      if (!Token.isUnresolved(eventBusName)) {\n        if (eventBusName === 'default') {\n          throw new Error(\n            '\\'eventBusName\\' must not be \\'default\\'',\n          );\n        } else if (eventBusName.indexOf('/') > -1) {\n          throw new Error(\n            '\\'eventBusName\\' must not contain \\'/\\'',\n          );\n        } else if (!eventBusNameRegex.test(eventBusName)) {\n          throw new Error(\n            `'eventBusName' must satisfy: ${eventBusNameRegex}`,\n          );\n        }\n      }\n      return { eventBusName };\n    }\n\n    if (eventSourceName !== undefined) {\n      // Ex: aws.partner/PartnerName/acct1/repo1\n      const eventSourceNameRegex = /^aws\\.partner(\\/[\\.\\-_A-Za-z0-9]+){2,}$/;\n      if (!eventSourceNameRegex.test(eventSourceName)) {\n        throw new Error(\n          `'eventSourceName' must satisfy: ${eventSourceNameRegex}`,\n        );\n      } else if (!eventBusNameRegex.test(eventSourceName)) {\n        throw new Error(\n          `'eventSourceName' must satisfy: ${eventBusNameRegex}`,\n        );\n      }\n      return { eventBusName: eventSourceName, eventSourceName };\n    }\n\n    return { eventBusName: defaultEventBusName };\n  }\n\n  /**\n   * The physical ID of this event bus resource\n   */\n  public readonly eventBusName: string;\n\n  /**\n   * The ARN of the event bus, such as:\n   * arn:aws:events:us-east-2:123456789012:event-bus/aws.partner/PartnerName/acct1/repo1.\n   */\n  public readonly eventBusArn: string;\n\n  /**\n   * The policy for the event bus in JSON form.\n   */\n  public readonly eventBusPolicy: string;\n\n  /**\n   * The name of the partner event source\n   */\n  public readonly eventSourceName?: string;\n\n  constructor(scope: Construct, id: string, props?: EventBusProps) {\n    const { eventBusName, eventSourceName } = EventBus.eventBusProps(\n      Lazy.string({ produce: () => Names.uniqueId(this) }),\n      props,\n    );\n\n    super(scope, id, { physicalName: eventBusName });\n\n    const eventBus = new CfnEventBus(this, 'Resource', {\n      name: this.physicalName,\n      eventSourceName,\n    });\n\n    this.eventBusArn = this.getResourceArnAttribute(eventBus.attrArn, {\n      service: 'events',\n      resource: 'event-bus',\n      resourceName: eventBus.name,\n    });\n\n    this.eventBusName = this.getResourceNameAttribute(eventBus.ref);\n    this.eventBusPolicy = eventBus.attrPolicy;\n    this.eventSourceName = eventBus.eventSourceName;\n  }\n}\n\nclass ImportedEventBus extends EventBusBase {\n  public readonly eventBusArn: string;\n  public readonly eventBusName: string;\n  public readonly eventBusPolicy: string;\n  public readonly eventSourceName?: string;\n  constructor(scope: Construct, id: string, attrs: EventBusAttributes) {\n    const arnParts = Stack.of(scope).splitArn(attrs.eventBusArn, ArnFormat.SLASH_RESOURCE_NAME);\n    super(scope, id, {\n      account: arnParts.account,\n      region: arnParts.region,\n    });\n\n    this.eventBusArn = attrs.eventBusArn;\n    this.eventBusName = attrs.eventBusName;\n    this.eventBusPolicy = attrs.eventBusPolicy;\n    this.eventSourceName = attrs.eventSourceName;\n  }\n}\n"]} |
\ | No newline at end of file |