Compare commits
19 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| f04aa94d10 | |||
| 323044ff31 | |||
| 936979e9ad | |||
| 2986852ad8 | |||
| 495056a515 | |||
| 8746053070 | |||
| 46e4a501e1 | |||
| 2e5cc74af2 | |||
| 474769db88 | |||
| e995b4e40a | |||
| 0f3b4d7df9 | |||
| 9769eb4076 | |||
| bb368d6a10 | |||
| eaddb9eb7e | |||
| 6375dcedb2 | |||
| 9577d5145a | |||
| 7f24dca8d7 | |||
| d2cdb754af | |||
| 3bb715c53d |
@@ -1,5 +1,6 @@
|
||||
name: release
|
||||
"on":
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
@@ -18,10 +19,12 @@ jobs:
|
||||
- uses: actions/checkout@v4
|
||||
with:
|
||||
persist-credentials: false
|
||||
- uses: actions/setup-node@v3
|
||||
|
||||
- uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 20
|
||||
cache: "npm"
|
||||
node-version-file: .node-version
|
||||
cache: 'npm'
|
||||
|
||||
- run: npm ci
|
||||
- run: npm run build
|
||||
- uses: ./
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
name: test
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
@@ -15,10 +16,12 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/setup-node@v3
|
||||
|
||||
- uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 20
|
||||
cache: "npm"
|
||||
node-version-file: .node-version
|
||||
cache: 'npm'
|
||||
|
||||
- run: npm ci
|
||||
- run: npm test
|
||||
|
||||
@@ -29,7 +32,7 @@ jobs:
|
||||
if: github.event.pull_request.head.repo.owner.login == github.event.pull_request.base.repo.owner.login
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/setup-node@v3
|
||||
- uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 20
|
||||
cache: "npm"
|
||||
|
||||
@@ -0,0 +1 @@
|
||||
20.9.0
|
||||
@@ -1,5 +1,7 @@
|
||||
# Create GitHub App Token
|
||||
|
||||
[](https://github.com/actions/create-github-app-token/actions/workflows/test.yml)
|
||||
|
||||
GitHub Action for creating a GitHub App installation access token.
|
||||
|
||||
## Usage
|
||||
@@ -46,7 +48,7 @@ jobs:
|
||||
# required
|
||||
app-id: ${{ vars.APP_ID }}
|
||||
private-key: ${{ secrets.PRIVATE_KEY }}
|
||||
- uses: actions/checkout@v3
|
||||
- uses: actions/checkout@v4
|
||||
with:
|
||||
token: ${{ steps.app-token.outputs.token }}
|
||||
ref: ${{ github.head_ref }}
|
||||
@@ -124,6 +126,52 @@ jobs:
|
||||
body: "Hello, World!"
|
||||
```
|
||||
|
||||
### Create tokens for multiple user or organization accounts
|
||||
|
||||
You can use a matrix strategy to create tokens for multiple user or organization accounts.
|
||||
|
||||
> [!NOTE]
|
||||
> See [this documentation](https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#multiline-strings) for information on using multiline strings in workflows.
|
||||
|
||||
```yaml
|
||||
on: [workflow_dispatch]
|
||||
|
||||
jobs:
|
||||
set-matrix:
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
matrix: ${{steps.set.outputs.matrix }}
|
||||
steps:
|
||||
- id: set
|
||||
run: echo 'matrix=[{"owner":"owner1"},{"owner":"owner2","repos":["repo1"]}]' >>"$GITHUB_OUTPUT"
|
||||
|
||||
use-matrix:
|
||||
name: '@${{ matrix.owners-and-repos.owner }} installation'
|
||||
needs: [set-matrix]
|
||||
runs-on: ubuntu-latest
|
||||
strategy:
|
||||
matrix:
|
||||
owners-and-repos: ${{ fromJson(needs.set-matrix.outputs.matrix) }}
|
||||
|
||||
steps:
|
||||
- uses: actions/create-github-app-token@v1
|
||||
id: app-token
|
||||
with:
|
||||
app-id: ${{ vars.APP_ID }}
|
||||
private-key: ${{ secrets.PRIVATE_KEY }}
|
||||
owner: ${{ matrix.owners-and-repos.owner }}
|
||||
repositories: ${{ join(matrix.owners-and-repos.repos) }}
|
||||
- uses: octokit/request-action@v2.x
|
||||
id: get-installation-repositories
|
||||
with:
|
||||
route: GET /installation/repositories
|
||||
env:
|
||||
GITHUB_TOKEN: ${{ steps.app-token.outputs.token }}
|
||||
- run: echo "$MULTILINE_JSON_STRING"
|
||||
env:
|
||||
MULTILINE_JSON_STRING: ${{ steps.get-installation-repositories.outputs.data }}
|
||||
```
|
||||
|
||||
## Inputs
|
||||
|
||||
### `app-id`
|
||||
|
||||
@@ -0,0 +1,25 @@
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="106"
|
||||
height="20" role="img" aria-label="Coverage: 100%">
|
||||
<title>Coverage: 100%</title>
|
||||
<linearGradient id="s" x2="0" y2="100%">
|
||||
<stop offset="0" stop-color="#bbb" stop-opacity=".1" />
|
||||
<stop offset="1" stop-opacity=".1" />
|
||||
</linearGradient>
|
||||
<clipPath id="r">
|
||||
<rect width="106" height="20" rx="3" fill="#fff" />
|
||||
</clipPath>
|
||||
<g clip-path="url(#r)">
|
||||
<rect width="63" height="20" fill="#555" />
|
||||
<rect x="63" width="43" height="20" fill="#4c1" />
|
||||
<rect width="106" height="20" fill="url(#s)" />
|
||||
</g>
|
||||
<g fill="#fff" text-anchor="middle" font-family="Verdana,Geneva,DejaVu Sans,sans-serif"
|
||||
text-rendering="geometricPrecision" font-size="110">
|
||||
<text aria-hidden="true" x="325" y="150" fill="#010101" fill-opacity=".3"
|
||||
transform="scale(.1)" textLength="530">Coverage</text>
|
||||
<text x="325" y="140" transform="scale(.1)" fill="#fff" textLength="530">Coverage</text>
|
||||
<text aria-hidden="true" x="835" y="150" fill="#010101" fill-opacity=".3"
|
||||
transform="scale(.1)" textLength="330">100%</text>
|
||||
<text x="835" y="140" transform="scale(.1)" fill="#fff" textLength="330">100%</text>
|
||||
</g>
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 1.3 KiB |
Vendored
+663
-290
File diff suppressed because it is too large
Load Diff
Vendored
+150
-132
@@ -34,10 +34,10 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
||||
|
||||
// node_modules/@actions/core/lib/utils.js
|
||||
var require_utils = __commonJS({
|
||||
"node_modules/@actions/core/lib/utils.js"(exports) {
|
||||
"node_modules/@actions/core/lib/utils.js"(exports2) {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.toCommandProperties = exports.toCommandValue = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.toCommandProperties = exports2.toCommandValue = void 0;
|
||||
function toCommandValue(input) {
|
||||
if (input === null || input === void 0) {
|
||||
return "";
|
||||
@@ -46,7 +46,7 @@ var require_utils = __commonJS({
|
||||
}
|
||||
return JSON.stringify(input);
|
||||
}
|
||||
exports.toCommandValue = toCommandValue;
|
||||
exports2.toCommandValue = toCommandValue;
|
||||
function toCommandProperties(annotationProperties) {
|
||||
if (!Object.keys(annotationProperties).length) {
|
||||
return {};
|
||||
@@ -60,15 +60,15 @@ var require_utils = __commonJS({
|
||||
endColumn: annotationProperties.endColumn
|
||||
};
|
||||
}
|
||||
exports.toCommandProperties = toCommandProperties;
|
||||
exports2.toCommandProperties = toCommandProperties;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/core/lib/command.js
|
||||
var require_command = __commonJS({
|
||||
"node_modules/@actions/core/lib/command.js"(exports) {
|
||||
"node_modules/@actions/core/lib/command.js"(exports2) {
|
||||
"use strict";
|
||||
var __createBinding = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
var __createBinding = exports2 && exports2.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
if (k2 === void 0)
|
||||
k2 = k;
|
||||
Object.defineProperty(o, k2, { enumerable: true, get: function() {
|
||||
@@ -79,12 +79,12 @@ var require_command = __commonJS({
|
||||
k2 = k;
|
||||
o[k2] = m[k];
|
||||
});
|
||||
var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
var __setModuleDefault = exports2 && exports2.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
} : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = exports && exports.__importStar || function(mod) {
|
||||
var __importStar = exports2 && exports2.__importStar || function(mod) {
|
||||
if (mod && mod.__esModule)
|
||||
return mod;
|
||||
var result = {};
|
||||
@@ -96,19 +96,19 @@ var require_command = __commonJS({
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.issue = exports.issueCommand = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.issue = exports2.issueCommand = void 0;
|
||||
var os = __importStar(require("os"));
|
||||
var utils_1 = require_utils();
|
||||
function issueCommand(command, properties, message) {
|
||||
const cmd = new Command(command, properties, message);
|
||||
process.stdout.write(cmd.toString() + os.EOL);
|
||||
}
|
||||
exports.issueCommand = issueCommand;
|
||||
exports2.issueCommand = issueCommand;
|
||||
function issue(name, message = "") {
|
||||
issueCommand(name, {}, message);
|
||||
}
|
||||
exports.issue = issue;
|
||||
exports2.issue = issue;
|
||||
var CMD_STRING = "::";
|
||||
var Command = class {
|
||||
constructor(command, properties, message) {
|
||||
@@ -486,9 +486,9 @@ var init_esm_node = __esm({
|
||||
|
||||
// node_modules/@actions/core/lib/file-command.js
|
||||
var require_file_command = __commonJS({
|
||||
"node_modules/@actions/core/lib/file-command.js"(exports) {
|
||||
"node_modules/@actions/core/lib/file-command.js"(exports2) {
|
||||
"use strict";
|
||||
var __createBinding = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
var __createBinding = exports2 && exports2.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
if (k2 === void 0)
|
||||
k2 = k;
|
||||
Object.defineProperty(o, k2, { enumerable: true, get: function() {
|
||||
@@ -499,12 +499,12 @@ var require_file_command = __commonJS({
|
||||
k2 = k;
|
||||
o[k2] = m[k];
|
||||
});
|
||||
var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
var __setModuleDefault = exports2 && exports2.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
} : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = exports && exports.__importStar || function(mod) {
|
||||
var __importStar = exports2 && exports2.__importStar || function(mod) {
|
||||
if (mod && mod.__esModule)
|
||||
return mod;
|
||||
var result = {};
|
||||
@@ -516,8 +516,8 @@ var require_file_command = __commonJS({
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.prepareKeyValueMessage = exports.issueFileCommand = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.prepareKeyValueMessage = exports2.issueFileCommand = void 0;
|
||||
var fs = __importStar(require("fs"));
|
||||
var os = __importStar(require("os"));
|
||||
var uuid_1 = (init_esm_node(), __toCommonJS(esm_node_exports));
|
||||
@@ -534,7 +534,7 @@ var require_file_command = __commonJS({
|
||||
encoding: "utf8"
|
||||
});
|
||||
}
|
||||
exports.issueFileCommand = issueFileCommand;
|
||||
exports2.issueFileCommand = issueFileCommand;
|
||||
function prepareKeyValueMessage(key, value) {
|
||||
const delimiter = `ghadelimiter_${uuid_1.v4()}`;
|
||||
const convertedValue = utils_1.toCommandValue(value);
|
||||
@@ -546,16 +546,16 @@ var require_file_command = __commonJS({
|
||||
}
|
||||
return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`;
|
||||
}
|
||||
exports.prepareKeyValueMessage = prepareKeyValueMessage;
|
||||
exports2.prepareKeyValueMessage = prepareKeyValueMessage;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/http-client/lib/proxy.js
|
||||
var require_proxy = __commonJS({
|
||||
"node_modules/@actions/http-client/lib/proxy.js"(exports) {
|
||||
"node_modules/@actions/http-client/lib/proxy.js"(exports2) {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.checkBypass = exports.getProxyUrl = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.checkBypass = exports2.getProxyUrl = void 0;
|
||||
function getProxyUrl(reqUrl) {
|
||||
const usingSsl = reqUrl.protocol === "https:";
|
||||
if (checkBypass(reqUrl)) {
|
||||
@@ -579,7 +579,7 @@ var require_proxy = __commonJS({
|
||||
return void 0;
|
||||
}
|
||||
}
|
||||
exports.getProxyUrl = getProxyUrl;
|
||||
exports2.getProxyUrl = getProxyUrl;
|
||||
function checkBypass(reqUrl) {
|
||||
if (!reqUrl.hostname) {
|
||||
return false;
|
||||
@@ -611,7 +611,7 @@ var require_proxy = __commonJS({
|
||||
}
|
||||
return false;
|
||||
}
|
||||
exports.checkBypass = checkBypass;
|
||||
exports2.checkBypass = checkBypass;
|
||||
function isLoopbackAddress(host) {
|
||||
const hostLower = host.toLowerCase();
|
||||
return hostLower === "localhost" || hostLower.startsWith("127.") || hostLower.startsWith("[::1]") || hostLower.startsWith("[0:0:0:0:0:0:0:1]");
|
||||
@@ -621,7 +621,7 @@ var require_proxy = __commonJS({
|
||||
|
||||
// node_modules/tunnel/lib/tunnel.js
|
||||
var require_tunnel = __commonJS({
|
||||
"node_modules/tunnel/lib/tunnel.js"(exports) {
|
||||
"node_modules/tunnel/lib/tunnel.js"(exports2) {
|
||||
"use strict";
|
||||
var net = require("net");
|
||||
var tls = require("tls");
|
||||
@@ -630,10 +630,10 @@ var require_tunnel = __commonJS({
|
||||
var events = require("events");
|
||||
var assert = require("assert");
|
||||
var util = require("util");
|
||||
exports.httpOverHttp = httpOverHttp;
|
||||
exports.httpsOverHttp = httpsOverHttp;
|
||||
exports.httpOverHttps = httpOverHttps;
|
||||
exports.httpsOverHttps = httpsOverHttps;
|
||||
exports2.httpOverHttp = httpOverHttp;
|
||||
exports2.httpsOverHttp = httpsOverHttp;
|
||||
exports2.httpOverHttps = httpOverHttps;
|
||||
exports2.httpsOverHttps = httpsOverHttps;
|
||||
function httpOverHttp(options) {
|
||||
var agent = new TunnelingAgent(options);
|
||||
agent.request = http.request;
|
||||
@@ -845,22 +845,22 @@ var require_tunnel = __commonJS({
|
||||
debug = function() {
|
||||
};
|
||||
}
|
||||
exports.debug = debug;
|
||||
exports2.debug = debug;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/tunnel/index.js
|
||||
var require_tunnel2 = __commonJS({
|
||||
"node_modules/tunnel/index.js"(exports, module2) {
|
||||
"node_modules/tunnel/index.js"(exports2, module2) {
|
||||
module2.exports = require_tunnel();
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/http-client/lib/index.js
|
||||
var require_lib = __commonJS({
|
||||
"node_modules/@actions/http-client/lib/index.js"(exports) {
|
||||
"node_modules/@actions/http-client/lib/index.js"(exports2) {
|
||||
"use strict";
|
||||
var __createBinding = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
var __createBinding = exports2 && exports2.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
if (k2 === void 0)
|
||||
k2 = k;
|
||||
Object.defineProperty(o, k2, { enumerable: true, get: function() {
|
||||
@@ -871,12 +871,12 @@ var require_lib = __commonJS({
|
||||
k2 = k;
|
||||
o[k2] = m[k];
|
||||
});
|
||||
var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
var __setModuleDefault = exports2 && exports2.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
} : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = exports && exports.__importStar || function(mod) {
|
||||
var __importStar = exports2 && exports2.__importStar || function(mod) {
|
||||
if (mod && mod.__esModule)
|
||||
return mod;
|
||||
var result = {};
|
||||
@@ -888,7 +888,7 @@ var require_lib = __commonJS({
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
var __awaiter = exports && exports.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
var __awaiter = exports2 && exports2.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
function adopt(value) {
|
||||
return value instanceof P ? value : new P(function(resolve) {
|
||||
resolve(value);
|
||||
@@ -915,8 +915,8 @@ var require_lib = __commonJS({
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.HttpClient = exports2.isHttps = exports2.HttpClientResponse = exports2.HttpClientError = exports2.getProxyUrl = exports2.MediaTypes = exports2.Headers = exports2.HttpCodes = void 0;
|
||||
var http = __importStar(require("http"));
|
||||
var https = __importStar(require("https"));
|
||||
var pm = __importStar(require_proxy());
|
||||
@@ -950,21 +950,21 @@ var require_lib = __commonJS({
|
||||
HttpCodes2[HttpCodes2["BadGateway"] = 502] = "BadGateway";
|
||||
HttpCodes2[HttpCodes2["ServiceUnavailable"] = 503] = "ServiceUnavailable";
|
||||
HttpCodes2[HttpCodes2["GatewayTimeout"] = 504] = "GatewayTimeout";
|
||||
})(HttpCodes = exports.HttpCodes || (exports.HttpCodes = {}));
|
||||
})(HttpCodes = exports2.HttpCodes || (exports2.HttpCodes = {}));
|
||||
var Headers;
|
||||
(function(Headers2) {
|
||||
Headers2["Accept"] = "accept";
|
||||
Headers2["ContentType"] = "content-type";
|
||||
})(Headers = exports.Headers || (exports.Headers = {}));
|
||||
})(Headers = exports2.Headers || (exports2.Headers = {}));
|
||||
var MediaTypes;
|
||||
(function(MediaTypes2) {
|
||||
MediaTypes2["ApplicationJson"] = "application/json";
|
||||
})(MediaTypes = exports.MediaTypes || (exports.MediaTypes = {}));
|
||||
})(MediaTypes = exports2.MediaTypes || (exports2.MediaTypes = {}));
|
||||
function getProxyUrl(serverUrl) {
|
||||
const proxyUrl = pm.getProxyUrl(new URL(serverUrl));
|
||||
return proxyUrl ? proxyUrl.href : "";
|
||||
}
|
||||
exports.getProxyUrl = getProxyUrl;
|
||||
exports2.getProxyUrl = getProxyUrl;
|
||||
var HttpRedirectCodes = [
|
||||
HttpCodes.MovedPermanently,
|
||||
HttpCodes.ResourceMoved,
|
||||
@@ -988,7 +988,7 @@ var require_lib = __commonJS({
|
||||
Object.setPrototypeOf(this, _HttpClientError.prototype);
|
||||
}
|
||||
};
|
||||
exports.HttpClientError = HttpClientError;
|
||||
exports2.HttpClientError = HttpClientError;
|
||||
var HttpClientResponse = class {
|
||||
constructor(message) {
|
||||
this.message = message;
|
||||
@@ -1020,12 +1020,12 @@ var require_lib = __commonJS({
|
||||
});
|
||||
}
|
||||
};
|
||||
exports.HttpClientResponse = HttpClientResponse;
|
||||
exports2.HttpClientResponse = HttpClientResponse;
|
||||
function isHttps(requestUrl) {
|
||||
const parsedUrl = new URL(requestUrl);
|
||||
return parsedUrl.protocol === "https:";
|
||||
}
|
||||
exports.isHttps = isHttps;
|
||||
exports2.isHttps = isHttps;
|
||||
var HttpClient = class {
|
||||
constructor(userAgent, handlers, requestOptions) {
|
||||
this._ignoreSslError = false;
|
||||
@@ -1444,16 +1444,16 @@ var require_lib = __commonJS({
|
||||
});
|
||||
}
|
||||
};
|
||||
exports.HttpClient = HttpClient;
|
||||
exports2.HttpClient = HttpClient;
|
||||
var lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => (c[k.toLowerCase()] = obj[k], c), {});
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/http-client/lib/auth.js
|
||||
var require_auth = __commonJS({
|
||||
"node_modules/@actions/http-client/lib/auth.js"(exports) {
|
||||
"node_modules/@actions/http-client/lib/auth.js"(exports2) {
|
||||
"use strict";
|
||||
var __awaiter = exports && exports.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
var __awaiter = exports2 && exports2.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
function adopt(value) {
|
||||
return value instanceof P ? value : new P(function(resolve) {
|
||||
resolve(value);
|
||||
@@ -1480,8 +1480,8 @@ var require_auth = __commonJS({
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.PersonalAccessTokenCredentialHandler = exports.BearerCredentialHandler = exports.BasicCredentialHandler = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.PersonalAccessTokenCredentialHandler = exports2.BearerCredentialHandler = exports2.BasicCredentialHandler = void 0;
|
||||
var BasicCredentialHandler = class {
|
||||
constructor(username, password) {
|
||||
this.username = username;
|
||||
@@ -1503,7 +1503,7 @@ var require_auth = __commonJS({
|
||||
});
|
||||
}
|
||||
};
|
||||
exports.BasicCredentialHandler = BasicCredentialHandler;
|
||||
exports2.BasicCredentialHandler = BasicCredentialHandler;
|
||||
var BearerCredentialHandler = class {
|
||||
constructor(token) {
|
||||
this.token = token;
|
||||
@@ -1526,7 +1526,7 @@ var require_auth = __commonJS({
|
||||
});
|
||||
}
|
||||
};
|
||||
exports.BearerCredentialHandler = BearerCredentialHandler;
|
||||
exports2.BearerCredentialHandler = BearerCredentialHandler;
|
||||
var PersonalAccessTokenCredentialHandler = class {
|
||||
constructor(token) {
|
||||
this.token = token;
|
||||
@@ -1549,15 +1549,15 @@ var require_auth = __commonJS({
|
||||
});
|
||||
}
|
||||
};
|
||||
exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler;
|
||||
exports2.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/core/lib/oidc-utils.js
|
||||
var require_oidc_utils = __commonJS({
|
||||
"node_modules/@actions/core/lib/oidc-utils.js"(exports) {
|
||||
"node_modules/@actions/core/lib/oidc-utils.js"(exports2) {
|
||||
"use strict";
|
||||
var __awaiter = exports && exports.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
var __awaiter = exports2 && exports2.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
function adopt(value) {
|
||||
return value instanceof P ? value : new P(function(resolve) {
|
||||
resolve(value);
|
||||
@@ -1584,8 +1584,8 @@ var require_oidc_utils = __commonJS({
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.OidcClient = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.OidcClient = void 0;
|
||||
var http_client_1 = require_lib();
|
||||
var auth_1 = require_auth();
|
||||
var core_1 = require_core();
|
||||
@@ -1647,15 +1647,15 @@ var require_oidc_utils = __commonJS({
|
||||
});
|
||||
}
|
||||
};
|
||||
exports.OidcClient = OidcClient;
|
||||
exports2.OidcClient = OidcClient;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/core/lib/summary.js
|
||||
var require_summary = __commonJS({
|
||||
"node_modules/@actions/core/lib/summary.js"(exports) {
|
||||
"node_modules/@actions/core/lib/summary.js"(exports2) {
|
||||
"use strict";
|
||||
var __awaiter = exports && exports.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
var __awaiter = exports2 && exports2.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
function adopt(value) {
|
||||
return value instanceof P ? value : new P(function(resolve) {
|
||||
resolve(value);
|
||||
@@ -1682,13 +1682,13 @@ var require_summary = __commonJS({
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.summary = exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.summary = exports2.markdownSummary = exports2.SUMMARY_DOCS_URL = exports2.SUMMARY_ENV_VAR = void 0;
|
||||
var os_1 = require("os");
|
||||
var fs_1 = require("fs");
|
||||
var { access, appendFile, writeFile } = fs_1.promises;
|
||||
exports.SUMMARY_ENV_VAR = "GITHUB_STEP_SUMMARY";
|
||||
exports.SUMMARY_DOCS_URL = "https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary";
|
||||
exports2.SUMMARY_ENV_VAR = "GITHUB_STEP_SUMMARY";
|
||||
exports2.SUMMARY_DOCS_URL = "https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary";
|
||||
var Summary = class {
|
||||
constructor() {
|
||||
this._buffer = "";
|
||||
@@ -1704,9 +1704,9 @@ var require_summary = __commonJS({
|
||||
if (this._filePath) {
|
||||
return this._filePath;
|
||||
}
|
||||
const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR];
|
||||
const pathFromEnv = process.env[exports2.SUMMARY_ENV_VAR];
|
||||
if (!pathFromEnv) {
|
||||
throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`);
|
||||
throw new Error(`Unable to find environment variable for $${exports2.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`);
|
||||
}
|
||||
try {
|
||||
yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK);
|
||||
@@ -1940,16 +1940,16 @@ var require_summary = __commonJS({
|
||||
}
|
||||
};
|
||||
var _summary = new Summary();
|
||||
exports.markdownSummary = _summary;
|
||||
exports.summary = _summary;
|
||||
exports2.markdownSummary = _summary;
|
||||
exports2.summary = _summary;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/core/lib/path-utils.js
|
||||
var require_path_utils = __commonJS({
|
||||
"node_modules/@actions/core/lib/path-utils.js"(exports) {
|
||||
"node_modules/@actions/core/lib/path-utils.js"(exports2) {
|
||||
"use strict";
|
||||
var __createBinding = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
var __createBinding = exports2 && exports2.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
if (k2 === void 0)
|
||||
k2 = k;
|
||||
Object.defineProperty(o, k2, { enumerable: true, get: function() {
|
||||
@@ -1960,12 +1960,12 @@ var require_path_utils = __commonJS({
|
||||
k2 = k;
|
||||
o[k2] = m[k];
|
||||
});
|
||||
var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
var __setModuleDefault = exports2 && exports2.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
} : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = exports && exports.__importStar || function(mod) {
|
||||
var __importStar = exports2 && exports2.__importStar || function(mod) {
|
||||
if (mod && mod.__esModule)
|
||||
return mod;
|
||||
var result = {};
|
||||
@@ -1977,29 +1977,29 @@ var require_path_utils = __commonJS({
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.toPlatformPath = exports.toWin32Path = exports.toPosixPath = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.toPlatformPath = exports2.toWin32Path = exports2.toPosixPath = void 0;
|
||||
var path = __importStar(require("path"));
|
||||
function toPosixPath(pth) {
|
||||
return pth.replace(/[\\]/g, "/");
|
||||
}
|
||||
exports.toPosixPath = toPosixPath;
|
||||
exports2.toPosixPath = toPosixPath;
|
||||
function toWin32Path(pth) {
|
||||
return pth.replace(/[/]/g, "\\");
|
||||
}
|
||||
exports.toWin32Path = toWin32Path;
|
||||
exports2.toWin32Path = toWin32Path;
|
||||
function toPlatformPath(pth) {
|
||||
return pth.replace(/[/\\]/g, path.sep);
|
||||
}
|
||||
exports.toPlatformPath = toPlatformPath;
|
||||
exports2.toPlatformPath = toPlatformPath;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@actions/core/lib/core.js
|
||||
var require_core = __commonJS({
|
||||
"node_modules/@actions/core/lib/core.js"(exports) {
|
||||
"node_modules/@actions/core/lib/core.js"(exports2) {
|
||||
"use strict";
|
||||
var __createBinding = exports && exports.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
var __createBinding = exports2 && exports2.__createBinding || (Object.create ? function(o, m, k, k2) {
|
||||
if (k2 === void 0)
|
||||
k2 = k;
|
||||
Object.defineProperty(o, k2, { enumerable: true, get: function() {
|
||||
@@ -2010,12 +2010,12 @@ var require_core = __commonJS({
|
||||
k2 = k;
|
||||
o[k2] = m[k];
|
||||
});
|
||||
var __setModuleDefault = exports && exports.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
var __setModuleDefault = exports2 && exports2.__setModuleDefault || (Object.create ? function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
} : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = exports && exports.__importStar || function(mod) {
|
||||
var __importStar = exports2 && exports2.__importStar || function(mod) {
|
||||
if (mod && mod.__esModule)
|
||||
return mod;
|
||||
var result = {};
|
||||
@@ -2027,7 +2027,7 @@ var require_core = __commonJS({
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
var __awaiter = exports && exports.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
var __awaiter = exports2 && exports2.__awaiter || function(thisArg, _arguments, P, generator) {
|
||||
function adopt(value) {
|
||||
return value instanceof P ? value : new P(function(resolve) {
|
||||
resolve(value);
|
||||
@@ -2054,8 +2054,8 @@ var require_core = __commonJS({
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
exports2.getIDToken = exports2.getState = exports2.saveState = exports2.group = exports2.endGroup = exports2.startGroup = exports2.info = exports2.notice = exports2.warning = exports2.error = exports2.debug = exports2.isDebug = exports2.setFailed = exports2.setCommandEcho = exports2.setOutput = exports2.getBooleanInput = exports2.getMultilineInput = exports2.getInput = exports2.addPath = exports2.setSecret = exports2.exportVariable = exports2.ExitCode = void 0;
|
||||
var command_1 = require_command();
|
||||
var file_command_1 = require_file_command();
|
||||
var utils_1 = require_utils();
|
||||
@@ -2066,7 +2066,7 @@ var require_core = __commonJS({
|
||||
(function(ExitCode2) {
|
||||
ExitCode2[ExitCode2["Success"] = 0] = "Success";
|
||||
ExitCode2[ExitCode2["Failure"] = 1] = "Failure";
|
||||
})(ExitCode = exports.ExitCode || (exports.ExitCode = {}));
|
||||
})(ExitCode = exports2.ExitCode || (exports2.ExitCode = {}));
|
||||
function exportVariable(name, val) {
|
||||
const convertedVal = utils_1.toCommandValue(val);
|
||||
process.env[name] = convertedVal;
|
||||
@@ -2076,11 +2076,11 @@ var require_core = __commonJS({
|
||||
}
|
||||
command_1.issueCommand("set-env", { name }, convertedVal);
|
||||
}
|
||||
exports.exportVariable = exportVariable;
|
||||
exports2.exportVariable = exportVariable;
|
||||
function setSecret(secret) {
|
||||
command_1.issueCommand("add-mask", {}, secret);
|
||||
}
|
||||
exports.setSecret = setSecret;
|
||||
exports2.setSecret = setSecret;
|
||||
function addPath(inputPath) {
|
||||
const filePath = process.env["GITHUB_PATH"] || "";
|
||||
if (filePath) {
|
||||
@@ -2090,7 +2090,7 @@ var require_core = __commonJS({
|
||||
}
|
||||
process.env["PATH"] = `${inputPath}${path.delimiter}${process.env["PATH"]}`;
|
||||
}
|
||||
exports.addPath = addPath;
|
||||
exports2.addPath = addPath;
|
||||
function getInput(name, options) {
|
||||
const val = process.env[`INPUT_${name.replace(/ /g, "_").toUpperCase()}`] || "";
|
||||
if (options && options.required && !val) {
|
||||
@@ -2101,7 +2101,7 @@ var require_core = __commonJS({
|
||||
}
|
||||
return val.trim();
|
||||
}
|
||||
exports.getInput = getInput;
|
||||
exports2.getInput = getInput;
|
||||
function getMultilineInput(name, options) {
|
||||
const inputs = getInput(name, options).split("\n").filter((x) => x !== "");
|
||||
if (options && options.trimWhitespace === false) {
|
||||
@@ -2109,7 +2109,7 @@ var require_core = __commonJS({
|
||||
}
|
||||
return inputs.map((input) => input.trim());
|
||||
}
|
||||
exports.getMultilineInput = getMultilineInput;
|
||||
exports2.getMultilineInput = getMultilineInput;
|
||||
function getBooleanInput(name, options) {
|
||||
const trueValue = ["true", "True", "TRUE"];
|
||||
const falseValue = ["false", "False", "FALSE"];
|
||||
@@ -2121,7 +2121,7 @@ var require_core = __commonJS({
|
||||
throw new TypeError(`Input does not meet YAML 1.2 "Core Schema" specification: ${name}
|
||||
Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
|
||||
}
|
||||
exports.getBooleanInput = getBooleanInput;
|
||||
exports2.getBooleanInput = getBooleanInput;
|
||||
function setOutput(name, value) {
|
||||
const filePath = process.env["GITHUB_OUTPUT"] || "";
|
||||
if (filePath) {
|
||||
@@ -2130,48 +2130,48 @@ Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
|
||||
process.stdout.write(os.EOL);
|
||||
command_1.issueCommand("set-output", { name }, utils_1.toCommandValue(value));
|
||||
}
|
||||
exports.setOutput = setOutput;
|
||||
exports2.setOutput = setOutput;
|
||||
function setCommandEcho(enabled) {
|
||||
command_1.issue("echo", enabled ? "on" : "off");
|
||||
}
|
||||
exports.setCommandEcho = setCommandEcho;
|
||||
exports2.setCommandEcho = setCommandEcho;
|
||||
function setFailed(message) {
|
||||
process.exitCode = ExitCode.Failure;
|
||||
error(message);
|
||||
}
|
||||
exports.setFailed = setFailed;
|
||||
exports2.setFailed = setFailed;
|
||||
function isDebug() {
|
||||
return process.env["RUNNER_DEBUG"] === "1";
|
||||
}
|
||||
exports.isDebug = isDebug;
|
||||
exports2.isDebug = isDebug;
|
||||
function debug(message) {
|
||||
command_1.issueCommand("debug", {}, message);
|
||||
}
|
||||
exports.debug = debug;
|
||||
exports2.debug = debug;
|
||||
function error(message, properties = {}) {
|
||||
command_1.issueCommand("error", utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
|
||||
}
|
||||
exports.error = error;
|
||||
exports2.error = error;
|
||||
function warning(message, properties = {}) {
|
||||
command_1.issueCommand("warning", utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
|
||||
}
|
||||
exports.warning = warning;
|
||||
exports2.warning = warning;
|
||||
function notice(message, properties = {}) {
|
||||
command_1.issueCommand("notice", utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
|
||||
}
|
||||
exports.notice = notice;
|
||||
exports2.notice = notice;
|
||||
function info(message) {
|
||||
process.stdout.write(message + os.EOL);
|
||||
}
|
||||
exports.info = info;
|
||||
exports2.info = info;
|
||||
function startGroup(name) {
|
||||
command_1.issue("group", name);
|
||||
}
|
||||
exports.startGroup = startGroup;
|
||||
exports2.startGroup = startGroup;
|
||||
function endGroup() {
|
||||
command_1.issue("endgroup");
|
||||
}
|
||||
exports.endGroup = endGroup;
|
||||
exports2.endGroup = endGroup;
|
||||
function group(name, fn) {
|
||||
return __awaiter(this, void 0, void 0, function* () {
|
||||
startGroup(name);
|
||||
@@ -2184,7 +2184,7 @@ Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
|
||||
return result;
|
||||
});
|
||||
}
|
||||
exports.group = group;
|
||||
exports2.group = group;
|
||||
function saveState(name, value) {
|
||||
const filePath = process.env["GITHUB_STATE"] || "";
|
||||
if (filePath) {
|
||||
@@ -2192,33 +2192,33 @@ Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
|
||||
}
|
||||
command_1.issueCommand("save-state", { name }, utils_1.toCommandValue(value));
|
||||
}
|
||||
exports.saveState = saveState;
|
||||
exports2.saveState = saveState;
|
||||
function getState(name) {
|
||||
return process.env[`STATE_${name}`] || "";
|
||||
}
|
||||
exports.getState = getState;
|
||||
exports2.getState = getState;
|
||||
function getIDToken(aud) {
|
||||
return __awaiter(this, void 0, void 0, function* () {
|
||||
return yield oidc_utils_1.OidcClient.getIDToken(aud);
|
||||
});
|
||||
}
|
||||
exports.getIDToken = getIDToken;
|
||||
exports2.getIDToken = getIDToken;
|
||||
var summary_1 = require_summary();
|
||||
Object.defineProperty(exports, "summary", { enumerable: true, get: function() {
|
||||
Object.defineProperty(exports2, "summary", { enumerable: true, get: function() {
|
||||
return summary_1.summary;
|
||||
} });
|
||||
var summary_2 = require_summary();
|
||||
Object.defineProperty(exports, "markdownSummary", { enumerable: true, get: function() {
|
||||
Object.defineProperty(exports2, "markdownSummary", { enumerable: true, get: function() {
|
||||
return summary_2.markdownSummary;
|
||||
} });
|
||||
var path_utils_1 = require_path_utils();
|
||||
Object.defineProperty(exports, "toPosixPath", { enumerable: true, get: function() {
|
||||
Object.defineProperty(exports2, "toPosixPath", { enumerable: true, get: function() {
|
||||
return path_utils_1.toPosixPath;
|
||||
} });
|
||||
Object.defineProperty(exports, "toWin32Path", { enumerable: true, get: function() {
|
||||
Object.defineProperty(exports2, "toWin32Path", { enumerable: true, get: function() {
|
||||
return path_utils_1.toWin32Path;
|
||||
} });
|
||||
Object.defineProperty(exports, "toPlatformPath", { enumerable: true, get: function() {
|
||||
Object.defineProperty(exports2, "toPlatformPath", { enumerable: true, get: function() {
|
||||
return path_utils_1.toPlatformPath;
|
||||
} });
|
||||
}
|
||||
@@ -2226,9 +2226,9 @@ Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
|
||||
|
||||
// node_modules/universal-user-agent/dist-node/index.js
|
||||
var require_dist_node = __commonJS({
|
||||
"node_modules/universal-user-agent/dist-node/index.js"(exports) {
|
||||
"node_modules/universal-user-agent/dist-node/index.js"(exports2) {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
function getUserAgent() {
|
||||
if (typeof navigator === "object" && "userAgent" in navigator) {
|
||||
return navigator.userAgent;
|
||||
@@ -2238,15 +2238,15 @@ var require_dist_node = __commonJS({
|
||||
}
|
||||
return "<environment undetectable>";
|
||||
}
|
||||
exports.getUserAgent = getUserAgent;
|
||||
exports2.getUserAgent = getUserAgent;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/is-plain-object/dist/is-plain-object.js
|
||||
var require_is_plain_object = __commonJS({
|
||||
"node_modules/is-plain-object/dist/is-plain-object.js"(exports) {
|
||||
"node_modules/is-plain-object/dist/is-plain-object.js"(exports2) {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
function isObject(o) {
|
||||
return Object.prototype.toString.call(o) === "[object Object]";
|
||||
}
|
||||
@@ -2265,13 +2265,13 @@ var require_is_plain_object = __commonJS({
|
||||
}
|
||||
return true;
|
||||
}
|
||||
exports.isPlainObject = isPlainObject;
|
||||
exports2.isPlainObject = isPlainObject;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/@octokit/endpoint/dist-node/index.js
|
||||
var require_dist_node2 = __commonJS({
|
||||
"node_modules/@octokit/endpoint/dist-node/index.js"(exports, module2) {
|
||||
"node_modules/@octokit/endpoint/dist-node/index.js"(exports2, module2) {
|
||||
"use strict";
|
||||
var __defProp2 = Object.defineProperty;
|
||||
var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor;
|
||||
@@ -2599,9 +2599,9 @@ var require_dist_node2 = __commonJS({
|
||||
|
||||
// node_modules/deprecation/dist-node/index.js
|
||||
var require_dist_node3 = __commonJS({
|
||||
"node_modules/deprecation/dist-node/index.js"(exports) {
|
||||
"node_modules/deprecation/dist-node/index.js"(exports2) {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||
var Deprecation = class extends Error {
|
||||
constructor(message) {
|
||||
super(message);
|
||||
@@ -2611,13 +2611,13 @@ var require_dist_node3 = __commonJS({
|
||||
this.name = "Deprecation";
|
||||
}
|
||||
};
|
||||
exports.Deprecation = Deprecation;
|
||||
exports2.Deprecation = Deprecation;
|
||||
}
|
||||
});
|
||||
|
||||
// node_modules/wrappy/wrappy.js
|
||||
var require_wrappy = __commonJS({
|
||||
"node_modules/wrappy/wrappy.js"(exports, module2) {
|
||||
"node_modules/wrappy/wrappy.js"(exports2, module2) {
|
||||
module2.exports = wrappy;
|
||||
function wrappy(fn, cb) {
|
||||
if (fn && cb)
|
||||
@@ -2648,7 +2648,7 @@ var require_wrappy = __commonJS({
|
||||
|
||||
// node_modules/once/once.js
|
||||
var require_once = __commonJS({
|
||||
"node_modules/once/once.js"(exports, module2) {
|
||||
"node_modules/once/once.js"(exports2, module2) {
|
||||
var wrappy = require_wrappy();
|
||||
module2.exports = wrappy(once);
|
||||
module2.exports.strict = wrappy(onceStrict);
|
||||
@@ -2693,7 +2693,7 @@ var require_once = __commonJS({
|
||||
|
||||
// node_modules/@octokit/request-error/dist-node/index.js
|
||||
var require_dist_node4 = __commonJS({
|
||||
"node_modules/@octokit/request-error/dist-node/index.js"(exports, module2) {
|
||||
"node_modules/@octokit/request-error/dist-node/index.js"(exports2, module2) {
|
||||
"use strict";
|
||||
var __create2 = Object.create;
|
||||
var __defProp2 = Object.defineProperty;
|
||||
@@ -2785,7 +2785,7 @@ var require_dist_node4 = __commonJS({
|
||||
|
||||
// node_modules/@octokit/request/dist-node/index.js
|
||||
var require_dist_node5 = __commonJS({
|
||||
"node_modules/@octokit/request/dist-node/index.js"(exports, module2) {
|
||||
"node_modules/@octokit/request/dist-node/index.js"(exports2, module2) {
|
||||
"use strict";
|
||||
var __defProp2 = Object.defineProperty;
|
||||
var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor;
|
||||
@@ -2811,8 +2811,18 @@ var require_dist_node5 = __commonJS({
|
||||
module2.exports = __toCommonJS2(dist_src_exports);
|
||||
var import_endpoint = require_dist_node2();
|
||||
var import_universal_user_agent = require_dist_node();
|
||||
var VERSION = "8.1.2";
|
||||
var import_is_plain_object = require_is_plain_object();
|
||||
var VERSION = "8.1.6";
|
||||
function isPlainObject(value) {
|
||||
if (typeof value !== "object" || value === null)
|
||||
return false;
|
||||
if (Object.prototype.toString.call(value) !== "[object Object]")
|
||||
return false;
|
||||
const proto = Object.getPrototypeOf(value);
|
||||
if (proto === null)
|
||||
return true;
|
||||
const Ctor = Object.prototype.hasOwnProperty.call(proto, "constructor") && proto.constructor;
|
||||
return typeof Ctor === "function" && Ctor instanceof Ctor && Function.prototype.call(Ctor) === Function.prototype.call(value);
|
||||
}
|
||||
var import_request_error = require_dist_node4();
|
||||
function getBufferResponse(response) {
|
||||
return response.arrayBuffer();
|
||||
@@ -2821,7 +2831,7 @@ var require_dist_node5 = __commonJS({
|
||||
var _a, _b, _c;
|
||||
const log = requestOptions.request && requestOptions.request.log ? requestOptions.request.log : console;
|
||||
const parseSuccessResponseBody = ((_a = requestOptions.request) == null ? void 0 : _a.parseSuccessResponseBody) !== false;
|
||||
if ((0, import_is_plain_object.isPlainObject)(requestOptions.body) || Array.isArray(requestOptions.body)) {
|
||||
if (isPlainObject(requestOptions.body) || Array.isArray(requestOptions.body)) {
|
||||
requestOptions.body = JSON.stringify(requestOptions.body);
|
||||
}
|
||||
let headers = {};
|
||||
@@ -2911,7 +2921,15 @@ var require_dist_node5 = __commonJS({
|
||||
throw error;
|
||||
else if (error.name === "AbortError")
|
||||
throw error;
|
||||
throw new import_request_error.RequestError(error.message, 500, {
|
||||
let message = error.message;
|
||||
if (error.name === "TypeError" && "cause" in error) {
|
||||
if (error.cause instanceof Error) {
|
||||
message = error.cause.message;
|
||||
} else if (typeof error.cause === "string") {
|
||||
message = error.cause;
|
||||
}
|
||||
}
|
||||
throw new import_request_error.RequestError(message, 500, {
|
||||
request: requestOptions
|
||||
});
|
||||
});
|
||||
@@ -2919,7 +2937,7 @@ var require_dist_node5 = __commonJS({
|
||||
async function getResponseData(response) {
|
||||
const contentType = response.headers.get("content-type");
|
||||
if (/application\/json/.test(contentType)) {
|
||||
return response.json();
|
||||
return response.json().catch(() => response.text()).catch(() => "");
|
||||
}
|
||||
if (!contentType || /^text\/|charset=utf-8$/.test(contentType)) {
|
||||
return response.text();
|
||||
|
||||
+62
-38
@@ -1,3 +1,4 @@
|
||||
import pRetry from "p-retry";
|
||||
// @ts-check
|
||||
|
||||
/**
|
||||
@@ -69,53 +70,28 @@ export async function main(
|
||||
request,
|
||||
});
|
||||
|
||||
const appAuthentication = await auth({
|
||||
type: "app",
|
||||
});
|
||||
|
||||
let authentication;
|
||||
// If at least one repository is set, get installation ID from that repository
|
||||
// https://docs.github.com/rest/apps/apps?apiVersion=2022-11-28#get-a-repository-installation-for-the-authenticated-app
|
||||
|
||||
if (parsedRepositoryNames) {
|
||||
const response = await request("GET /repos/{owner}/{repo}/installation", {
|
||||
owner: parsedOwner,
|
||||
repo: parsedRepositoryNames.split(",")[0],
|
||||
headers: {
|
||||
authorization: `bearer ${appAuthentication.token}`,
|
||||
authentication = await pRetry(() => getTokenFromRepository(request, auth, parsedOwner, parsedRepositoryNames), {
|
||||
onFailedAttempt: (error) => {
|
||||
core.info(
|
||||
`Failed to create token for "${parsedRepositoryNames}" (attempt ${error.attemptNumber}): ${error.message}`
|
||||
);
|
||||
},
|
||||
retries: 3,
|
||||
});
|
||||
|
||||
// Get token for given repositories
|
||||
authentication = await auth({
|
||||
type: "installation",
|
||||
installationId: response.data.id,
|
||||
repositoryNames: parsedRepositoryNames.split(","),
|
||||
});
|
||||
} else {
|
||||
// Otherwise get the installation for the owner, which can either be an organization or a user account
|
||||
// https://docs.github.com/rest/apps/apps?apiVersion=2022-11-28#get-a-repository-installation-for-the-authenticated-app
|
||||
const response = await request("GET /orgs/{org}/installation", {
|
||||
org: parsedOwner,
|
||||
headers: {
|
||||
authorization: `bearer ${appAuthentication.token}`,
|
||||
authentication = await pRetry(() => getTokenFromOwner(request, auth, parsedOwner), {
|
||||
onFailedAttempt: (error) => {
|
||||
core.info(
|
||||
`Failed to create token for "${parsedOwner}" (attempt ${error.attemptNumber}): ${error.message}`
|
||||
);
|
||||
},
|
||||
}).catch((error) => {
|
||||
/* c8 ignore next */
|
||||
if (error.status !== 404) throw error;
|
||||
|
||||
// https://docs.github.com/rest/apps/apps?apiVersion=2022-11-28#get-a-user-installation-for-the-authenticated-app
|
||||
return request("GET /users/{username}/installation", {
|
||||
username: parsedOwner,
|
||||
headers: {
|
||||
authorization: `bearer ${appAuthentication.token}`,
|
||||
},
|
||||
});
|
||||
});
|
||||
|
||||
// Get token for for all repositories of the given installation
|
||||
authentication = await auth({
|
||||
type: "installation",
|
||||
installationId: response.data.id,
|
||||
retries: 3,
|
||||
});
|
||||
}
|
||||
|
||||
@@ -129,3 +105,51 @@ export async function main(
|
||||
core.saveState("token", authentication.token);
|
||||
}
|
||||
}
|
||||
|
||||
async function getTokenFromOwner(request, auth, parsedOwner) {
|
||||
// https://docs.github.com/en/rest/apps/apps?apiVersion=2022-11-28#get-an-organization-installation-for-the-authenticated-app
|
||||
const response = await request("GET /orgs/{org}/installation", {
|
||||
org: parsedOwner,
|
||||
request: {
|
||||
hook: auth.hook,
|
||||
},
|
||||
}).catch((error) => {
|
||||
/* c8 ignore next */
|
||||
if (error.status !== 404) throw error;
|
||||
|
||||
// https://docs.github.com/rest/apps/apps?apiVersion=2022-11-28#get-a-user-installation-for-the-authenticated-app
|
||||
return request("GET /users/{username}/installation", {
|
||||
username: parsedOwner,
|
||||
request: {
|
||||
hook: auth.hook,
|
||||
},
|
||||
});
|
||||
});
|
||||
|
||||
// Get token for for all repositories of the given installation
|
||||
const authentication = await auth({
|
||||
type: "installation",
|
||||
installationId: response.data.id,
|
||||
});
|
||||
return authentication;
|
||||
}
|
||||
|
||||
async function getTokenFromRepository(request, auth, parsedOwner, parsedRepositoryNames) {
|
||||
// https://docs.github.com/rest/apps/apps?apiVersion=2022-11-28#get-a-repository-installation-for-the-authenticated-app
|
||||
const response = await request("GET /repos/{owner}/{repo}/installation", {
|
||||
owner: parsedOwner,
|
||||
repo: parsedRepositoryNames.split(",")[0],
|
||||
request: {
|
||||
hook: auth.hook,
|
||||
},
|
||||
});
|
||||
|
||||
// Get token for given repositories
|
||||
const authentication = await auth({
|
||||
type: "installation",
|
||||
installationId: response.data.id,
|
||||
repositoryNames: parsedRepositoryNames.split(","),
|
||||
});
|
||||
|
||||
return authentication;
|
||||
}
|
||||
Generated
+916
-1404
File diff suppressed because it is too large
Load Diff
+11
-9
@@ -2,10 +2,10 @@
|
||||
"name": "create-github-app-token",
|
||||
"private": true,
|
||||
"type": "module",
|
||||
"version": "1.5.0",
|
||||
"version": "1.6.3",
|
||||
"description": "GitHub Action for creating a GitHub App Installation Access Token",
|
||||
"scripts": {
|
||||
"build": "esbuild main.js post.js --bundle --outdir=dist --out-extension:.js=.cjs --platform=node --target=node16.16",
|
||||
"build": "esbuild main.js post.js --bundle --outdir=dist --out-extension:.js=.cjs --platform=node --target=node20.0.0",
|
||||
"test": "c8 --100 ava tests/index.js",
|
||||
"coverage": "c8 report --reporter html",
|
||||
"postcoverage": "open-cli coverage/index.html"
|
||||
@@ -13,18 +13,20 @@
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@actions/core": "^1.10.1",
|
||||
"@octokit/auth-app": "^6.0.1",
|
||||
"@octokit/request": "^8.1.2"
|
||||
"@octokit/auth-app": "^6.0.3",
|
||||
"@octokit/request": "^8.1.6",
|
||||
"p-retry": "^6.2.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"ava": "^5.3.1",
|
||||
"@sinonjs/fake-timers": "^11.2.2",
|
||||
"ava": "^6.0.1",
|
||||
"c8": "^8.0.1",
|
||||
"dotenv": "^16.3.1",
|
||||
"esbuild": "^0.19.4",
|
||||
"esbuild": "^0.19.11",
|
||||
"execa": "^8.0.1",
|
||||
"open-cli": "^7.2.0",
|
||||
"undici": "^5.25.2",
|
||||
"yaml": "^2.3.2"
|
||||
"open-cli": "^8.0.0",
|
||||
"undici": "^6.2.1",
|
||||
"yaml": "^2.3.4"
|
||||
},
|
||||
"release": {
|
||||
"branches": [
|
||||
|
||||
@@ -0,0 +1,56 @@
|
||||
import { test } from "./main.js";
|
||||
|
||||
import { install } from "@sinonjs/fake-timers";
|
||||
|
||||
// Verify `main` retry when the clock has drifted.
|
||||
await test((mockPool) => {
|
||||
process.env.INPUT_OWNER = 'actions'
|
||||
process.env.INPUT_REPOSITORIES = 'failed-repo';
|
||||
const owner = process.env.INPUT_OWNER
|
||||
const repo = process.env.INPUT_REPOSITORIES
|
||||
const mockInstallationId = "123456";
|
||||
|
||||
install({ now: 0, toFake: ["Date"] });
|
||||
|
||||
mockPool
|
||||
.intercept({
|
||||
path: `/repos/${owner}/${repo}/installation`,
|
||||
method: "GET",
|
||||
headers: {
|
||||
accept: "application/vnd.github.v3+json",
|
||||
"user-agent": "actions/create-github-app-token",
|
||||
// Intentionally omitting the `authorization` header, since JWT creation is not idempotent.
|
||||
},
|
||||
})
|
||||
.reply(({ headers }) => {
|
||||
const [_, jwt] = (headers.authorization || "").split(" ");
|
||||
const payload = JSON.parse(Buffer.from(jwt.split(".")[1], "base64").toString());
|
||||
|
||||
if (payload.iat < 0) {
|
||||
return {
|
||||
statusCode: 401,
|
||||
data: {
|
||||
message: "'Issued at' claim ('iat') must be an Integer representing the time that the assertion was issued."
|
||||
},
|
||||
responseOptions: {
|
||||
headers: {
|
||||
"content-type": "application/json",
|
||||
"date": new Date(Date.now() + 30000).toUTCString()
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
return {
|
||||
statusCode: 200,
|
||||
data: {
|
||||
id: mockInstallationId
|
||||
},
|
||||
responseOptions: {
|
||||
headers: {
|
||||
"content-type": "application/json"
|
||||
}
|
||||
}
|
||||
};
|
||||
}).times(2);
|
||||
});
|
||||
@@ -0,0 +1,39 @@
|
||||
import { test } from "./main.js";
|
||||
|
||||
// Verify `main` retry when the GitHub API returns a 500 error.
|
||||
await test((mockPool) => {
|
||||
process.env.INPUT_OWNER = 'actions'
|
||||
process.env.INPUT_REPOSITORIES = 'failed-repo';
|
||||
const owner = process.env.INPUT_OWNER
|
||||
const repo = process.env.INPUT_REPOSITORIES
|
||||
const mockInstallationId = "123456";
|
||||
|
||||
mockPool
|
||||
.intercept({
|
||||
path: `/repos/${owner}/${repo}/installation`,
|
||||
method: "GET",
|
||||
headers: {
|
||||
accept: "application/vnd.github.v3+json",
|
||||
"user-agent": "actions/create-github-app-token",
|
||||
// Intentionally omitting the `authorization` header, since JWT creation is not idempotent.
|
||||
},
|
||||
})
|
||||
.reply(500, 'GitHub API not available')
|
||||
|
||||
mockPool
|
||||
.intercept({
|
||||
path: `/repos/${owner}/${repo}/installation`,
|
||||
method: "GET",
|
||||
headers: {
|
||||
accept: "application/vnd.github.v3+json",
|
||||
"user-agent": "actions/create-github-app-token",
|
||||
// Intentionally omitting the `authorization` header, since JWT creation is not idempotent.
|
||||
},
|
||||
})
|
||||
.reply(
|
||||
200,
|
||||
{ id: mockInstallationId },
|
||||
{ headers: { "content-type": "application/json" } }
|
||||
);
|
||||
|
||||
});
|
||||
@@ -0,0 +1,36 @@
|
||||
import { test } from "./main.js";
|
||||
|
||||
// Verify `main` successfully obtains a token when the `owner` input is set (to a user), but the `repositories` input isn’t set.
|
||||
await test((mockPool) => {
|
||||
process.env.INPUT_OWNER = "smockle";
|
||||
delete process.env.INPUT_REPOSITORIES;
|
||||
|
||||
// Mock installation id request
|
||||
const mockInstallationId = "123456";
|
||||
mockPool
|
||||
.intercept({
|
||||
path: `/orgs/${process.env.INPUT_OWNER}/installation`,
|
||||
method: "GET",
|
||||
headers: {
|
||||
accept: "application/vnd.github.v3+json",
|
||||
"user-agent": "actions/create-github-app-token",
|
||||
// Intentionally omitting the `authorization` header, since JWT creation is not idempotent.
|
||||
},
|
||||
})
|
||||
.reply(500, 'GitHub API not available')
|
||||
mockPool
|
||||
.intercept({
|
||||
path: `/orgs/${process.env.INPUT_OWNER}/installation`,
|
||||
method: "GET",
|
||||
headers: {
|
||||
accept: "application/vnd.github.v3+json",
|
||||
"user-agent": "actions/create-github-app-token",
|
||||
// Intentionally omitting the `authorization` header, since JWT creation is not idempotent.
|
||||
},
|
||||
})
|
||||
.reply(
|
||||
200,
|
||||
{ id: mockInstallationId },
|
||||
{ headers: { "content-type": "application/json" } }
|
||||
);
|
||||
});
|
||||
@@ -56,6 +56,21 @@ Generated by [AVA](https://avajs.dev).
|
||||
|
||||
''
|
||||
|
||||
## main-token-get-owner-set-repo-fail-response.test.js
|
||||
|
||||
> stderr
|
||||
|
||||
''
|
||||
|
||||
> stdout
|
||||
|
||||
`owner and repositories set, creating token for repositories "failed-repo" owned by "actions"␊
|
||||
Failed to create token for "failed-repo" (attempt 1): GitHub API not available␊
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
|
||||
## main-token-get-owner-set-repo-set-to-many.test.js
|
||||
|
||||
> stderr
|
||||
@@ -98,6 +113,21 @@ Generated by [AVA](https://avajs.dev).
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
|
||||
## main-token-get-owner-set-to-user-fail-response.test.js
|
||||
|
||||
> stderr
|
||||
|
||||
''
|
||||
|
||||
> stdout
|
||||
|
||||
`repositories not set, creating token for all repositories for given owner "smockle"␊
|
||||
Failed to create token for "smockle" (attempt 1): GitHub API not available␊
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
|
||||
## main-token-get-owner-set-to-user-repo-unset.test.js
|
||||
|
||||
> stderr
|
||||
|
||||
Binary file not shown.
Reference in New Issue
Block a user