mrpj 0.2.5 → 0.2.7
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 +526 -291
- package/API.md +210 -2
- package/lib/components/SelfMutationOnForks.d.ts +29 -0
- package/lib/components/SelfMutationOnForks.js +101 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.js +18 -0
- package/lib/construct-project-options.d.ts +15 -0
- package/lib/construct-project-options.js +1 -1
- package/lib/construct-project.js +1 -1
- package/lib/features/automation.d.ts +4 -1
- package/lib/features/automation.js +12 -2
- package/lib/features/index.d.ts +1 -0
- package/lib/features/index.js +4 -2
- package/lib/features/self-mutation.d.ts +7 -0
- package/lib/features/self-mutation.js +14 -0
- package/lib/index.d.ts +1 -0
- package/lib/index.js +3 -2
- package/lib/logo/Logo.js +1 -1
- package/lib/logo/SvgFile.js +1 -1
- package/lib/logo/Wordmark.js +1 -1
- package/lib/projen-project-options.d.ts +22 -1
- package/lib/projen-project-options.js +1 -1
- package/lib/projen-project.js +6 -5
- package/lib/typescript-project-options.d.ts +22 -1
- package/lib/typescript-project-options.js +1 -1
- package/lib/typescript-project.js +5 -4
- package/package.json +11 -11
- package/resources/node-versions.json +5 -4
package/API.md
CHANGED
|
@@ -5142,6 +5142,8 @@ const constructProjectOptions: ConstructProjectOptions = { ... }
|
|
|
5142
5142
|
| <code><a href="#mrpj.ConstructProjectOptions.property.repositoryUrl">repositoryUrl</a></code> | <code>string</code> | Git repository URL. |
|
|
5143
5143
|
| <code><a href="#mrpj.ConstructProjectOptions.property.allowLibraryDependencies">allowLibraryDependencies</a></code> | <code>boolean</code> | Allow the project to include `peerDependencies` and `bundledDependencies`. |
|
|
5144
5144
|
| <code><a href="#mrpj.ConstructProjectOptions.property.artifactsDirectory">artifactsDirectory</a></code> | <code>string</code> | A directory which will contain build artifacts. |
|
|
5145
|
+
| <code><a href="#mrpj.ConstructProjectOptions.property.auditDeps">auditDeps</a></code> | <code>boolean</code> | Run security audit on dependencies. |
|
|
5146
|
+
| <code><a href="#mrpj.ConstructProjectOptions.property.auditDepsOptions">auditDepsOptions</a></code> | <code>projen.javascript.AuditOptions</code> | Security audit options. |
|
|
5145
5147
|
| <code><a href="#mrpj.ConstructProjectOptions.property.authorEmail">authorEmail</a></code> | <code>string</code> | Author's e-mail. |
|
|
5146
5148
|
| <code><a href="#mrpj.ConstructProjectOptions.property.authorName">authorName</a></code> | <code>string</code> | Author's name. |
|
|
5147
5149
|
| <code><a href="#mrpj.ConstructProjectOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Is the author an organization. |
|
|
@@ -5411,6 +5413,36 @@ A directory which will contain build artifacts.
|
|
|
5411
5413
|
|
|
5412
5414
|
---
|
|
5413
5415
|
|
|
5416
|
+
##### `auditDeps`<sup>Optional</sup> <a name="auditDeps" id="mrpj.ConstructProjectOptions.property.auditDeps"></a>
|
|
5417
|
+
|
|
5418
|
+
```typescript
|
|
5419
|
+
public readonly auditDeps: boolean;
|
|
5420
|
+
```
|
|
5421
|
+
|
|
5422
|
+
- *Type:* boolean
|
|
5423
|
+
- *Default:* false
|
|
5424
|
+
|
|
5425
|
+
Run security audit on dependencies.
|
|
5426
|
+
|
|
5427
|
+
When enabled, creates an "audit" task that checks for known security vulnerabilities
|
|
5428
|
+
in dependencies. By default, runs during every build and checks for "high" severity
|
|
5429
|
+
vulnerabilities or above in all dependencies (including dev dependencies).
|
|
5430
|
+
|
|
5431
|
+
---
|
|
5432
|
+
|
|
5433
|
+
##### `auditDepsOptions`<sup>Optional</sup> <a name="auditDepsOptions" id="mrpj.ConstructProjectOptions.property.auditDepsOptions"></a>
|
|
5434
|
+
|
|
5435
|
+
```typescript
|
|
5436
|
+
public readonly auditDepsOptions: AuditOptions;
|
|
5437
|
+
```
|
|
5438
|
+
|
|
5439
|
+
- *Type:* projen.javascript.AuditOptions
|
|
5440
|
+
- *Default:* default options
|
|
5441
|
+
|
|
5442
|
+
Security audit options.
|
|
5443
|
+
|
|
5444
|
+
---
|
|
5445
|
+
|
|
5414
5446
|
##### `authorEmail`<sup>Optional</sup> <a name="authorEmail" id="mrpj.ConstructProjectOptions.property.authorEmail"></a>
|
|
5415
5447
|
|
|
5416
5448
|
```typescript
|
|
@@ -8064,6 +8096,8 @@ const projenProjectOptions: ProjenProjectOptions = { ... }
|
|
|
8064
8096
|
| <code><a href="#mrpj.ProjenProjectOptions.property.allowedCommitTypes">allowedCommitTypes</a></code> | <code>string[]</code> | Which conventional commit types are allowed to be used Types listed in `releasableCommitTypes` are always allowed. |
|
|
8065
8097
|
| <code><a href="#mrpj.ProjenProjectOptions.property.allowLibraryDependencies">allowLibraryDependencies</a></code> | <code>boolean</code> | Allow the project to include `peerDependencies` and `bundledDependencies`. |
|
|
8066
8098
|
| <code><a href="#mrpj.ProjenProjectOptions.property.artifactsDirectory">artifactsDirectory</a></code> | <code>string</code> | A directory which will contain build artifacts. |
|
|
8099
|
+
| <code><a href="#mrpj.ProjenProjectOptions.property.auditDeps">auditDeps</a></code> | <code>boolean</code> | Run security audit on dependencies. |
|
|
8100
|
+
| <code><a href="#mrpj.ProjenProjectOptions.property.auditDepsOptions">auditDepsOptions</a></code> | <code>projen.javascript.AuditOptions</code> | Security audit options. |
|
|
8067
8101
|
| <code><a href="#mrpj.ProjenProjectOptions.property.authorAddress">authorAddress</a></code> | <code>string</code> | Email or URL of the library author. |
|
|
8068
8102
|
| <code><a href="#mrpj.ProjenProjectOptions.property.authorEmail">authorEmail</a></code> | <code>string</code> | Author's e-mail. |
|
|
8069
8103
|
| <code><a href="#mrpj.ProjenProjectOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Is the author an organization. |
|
|
@@ -8071,6 +8105,7 @@ const projenProjectOptions: ProjenProjectOptions = { ... }
|
|
|
8071
8105
|
| <code><a href="#mrpj.ProjenProjectOptions.property.autoApproveUpgrades">autoApproveUpgrades</a></code> | <code>boolean</code> | Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued). |
|
|
8072
8106
|
| <code><a href="#mrpj.ProjenProjectOptions.property.autoDetectBin">autoDetectBin</a></code> | <code>boolean</code> | Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section. |
|
|
8073
8107
|
| <code><a href="#mrpj.ProjenProjectOptions.property.automationAppName">automationAppName</a></code> | <code>string</code> | Use this app for workflow automation. |
|
|
8108
|
+
| <code><a href="#mrpj.ProjenProjectOptions.property.automationEnvironment">automationEnvironment</a></code> | <code>string</code> | Protect any automation with this environment. |
|
|
8074
8109
|
| <code><a href="#mrpj.ProjenProjectOptions.property.autoMerge">autoMerge</a></code> | <code>boolean</code> | Enable automatic merging on GitHub. |
|
|
8075
8110
|
| <code><a href="#mrpj.ProjenProjectOptions.property.autoMergeOptions">autoMergeOptions</a></code> | <code>projen.github.AutoMergeOptions</code> | Configure options for automatic merging on GitHub. |
|
|
8076
8111
|
| <code><a href="#mrpj.ProjenProjectOptions.property.bin">bin</a></code> | <code>{[ key: string ]: string}</code> | Binary programs vended with your module. |
|
|
@@ -8281,6 +8316,36 @@ A directory which will contain build artifacts.
|
|
|
8281
8316
|
|
|
8282
8317
|
---
|
|
8283
8318
|
|
|
8319
|
+
##### `auditDeps`<sup>Optional</sup> <a name="auditDeps" id="mrpj.ProjenProjectOptions.property.auditDeps"></a>
|
|
8320
|
+
|
|
8321
|
+
```typescript
|
|
8322
|
+
public readonly auditDeps: boolean;
|
|
8323
|
+
```
|
|
8324
|
+
|
|
8325
|
+
- *Type:* boolean
|
|
8326
|
+
- *Default:* false
|
|
8327
|
+
|
|
8328
|
+
Run security audit on dependencies.
|
|
8329
|
+
|
|
8330
|
+
When enabled, creates an "audit" task that checks for known security vulnerabilities
|
|
8331
|
+
in dependencies. By default, runs during every build and checks for "high" severity
|
|
8332
|
+
vulnerabilities or above in all dependencies (including dev dependencies).
|
|
8333
|
+
|
|
8334
|
+
---
|
|
8335
|
+
|
|
8336
|
+
##### `auditDepsOptions`<sup>Optional</sup> <a name="auditDepsOptions" id="mrpj.ProjenProjectOptions.property.auditDepsOptions"></a>
|
|
8337
|
+
|
|
8338
|
+
```typescript
|
|
8339
|
+
public readonly auditDepsOptions: AuditOptions;
|
|
8340
|
+
```
|
|
8341
|
+
|
|
8342
|
+
- *Type:* projen.javascript.AuditOptions
|
|
8343
|
+
- *Default:* default options
|
|
8344
|
+
|
|
8345
|
+
Security audit options.
|
|
8346
|
+
|
|
8347
|
+
---
|
|
8348
|
+
|
|
8284
8349
|
##### `authorAddress`<sup>Optional</sup> <a name="authorAddress" id="mrpj.ProjenProjectOptions.property.authorAddress"></a>
|
|
8285
8350
|
|
|
8286
8351
|
```typescript
|
|
@@ -8366,7 +8431,7 @@ public readonly automationAppName: string;
|
|
|
8366
8431
|
```
|
|
8367
8432
|
|
|
8368
8433
|
- *Type:* string
|
|
8369
|
-
- *Default:*
|
|
8434
|
+
- *Default:* none
|
|
8370
8435
|
|
|
8371
8436
|
Use this app for workflow automation.
|
|
8372
8437
|
|
|
@@ -8374,6 +8439,21 @@ Remember to install the app and to configure credentials.
|
|
|
8374
8439
|
|
|
8375
8440
|
---
|
|
8376
8441
|
|
|
8442
|
+
##### `automationEnvironment`<sup>Optional</sup> <a name="automationEnvironment" id="mrpj.ProjenProjectOptions.property.automationEnvironment"></a>
|
|
8443
|
+
|
|
8444
|
+
```typescript
|
|
8445
|
+
public readonly automationEnvironment: string;
|
|
8446
|
+
```
|
|
8447
|
+
|
|
8448
|
+
- *Type:* string
|
|
8449
|
+
- *Default:* "automation"
|
|
8450
|
+
|
|
8451
|
+
Protect any automation with this environment.
|
|
8452
|
+
|
|
8453
|
+
You will need to set the environment up in GitHub. Credentials can only be used within this environment.
|
|
8454
|
+
|
|
8455
|
+
---
|
|
8456
|
+
|
|
8377
8457
|
##### `autoMerge`<sup>Optional</sup> <a name="autoMerge" id="mrpj.ProjenProjectOptions.property.autoMerge"></a>
|
|
8378
8458
|
|
|
8379
8459
|
```typescript
|
|
@@ -10391,6 +10471,39 @@ Options for Yarn Berry.
|
|
|
10391
10471
|
|
|
10392
10472
|
---
|
|
10393
10473
|
|
|
10474
|
+
### SelfMutationOnForksOptions <a name="SelfMutationOnForksOptions" id="mrpj.components.SelfMutationOnForksOptions"></a>
|
|
10475
|
+
|
|
10476
|
+
Options for configuring self-mutation behavior on forks.
|
|
10477
|
+
|
|
10478
|
+
#### Initializer <a name="Initializer" id="mrpj.components.SelfMutationOnForksOptions.Initializer"></a>
|
|
10479
|
+
|
|
10480
|
+
```typescript
|
|
10481
|
+
import { components } from 'mrpj'
|
|
10482
|
+
|
|
10483
|
+
const selfMutationOnForksOptions: components.SelfMutationOnForksOptions = { ... }
|
|
10484
|
+
```
|
|
10485
|
+
|
|
10486
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
10487
|
+
|
|
10488
|
+
| **Name** | **Type** | **Description** |
|
|
10489
|
+
| --- | --- | --- |
|
|
10490
|
+
| <code><a href="#mrpj.components.SelfMutationOnForksOptions.property.environment">environment</a></code> | <code>string</code> | Environment name to use for the workflow. |
|
|
10491
|
+
|
|
10492
|
+
---
|
|
10493
|
+
|
|
10494
|
+
##### `environment`<sup>Optional</sup> <a name="environment" id="mrpj.components.SelfMutationOnForksOptions.property.environment"></a>
|
|
10495
|
+
|
|
10496
|
+
```typescript
|
|
10497
|
+
public readonly environment: string;
|
|
10498
|
+
```
|
|
10499
|
+
|
|
10500
|
+
- *Type:* string
|
|
10501
|
+
- *Default:* no environment specified
|
|
10502
|
+
|
|
10503
|
+
Environment name to use for the workflow.
|
|
10504
|
+
|
|
10505
|
+
---
|
|
10506
|
+
|
|
10394
10507
|
### SizeOptions <a name="SizeOptions" id="mrpj.logo.SizeOptions"></a>
|
|
10395
10508
|
|
|
10396
10509
|
#### Initializer <a name="Initializer" id="mrpj.logo.SizeOptions.Initializer"></a>
|
|
@@ -10603,6 +10716,8 @@ const typeScriptProjectOptions: TypeScriptProjectOptions = { ... }
|
|
|
10603
10716
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.allowedCommitTypes">allowedCommitTypes</a></code> | <code>string[]</code> | Which conventional commit types are allowed to be used Types listed in `releasableCommitTypes` are always allowed. |
|
|
10604
10717
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.allowLibraryDependencies">allowLibraryDependencies</a></code> | <code>boolean</code> | Allow the project to include `peerDependencies` and `bundledDependencies`. |
|
|
10605
10718
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.artifactsDirectory">artifactsDirectory</a></code> | <code>string</code> | A directory which will contain build artifacts. |
|
|
10719
|
+
| <code><a href="#mrpj.TypeScriptProjectOptions.property.auditDeps">auditDeps</a></code> | <code>boolean</code> | Run security audit on dependencies. |
|
|
10720
|
+
| <code><a href="#mrpj.TypeScriptProjectOptions.property.auditDepsOptions">auditDepsOptions</a></code> | <code>projen.javascript.AuditOptions</code> | Security audit options. |
|
|
10606
10721
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.authorEmail">authorEmail</a></code> | <code>string</code> | Author's e-mail. |
|
|
10607
10722
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.authorOrganization">authorOrganization</a></code> | <code>boolean</code> | Is the author an organization. |
|
|
10608
10723
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.authorUrl">authorUrl</a></code> | <code>string</code> | Author's URL / Website. |
|
|
@@ -10610,6 +10725,7 @@ const typeScriptProjectOptions: TypeScriptProjectOptions = { ... }
|
|
|
10610
10725
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.autoApproveUpgrades">autoApproveUpgrades</a></code> | <code>boolean</code> | Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued). |
|
|
10611
10726
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.autoDetectBin">autoDetectBin</a></code> | <code>boolean</code> | Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section. |
|
|
10612
10727
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.automationAppName">automationAppName</a></code> | <code>string</code> | Use this app for workflow automation. |
|
|
10728
|
+
| <code><a href="#mrpj.TypeScriptProjectOptions.property.automationEnvironment">automationEnvironment</a></code> | <code>string</code> | Protect any automation with this environment. |
|
|
10613
10729
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.autoMerge">autoMerge</a></code> | <code>boolean</code> | Enable automatic merging on GitHub. |
|
|
10614
10730
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.autoMergeOptions">autoMergeOptions</a></code> | <code>projen.github.AutoMergeOptions</code> | Configure options for automatic merging on GitHub. |
|
|
10615
10731
|
| <code><a href="#mrpj.TypeScriptProjectOptions.property.bin">bin</a></code> | <code>{[ key: string ]: string}</code> | Binary programs vended with your module. |
|
|
@@ -10811,6 +10927,36 @@ A directory which will contain build artifacts.
|
|
|
10811
10927
|
|
|
10812
10928
|
---
|
|
10813
10929
|
|
|
10930
|
+
##### `auditDeps`<sup>Optional</sup> <a name="auditDeps" id="mrpj.TypeScriptProjectOptions.property.auditDeps"></a>
|
|
10931
|
+
|
|
10932
|
+
```typescript
|
|
10933
|
+
public readonly auditDeps: boolean;
|
|
10934
|
+
```
|
|
10935
|
+
|
|
10936
|
+
- *Type:* boolean
|
|
10937
|
+
- *Default:* false
|
|
10938
|
+
|
|
10939
|
+
Run security audit on dependencies.
|
|
10940
|
+
|
|
10941
|
+
When enabled, creates an "audit" task that checks for known security vulnerabilities
|
|
10942
|
+
in dependencies. By default, runs during every build and checks for "high" severity
|
|
10943
|
+
vulnerabilities or above in all dependencies (including dev dependencies).
|
|
10944
|
+
|
|
10945
|
+
---
|
|
10946
|
+
|
|
10947
|
+
##### `auditDepsOptions`<sup>Optional</sup> <a name="auditDepsOptions" id="mrpj.TypeScriptProjectOptions.property.auditDepsOptions"></a>
|
|
10948
|
+
|
|
10949
|
+
```typescript
|
|
10950
|
+
public readonly auditDepsOptions: AuditOptions;
|
|
10951
|
+
```
|
|
10952
|
+
|
|
10953
|
+
- *Type:* projen.javascript.AuditOptions
|
|
10954
|
+
- *Default:* default options
|
|
10955
|
+
|
|
10956
|
+
Security audit options.
|
|
10957
|
+
|
|
10958
|
+
---
|
|
10959
|
+
|
|
10814
10960
|
##### `authorEmail`<sup>Optional</sup> <a name="authorEmail" id="mrpj.TypeScriptProjectOptions.property.authorEmail"></a>
|
|
10815
10961
|
|
|
10816
10962
|
```typescript
|
|
@@ -10895,7 +11041,7 @@ public readonly automationAppName: string;
|
|
|
10895
11041
|
```
|
|
10896
11042
|
|
|
10897
11043
|
- *Type:* string
|
|
10898
|
-
- *Default:*
|
|
11044
|
+
- *Default:* none
|
|
10899
11045
|
|
|
10900
11046
|
Use this app for workflow automation.
|
|
10901
11047
|
|
|
@@ -10903,6 +11049,21 @@ Remember to install the app and to configure credentials.
|
|
|
10903
11049
|
|
|
10904
11050
|
---
|
|
10905
11051
|
|
|
11052
|
+
##### `automationEnvironment`<sup>Optional</sup> <a name="automationEnvironment" id="mrpj.TypeScriptProjectOptions.property.automationEnvironment"></a>
|
|
11053
|
+
|
|
11054
|
+
```typescript
|
|
11055
|
+
public readonly automationEnvironment: string;
|
|
11056
|
+
```
|
|
11057
|
+
|
|
11058
|
+
- *Type:* string
|
|
11059
|
+
- *Default:* "automation"
|
|
11060
|
+
|
|
11061
|
+
Protect any automation with this environment.
|
|
11062
|
+
|
|
11063
|
+
You will need to set the environment up in GitHub. Credentials can only be used within this environment.
|
|
11064
|
+
|
|
11065
|
+
---
|
|
11066
|
+
|
|
10906
11067
|
##### `autoMerge`<sup>Optional</sup> <a name="autoMerge" id="mrpj.TypeScriptProjectOptions.property.autoMerge"></a>
|
|
10907
11068
|
|
|
10908
11069
|
```typescript
|
|
@@ -13127,6 +13288,53 @@ Scale the logo by a factor.
|
|
|
13127
13288
|
---
|
|
13128
13289
|
|
|
13129
13290
|
|
|
13291
|
+
### SelfMutationOnForks <a name="SelfMutationOnForks" id="mrpj.components.SelfMutationOnForks"></a>
|
|
13292
|
+
|
|
13293
|
+
Configures GitHub workflows to enable self-mutation on fork pull requests.
|
|
13294
|
+
|
|
13295
|
+
This class sets up a workflow that will automatically apply projen-generated changes
|
|
13296
|
+
when a build fails due to outdated generated files. The workflow:
|
|
13297
|
+
|
|
13298
|
+
1. Runs when the build workflow fails on a PR
|
|
13299
|
+
2. Downloads any patch file generated during the failed build
|
|
13300
|
+
3. Authenticates using GitHub App credentials
|
|
13301
|
+
4. Checks out the PR branch
|
|
13302
|
+
5. Applies the patch if it exists and can be applied cleanly
|
|
13303
|
+
6. Commits and pushes the changes back to the PR
|
|
13304
|
+
|
|
13305
|
+
This enables automated fixes for common projen-related issues on fork PRs.
|
|
13306
|
+
|
|
13307
|
+
#### Initializers <a name="Initializers" id="mrpj.components.SelfMutationOnForks.Initializer"></a>
|
|
13308
|
+
|
|
13309
|
+
```typescript
|
|
13310
|
+
import { components } from 'mrpj'
|
|
13311
|
+
|
|
13312
|
+
new components.SelfMutationOnForks(project: Project, options?: SelfMutationOnForksOptions)
|
|
13313
|
+
```
|
|
13314
|
+
|
|
13315
|
+
| **Name** | **Type** | **Description** |
|
|
13316
|
+
| --- | --- | --- |
|
|
13317
|
+
| <code><a href="#mrpj.components.SelfMutationOnForks.Initializer.parameter.project">project</a></code> | <code>projen.Project</code> | *No description.* |
|
|
13318
|
+
| <code><a href="#mrpj.components.SelfMutationOnForks.Initializer.parameter.options">options</a></code> | <code>mrpj.components.SelfMutationOnForksOptions</code> | *No description.* |
|
|
13319
|
+
|
|
13320
|
+
---
|
|
13321
|
+
|
|
13322
|
+
##### `project`<sup>Required</sup> <a name="project" id="mrpj.components.SelfMutationOnForks.Initializer.parameter.project"></a>
|
|
13323
|
+
|
|
13324
|
+
- *Type:* projen.Project
|
|
13325
|
+
|
|
13326
|
+
---
|
|
13327
|
+
|
|
13328
|
+
##### `options`<sup>Optional</sup> <a name="options" id="mrpj.components.SelfMutationOnForks.Initializer.parameter.options"></a>
|
|
13329
|
+
|
|
13330
|
+
- *Type:* mrpj.components.SelfMutationOnForksOptions
|
|
13331
|
+
|
|
13332
|
+
---
|
|
13333
|
+
|
|
13334
|
+
|
|
13335
|
+
|
|
13336
|
+
|
|
13337
|
+
|
|
13130
13338
|
## Protocols <a name="Protocols" id="Protocols"></a>
|
|
13131
13339
|
|
|
13132
13340
|
### ILogo <a name="ILogo" id="mrpj.logo.ILogo"></a>
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { Project } from 'projen';
|
|
2
|
+
/**
|
|
3
|
+
* Options for configuring self-mutation behavior on forks
|
|
4
|
+
*/
|
|
5
|
+
export interface SelfMutationOnForksOptions {
|
|
6
|
+
/**
|
|
7
|
+
* Environment name to use for the workflow
|
|
8
|
+
* @default - no environment specified
|
|
9
|
+
*/
|
|
10
|
+
readonly environment?: string;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Configures GitHub workflows to enable self-mutation on fork pull requests.
|
|
14
|
+
*
|
|
15
|
+
* This class sets up a workflow that will automatically apply projen-generated changes
|
|
16
|
+
* when a build fails due to outdated generated files. The workflow:
|
|
17
|
+
*
|
|
18
|
+
* 1. Runs when the build workflow fails on a PR
|
|
19
|
+
* 2. Downloads any patch file generated during the failed build
|
|
20
|
+
* 3. Authenticates using GitHub App credentials
|
|
21
|
+
* 4. Checks out the PR branch
|
|
22
|
+
* 5. Applies the patch if it exists and can be applied cleanly
|
|
23
|
+
* 6. Commits and pushes the changes back to the PR
|
|
24
|
+
*
|
|
25
|
+
* This enables automated fixes for common projen-related issues on fork PRs.
|
|
26
|
+
*/
|
|
27
|
+
export declare class SelfMutationOnForks {
|
|
28
|
+
constructor(project: Project, options?: SelfMutationOnForksOptions);
|
|
29
|
+
}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.SelfMutationOnForks = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const projen_1 = require("projen");
|
|
7
|
+
/**
|
|
8
|
+
* Configures GitHub workflows to enable self-mutation on fork pull requests.
|
|
9
|
+
*
|
|
10
|
+
* This class sets up a workflow that will automatically apply projen-generated changes
|
|
11
|
+
* when a build fails due to outdated generated files. The workflow:
|
|
12
|
+
*
|
|
13
|
+
* 1. Runs when the build workflow fails on a PR
|
|
14
|
+
* 2. Downloads any patch file generated during the failed build
|
|
15
|
+
* 3. Authenticates using GitHub App credentials
|
|
16
|
+
* 4. Checks out the PR branch
|
|
17
|
+
* 5. Applies the patch if it exists and can be applied cleanly
|
|
18
|
+
* 6. Commits and pushes the changes back to the PR
|
|
19
|
+
*
|
|
20
|
+
* This enables automated fixes for common projen-related issues on fork PRs.
|
|
21
|
+
*/
|
|
22
|
+
class SelfMutationOnForks {
|
|
23
|
+
constructor(project, options = {}) {
|
|
24
|
+
const cicd = projen_1.github.GitHub.of(project);
|
|
25
|
+
if (!cicd)
|
|
26
|
+
return;
|
|
27
|
+
const buildWorkflow = cicd.tryFindWorkflow('build');
|
|
28
|
+
if (!buildWorkflow)
|
|
29
|
+
return;
|
|
30
|
+
// Update condition to run on all pull requests
|
|
31
|
+
buildWorkflow.file?.patch(projen_1.JsonPatch.remove('/jobs/self-mutation'));
|
|
32
|
+
// Add a new self mutation workflow that runs on completion of build
|
|
33
|
+
// and if the build failed and there is a patch, updates the PR
|
|
34
|
+
const selfMutation = cicd?.addWorkflow('self-mutation');
|
|
35
|
+
selfMutation?.on({
|
|
36
|
+
workflowRun: {
|
|
37
|
+
workflows: [buildWorkflow.name],
|
|
38
|
+
types: ['completed'],
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
selfMutation?.addJob('self-mutation', {
|
|
42
|
+
runsOn: ['ubuntu-latest'],
|
|
43
|
+
if: "github.event.workflow_run.conclusion == 'failure' && github.event.workflow_run.event == 'pull_request'",
|
|
44
|
+
permissions: {
|
|
45
|
+
contents: projen_1.github.workflows.JobPermission.READ,
|
|
46
|
+
},
|
|
47
|
+
environment: options.environment,
|
|
48
|
+
steps: [
|
|
49
|
+
{
|
|
50
|
+
name: 'Download patch',
|
|
51
|
+
id: 'download_patch',
|
|
52
|
+
continueOnError: true,
|
|
53
|
+
uses: 'dawidd6/action-download-artifact@ac66b43f0e6a346234dd65d4d0c8fbb31cb316e5',
|
|
54
|
+
with: {
|
|
55
|
+
run_id: '${{ github.event.workflow_run.id }}',
|
|
56
|
+
name: 'repo.patch',
|
|
57
|
+
path: '${{ runner.temp }}',
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
...conditionalSteps('steps.download_patch.outcome == \'success\'', cicd.projenCredentials.setupSteps, projen_1.github.WorkflowSteps.checkout({
|
|
61
|
+
name: 'Checkout PR',
|
|
62
|
+
with: {
|
|
63
|
+
repository: '${{ github.event.workflow_run.head_repository.full_name }}',
|
|
64
|
+
ref: '${{ github.event.workflow_run.head_branch }}',
|
|
65
|
+
token: cicd.projenCredentials.tokenRef,
|
|
66
|
+
},
|
|
67
|
+
}), {
|
|
68
|
+
name: 'Apply patch to PR',
|
|
69
|
+
run: [
|
|
70
|
+
'set -e',
|
|
71
|
+
'if [ ! -f "${{ runner.temp }}/repo.patch" ]; then',
|
|
72
|
+
' echo "Patch file not found"',
|
|
73
|
+
' exit 1',
|
|
74
|
+
'fi',
|
|
75
|
+
'git config user.name "github-actions[bot]"',
|
|
76
|
+
'git config user.email "github-actions[bot]@users.noreply.github.com"',
|
|
77
|
+
'if ! git apply --check ${{ runner.temp }}/repo.patch; then',
|
|
78
|
+
' echo "Patch cannot be applied cleanly"',
|
|
79
|
+
' exit 1',
|
|
80
|
+
'fi',
|
|
81
|
+
'git apply ${{ runner.temp }}/repo.patch',
|
|
82
|
+
'if [ -z "$(git status --porcelain)" ]; then',
|
|
83
|
+
' echo "No changes to commit"',
|
|
84
|
+
' exit 0',
|
|
85
|
+
'fi',
|
|
86
|
+
'git add .',
|
|
87
|
+
'git commit -s -m "chore: self mutation"',
|
|
88
|
+
'git push',
|
|
89
|
+
].join('\n'),
|
|
90
|
+
}),
|
|
91
|
+
],
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
exports.SelfMutationOnForks = SelfMutationOnForks;
|
|
96
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
97
|
+
SelfMutationOnForks[_a] = { fqn: "mrpj.components.SelfMutationOnForks", version: "0.2.7" };
|
|
98
|
+
function conditionalSteps(cond, ...steps) {
|
|
99
|
+
return steps.flatMap(s => s).map(s => ({ ...s, if: s.if ?? cond }));
|
|
100
|
+
}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SelfMutationOnForks.js","sourceRoot":"","sources":["../../src/components/SelfMutationOnForks.ts"],"names":[],"mappings":";;;;;AACA,mCAA2C;AAa3C;;;;;;;;;;;;;;GAcG;AACH,MAAa,mBAAmB;IAC9B,YAAY,OAAgB,EAAE,UAAsC,EAAE;QACpE,MAAM,IAAI,GAAG,eAAM,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QACpD,IAAI,CAAC,aAAa;YAAE,OAAO;QAE3B,+CAA+C;QAC/C,aAAa,CAAC,IAAI,EAAE,KAAK,CACvB,kBAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,CACxC,CAAC;QAEF,oEAAoE;QACpE,+DAA+D;QAC/D,MAAM,YAAY,GAAG,IAAI,EAAE,WAAW,CAAC,eAAe,CAAC,CAAC;QACxD,YAAY,EAAE,EAAE,CAAC;YACf,WAAW,EAAE;gBACX,SAAS,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC;gBAC/B,KAAK,EAAE,CAAC,WAAW,CAAC;aACrB;SACF,CAAC,CAAC;QAEH,YAAY,EAAE,MAAM,CAAC,eAAe,EAAE;YACpC,MAAM,EAAE,CAAC,eAAe,CAAC;YACzB,EAAE,EAAE,wGAAwG;YAC5G,WAAW,EAAE;gBACX,QAAQ,EAAE,eAAM,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI;aAC9C;YACD,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,gBAAgB;oBACtB,EAAE,EAAE,gBAAgB;oBACpB,eAAe,EAAE,IAAI;oBACrB,IAAI,EAAE,2EAA2E;oBACjF,IAAI,EAAE;wBACJ,MAAM,EAAE,qCAAqC;wBAC7C,IAAI,EAAE,YAAY;wBAClB,IAAI,EAAE,oBAAoB;qBAC3B;iBACF;gBACD,GAAG,gBAAgB,CACjB,6CAA6C,EAC7C,IAAI,CAAC,iBAAiB,CAAC,UAAU,EACjC,eAAM,CAAC,aAAa,CAAC,QAAQ,CAAC;oBAC5B,IAAI,EAAE,aAAa;oBACnB,IAAI,EAAE;wBACJ,UAAU,EAAE,4DAA4D;wBACxE,GAAG,EAAE,8CAA8C;wBACnD,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,QAAQ;qBACvC;iBACF,CAAC,EACF;oBACE,IAAI,EAAE,mBAAmB;oBACzB,GAAG,EAAE;wBACH,QAAQ;wBACR,mDAAmD;wBACnD,+BAA+B;wBAC/B,UAAU;wBACV,IAAI;wBACJ,4CAA4C;wBAC5C,sEAAsE;wBACtE,4DAA4D;wBAC5D,0CAA0C;wBAC1C,UAAU;wBACV,IAAI;wBACJ,yCAAyC;wBACzC,6CAA6C;wBAC7C,+BAA+B;wBAC/B,UAAU;wBACV,IAAI;wBACJ,WAAW;wBACX,yCAAyC;wBACzC,UAAU;qBACX,CAAC,IAAI,CAAC,IAAI,CAAC;iBACb,CACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;;AAhFH,kDAiFC;;;AAED,SAAS,gBAAgB,CAAC,IAAY,EAAE,GAAG,KAAmE;IAC5G,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC;AACtE,CAAC","sourcesContent":["import type { Project } from 'projen';\nimport { JsonPatch, github } from 'projen';\n\n/**\n * Options for configuring self-mutation behavior on forks\n */\nexport interface SelfMutationOnForksOptions {\n  /**\n   * Environment name to use for the workflow\n   * @default - no environment specified\n   */\n  readonly environment?: string;\n}\n\n/**\n * Configures GitHub workflows to enable self-mutation on fork pull requests.\n *\n * This class sets up a workflow that will automatically apply projen-generated changes\n * when a build fails due to outdated generated files. The workflow:\n *\n * 1. Runs when the build workflow fails on a PR\n * 2. Downloads any patch file generated during the failed build\n * 3. Authenticates using GitHub App credentials\n * 4. Checks out the PR branch\n * 5. Applies the patch if it exists and can be applied cleanly\n * 6. Commits and pushes the changes back to the PR\n *\n * This enables automated fixes for common projen-related issues on fork PRs.\n */\nexport class SelfMutationOnForks {\n  constructor(project: Project, options: SelfMutationOnForksOptions = {}) {\n    const cicd = github.GitHub.of(project);\n    if (!cicd) return;\n\n    const buildWorkflow = cicd.tryFindWorkflow('build');\n    if (!buildWorkflow) return;\n\n    // Update condition to run on all pull requests\n    buildWorkflow.file?.patch(\n      JsonPatch.remove('/jobs/self-mutation'),\n    );\n\n    // Add a new self mutation workflow that runs on completion of build\n    // and if the build failed and there is a patch, updates the PR\n    const selfMutation = cicd?.addWorkflow('self-mutation');\n    selfMutation?.on({\n      workflowRun: {\n        workflows: [buildWorkflow.name],\n        types: ['completed'],\n      },\n    });\n\n    selfMutation?.addJob('self-mutation', {\n      runsOn: ['ubuntu-latest'],\n      if: \"github.event.workflow_run.conclusion == 'failure' && github.event.workflow_run.event == 'pull_request'\",\n      permissions: {\n        contents: github.workflows.JobPermission.READ,\n      },\n      environment: options.environment,\n      steps: [\n        {\n          name: 'Download patch',\n          id: 'download_patch',\n          continueOnError: true,\n          uses: 'dawidd6/action-download-artifact@ac66b43f0e6a346234dd65d4d0c8fbb31cb316e5',\n          with: {\n            run_id: '${{ github.event.workflow_run.id }}',\n            name: 'repo.patch',\n            path: '${{ runner.temp }}',\n          },\n        },\n        ...conditionalSteps(\n          'steps.download_patch.outcome == \\'success\\'',\n          cicd.projenCredentials.setupSteps,\n          github.WorkflowSteps.checkout({\n            name: 'Checkout PR',\n            with: {\n              repository: '${{ github.event.workflow_run.head_repository.full_name }}',\n              ref: '${{ github.event.workflow_run.head_branch }}',\n              token: cicd.projenCredentials.tokenRef,\n            },\n          }),\n          {\n            name: 'Apply patch to PR',\n            run: [\n              'set -e',\n              'if [ ! -f \"${{ runner.temp }}/repo.patch\" ]; then',\n              '  echo \"Patch file not found\"',\n              '  exit 1',\n              'fi',\n              'git config user.name \"github-actions[bot]\"',\n              'git config user.email \"github-actions[bot]@users.noreply.github.com\"',\n              'if ! git apply --check ${{ runner.temp }}/repo.patch; then',\n              '  echo \"Patch cannot be applied cleanly\"',\n              '  exit 1',\n              'fi',\n              'git apply ${{ runner.temp }}/repo.patch',\n              'if [ -z \"$(git status --porcelain)\" ]; then',\n              '  echo \"No changes to commit\"',\n              '  exit 0',\n              'fi',\n              'git add .',\n              'git commit -s -m \"chore: self mutation\"',\n              'git push',\n            ].join('\\n'),\n          },\n        ),\n      ],\n    });\n  }\n}\n\nfunction conditionalSteps(cond: string, ...steps: Array<github.workflows.JobStep | github.workflows.JobStep[]>): github.workflows.JobStep[] {\n  return steps.flatMap(s => s).map(s => ({ ...s, if: s.if ?? cond }));\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './SelfMutationOnForks';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./SelfMutationOnForks"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsd0RBQXNDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9TZWxmTXV0YXRpb25PbkZvcmtzJztcbiJdfQ==
|
|
@@ -511,6 +511,21 @@ export interface ConstructProjectOptions {
|
|
|
511
511
|
* @stability stable
|
|
512
512
|
*/
|
|
513
513
|
readonly autoApproveUpgrades?: boolean;
|
|
514
|
+
/**
|
|
515
|
+
* Security audit options.
|
|
516
|
+
* @default - default options
|
|
517
|
+
* @stability stable
|
|
518
|
+
*/
|
|
519
|
+
readonly auditDepsOptions?: javascript.AuditOptions;
|
|
520
|
+
/**
|
|
521
|
+
* Run security audit on dependencies.
|
|
522
|
+
* When enabled, creates an "audit" task that checks for known security vulnerabilities
|
|
523
|
+
* in dependencies. By default, runs during every build and checks for "high" severity
|
|
524
|
+
* vulnerabilities or above in all dependencies (including dev dependencies).
|
|
525
|
+
* @default false
|
|
526
|
+
* @stability stable
|
|
527
|
+
*/
|
|
528
|
+
readonly auditDeps?: boolean;
|
|
514
529
|
/**
|
|
515
530
|
* A directory which will contain build artifacts.
|
|
516
531
|
* @default "dist"
|