@macedon-technologies/batman 1.0.18 ā 1.1.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.
- package/.jsii +108 -9
- package/API.md +305 -0
- package/lib/BatmanProject.d.ts +4 -0
- package/lib/BatmanProject.js +6 -2
- package/lib/CodeOwnersFile.d.ts +8 -0
- package/lib/CodeOwnersFile.js +20 -0
- package/lib/PrDeployWorkflow.js +20 -1
- package/lib/ProductionDeployWorkflow.js +32 -3
- package/lib/StagingDeployWorkflow.js +32 -3
- package/lib/index.d.ts +1 -0
- package/lib/index.js +2 -1
- package/package.json +1 -1
package/.jsii
CHANGED
|
@@ -155,7 +155,7 @@
|
|
|
155
155
|
},
|
|
156
156
|
"locationInModule": {
|
|
157
157
|
"filename": "src/BatmanProject.ts",
|
|
158
|
-
"line":
|
|
158
|
+
"line": 38
|
|
159
159
|
},
|
|
160
160
|
"parameters": [
|
|
161
161
|
{
|
|
@@ -169,7 +169,7 @@
|
|
|
169
169
|
"kind": "class",
|
|
170
170
|
"locationInModule": {
|
|
171
171
|
"filename": "src/BatmanProject.ts",
|
|
172
|
-
"line":
|
|
172
|
+
"line": 37
|
|
173
173
|
},
|
|
174
174
|
"name": "BatmanProject",
|
|
175
175
|
"symbolId": "src/BatmanProject:BatmanProject"
|
|
@@ -187,7 +187,7 @@
|
|
|
187
187
|
"kind": "interface",
|
|
188
188
|
"locationInModule": {
|
|
189
189
|
"filename": "src/BatmanProject.ts",
|
|
190
|
-
"line":
|
|
190
|
+
"line": 8
|
|
191
191
|
},
|
|
192
192
|
"name": "BatmanProjectOptions",
|
|
193
193
|
"properties": [
|
|
@@ -200,7 +200,7 @@
|
|
|
200
200
|
"immutable": true,
|
|
201
201
|
"locationInModule": {
|
|
202
202
|
"filename": "src/BatmanProject.ts",
|
|
203
|
-
"line":
|
|
203
|
+
"line": 13
|
|
204
204
|
},
|
|
205
205
|
"name": "dev",
|
|
206
206
|
"type": {
|
|
@@ -216,7 +216,7 @@
|
|
|
216
216
|
"immutable": true,
|
|
217
217
|
"locationInModule": {
|
|
218
218
|
"filename": "src/BatmanProject.ts",
|
|
219
|
-
"line":
|
|
219
|
+
"line": 23
|
|
220
220
|
},
|
|
221
221
|
"name": "prod",
|
|
222
222
|
"type": {
|
|
@@ -232,13 +232,35 @@
|
|
|
232
232
|
"immutable": true,
|
|
233
233
|
"locationInModule": {
|
|
234
234
|
"filename": "src/BatmanProject.ts",
|
|
235
|
-
"line":
|
|
235
|
+
"line": 18
|
|
236
236
|
},
|
|
237
237
|
"name": "staging",
|
|
238
238
|
"type": {
|
|
239
239
|
"fqn": "@macedon-technologies/batman.ApplicationEnvironmentConfig"
|
|
240
240
|
}
|
|
241
241
|
},
|
|
242
|
+
{
|
|
243
|
+
"abstract": true,
|
|
244
|
+
"docs": {
|
|
245
|
+
"stability": "stable",
|
|
246
|
+
"summary": "Additional code owners to add to the CODEOWNERS file."
|
|
247
|
+
},
|
|
248
|
+
"immutable": true,
|
|
249
|
+
"locationInModule": {
|
|
250
|
+
"filename": "src/BatmanProject.ts",
|
|
251
|
+
"line": 33
|
|
252
|
+
},
|
|
253
|
+
"name": "additionalCodeOwners",
|
|
254
|
+
"optional": true,
|
|
255
|
+
"type": {
|
|
256
|
+
"collection": {
|
|
257
|
+
"elementtype": {
|
|
258
|
+
"primitive": "string"
|
|
259
|
+
},
|
|
260
|
+
"kind": "array"
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
},
|
|
242
264
|
{
|
|
243
265
|
"abstract": true,
|
|
244
266
|
"docs": {
|
|
@@ -248,7 +270,7 @@
|
|
|
248
270
|
"immutable": true,
|
|
249
271
|
"locationInModule": {
|
|
250
272
|
"filename": "src/BatmanProject.ts",
|
|
251
|
-
"line":
|
|
273
|
+
"line": 28
|
|
252
274
|
},
|
|
253
275
|
"name": "additionalTags",
|
|
254
276
|
"optional": true,
|
|
@@ -264,6 +286,83 @@
|
|
|
264
286
|
],
|
|
265
287
|
"symbolId": "src/BatmanProject:BatmanProjectOptions"
|
|
266
288
|
},
|
|
289
|
+
"@macedon-technologies/batman.CodeOwnersFile": {
|
|
290
|
+
"assembly": "@macedon-technologies/batman",
|
|
291
|
+
"base": "projen.TextFile",
|
|
292
|
+
"docs": {
|
|
293
|
+
"stability": "stable"
|
|
294
|
+
},
|
|
295
|
+
"fqn": "@macedon-technologies/batman.CodeOwnersFile",
|
|
296
|
+
"initializer": {
|
|
297
|
+
"docs": {
|
|
298
|
+
"stability": "stable"
|
|
299
|
+
},
|
|
300
|
+
"locationInModule": {
|
|
301
|
+
"filename": "src/CodeOwnersFile.ts",
|
|
302
|
+
"line": 9
|
|
303
|
+
},
|
|
304
|
+
"parameters": [
|
|
305
|
+
{
|
|
306
|
+
"name": "project",
|
|
307
|
+
"type": {
|
|
308
|
+
"fqn": "projen.awscdk.AwsCdkTypeScriptApp"
|
|
309
|
+
}
|
|
310
|
+
},
|
|
311
|
+
{
|
|
312
|
+
"name": "options",
|
|
313
|
+
"optional": true,
|
|
314
|
+
"type": {
|
|
315
|
+
"fqn": "@macedon-technologies/batman.CodeOwnersFileOptions"
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
]
|
|
319
|
+
},
|
|
320
|
+
"kind": "class",
|
|
321
|
+
"locationInModule": {
|
|
322
|
+
"filename": "src/CodeOwnersFile.ts",
|
|
323
|
+
"line": 8
|
|
324
|
+
},
|
|
325
|
+
"name": "CodeOwnersFile",
|
|
326
|
+
"symbolId": "src/CodeOwnersFile:CodeOwnersFile"
|
|
327
|
+
},
|
|
328
|
+
"@macedon-technologies/batman.CodeOwnersFileOptions": {
|
|
329
|
+
"assembly": "@macedon-technologies/batman",
|
|
330
|
+
"datatype": true,
|
|
331
|
+
"docs": {
|
|
332
|
+
"stability": "stable"
|
|
333
|
+
},
|
|
334
|
+
"fqn": "@macedon-technologies/batman.CodeOwnersFileOptions",
|
|
335
|
+
"kind": "interface",
|
|
336
|
+
"locationInModule": {
|
|
337
|
+
"filename": "src/CodeOwnersFile.ts",
|
|
338
|
+
"line": 4
|
|
339
|
+
},
|
|
340
|
+
"name": "CodeOwnersFileOptions",
|
|
341
|
+
"properties": [
|
|
342
|
+
{
|
|
343
|
+
"abstract": true,
|
|
344
|
+
"docs": {
|
|
345
|
+
"stability": "stable"
|
|
346
|
+
},
|
|
347
|
+
"immutable": true,
|
|
348
|
+
"locationInModule": {
|
|
349
|
+
"filename": "src/CodeOwnersFile.ts",
|
|
350
|
+
"line": 5
|
|
351
|
+
},
|
|
352
|
+
"name": "additionalOwners",
|
|
353
|
+
"optional": true,
|
|
354
|
+
"type": {
|
|
355
|
+
"collection": {
|
|
356
|
+
"elementtype": {
|
|
357
|
+
"primitive": "string"
|
|
358
|
+
},
|
|
359
|
+
"kind": "array"
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
],
|
|
364
|
+
"symbolId": "src/CodeOwnersFile:CodeOwnersFileOptions"
|
|
365
|
+
},
|
|
267
366
|
"@macedon-technologies/batman.EnvironmentConfig": {
|
|
268
367
|
"assembly": "@macedon-technologies/batman",
|
|
269
368
|
"datatype": true,
|
|
@@ -632,6 +731,6 @@
|
|
|
632
731
|
"symbolId": "src/StagingDeployWorkflow:StagingDeployWorkflowOptions"
|
|
633
732
|
}
|
|
634
733
|
},
|
|
635
|
-
"version": "1.0
|
|
636
|
-
"fingerprint": "
|
|
734
|
+
"version": "1.1.0",
|
|
735
|
+
"fingerprint": "ERDgI81vdP1ZDtCBp28XH0O7m17pUwRA6ODICJafrFg="
|
|
637
736
|
}
|
package/API.md
CHANGED
|
@@ -1598,6 +1598,270 @@ public readonly DEFAULT_TS_JEST_TRANFORM_PATTERN: string;
|
|
|
1598
1598
|
|
|
1599
1599
|
---
|
|
1600
1600
|
|
|
1601
|
+
### CodeOwnersFile <a name="CodeOwnersFile" id="@macedon-technologies/batman.CodeOwnersFile"></a>
|
|
1602
|
+
|
|
1603
|
+
#### Initializers <a name="Initializers" id="@macedon-technologies/batman.CodeOwnersFile.Initializer"></a>
|
|
1604
|
+
|
|
1605
|
+
```typescript
|
|
1606
|
+
import { CodeOwnersFile } from '@macedon-technologies/batman'
|
|
1607
|
+
|
|
1608
|
+
new CodeOwnersFile(project: AwsCdkTypeScriptApp, options?: CodeOwnersFileOptions)
|
|
1609
|
+
```
|
|
1610
|
+
|
|
1611
|
+
| **Name** | **Type** | **Description** |
|
|
1612
|
+
| --- | --- | --- |
|
|
1613
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.Initializer.parameter.project">project</a></code> | <code>projen.awscdk.AwsCdkTypeScriptApp</code> | *No description.* |
|
|
1614
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.Initializer.parameter.options">options</a></code> | <code><a href="#@macedon-technologies/batman.CodeOwnersFileOptions">CodeOwnersFileOptions</a></code> | *No description.* |
|
|
1615
|
+
|
|
1616
|
+
---
|
|
1617
|
+
|
|
1618
|
+
##### `project`<sup>Required</sup> <a name="project" id="@macedon-technologies/batman.CodeOwnersFile.Initializer.parameter.project"></a>
|
|
1619
|
+
|
|
1620
|
+
- *Type:* projen.awscdk.AwsCdkTypeScriptApp
|
|
1621
|
+
|
|
1622
|
+
---
|
|
1623
|
+
|
|
1624
|
+
##### `options`<sup>Optional</sup> <a name="options" id="@macedon-technologies/batman.CodeOwnersFile.Initializer.parameter.options"></a>
|
|
1625
|
+
|
|
1626
|
+
- *Type:* <a href="#@macedon-technologies/batman.CodeOwnersFileOptions">CodeOwnersFileOptions</a>
|
|
1627
|
+
|
|
1628
|
+
---
|
|
1629
|
+
|
|
1630
|
+
#### Methods <a name="Methods" id="Methods"></a>
|
|
1631
|
+
|
|
1632
|
+
| **Name** | **Description** |
|
|
1633
|
+
| --- | --- |
|
|
1634
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
1635
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.postSynthesize">postSynthesize</a></code> | Called after synthesis. |
|
|
1636
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.preSynthesize">preSynthesize</a></code> | Called before synthesis. |
|
|
1637
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.synthesize">synthesize</a></code> | Writes the file to the project's output directory. |
|
|
1638
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.addLine">addLine</a></code> | Adds a line to the text file. |
|
|
1639
|
+
|
|
1640
|
+
---
|
|
1641
|
+
|
|
1642
|
+
##### `toString` <a name="toString" id="@macedon-technologies/batman.CodeOwnersFile.toString"></a>
|
|
1643
|
+
|
|
1644
|
+
```typescript
|
|
1645
|
+
public toString(): string
|
|
1646
|
+
```
|
|
1647
|
+
|
|
1648
|
+
Returns a string representation of this construct.
|
|
1649
|
+
|
|
1650
|
+
##### `postSynthesize` <a name="postSynthesize" id="@macedon-technologies/batman.CodeOwnersFile.postSynthesize"></a>
|
|
1651
|
+
|
|
1652
|
+
```typescript
|
|
1653
|
+
public postSynthesize(): void
|
|
1654
|
+
```
|
|
1655
|
+
|
|
1656
|
+
Called after synthesis.
|
|
1657
|
+
|
|
1658
|
+
Order is *not* guaranteed.
|
|
1659
|
+
|
|
1660
|
+
##### `preSynthesize` <a name="preSynthesize" id="@macedon-technologies/batman.CodeOwnersFile.preSynthesize"></a>
|
|
1661
|
+
|
|
1662
|
+
```typescript
|
|
1663
|
+
public preSynthesize(): void
|
|
1664
|
+
```
|
|
1665
|
+
|
|
1666
|
+
Called before synthesis.
|
|
1667
|
+
|
|
1668
|
+
##### `synthesize` <a name="synthesize" id="@macedon-technologies/batman.CodeOwnersFile.synthesize"></a>
|
|
1669
|
+
|
|
1670
|
+
```typescript
|
|
1671
|
+
public synthesize(): void
|
|
1672
|
+
```
|
|
1673
|
+
|
|
1674
|
+
Writes the file to the project's output directory.
|
|
1675
|
+
|
|
1676
|
+
##### `addLine` <a name="addLine" id="@macedon-technologies/batman.CodeOwnersFile.addLine"></a>
|
|
1677
|
+
|
|
1678
|
+
```typescript
|
|
1679
|
+
public addLine(line: string): void
|
|
1680
|
+
```
|
|
1681
|
+
|
|
1682
|
+
Adds a line to the text file.
|
|
1683
|
+
|
|
1684
|
+
###### `line`<sup>Required</sup> <a name="line" id="@macedon-technologies/batman.CodeOwnersFile.addLine.parameter.line"></a>
|
|
1685
|
+
|
|
1686
|
+
- *Type:* string
|
|
1687
|
+
|
|
1688
|
+
the line to add (can use tokens).
|
|
1689
|
+
|
|
1690
|
+
---
|
|
1691
|
+
|
|
1692
|
+
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
1693
|
+
|
|
1694
|
+
| **Name** | **Description** |
|
|
1695
|
+
| --- | --- |
|
|
1696
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
|
|
1697
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.isComponent">isComponent</a></code> | Test whether the given construct is a component. |
|
|
1698
|
+
|
|
1699
|
+
---
|
|
1700
|
+
|
|
1701
|
+
##### `isConstruct` <a name="isConstruct" id="@macedon-technologies/batman.CodeOwnersFile.isConstruct"></a>
|
|
1702
|
+
|
|
1703
|
+
```typescript
|
|
1704
|
+
import { CodeOwnersFile } from '@macedon-technologies/batman'
|
|
1705
|
+
|
|
1706
|
+
CodeOwnersFile.isConstruct(x: any)
|
|
1707
|
+
```
|
|
1708
|
+
|
|
1709
|
+
Checks if `x` is a construct.
|
|
1710
|
+
|
|
1711
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
1712
|
+
instances, even when the construct library is symlinked.
|
|
1713
|
+
|
|
1714
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
1715
|
+
disk are seen as independent, completely different libraries. As a
|
|
1716
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
1717
|
+
is seen as a different class, and an instance of one class will not test as
|
|
1718
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
1719
|
+
like this, but users may manually symlink construct libraries together or
|
|
1720
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
1721
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
1722
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
1723
|
+
this type-testing method instead.
|
|
1724
|
+
|
|
1725
|
+
###### `x`<sup>Required</sup> <a name="x" id="@macedon-technologies/batman.CodeOwnersFile.isConstruct.parameter.x"></a>
|
|
1726
|
+
|
|
1727
|
+
- *Type:* any
|
|
1728
|
+
|
|
1729
|
+
Any object.
|
|
1730
|
+
|
|
1731
|
+
---
|
|
1732
|
+
|
|
1733
|
+
##### `isComponent` <a name="isComponent" id="@macedon-technologies/batman.CodeOwnersFile.isComponent"></a>
|
|
1734
|
+
|
|
1735
|
+
```typescript
|
|
1736
|
+
import { CodeOwnersFile } from '@macedon-technologies/batman'
|
|
1737
|
+
|
|
1738
|
+
CodeOwnersFile.isComponent(x: any)
|
|
1739
|
+
```
|
|
1740
|
+
|
|
1741
|
+
Test whether the given construct is a component.
|
|
1742
|
+
|
|
1743
|
+
###### `x`<sup>Required</sup> <a name="x" id="@macedon-technologies/batman.CodeOwnersFile.isComponent.parameter.x"></a>
|
|
1744
|
+
|
|
1745
|
+
- *Type:* any
|
|
1746
|
+
|
|
1747
|
+
---
|
|
1748
|
+
|
|
1749
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
1750
|
+
|
|
1751
|
+
| **Name** | **Type** | **Description** |
|
|
1752
|
+
| --- | --- | --- |
|
|
1753
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
|
|
1754
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.project">project</a></code> | <code>projen.Project</code> | *No description.* |
|
|
1755
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.absolutePath">absolutePath</a></code> | <code>string</code> | The absolute path of this file. |
|
|
1756
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.path">path</a></code> | <code>string</code> | The file path, relative to the project's outdir. |
|
|
1757
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.changed">changed</a></code> | <code>boolean</code> | Indicates if the file has been changed during synthesis. |
|
|
1758
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.marker">marker</a></code> | <code>string</code> | The projen marker, used to identify files as projen-generated. |
|
|
1759
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.executable">executable</a></code> | <code>boolean</code> | Indicates if the file should be marked as executable. |
|
|
1760
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFile.property.readonly">readonly</a></code> | <code>boolean</code> | Indicates if the file should be read-only or read-write. |
|
|
1761
|
+
|
|
1762
|
+
---
|
|
1763
|
+
|
|
1764
|
+
##### `node`<sup>Required</sup> <a name="node" id="@macedon-technologies/batman.CodeOwnersFile.property.node"></a>
|
|
1765
|
+
|
|
1766
|
+
```typescript
|
|
1767
|
+
public readonly node: Node;
|
|
1768
|
+
```
|
|
1769
|
+
|
|
1770
|
+
- *Type:* constructs.Node
|
|
1771
|
+
|
|
1772
|
+
The tree node.
|
|
1773
|
+
|
|
1774
|
+
---
|
|
1775
|
+
|
|
1776
|
+
##### `project`<sup>Required</sup> <a name="project" id="@macedon-technologies/batman.CodeOwnersFile.property.project"></a>
|
|
1777
|
+
|
|
1778
|
+
```typescript
|
|
1779
|
+
public readonly project: Project;
|
|
1780
|
+
```
|
|
1781
|
+
|
|
1782
|
+
- *Type:* projen.Project
|
|
1783
|
+
|
|
1784
|
+
---
|
|
1785
|
+
|
|
1786
|
+
##### `absolutePath`<sup>Required</sup> <a name="absolutePath" id="@macedon-technologies/batman.CodeOwnersFile.property.absolutePath"></a>
|
|
1787
|
+
|
|
1788
|
+
```typescript
|
|
1789
|
+
public readonly absolutePath: string;
|
|
1790
|
+
```
|
|
1791
|
+
|
|
1792
|
+
- *Type:* string
|
|
1793
|
+
|
|
1794
|
+
The absolute path of this file.
|
|
1795
|
+
|
|
1796
|
+
---
|
|
1797
|
+
|
|
1798
|
+
##### `path`<sup>Required</sup> <a name="path" id="@macedon-technologies/batman.CodeOwnersFile.property.path"></a>
|
|
1799
|
+
|
|
1800
|
+
```typescript
|
|
1801
|
+
public readonly path: string;
|
|
1802
|
+
```
|
|
1803
|
+
|
|
1804
|
+
- *Type:* string
|
|
1805
|
+
|
|
1806
|
+
The file path, relative to the project's outdir.
|
|
1807
|
+
|
|
1808
|
+
---
|
|
1809
|
+
|
|
1810
|
+
##### `changed`<sup>Optional</sup> <a name="changed" id="@macedon-technologies/batman.CodeOwnersFile.property.changed"></a>
|
|
1811
|
+
|
|
1812
|
+
```typescript
|
|
1813
|
+
public readonly changed: boolean;
|
|
1814
|
+
```
|
|
1815
|
+
|
|
1816
|
+
- *Type:* boolean
|
|
1817
|
+
|
|
1818
|
+
Indicates if the file has been changed during synthesis.
|
|
1819
|
+
|
|
1820
|
+
This property is
|
|
1821
|
+
only available in `postSynthesize()` hooks. If this is `undefined`, the
|
|
1822
|
+
file has not been synthesized yet.
|
|
1823
|
+
|
|
1824
|
+
---
|
|
1825
|
+
|
|
1826
|
+
##### `marker`<sup>Optional</sup> <a name="marker" id="@macedon-technologies/batman.CodeOwnersFile.property.marker"></a>
|
|
1827
|
+
|
|
1828
|
+
```typescript
|
|
1829
|
+
public readonly marker: string;
|
|
1830
|
+
```
|
|
1831
|
+
|
|
1832
|
+
- *Type:* string
|
|
1833
|
+
|
|
1834
|
+
The projen marker, used to identify files as projen-generated.
|
|
1835
|
+
|
|
1836
|
+
Value is undefined if the project is being ejected.
|
|
1837
|
+
|
|
1838
|
+
---
|
|
1839
|
+
|
|
1840
|
+
##### `executable`<sup>Required</sup> <a name="executable" id="@macedon-technologies/batman.CodeOwnersFile.property.executable"></a>
|
|
1841
|
+
|
|
1842
|
+
```typescript
|
|
1843
|
+
public readonly executable: boolean;
|
|
1844
|
+
```
|
|
1845
|
+
|
|
1846
|
+
- *Type:* boolean
|
|
1847
|
+
|
|
1848
|
+
Indicates if the file should be marked as executable.
|
|
1849
|
+
|
|
1850
|
+
---
|
|
1851
|
+
|
|
1852
|
+
##### `readonly`<sup>Required</sup> <a name="readonly" id="@macedon-technologies/batman.CodeOwnersFile.property.readonly"></a>
|
|
1853
|
+
|
|
1854
|
+
```typescript
|
|
1855
|
+
public readonly readonly: boolean;
|
|
1856
|
+
```
|
|
1857
|
+
|
|
1858
|
+
- *Type:* boolean
|
|
1859
|
+
|
|
1860
|
+
Indicates if the file should be read-only or read-write.
|
|
1861
|
+
|
|
1862
|
+
---
|
|
1863
|
+
|
|
1864
|
+
|
|
1601
1865
|
### ProductionDeployWorkflow <a name="ProductionDeployWorkflow" id="@macedon-technologies/batman.ProductionDeployWorkflow"></a>
|
|
1602
1866
|
|
|
1603
1867
|
#### Initializers <a name="Initializers" id="@macedon-technologies/batman.ProductionDeployWorkflow.Initializer"></a>
|
|
@@ -2808,6 +3072,7 @@ const batmanProjectOptions: BatmanProjectOptions = { ... }
|
|
|
2808
3072
|
| <code><a href="#@macedon-technologies/batman.BatmanProjectOptions.property.dev">dev</a></code> | <code><a href="#@macedon-technologies/batman.ApplicationEnvironmentConfig">ApplicationEnvironmentConfig</a></code> | Development environment configuration. |
|
|
2809
3073
|
| <code><a href="#@macedon-technologies/batman.BatmanProjectOptions.property.prod">prod</a></code> | <code><a href="#@macedon-technologies/batman.ApplicationEnvironmentConfig">ApplicationEnvironmentConfig</a></code> | Production environment configuration. |
|
|
2810
3074
|
| <code><a href="#@macedon-technologies/batman.BatmanProjectOptions.property.staging">staging</a></code> | <code><a href="#@macedon-technologies/batman.ApplicationEnvironmentConfig">ApplicationEnvironmentConfig</a></code> | Development environment configuration. |
|
|
3075
|
+
| <code><a href="#@macedon-technologies/batman.BatmanProjectOptions.property.additionalCodeOwners">additionalCodeOwners</a></code> | <code>string[]</code> | Additional code owners to add to the CODEOWNERS file. |
|
|
2811
3076
|
| <code><a href="#@macedon-technologies/batman.BatmanProjectOptions.property.additionalTags">additionalTags</a></code> | <code>{[ key: string ]: string}</code> | Additional tags to apply to all stacks. |
|
|
2812
3077
|
|
|
2813
3078
|
---
|
|
@@ -5428,6 +5693,18 @@ Development environment configuration.
|
|
|
5428
5693
|
|
|
5429
5694
|
---
|
|
5430
5695
|
|
|
5696
|
+
##### `additionalCodeOwners`<sup>Optional</sup> <a name="additionalCodeOwners" id="@macedon-technologies/batman.BatmanProjectOptions.property.additionalCodeOwners"></a>
|
|
5697
|
+
|
|
5698
|
+
```typescript
|
|
5699
|
+
public readonly additionalCodeOwners: string[];
|
|
5700
|
+
```
|
|
5701
|
+
|
|
5702
|
+
- *Type:* string[]
|
|
5703
|
+
|
|
5704
|
+
Additional code owners to add to the CODEOWNERS file.
|
|
5705
|
+
|
|
5706
|
+
---
|
|
5707
|
+
|
|
5431
5708
|
##### `additionalTags`<sup>Optional</sup> <a name="additionalTags" id="@macedon-technologies/batman.BatmanProjectOptions.property.additionalTags"></a>
|
|
5432
5709
|
|
|
5433
5710
|
```typescript
|
|
@@ -5440,6 +5717,34 @@ Additional tags to apply to all stacks.
|
|
|
5440
5717
|
|
|
5441
5718
|
---
|
|
5442
5719
|
|
|
5720
|
+
### CodeOwnersFileOptions <a name="CodeOwnersFileOptions" id="@macedon-technologies/batman.CodeOwnersFileOptions"></a>
|
|
5721
|
+
|
|
5722
|
+
#### Initializer <a name="Initializer" id="@macedon-technologies/batman.CodeOwnersFileOptions.Initializer"></a>
|
|
5723
|
+
|
|
5724
|
+
```typescript
|
|
5725
|
+
import { CodeOwnersFileOptions } from '@macedon-technologies/batman'
|
|
5726
|
+
|
|
5727
|
+
const codeOwnersFileOptions: CodeOwnersFileOptions = { ... }
|
|
5728
|
+
```
|
|
5729
|
+
|
|
5730
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
5731
|
+
|
|
5732
|
+
| **Name** | **Type** | **Description** |
|
|
5733
|
+
| --- | --- | --- |
|
|
5734
|
+
| <code><a href="#@macedon-technologies/batman.CodeOwnersFileOptions.property.additionalOwners">additionalOwners</a></code> | <code>string[]</code> | *No description.* |
|
|
5735
|
+
|
|
5736
|
+
---
|
|
5737
|
+
|
|
5738
|
+
##### `additionalOwners`<sup>Optional</sup> <a name="additionalOwners" id="@macedon-technologies/batman.CodeOwnersFileOptions.property.additionalOwners"></a>
|
|
5739
|
+
|
|
5740
|
+
```typescript
|
|
5741
|
+
public readonly additionalOwners: string[];
|
|
5742
|
+
```
|
|
5743
|
+
|
|
5744
|
+
- *Type:* string[]
|
|
5745
|
+
|
|
5746
|
+
---
|
|
5747
|
+
|
|
5443
5748
|
### EnvironmentConfig <a name="EnvironmentConfig" id="@macedon-technologies/batman.EnvironmentConfig"></a>
|
|
5444
5749
|
|
|
5445
5750
|
#### Initializer <a name="Initializer" id="@macedon-technologies/batman.EnvironmentConfig.Initializer"></a>
|
package/lib/BatmanProject.d.ts
CHANGED
|
@@ -19,6 +19,10 @@ export interface BatmanProjectOptions extends AwsCdkTypeScriptAppOptions {
|
|
|
19
19
|
readonly additionalTags?: {
|
|
20
20
|
[key: string]: string;
|
|
21
21
|
};
|
|
22
|
+
/**
|
|
23
|
+
* Additional code owners to add to the CODEOWNERS file
|
|
24
|
+
*/
|
|
25
|
+
readonly additionalCodeOwners?: string[];
|
|
22
26
|
}
|
|
23
27
|
export declare class BatmanProject extends AwsCdkTypeScriptApp {
|
|
24
28
|
constructor(options: BatmanProjectOptions);
|
package/lib/BatmanProject.js
CHANGED
|
@@ -6,6 +6,7 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
6
6
|
const awscdk_1 = require("projen/lib/awscdk");
|
|
7
7
|
const github_1 = require("projen/lib/github");
|
|
8
8
|
const Application_1 = require("./Application");
|
|
9
|
+
const CodeOwnersFile_1 = require("./CodeOwnersFile");
|
|
9
10
|
const GitHubRolesFile_1 = require("./GitHubRolesFile");
|
|
10
11
|
const ViteReactProject_1 = require("./ViteReactProject");
|
|
11
12
|
class BatmanProject extends awscdk_1.AwsCdkTypeScriptApp {
|
|
@@ -83,6 +84,9 @@ class BatmanProject extends awscdk_1.AwsCdkTypeScriptApp {
|
|
|
83
84
|
account: PRIMARY_ACCOUNT,
|
|
84
85
|
primaryRegion: PRIMARY_REGION,
|
|
85
86
|
});
|
|
87
|
+
new CodeOwnersFile_1.CodeOwnersFile(this, {
|
|
88
|
+
additionalOwners: options.additionalCodeOwners,
|
|
89
|
+
});
|
|
86
90
|
const viteReact = new ViteReactProject_1.ViteReactProject({
|
|
87
91
|
name: 'web',
|
|
88
92
|
defaultReleaseBranch: 'main',
|
|
@@ -105,5 +109,5 @@ class BatmanProject extends awscdk_1.AwsCdkTypeScriptApp {
|
|
|
105
109
|
}
|
|
106
110
|
exports.BatmanProject = BatmanProject;
|
|
107
111
|
_a = JSII_RTTI_SYMBOL_1;
|
|
108
|
-
BatmanProject[_a] = { fqn: "@macedon-technologies/batman.BatmanProject", version: "1.0
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
BatmanProject[_a] = { fqn: "@macedon-technologies/batman.BatmanProject", version: "1.1.0" };
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BatmanProject.js","sourceRoot":"","sources":["../src/BatmanProject.ts"],"names":[],"mappings":";;;;;AAAA,8CAAoF;AACpF,8CAAsD;AACtD,+CAA0E;AAC1E,qDAAkD;AAClD,uDAAoD;AACpD,yDAAsD;AA+BtD,MAAa,aAAc,SAAQ,4BAAmB;IACpD,YAAY,OAA6B;QACvC,KAAK,CAAC;YACJ,GAAG,OAAO;YACV,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,SAAS;YAC3C,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,IAAI,MAAM;YAC5D,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,UAAU,EAAE,IAAI;YAChB,aAAa,EAAE,KAAK;YACpB,IAAI,EAAE;gBACJ,mBAAmB;gBACnB,gBAAgB;gBAChB,WAAW;gBACX,IAAI;gBACJ,qBAAqB;gBACrB,sBAAsB;gBACtB,2BAA2B;gBAC3B,0BAA0B;gBAC1B,mCAAmC;gBACnC,cAAc;gBACd,iCAAiC;gBACjC,SAAS;gBACT,iBAAiB;gBACjB,GAAG,OAAO,CAAC,IAAI,IAAI,EAAE;aACtB;YACD,OAAO,EAAE;gBACP,qBAAqB;gBACrB,SAAS;gBACT,cAAc;gBACd,qCAAqC;gBACrC,GAAG,OAAO,CAAC,OAAO,IAAI,EAAE;aACzB;YACD,SAAS,EAAE;gBACT,mDAAmD;gBACnD,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE;aAC3B;YACD,QAAQ,EAAE;gBACR,GAAG,OAAO,CAAC,QAAQ;gBACnB,eAAe,EAAE;oBACf,GAAG,OAAO,CAAC,QAAQ,EAAE,eAAe;oBACpC,eAAe,EAAE,IAAI;oBACrB,0BAA0B,EAAE,IAAI;iBACjC;aACF;YACD,UAAU,EAAE,KAAK;YACjB,cAAc,EAAE,OAAO,CAAC,cAAc,IAAI,IAAI;YAC9C,kBAAkB,EAAE;gBAClB,eAAe,EAAE;oBACf,iBAAiB,EAAE,0BAAiB,CAAC,uBAAuB,CAAC;wBAC3D,MAAM,EAAE,cAAc;qBACvB,CAAC;iBACH;aACF;SACF,CAAC,CAAC;QAGH,gCAAgC;QAChC,MAAM,eAAe,GAAG,cAAc,CAAC;QACvC,MAAM,cAAc,GAAG,WAAW,CAAC;QAEnC,IAAI,yBAAW,CAAC,IAAI,EAAE;YACpB,gBAAgB,EAAE,wBAAwB,OAAO,CAAC,IAAI,EAAE;YACxD,mBAAmB,EAAE,0DAA0D;YAC/E,GAAG,EAAE;gBACH,GAAG,OAAO,CAAC,GAAG;aACf;YACD,OAAO,EAAE;gBACP,GAAG,OAAO,CAAC,OAAO;aACnB;YACD,IAAI,EAAE;gBACJ,GAAG,OAAO,CAAC,GAAG;aACf;YACD,cAAc,EAAE,OAAO,CAAC,cAAc;SACvC,CAAC,CAAC;QAEH,IAAI,iCAAe,CAAC,IAAI,EAAE;YACxB,OAAO,EAAE,eAAe;YACxB,aAAa,EAAE,cAAc;SAC9B,CAAC,CAAC;QAEH,IAAI,+BAAc,CAAC,IAAI,EAAE;YACvB,gBAAgB,EAAE,OAAO,CAAC,oBAAoB;SAC/C,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,mCAAgB,CAAC;YACrC,IAAI,EAAE,KAAK;YACX,oBAAoB,EAAE,MAAM;YAC5B,MAAM,EAAE,IAAI;YACZ,MAAM,EAAE,KAAK;SACd,CAAC,CAAC;QACH,SAAS,CAAC,cAAc,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAChD,SAAS,CAAC,cAAc,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;QAEpD,MAAM,YAAY,GAAG,CAAC,GAAG,IAAc,EAAE,EAAE;YACzC,OAAO,gBAAgB,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAC7D,CAAC,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;YAClB,IAAI,EAAE,YAAY,CAChB,gFAAgF,EAChF,SAAS,CAAC,UAAU,CACrB;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YACtB,IAAI,EAAE,gFAAgF;YACtF,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC;IAGL,CAAC;;AA9GH,sCA+GC","sourcesContent":["import { AwsCdkTypeScriptApp, AwsCdkTypeScriptAppOptions } from 'projen/lib/awscdk';\nimport { GithubCredentials } from 'projen/lib/github';\nimport { Application, ApplicationEnvironmentConfig } from './Application';\nimport { CodeOwnersFile } from './CodeOwnersFile';\nimport { GitHubRolesFile } from './GitHubRolesFile';\nimport { ViteReactProject } from './ViteReactProject';\n\nexport interface BatmanProjectOptions extends AwsCdkTypeScriptAppOptions {\n\n  /**\n   * Development environment configuration\n   */\n  readonly dev: ApplicationEnvironmentConfig;\n\n  /**\n   * Development environment configuration\n   */\n  readonly staging: ApplicationEnvironmentConfig;\n\n  /**\n   * Production environment configuration\n   */\n  readonly prod: ApplicationEnvironmentConfig;\n\n  /**\n   * Additional tags to apply to all stacks\n   */\n  readonly additionalTags?: { [key: string]: string };\n\n  /**\n   * Additional code owners to add to the CODEOWNERS file\n   */\n  readonly additionalCodeOwners?: string[];\n}\n\n\nexport class BatmanProject extends AwsCdkTypeScriptApp {\n  constructor(options: BatmanProjectOptions) {\n    super({\n      ...options,\n      cdkVersion: options.cdkVersion || '2.224.0',\n      defaultReleaseBranch: options.defaultReleaseBranch || 'main',\n      name: options.name,\n      projenrcTs: true,\n      buildWorkflow: false,\n      deps: [\n        '@types/aws-lambda',\n        '@types/express',\n        '@types/pg',\n        'pg',\n        '@aws-sdk/rds-signer',\n        '@matthewbonig/secret',\n        'datadog-cdk-constructs-v2',\n        '@cdklabs/aws-lambda-rust',\n        '@aws-lambda-powertools/parameters',\n        'jsonwebtoken',\n        '@aws-sdk/client-secrets-manager',\n        'express',\n        'serverless-http',\n        ...options.deps || [],\n      ],\n      devDeps: [\n        '@types/jsonwebtoken',\n        'nodemon',\n        'concurrently',\n        '@macedon-technologies/batman@^1.0.0',\n        ...options.devDeps || [],\n      ],\n      gitignore: [\n        'src/constructs/handler/clerk-authorizer/target/**',\n        ...options.gitignore || [],\n      ],\n      tsconfig: {\n        ...options.tsconfig,\n        compilerOptions: {\n          ...options.tsconfig?.compilerOptions,\n          isolatedModules: true,\n          allowImportingTsExtensions: true,\n        },\n      },\n      sampleCode: false,\n      minNodeVersion: options.minNodeVersion || '22',\n      depsUpgradeOptions: {\n        workflowOptions: {\n          projenCredentials: GithubCredentials.fromPersonalAccessToken({\n            secret: 'GITHUB_TOKEN',\n          }),\n        },\n      },\n    });\n\n\n    // Create standard project files\n    const PRIMARY_ACCOUNT = '015955817263';\n    const PRIMARY_REGION = 'us-east-1';\n\n    new Application(this, {\n      githubRepository: `macedon-technologies/${options.name}`,\n      clerkPublishableKey: 'pk_test_aW50ZW5zZS1sZWVjaC0yMi5jbGVyay5hY2NvdW50cy5kZXYk',\n      dev: {\n        ...options.dev,\n      },\n      staging: {\n        ...options.staging,\n      },\n      prod: {\n        ...options.dev,\n      },\n      additionalTags: options.additionalTags,\n    });\n\n    new GitHubRolesFile(this, {\n      account: PRIMARY_ACCOUNT,\n      primaryRegion: PRIMARY_REGION,\n    });\n\n    new CodeOwnersFile(this, {\n      additionalOwners: options.additionalCodeOwners,\n    });\n\n    const viteReact = new ViteReactProject({\n      name: 'web',\n      defaultReleaseBranch: 'main',\n      parent: this,\n      outdir: 'web',\n    });\n    viteReact.addConfigField('something', 'number');\n    viteReact.addConfigField('somethingElse', 'string');\n\n    const concurrently = (...args: string[]) => {\n      return `concurrently ${args.map(a => `\"${a}\"`).join(' ')}`;\n    };\n\n    this.addTask('dev', {\n      exec: concurrently(\n        'nodemon --watch ./src/constructs/handler --watch ./local/dev.ts ./local/dev.ts',\n        viteReact.devCommand,\n      ),\n    });\n\n    this.addTask('cdk:dev', {\n      exec: 'yarn cdk -a \"npx ts-node -P tsconfig.json --prefer-ts-exts src/LocalDevApp.ts\"',\n      receiveArgs: true,\n    });\n\n\n  }\n}\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { TextFile } from 'projen';
|
|
2
|
+
import { AwsCdkTypeScriptApp } from 'projen/lib/awscdk';
|
|
3
|
+
export interface CodeOwnersFileOptions {
|
|
4
|
+
readonly additionalOwners?: string[];
|
|
5
|
+
}
|
|
6
|
+
export declare class CodeOwnersFile extends TextFile {
|
|
7
|
+
constructor(project: AwsCdkTypeScriptApp, options?: CodeOwnersFileOptions);
|
|
8
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.CodeOwnersFile = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const projen_1 = require("projen");
|
|
7
|
+
class CodeOwnersFile extends projen_1.TextFile {
|
|
8
|
+
constructor(project, options = {}) {
|
|
9
|
+
const defaultOwners = ['* @macedon-technologies/platform'];
|
|
10
|
+
const allOwners = [...defaultOwners, ...(options.additionalOwners || [])];
|
|
11
|
+
super(project, '.github/CODEOWNERS', {
|
|
12
|
+
lines: allOwners,
|
|
13
|
+
marker: true,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.CodeOwnersFile = CodeOwnersFile;
|
|
18
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
19
|
+
CodeOwnersFile[_a] = { fqn: "@macedon-technologies/batman.CodeOwnersFile", version: "1.1.0" };
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29kZU93bmVyc0ZpbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvQ29kZU93bmVyc0ZpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBa0M7QUFPbEMsTUFBYSxjQUFlLFNBQVEsaUJBQVE7SUFDMUMsWUFBWSxPQUE0QixFQUFFLFVBQWlDLEVBQUU7UUFDM0UsTUFBTSxhQUFhLEdBQUcsQ0FBQyxrQ0FBa0MsQ0FBQyxDQUFDO1FBQzNELE1BQU0sU0FBUyxHQUFHLENBQUMsR0FBRyxhQUFhLEVBQUUsR0FBRyxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRTFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUU7WUFDbkMsS0FBSyxFQUFFLFNBQVM7WUFDaEIsTUFBTSxFQUFFLElBQUk7U0FDYixDQUFDLENBQUM7SUFDTCxDQUFDOztBQVRILHdDQVVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGV4dEZpbGUgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgQXdzQ2RrVHlwZVNjcmlwdEFwcCB9IGZyb20gJ3Byb2plbi9saWIvYXdzY2RrJztcblxuZXhwb3J0IGludGVyZmFjZSBDb2RlT3duZXJzRmlsZU9wdGlvbnMge1xuICByZWFkb25seSBhZGRpdGlvbmFsT3duZXJzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBjbGFzcyBDb2RlT3duZXJzRmlsZSBleHRlbmRzIFRleHRGaWxlIHtcbiAgY29uc3RydWN0b3IocHJvamVjdDogQXdzQ2RrVHlwZVNjcmlwdEFwcCwgb3B0aW9uczogQ29kZU93bmVyc0ZpbGVPcHRpb25zID0ge30pIHtcbiAgICBjb25zdCBkZWZhdWx0T3duZXJzID0gWycqIEBtYWNlZG9uLXRlY2hub2xvZ2llcy9wbGF0Zm9ybSddO1xuICAgIGNvbnN0IGFsbE93bmVycyA9IFsuLi5kZWZhdWx0T3duZXJzLCAuLi4ob3B0aW9ucy5hZGRpdGlvbmFsT3duZXJzIHx8IFtdKV07XG5cbiAgICBzdXBlcihwcm9qZWN0LCAnLmdpdGh1Yi9DT0RFT1dORVJTJywge1xuICAgICAgbGluZXM6IGFsbE93bmVycyxcbiAgICAgIG1hcmtlcjogdHJ1ZSxcbiAgICB9KTtcbiAgfVxufVxuIl19
|
package/lib/PrDeployWorkflow.js
CHANGED
|
@@ -95,6 +95,25 @@ class PrDeployWorkflow extends projen_1.YamlFile {
|
|
|
95
95
|
].join('\n'),
|
|
96
96
|
},
|
|
97
97
|
},
|
|
98
|
+
{
|
|
99
|
+
name: 'Notify Slack',
|
|
100
|
+
if: 'always()',
|
|
101
|
+
run: [
|
|
102
|
+
'STATUS="${{ job.status }}"',
|
|
103
|
+
'COLOR="good"',
|
|
104
|
+
'if [ "$STATUS" != "success" ]; then',
|
|
105
|
+
' COLOR="danger"',
|
|
106
|
+
'fi',
|
|
107
|
+
'WEBSITE_URL="${{ steps.outputs.outputs.website_url }}"',
|
|
108
|
+
'MESSAGE="PR Deploy: $STATUS\\nRepo: ${{ github.repository }}\\nPR: #${{ github.event.number }}\\nCommit: ${{ github.sha }}"',
|
|
109
|
+
'if [ -n "$WEBSITE_URL" ]; then',
|
|
110
|
+
' MESSAGE="$MESSAGE\\nš Website: <$WEBSITE_URL|View Site>"',
|
|
111
|
+
'fi',
|
|
112
|
+
'curl -X POST -H \'Content-type: application/json\' \\',
|
|
113
|
+
' --data "{\\"attachments\\":[{\\"color\\":\\"$COLOR\\",\\"text\\":\\"$MESSAGE\\"}]}" \\',
|
|
114
|
+
' ${{ secrets.SLACK_CHANNEL }}',
|
|
115
|
+
].join('\n'),
|
|
116
|
+
},
|
|
98
117
|
],
|
|
99
118
|
},
|
|
100
119
|
},
|
|
@@ -103,4 +122,4 @@ class PrDeployWorkflow extends projen_1.YamlFile {
|
|
|
103
122
|
}
|
|
104
123
|
}
|
|
105
124
|
exports.PrDeployWorkflow = PrDeployWorkflow;
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PrDeployWorkflow.js","sourceRoot":"","sources":["../src/PrDeployWorkflow.ts"],"names":[],"mappings":";;;AAAA,mCAAkC;AASlC,MAAa,gBAAiB,SAAQ,iBAAQ;IAC5C,YAAY,OAA4B,EAAE,OAAgC;QACxE,KAAK,CAAC,OAAO,EAAE,iCAAiC,EAAE;YAChD,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,IAAI;YACd,GAAG,EAAE;gBACH,IAAI,EAAE,WAAW;gBACjB,EAAE,EAAE;oBACF,YAAY,EAAE;wBACZ,KAAK,EAAE,CAAC,QAAQ,EAAE,aAAa,EAAE,UAAU,CAAC;qBAC7C;iBACF;gBACD,WAAW,EAAE;oBACX,UAAU,EAAE,OAAO;oBACnB,UAAU,EAAE,MAAM;oBAClB,eAAe,EAAE,OAAO;iBACzB;gBACD,IAAI,EAAE;oBACJ,MAAM,EAAE;wBACN,SAAS,EAAE,eAAe;wBAC1B,OAAO,EAAE;4BACP;gCACE,IAAI,EAAE,UAAU;gCAChB,IAAI,EAAE,qBAAqB;6BAC5B;4BACD;gCACE,IAAI,EAAE,eAAe;gCACrB,IAAI,EAAE,uBAAuB;gCAC7B,IAAI,EAAE;oCACJ,cAAc,EAAE,IAAI;iCACrB;6BACF;4BACD;gCACE,IAAI,EAAE,2BAA2B;gCACjC,IAAI,EAAE,0CAA0C;gCAChD,IAAI,EAAE;oCACJ,gBAAgB,EAAE,OAAO,CAAC,OAAO;oCACjC,YAAY,EAAE,OAAO,CAAC,SAAS;iCAChC;6BACF;4BACD;gCACE,IAAI,EAAE,sBAAsB;gCAC5B,GAAG,EAAE,gCAAgC;6BACtC;4BACD;gCACE,IAAI,EAAE,oBAAoB;gCAC1B,GAAG,EAAE,+BAA+B,OAAO,CAAC,mBAAmB,4EAA4E;6BAC5I;4BACD;gCACE,IAAI,EAAE,eAAe;gCACrB,EAAE,EAAE,QAAQ;gCACZ,GAAG,EAAE;oCACH,WAAW,EAAE,wBAAwB;iCACtC;gCACD,GAAG,EAAE;oCACH,gEAAgE;oCAChE,qCAAqC;oCACrC,sCAAsC;oCACtC,yCAAyC;oCACzC,4HAA4H;iCAC7H,CAAC,IAAI,CAAC,IAAI,CAAC;6BACb;4BACD;gCACE,IAAI,EAAE,iBAAiB;gCACvB,EAAE,EAAE,SAAS;gCACb,GAAG,EAAE;oCACH,sEAAsE;oCACtE,mDAAmD;oCACnD,kCAAkC;iCACnC,CAAC,IAAI,CAAC,IAAI,CAAC;6BACb;4BACD;gCACE,IAAI,EAAE,YAAY;gCAClB,IAAI,EAAE,0BAA0B;gCAChC,EAAE,EAAE,WAAW;gCACf,IAAI,EAAE;oCACJ,MAAM,EAAE;wCACN,kEAAkE;wCAClE,sGAAsG;wCACtG,EAAE;wCACF,mBAAmB;wCACnB,gDAAgD;wCAChD,GAAG;wCACH,EAAE;wCACF,oCAAoC;wCACpC,uCAAuC;wCACvC,8BAA8B;wCAC9B,4BAA4B;wCAC5B,cAAc;wCACd,IAAI;qCACL,CAAC,IAAI,CAAC,IAAI,CAAC;iCACb;6BACF;4BACD;gCACE,IAAI,EAAE,cAAc;gCACpB,EAAE,EAAE,UAAU;gCACd,GAAG,EAAE;oCACH,4BAA4B;oCAC5B,cAAc;oCACd,qCAAqC;oCACrC,kBAAkB;oCAClB,IAAI;oCACJ,wDAAwD;oCACxD,6HAA6H;oCAC7H,gCAAgC;oCAChC,6DAA6D;oCAC7D,IAAI;oCACJ,uDAAuD;oCACvD,0FAA0F;oCAC1F,gCAAgC;iCACjC,CAAC,IAAI,CAAC,IAAI,CAAC;6BACb;yBACF;qBACF;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;CACF;AAtHD,4CAsHC","sourcesContent":["import { YamlFile } from 'projen';\nimport { AwsCdkTypeScriptApp } from 'projen/lib/awscdk';\n\nexport interface PrDeployWorkflowOptions {\n  readonly roleArn: string;\n  readonly awsRegion: string;\n  readonly clerkPublishableKey: string;\n}\n\nexport class PrDeployWorkflow extends YamlFile {\n  constructor(project: AwsCdkTypeScriptApp, options: PrDeployWorkflowOptions) {\n    super(project, '.github/workflows/pr-deploy.yml', {\n      marker: true,\n      readonly: true,\n      obj: {\n        name: 'PR Deploy',\n        on: {\n          pull_request: {\n            types: ['opened', 'synchronize', 'reopened'],\n          },\n        },\n        permissions: {\n          'id-token': 'write',\n          'contents': 'read',\n          'pull-requests': 'write',\n        },\n        jobs: {\n          deploy: {\n            'runs-on': 'ubuntu-latest',\n            'steps': [\n              {\n                name: 'Checkout',\n                uses: 'actions/checkout@v5',\n              },\n              {\n                name: 'Setup Node.js',\n                uses: 'actions/setup-node@v5',\n                with: {\n                  'node-version': '24',\n                },\n              },\n              {\n                name: 'Configure AWS credentials',\n                uses: 'aws-actions/configure-aws-credentials@v4',\n                with: {\n                  'role-to-assume': options.roleArn,\n                  'aws-region': options.awsRegion,\n                },\n              },\n              {\n                name: 'Install dependencies',\n                run: 'yarn install --frozen-lockfile',\n              },\n              {\n                name: 'Update config.json',\n                run: `jq '.clerkPublishableKey = \"${options.clerkPublishableKey}\"' web/public/config.json > tmp.json && mv tmp.json web/public/config.json`,\n              },\n              {\n                name: 'Deploy to AWS',\n                id: 'deploy',\n                env: {\n                  BRANCH_NAME: '${{ github.head_ref }}',\n                },\n                run: [\n                  '# Strip conventional commit prefix (feat/, fix/, chore/, etc.)',\n                  'CLEAN_BRANCH_NAME=${BRANCH_NAME#*/}',\n                  'echo \"Original branch: $BRANCH_NAME\"',\n                  'echo \"Clean branch: $CLEAN_BRANCH_NAME\"',\n                  'yarn cdk:dev --context local-dev-prefix=$CLEAN_BRANCH_NAME deploy --require-approval never --outputs-file cdk-outputs.json',\n                ].join('\\n'),\n              },\n              {\n                name: 'Extract outputs',\n                id: 'outputs',\n                run: [\n                  'WEBSITE_URL=$(jq -r \\'.[] | .WebsiteUrl // empty\\' cdk-outputs.json)',\n                  'echo \"website_url=$WEBSITE_URL\" >> $GITHUB_OUTPUT',\n                  'echo \"Website URL: $WEBSITE_URL\"',\n                ].join('\\n'),\n              },\n              {\n                name: 'Comment PR',\n                uses: 'actions/github-script@v7',\n                if: 'success()',\n                with: {\n                  script: [\n                    'const websiteUrl = \\'${{ steps.outputs.outputs.website_url }}\\';',\n                    'let body = \\'✅ Successfully deployed branch `${{ github.head_ref }}` to AWS dev environment\\\\n\\\\n\\';',\n                    '',\n                    'if (websiteUrl) {',\n                    '  body += `🌐 **Website URL:** ${websiteUrl}`;',\n                    '}',\n                    '',\n                    'github.rest.issues.createComment({',\n                    '  issue_number: context.issue.number,',\n                    '  owner: context.repo.owner,',\n                    '  repo: context.repo.repo,',\n                    '  body: body',\n                    '})',\n                  ].join('\\n'),\n                },\n              },\n              {\n                name: 'Notify Slack',\n                if: 'always()',\n                run: [\n                  'STATUS=\"${{ job.status }}\"',\n                  'COLOR=\"good\"',\n                  'if [ \"$STATUS\" != \"success\" ]; then',\n                  '  COLOR=\"danger\"',\n                  'fi',\n                  'WEBSITE_URL=\"${{ steps.outputs.outputs.website_url }}\"',\n                  'MESSAGE=\"PR Deploy: $STATUS\\\\nRepo: ${{ github.repository }}\\\\nPR: #${{ github.event.number }}\\\\nCommit: ${{ github.sha }}\"',\n                  'if [ -n \"$WEBSITE_URL\" ]; then',\n                  '  MESSAGE=\"$MESSAGE\\\\n🌐 Website: <$WEBSITE_URL|View Site>\"',\n                  'fi',\n                  'curl -X POST -H \\'Content-type: application/json\\' \\\\',\n                  '  --data \"{\\\\\"attachments\\\\\":[{\\\\\"color\\\\\":\\\\\"$COLOR\\\\\",\\\\\"text\\\\\":\\\\\"$MESSAGE\\\\\"}]}\" \\\\',\n                  '  ${{ secrets.SLACK_CHANNEL }}',\n                ].join('\\n'),\n              },\n            ],\n          },\n        },\n      },\n    });\n  }\n}\n"]}
|
|
@@ -53,7 +53,36 @@ class ProductionDeployWorkflow extends projen_1.YamlFile {
|
|
|
53
53
|
},
|
|
54
54
|
{
|
|
55
55
|
name: 'Deploy to production',
|
|
56
|
-
|
|
56
|
+
id: 'deploy',
|
|
57
|
+
run: `yarn cdk deploy -e ${options.projectName}-prod --require-approval never --outputs-file cdk-outputs.json`,
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
name: 'Extract outputs',
|
|
61
|
+
id: 'outputs',
|
|
62
|
+
run: [
|
|
63
|
+
'WEBSITE_URL=$(jq -r \'.[] | .WebsiteUrl // empty\' cdk-outputs.json)',
|
|
64
|
+
'echo "website_url=$WEBSITE_URL" >> $GITHUB_OUTPUT',
|
|
65
|
+
'echo "Website URL: $WEBSITE_URL"',
|
|
66
|
+
].join('\n'),
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
name: 'Notify Slack',
|
|
70
|
+
if: 'always()',
|
|
71
|
+
run: [
|
|
72
|
+
'STATUS="${{ job.status }}"',
|
|
73
|
+
'COLOR="good"',
|
|
74
|
+
'if [ "$STATUS" != "success" ]; then',
|
|
75
|
+
' COLOR="danger"',
|
|
76
|
+
'fi',
|
|
77
|
+
'WEBSITE_URL="${{ steps.outputs.outputs.website_url }}"',
|
|
78
|
+
'MESSAGE="Production Deploy: $STATUS\\nRepo: ${{ github.repository }}\\nTag: ${{ github.ref_name }}\\nCommit: ${{ github.sha }}"',
|
|
79
|
+
'if [ -n "$WEBSITE_URL" ]; then',
|
|
80
|
+
' MESSAGE="$MESSAGE\\nš Website: <$WEBSITE_URL|View Site>"',
|
|
81
|
+
'fi',
|
|
82
|
+
'curl -X POST -H \'Content-type: application/json\' \\',
|
|
83
|
+
' --data "{\\"attachments\\":[{\\"color\\":\\"$COLOR\\",\\"text\\":\\"$MESSAGE\\"}]}" \\',
|
|
84
|
+
' ${{ secrets.SLACK_CHANNEL }}',
|
|
85
|
+
].join('\n'),
|
|
57
86
|
},
|
|
58
87
|
],
|
|
59
88
|
},
|
|
@@ -64,5 +93,5 @@ class ProductionDeployWorkflow extends projen_1.YamlFile {
|
|
|
64
93
|
}
|
|
65
94
|
exports.ProductionDeployWorkflow = ProductionDeployWorkflow;
|
|
66
95
|
_a = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
ProductionDeployWorkflow[_a] = { fqn: "@macedon-technologies/batman.ProductionDeployWorkflow", version: "1.0
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
ProductionDeployWorkflow[_a] = { fqn: "@macedon-technologies/batman.ProductionDeployWorkflow", version: "1.1.0" };
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHJvZHVjdGlvbkRlcGxveVdvcmtmbG93LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL1Byb2R1Y3Rpb25EZXBsb3lXb3JrZmxvdy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1DQUFrQztBQVVsQyxNQUFhLHdCQUF5QixTQUFRLGlCQUFRO0lBQ3BELFlBQVksT0FBNEIsRUFBRSxPQUF3QztRQUNoRixLQUFLLENBQUMsT0FBTyxFQUFFLHlDQUF5QyxFQUFFO1lBQ3hELE1BQU0sRUFBRSxJQUFJO1lBQ1osUUFBUSxFQUFFLElBQUk7WUFDZCxHQUFHLEVBQUU7Z0JBQ0gsSUFBSSxFQUFFLG1CQUFtQjtnQkFDekIsRUFBRSxFQUFFO29CQUNGLElBQUksRUFBRTt3QkFDSixJQUFJLEVBQUUsQ0FBQyxHQUFHLENBQUM7cUJBQ1o7aUJBQ0Y7Z0JBQ0QsV0FBVyxFQUFFO29CQUNYLFVBQVUsRUFBRSxPQUFPO29CQUNuQixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7Z0JBQ0QsSUFBSSxFQUFFO29CQUNKLE1BQU0sRUFBRTt3QkFDTixTQUFTLEVBQUUsZUFBZTt3QkFDMUIsT0FBTyxFQUFFOzRCQUNQO2dDQUNFLElBQUksRUFBRSxVQUFVO2dDQUNoQixJQUFJLEVBQUUscUJBQXFCOzZCQUM1Qjs0QkFDRDtnQ0FDRSxJQUFJLEVBQUUsZUFBZTtnQ0FDckIsSUFBSSxFQUFFLHVCQUF1QjtnQ0FDN0IsSUFBSSxFQUFFO29DQUNKLGNBQWMsRUFBRSxJQUFJO2lDQUNyQjs2QkFDRjs0QkFDRDtnQ0FDRSxJQUFJLEVBQUUsMkJBQTJCO2dDQUNqQyxJQUFJLEVBQUUsMENBQTBDO2dDQUNoRCxJQUFJLEVBQUU7b0NBQ0osZ0JBQWdCLEVBQUUsT0FBTyxDQUFDLE9BQU87b0NBQ2pDLFlBQVksRUFBRSxPQUFPLENBQUMsU0FBUztpQ0FDaEM7NkJBQ0Y7NEJBQ0Q7Z0NBQ0UsSUFBSSxFQUFFLHNCQUFzQjtnQ0FDNUIsR0FBRyxFQUFFLGdDQUFnQzs2QkFDdEM7NEJBQ0Q7Z0NBQ0UsSUFBSSxFQUFFLG9CQUFvQjtnQ0FDMUIsR0FBRyxFQUFFLCtCQUErQixPQUFPLENBQUMsbUJBQW1CLDRFQUE0RTs2QkFDNUk7NEJBQ0Q7Z0NBQ0UsSUFBSSxFQUFFLHNCQUFzQjtnQ0FDNUIsRUFBRSxFQUFFLFFBQVE7Z0NBQ1osR0FBRyxFQUFFLHNCQUFzQixPQUFPLENBQUMsV0FBVyxnRUFBZ0U7NkJBQy9HOzRCQUNEO2dDQUNFLElBQUksRUFBRSxpQkFBaUI7Z0NBQ3ZCLEVBQUUsRUFBRSxTQUFTO2dDQUNiLEdBQUcsRUFBRTtvQ0FDSCxzRUFBc0U7b0NBQ3RFLG1EQUFtRDtvQ0FDbkQsa0NBQWtDO2lDQUNuQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7NkJBQ2I7NEJBQ0Q7Z0NBQ0UsSUFBSSxFQUFFLGNBQWM7Z0NBQ3BCLEVBQUUsRUFBRSxVQUFVO2dDQUNkLEdBQUcsRUFBRTtvQ0FDSCw0QkFBNEI7b0NBQzVCLGNBQWM7b0NBQ2QscUNBQXFDO29DQUNyQyxrQkFBa0I7b0NBQ2xCLElBQUk7b0NBQ0osd0RBQXdEO29DQUN4RCxpSUFBaUk7b0NBQ2pJLGdDQUFnQztvQ0FDaEMsNkRBQTZEO29DQUM3RCxJQUFJO29DQUNKLHVEQUF1RDtvQ0FDdkQsMEZBQTBGO29DQUMxRixnQ0FBZ0M7aUNBQ2pDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQzs2QkFDYjt5QkFDRjtxQkFDRjtpQkFDRjthQUNGO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFyRkgsNERBc0ZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgWWFtbEZpbGUgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgQXdzQ2RrVHlwZVNjcmlwdEFwcCB9IGZyb20gJ3Byb2plbi9saWIvYXdzY2RrJztcblxuZXhwb3J0IGludGVyZmFjZSBQcm9kdWN0aW9uRGVwbG95V29ya2Zsb3dPcHRpb25zIHtcbiAgcmVhZG9ubHkgcm9sZUFybjogc3RyaW5nO1xuICByZWFkb25seSBhd3NSZWdpb246IHN0cmluZztcbiAgcmVhZG9ubHkgcHJvamVjdE5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgY2xlcmtQdWJsaXNoYWJsZUtleTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgUHJvZHVjdGlvbkRlcGxveVdvcmtmbG93IGV4dGVuZHMgWWFtbEZpbGUge1xuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBBd3NDZGtUeXBlU2NyaXB0QXBwLCBvcHRpb25zOiBQcm9kdWN0aW9uRGVwbG95V29ya2Zsb3dPcHRpb25zKSB7XG4gICAgc3VwZXIocHJvamVjdCwgJy5naXRodWIvd29ya2Zsb3dzL3Byb2R1Y3Rpb24tZGVwbG95LnltbCcsIHtcbiAgICAgIG1hcmtlcjogdHJ1ZSxcbiAgICAgIHJlYWRvbmx5OiB0cnVlLFxuICAgICAgb2JqOiB7XG4gICAgICAgIG5hbWU6ICdQcm9kdWN0aW9uIERlcGxveScsXG4gICAgICAgIG9uOiB7XG4gICAgICAgICAgcHVzaDoge1xuICAgICAgICAgICAgdGFnczogWycqJ10sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgcGVybWlzc2lvbnM6IHtcbiAgICAgICAgICAnaWQtdG9rZW4nOiAnd3JpdGUnLFxuICAgICAgICAgICdjb250ZW50cyc6ICdyZWFkJyxcbiAgICAgICAgfSxcbiAgICAgICAgam9iczoge1xuICAgICAgICAgIGRlcGxveToge1xuICAgICAgICAgICAgJ3J1bnMtb24nOiAndWJ1bnR1LWxhdGVzdCcsXG4gICAgICAgICAgICAnc3RlcHMnOiBbXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBuYW1lOiAnQ2hlY2tvdXQnLFxuICAgICAgICAgICAgICAgIHVzZXM6ICdhY3Rpb25zL2NoZWNrb3V0QHY1JyxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG5hbWU6ICdTZXR1cCBOb2RlLmpzJyxcbiAgICAgICAgICAgICAgICB1c2VzOiAnYWN0aW9ucy9zZXR1cC1ub2RlQHY1JyxcbiAgICAgICAgICAgICAgICB3aXRoOiB7XG4gICAgICAgICAgICAgICAgICAnbm9kZS12ZXJzaW9uJzogJzI0JyxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbmFtZTogJ0NvbmZpZ3VyZSBBV1MgY3JlZGVudGlhbHMnLFxuICAgICAgICAgICAgICAgIHVzZXM6ICdhd3MtYWN0aW9ucy9jb25maWd1cmUtYXdzLWNyZWRlbnRpYWxzQHY0JyxcbiAgICAgICAgICAgICAgICB3aXRoOiB7XG4gICAgICAgICAgICAgICAgICAncm9sZS10by1hc3N1bWUnOiBvcHRpb25zLnJvbGVBcm4sXG4gICAgICAgICAgICAgICAgICAnYXdzLXJlZ2lvbic6IG9wdGlvbnMuYXdzUmVnaW9uLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBuYW1lOiAnSW5zdGFsbCBkZXBlbmRlbmNpZXMnLFxuICAgICAgICAgICAgICAgIHJ1bjogJ3lhcm4gaW5zdGFsbCAtLWZyb3plbi1sb2NrZmlsZScsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBuYW1lOiAnVXBkYXRlIGNvbmZpZy5qc29uJyxcbiAgICAgICAgICAgICAgICBydW46IGBqcSAnLmNsZXJrUHVibGlzaGFibGVLZXkgPSBcIiR7b3B0aW9ucy5jbGVya1B1Ymxpc2hhYmxlS2V5fVwiJyB3ZWIvcHVibGljL2NvbmZpZy5qc29uID4gdG1wLmpzb24gJiYgbXYgdG1wLmpzb24gd2ViL3B1YmxpYy9jb25maWcuanNvbmAsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBuYW1lOiAnRGVwbG95IHRvIHByb2R1Y3Rpb24nLFxuICAgICAgICAgICAgICAgIGlkOiAnZGVwbG95JyxcbiAgICAgICAgICAgICAgICBydW46IGB5YXJuIGNkayBkZXBsb3kgLWUgJHtvcHRpb25zLnByb2plY3ROYW1lfS1wcm9kIC0tcmVxdWlyZS1hcHByb3ZhbCBuZXZlciAtLW91dHB1dHMtZmlsZSBjZGstb3V0cHV0cy5qc29uYCxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG5hbWU6ICdFeHRyYWN0IG91dHB1dHMnLFxuICAgICAgICAgICAgICAgIGlkOiAnb3V0cHV0cycsXG4gICAgICAgICAgICAgICAgcnVuOiBbXG4gICAgICAgICAgICAgICAgICAnV0VCU0lURV9VUkw9JChqcSAtciBcXCcuW10gfCAuV2Vic2l0ZVVybCAvLyBlbXB0eVxcJyBjZGstb3V0cHV0cy5qc29uKScsXG4gICAgICAgICAgICAgICAgICAnZWNobyBcIndlYnNpdGVfdXJsPSRXRUJTSVRFX1VSTFwiID4+ICRHSVRIVUJfT1VUUFVUJyxcbiAgICAgICAgICAgICAgICAgICdlY2hvIFwiV2Vic2l0ZSBVUkw6ICRXRUJTSVRFX1VSTFwiJyxcbiAgICAgICAgICAgICAgICBdLmpvaW4oJ1xcbicpLFxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbmFtZTogJ05vdGlmeSBTbGFjaycsXG4gICAgICAgICAgICAgICAgaWY6ICdhbHdheXMoKScsXG4gICAgICAgICAgICAgICAgcnVuOiBbXG4gICAgICAgICAgICAgICAgICAnU1RBVFVTPVwiJHt7IGpvYi5zdGF0dXMgfX1cIicsXG4gICAgICAgICAgICAgICAgICAnQ09MT1I9XCJnb29kXCInLFxuICAgICAgICAgICAgICAgICAgJ2lmIFsgXCIkU1RBVFVTXCIgIT0gXCJzdWNjZXNzXCIgXTsgdGhlbicsXG4gICAgICAgICAgICAgICAgICAnICBDT0xPUj1cImRhbmdlclwiJyxcbiAgICAgICAgICAgICAgICAgICdmaScsXG4gICAgICAgICAgICAgICAgICAnV0VCU0lURV9VUkw9XCIke3sgc3RlcHMub3V0cHV0cy5vdXRwdXRzLndlYnNpdGVfdXJsIH19XCInLFxuICAgICAgICAgICAgICAgICAgJ01FU1NBR0U9XCJQcm9kdWN0aW9uIERlcGxveTogJFNUQVRVU1xcXFxuUmVwbzogJHt7IGdpdGh1Yi5yZXBvc2l0b3J5IH19XFxcXG5UYWc6ICR7eyBnaXRodWIucmVmX25hbWUgfX1cXFxcbkNvbW1pdDogJHt7IGdpdGh1Yi5zaGEgfX1cIicsXG4gICAgICAgICAgICAgICAgICAnaWYgWyAtbiBcIiRXRUJTSVRFX1VSTFwiIF07IHRoZW4nLFxuICAgICAgICAgICAgICAgICAgJyAgTUVTU0FHRT1cIiRNRVNTQUdFXFxcXG7wn4yQIFdlYnNpdGU6IDwkV0VCU0lURV9VUkx8VmlldyBTaXRlPlwiJyxcbiAgICAgICAgICAgICAgICAgICdmaScsXG4gICAgICAgICAgICAgICAgICAnY3VybCAtWCBQT1NUIC1IIFxcJ0NvbnRlbnQtdHlwZTogYXBwbGljYXRpb24vanNvblxcJyBcXFxcJyxcbiAgICAgICAgICAgICAgICAgICcgIC0tZGF0YSBcIntcXFxcXCJhdHRhY2htZW50c1xcXFxcIjpbe1xcXFxcImNvbG9yXFxcXFwiOlxcXFxcIiRDT0xPUlxcXFxcIixcXFxcXCJ0ZXh0XFxcXFwiOlxcXFxcIiRNRVNTQUdFXFxcXFwifV19XCIgXFxcXCcsXG4gICAgICAgICAgICAgICAgICAnICAke3sgc2VjcmV0cy5TTEFDS19DSEFOTkVMIH19JyxcbiAgICAgICAgICAgICAgICBdLmpvaW4oJ1xcbicpLFxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgXSxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuIl19
|
|
@@ -53,7 +53,36 @@ class StagingDeployWorkflow extends projen_1.YamlFile {
|
|
|
53
53
|
},
|
|
54
54
|
{
|
|
55
55
|
name: 'Deploy to staging',
|
|
56
|
-
|
|
56
|
+
id: 'deploy',
|
|
57
|
+
run: `yarn cdk deploy -e ${options.projectName}-staging --require-approval never --outputs-file cdk-outputs.json`,
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
name: 'Extract outputs',
|
|
61
|
+
id: 'outputs',
|
|
62
|
+
run: [
|
|
63
|
+
'WEBSITE_URL=$(jq -r \'.[] | .WebsiteUrl // empty\' cdk-outputs.json)',
|
|
64
|
+
'echo "website_url=$WEBSITE_URL" >> $GITHUB_OUTPUT',
|
|
65
|
+
'echo "Website URL: $WEBSITE_URL"',
|
|
66
|
+
].join('\n'),
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
name: 'Notify Slack',
|
|
70
|
+
if: 'always()',
|
|
71
|
+
run: [
|
|
72
|
+
'STATUS="${{ job.status }}"',
|
|
73
|
+
'COLOR="good"',
|
|
74
|
+
'if [ "$STATUS" != "success" ]; then',
|
|
75
|
+
' COLOR="danger"',
|
|
76
|
+
'fi',
|
|
77
|
+
'WEBSITE_URL="${{ steps.outputs.outputs.website_url }}"',
|
|
78
|
+
'MESSAGE="Staging Deploy: $STATUS\\nRepo: ${{ github.repository }}\\nBranch: ${{ github.ref_name }}\\nCommit: ${{ github.sha }}"',
|
|
79
|
+
'if [ -n "$WEBSITE_URL" ]; then',
|
|
80
|
+
' MESSAGE="$MESSAGE\\nš Website: <$WEBSITE_URL|View Site>"',
|
|
81
|
+
'fi',
|
|
82
|
+
'curl -X POST -H \'Content-type: application/json\' \\',
|
|
83
|
+
' --data "{\\"attachments\\":[{\\"color\\":\\"$COLOR\\",\\"text\\":\\"$MESSAGE\\"}]}" \\',
|
|
84
|
+
' ${{ secrets.SLACK_CHANNEL }}',
|
|
85
|
+
].join('\n'),
|
|
57
86
|
},
|
|
58
87
|
],
|
|
59
88
|
},
|
|
@@ -64,5 +93,5 @@ class StagingDeployWorkflow extends projen_1.YamlFile {
|
|
|
64
93
|
}
|
|
65
94
|
exports.StagingDeployWorkflow = StagingDeployWorkflow;
|
|
66
95
|
_a = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
StagingDeployWorkflow[_a] = { fqn: "@macedon-technologies/batman.StagingDeployWorkflow", version: "1.0
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
StagingDeployWorkflow[_a] = { fqn: "@macedon-technologies/batman.StagingDeployWorkflow", version: "1.1.0" };
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhZ2luZ0RlcGxveVdvcmtmbG93LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL1N0YWdpbmdEZXBsb3lXb3JrZmxvdy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1DQUFrQztBQVVsQyxNQUFhLHFCQUFzQixTQUFRLGlCQUFRO0lBQ2pELFlBQVksT0FBNEIsRUFBRSxPQUFxQztRQUM3RSxLQUFLLENBQUMsT0FBTyxFQUFFLHNDQUFzQyxFQUFFO1lBQ3JELE1BQU0sRUFBRSxJQUFJO1lBQ1osUUFBUSxFQUFFLElBQUk7WUFDZCxHQUFHLEVBQUU7Z0JBQ0gsSUFBSSxFQUFFLGdCQUFnQjtnQkFDdEIsRUFBRSxFQUFFO29CQUNGLElBQUksRUFBRTt3QkFDSixRQUFRLEVBQUUsQ0FBQyxNQUFNLENBQUM7cUJBQ25CO2lCQUNGO2dCQUNELFdBQVcsRUFBRTtvQkFDWCxVQUFVLEVBQUUsT0FBTztvQkFDbkIsVUFBVSxFQUFFLE1BQU07aUJBQ25CO2dCQUNELElBQUksRUFBRTtvQkFDSixNQUFNLEVBQUU7d0JBQ04sU0FBUyxFQUFFLGVBQWU7d0JBQzFCLE9BQU8sRUFBRTs0QkFDUDtnQ0FDRSxJQUFJLEVBQUUsVUFBVTtnQ0FDaEIsSUFBSSxFQUFFLHFCQUFxQjs2QkFDNUI7NEJBQ0Q7Z0NBQ0UsSUFBSSxFQUFFLGVBQWU7Z0NBQ3JCLElBQUksRUFBRSx1QkFBdUI7Z0NBQzdCLElBQUksRUFBRTtvQ0FDSixjQUFjLEVBQUUsSUFBSTtpQ0FDckI7NkJBQ0Y7NEJBQ0Q7Z0NBQ0UsSUFBSSxFQUFFLDJCQUEyQjtnQ0FDakMsSUFBSSxFQUFFLDBDQUEwQztnQ0FDaEQsSUFBSSxFQUFFO29DQUNKLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxPQUFPO29DQUNqQyxZQUFZLEVBQUUsT0FBTyxDQUFDLFNBQVM7aUNBQ2hDOzZCQUNGOzRCQUNEO2dDQUNFLElBQUksRUFBRSxzQkFBc0I7Z0NBQzVCLEdBQUcsRUFBRSxnQ0FBZ0M7NkJBQ3RDOzRCQUNEO2dDQUNFLElBQUksRUFBRSxvQkFBb0I7Z0NBQzFCLEdBQUcsRUFBRSwrQkFBK0IsT0FBTyxDQUFDLG1CQUFtQiw0RUFBNEU7NkJBQzVJOzRCQUNEO2dDQUNFLElBQUksRUFBRSxtQkFBbUI7Z0NBQ3pCLEVBQUUsRUFBRSxRQUFRO2dDQUNaLEdBQUcsRUFBRSxzQkFBc0IsT0FBTyxDQUFDLFdBQVcsbUVBQW1FOzZCQUNsSDs0QkFDRDtnQ0FDRSxJQUFJLEVBQUUsaUJBQWlCO2dDQUN2QixFQUFFLEVBQUUsU0FBUztnQ0FDYixHQUFHLEVBQUU7b0NBQ0gsc0VBQXNFO29DQUN0RSxtREFBbUQ7b0NBQ25ELGtDQUFrQztpQ0FDbkMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDOzZCQUNiOzRCQUNEO2dDQUNFLElBQUksRUFBRSxjQUFjO2dDQUNwQixFQUFFLEVBQUUsVUFBVTtnQ0FDZCxHQUFHLEVBQUU7b0NBQ0gsNEJBQTRCO29DQUM1QixjQUFjO29DQUNkLHFDQUFxQztvQ0FDckMsa0JBQWtCO29DQUNsQixJQUFJO29DQUNKLHdEQUF3RDtvQ0FDeEQsaUlBQWlJO29DQUNqSSxnQ0FBZ0M7b0NBQ2hDLDZEQUE2RDtvQ0FDN0QsSUFBSTtvQ0FDSix1REFBdUQ7b0NBQ3ZELDBGQUEwRjtvQ0FDMUYsZ0NBQWdDO2lDQUNqQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7NkJBQ2I7eUJBQ0Y7cUJBQ0Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBckZILHNEQXNGQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFlhbWxGaWxlIH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IEF3c0Nka1R5cGVTY3JpcHRBcHAgfSBmcm9tICdwcm9qZW4vbGliL2F3c2Nkayc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RhZ2luZ0RlcGxveVdvcmtmbG93T3B0aW9ucyB7XG4gIHJlYWRvbmx5IHJvbGVBcm46IHN0cmluZztcbiAgcmVhZG9ubHkgYXdzUmVnaW9uOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHByb2plY3ROYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGNsZXJrUHVibGlzaGFibGVLZXk6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIFN0YWdpbmdEZXBsb3lXb3JrZmxvdyBleHRlbmRzIFlhbWxGaWxlIHtcbiAgY29uc3RydWN0b3IocHJvamVjdDogQXdzQ2RrVHlwZVNjcmlwdEFwcCwgb3B0aW9uczogU3RhZ2luZ0RlcGxveVdvcmtmbG93T3B0aW9ucykge1xuICAgIHN1cGVyKHByb2plY3QsICcuZ2l0aHViL3dvcmtmbG93cy9zdGFnaW5nLWRlcGxveS55bWwnLCB7XG4gICAgICBtYXJrZXI6IHRydWUsXG4gICAgICByZWFkb25seTogdHJ1ZSxcbiAgICAgIG9iajoge1xuICAgICAgICBuYW1lOiAnU3RhZ2luZyBEZXBsb3knLFxuICAgICAgICBvbjoge1xuICAgICAgICAgIHB1c2g6IHtcbiAgICAgICAgICAgIGJyYW5jaGVzOiBbJ21haW4nXSxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICBwZXJtaXNzaW9uczoge1xuICAgICAgICAgICdpZC10b2tlbic6ICd3cml0ZScsXG4gICAgICAgICAgJ2NvbnRlbnRzJzogJ3JlYWQnLFxuICAgICAgICB9LFxuICAgICAgICBqb2JzOiB7XG4gICAgICAgICAgZGVwbG95OiB7XG4gICAgICAgICAgICAncnVucy1vbic6ICd1YnVudHUtbGF0ZXN0JyxcbiAgICAgICAgICAgICdzdGVwcyc6IFtcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG5hbWU6ICdDaGVja291dCcsXG4gICAgICAgICAgICAgICAgdXNlczogJ2FjdGlvbnMvY2hlY2tvdXRAdjUnLFxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbmFtZTogJ1NldHVwIE5vZGUuanMnLFxuICAgICAgICAgICAgICAgIHVzZXM6ICdhY3Rpb25zL3NldHVwLW5vZGVAdjUnLFxuICAgICAgICAgICAgICAgIHdpdGg6IHtcbiAgICAgICAgICAgICAgICAgICdub2RlLXZlcnNpb24nOiAnMjQnLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBuYW1lOiAnQ29uZmlndXJlIEFXUyBjcmVkZW50aWFscycsXG4gICAgICAgICAgICAgICAgdXNlczogJ2F3cy1hY3Rpb25zL2NvbmZpZ3VyZS1hd3MtY3JlZGVudGlhbHNAdjQnLFxuICAgICAgICAgICAgICAgIHdpdGg6IHtcbiAgICAgICAgICAgICAgICAgICdyb2xlLXRvLWFzc3VtZSc6IG9wdGlvbnMucm9sZUFybixcbiAgICAgICAgICAgICAgICAgICdhd3MtcmVnaW9uJzogb3B0aW9ucy5hd3NSZWdpb24sXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG5hbWU6ICdJbnN0YWxsIGRlcGVuZGVuY2llcycsXG4gICAgICAgICAgICAgICAgcnVuOiAneWFybiBpbnN0YWxsIC0tZnJvemVuLWxvY2tmaWxlJyxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG5hbWU6ICdVcGRhdGUgY29uZmlnLmpzb24nLFxuICAgICAgICAgICAgICAgIHJ1bjogYGpxICcuY2xlcmtQdWJsaXNoYWJsZUtleSA9IFwiJHtvcHRpb25zLmNsZXJrUHVibGlzaGFibGVLZXl9XCInIHdlYi9wdWJsaWMvY29uZmlnLmpzb24gPiB0bXAuanNvbiAmJiBtdiB0bXAuanNvbiB3ZWIvcHVibGljL2NvbmZpZy5qc29uYCxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG5hbWU6ICdEZXBsb3kgdG8gc3RhZ2luZycsXG4gICAgICAgICAgICAgICAgaWQ6ICdkZXBsb3knLFxuICAgICAgICAgICAgICAgIHJ1bjogYHlhcm4gY2RrIGRlcGxveSAtZSAke29wdGlvbnMucHJvamVjdE5hbWV9LXN0YWdpbmcgLS1yZXF1aXJlLWFwcHJvdmFsIG5ldmVyIC0tb3V0cHV0cy1maWxlIGNkay1vdXRwdXRzLmpzb25gLFxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbmFtZTogJ0V4dHJhY3Qgb3V0cHV0cycsXG4gICAgICAgICAgICAgICAgaWQ6ICdvdXRwdXRzJyxcbiAgICAgICAgICAgICAgICBydW46IFtcbiAgICAgICAgICAgICAgICAgICdXRUJTSVRFX1VSTD0kKGpxIC1yIFxcJy5bXSB8IC5XZWJzaXRlVXJsIC8vIGVtcHR5XFwnIGNkay1vdXRwdXRzLmpzb24pJyxcbiAgICAgICAgICAgICAgICAgICdlY2hvIFwid2Vic2l0ZV91cmw9JFdFQlNJVEVfVVJMXCIgPj4gJEdJVEhVQl9PVVRQVVQnLFxuICAgICAgICAgICAgICAgICAgJ2VjaG8gXCJXZWJzaXRlIFVSTDogJFdFQlNJVEVfVVJMXCInLFxuICAgICAgICAgICAgICAgIF0uam9pbignXFxuJyksXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBuYW1lOiAnTm90aWZ5IFNsYWNrJyxcbiAgICAgICAgICAgICAgICBpZjogJ2Fsd2F5cygpJyxcbiAgICAgICAgICAgICAgICBydW46IFtcbiAgICAgICAgICAgICAgICAgICdTVEFUVVM9XCIke3sgam9iLnN0YXR1cyB9fVwiJyxcbiAgICAgICAgICAgICAgICAgICdDT0xPUj1cImdvb2RcIicsXG4gICAgICAgICAgICAgICAgICAnaWYgWyBcIiRTVEFUVVNcIiAhPSBcInN1Y2Nlc3NcIiBdOyB0aGVuJyxcbiAgICAgICAgICAgICAgICAgICcgIENPTE9SPVwiZGFuZ2VyXCInLFxuICAgICAgICAgICAgICAgICAgJ2ZpJyxcbiAgICAgICAgICAgICAgICAgICdXRUJTSVRFX1VSTD1cIiR7eyBzdGVwcy5vdXRwdXRzLm91dHB1dHMud2Vic2l0ZV91cmwgfX1cIicsXG4gICAgICAgICAgICAgICAgICAnTUVTU0FHRT1cIlN0YWdpbmcgRGVwbG95OiAkU1RBVFVTXFxcXG5SZXBvOiAke3sgZ2l0aHViLnJlcG9zaXRvcnkgfX1cXFxcbkJyYW5jaDogJHt7IGdpdGh1Yi5yZWZfbmFtZSB9fVxcXFxuQ29tbWl0OiAke3sgZ2l0aHViLnNoYSB9fVwiJyxcbiAgICAgICAgICAgICAgICAgICdpZiBbIC1uIFwiJFdFQlNJVEVfVVJMXCIgXTsgdGhlbicsXG4gICAgICAgICAgICAgICAgICAnICBNRVNTQUdFPVwiJE1FU1NBR0VcXFxcbvCfjJAgV2Vic2l0ZTogPCRXRUJTSVRFX1VSTHxWaWV3IFNpdGU+XCInLFxuICAgICAgICAgICAgICAgICAgJ2ZpJyxcbiAgICAgICAgICAgICAgICAgICdjdXJsIC1YIFBPU1QgLUggXFwnQ29udGVudC10eXBlOiBhcHBsaWNhdGlvbi9qc29uXFwnIFxcXFwnLFxuICAgICAgICAgICAgICAgICAgJyAgLS1kYXRhIFwie1xcXFxcImF0dGFjaG1lbnRzXFxcXFwiOlt7XFxcXFwiY29sb3JcXFxcXCI6XFxcXFwiJENPTE9SXFxcXFwiLFxcXFxcInRleHRcXFxcXCI6XFxcXFwiJE1FU1NBR0VcXFxcXCJ9XX1cIiBcXFxcJyxcbiAgICAgICAgICAgICAgICAgICcgICR7eyBzZWNyZXRzLlNMQUNLX0NIQU5ORUwgfX0nLFxuICAgICAgICAgICAgICAgIF0uam9pbignXFxuJyksXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
package/lib/index.d.ts
CHANGED
package/lib/index.js
CHANGED
|
@@ -15,6 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./BatmanProject"), exports);
|
|
18
|
+
__exportStar(require("./CodeOwnersFile"), exports);
|
|
18
19
|
__exportStar(require("./StagingDeployWorkflow"), exports);
|
|
19
20
|
__exportStar(require("./ProductionDeployWorkflow"), exports);
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGtEQUFnQztBQUNoQyxtREFBaUM7QUFHakMsMERBQXdDO0FBQ3hDLDZEQUEyQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vQmF0bWFuUHJvamVjdCc7XG5leHBvcnQgKiBmcm9tICcuL0NvZGVPd25lcnNGaWxlJztcbmV4cG9ydCB7IEVudmlyb25tZW50Q29uZmlnIH0gZnJvbSAnLi9NYWluRmlsZSc7XG5leHBvcnQgeyBBcHBsaWNhdGlvbkVudmlyb25tZW50Q29uZmlnIH0gZnJvbSAnLi9BcHBsaWNhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL1N0YWdpbmdEZXBsb3lXb3JrZmxvdyc7XG5leHBvcnQgKiBmcm9tICcuL1Byb2R1Y3Rpb25EZXBsb3lXb3JrZmxvdyc7XG4iXX0=
|