Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| c4fa18d55c | |||
| 0c014070f9 | |||
| f04aa94d10 | |||
| 323044ff31 | |||
| 936979e9ad | |||
| 2986852ad8 | |||
| 495056a515 | |||
| 8746053070 |
@@ -157,8 +157,8 @@ jobs:
|
||||
- uses: actions/create-github-app-token@v1
|
||||
id: app-token
|
||||
with:
|
||||
app_id: ${{ vars.APP_ID }}
|
||||
private_key: ${{ secrets.PRIVATE_KEY }}
|
||||
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
|
||||
|
||||
Vendored
+263
-259
File diff suppressed because it is too large
Load Diff
Vendored
+149
-133
@@ -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;
|
||||
@@ -3003,12 +3003,28 @@ async function post(core2, request2) {
|
||||
core2.info("Token is not set");
|
||||
return;
|
||||
}
|
||||
await request2("DELETE /installation/token", {
|
||||
headers: {
|
||||
authorization: `token ${token}`
|
||||
}
|
||||
});
|
||||
core2.info("Token revoked");
|
||||
const expiresAt = core2.getState("expiresAt");
|
||||
if (expiresAt && tokenExpiresIn(expiresAt) < 0) {
|
||||
core2.info("Token expired, skipping token revocation");
|
||||
return;
|
||||
}
|
||||
try {
|
||||
await request2("DELETE /installation/token", {
|
||||
headers: {
|
||||
authorization: `token ${token}`
|
||||
}
|
||||
});
|
||||
core2.info("Token revoked");
|
||||
} catch (error) {
|
||||
core2.warning(
|
||||
`Token revocation failed: ${error.message}`
|
||||
);
|
||||
}
|
||||
}
|
||||
function tokenExpiresIn(expiresAt) {
|
||||
const now = /* @__PURE__ */ new Date();
|
||||
const expiresAtDate = new Date(expiresAt);
|
||||
return Math.round((expiresAtDate.getTime() - now.getTime()) / 1e3);
|
||||
}
|
||||
|
||||
// lib/request.js
|
||||
|
||||
+11
-14
@@ -70,15 +70,11 @@ 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
|
||||
|
||||
if (parsedRepositoryNames) {
|
||||
authentication = await pRetry(() => getTokenFromRepository(request, auth, parsedOwner,appAuthentication, parsedRepositoryNames), {
|
||||
authentication = await pRetry(() => getTokenFromRepository(request, auth, parsedOwner, parsedRepositoryNames), {
|
||||
onFailedAttempt: (error) => {
|
||||
core.info(
|
||||
`Failed to create token for "${parsedRepositoryNames}" (attempt ${error.attemptNumber}): ${error.message}`
|
||||
@@ -89,7 +85,7 @@ export async function main(
|
||||
|
||||
} else {
|
||||
// Otherwise get the installation for the owner, which can either be an organization or a user account
|
||||
authentication = await pRetry(() => getTokenFromOwner(request, auth, appAuthentication, parsedOwner), {
|
||||
authentication = await pRetry(() => getTokenFromOwner(request, auth, parsedOwner), {
|
||||
onFailedAttempt: (error) => {
|
||||
core.info(
|
||||
`Failed to create token for "${parsedOwner}" (attempt ${error.attemptNumber}): ${error.message}`
|
||||
@@ -107,15 +103,16 @@ export async function main(
|
||||
// Make token accessible to post function (so we can invalidate it)
|
||||
if (!skipTokenRevoke) {
|
||||
core.saveState("token", authentication.token);
|
||||
core.setOutput("expiresAt", authentication.expiresAt);
|
||||
}
|
||||
}
|
||||
|
||||
async function getTokenFromOwner(request, auth, appAuthentication, parsedOwner) {
|
||||
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,
|
||||
headers: {
|
||||
authorization: `bearer ${appAuthentication.token}`,
|
||||
request: {
|
||||
hook: auth.hook,
|
||||
},
|
||||
}).catch((error) => {
|
||||
/* c8 ignore next */
|
||||
@@ -124,8 +121,8 @@ async function getTokenFromOwner(request, auth, appAuthentication, parsedOwner)
|
||||
// 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}`,
|
||||
request: {
|
||||
hook: auth.hook,
|
||||
},
|
||||
});
|
||||
});
|
||||
@@ -138,13 +135,13 @@ async function getTokenFromOwner(request, auth, appAuthentication, parsedOwner)
|
||||
return authentication;
|
||||
}
|
||||
|
||||
async function getTokenFromRepository(request, auth, parsedOwner,appAuthentication, parsedRepositoryNames) {
|
||||
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],
|
||||
headers: {
|
||||
authorization: `bearer ${appAuthentication.token}`,
|
||||
request: {
|
||||
hook: auth.hook,
|
||||
},
|
||||
});
|
||||
|
||||
|
||||
+26
-6
@@ -21,11 +21,31 @@ export async function post(core, request) {
|
||||
return;
|
||||
}
|
||||
|
||||
await request("DELETE /installation/token", {
|
||||
headers: {
|
||||
authorization: `token ${token}`,
|
||||
},
|
||||
});
|
||||
const expiresAt = core.getState("expiresAt");
|
||||
if (expiresAt && tokenExpiresIn(expiresAt) < 0) {
|
||||
core.info("Token expired, skipping token revocation");
|
||||
return;
|
||||
}
|
||||
|
||||
core.info("Token revoked");
|
||||
try {
|
||||
await request("DELETE /installation/token", {
|
||||
headers: {
|
||||
authorization: `token ${token}`,
|
||||
},
|
||||
});
|
||||
core.info("Token revoked");
|
||||
} catch (error) {
|
||||
core.warning(
|
||||
`Token revocation failed: ${error.message}`)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} expiresAt
|
||||
*/
|
||||
function tokenExpiresIn(expiresAt) {
|
||||
const now = new Date();
|
||||
const expiresAtDate = new Date(expiresAt);
|
||||
|
||||
return Math.round((expiresAtDate.getTime() - now.getTime()) / 1000);
|
||||
}
|
||||
|
||||
Generated
+879
-1407
File diff suppressed because it is too large
Load Diff
+8
-7
@@ -2,7 +2,7 @@
|
||||
"name": "create-github-app-token",
|
||||
"private": true,
|
||||
"type": "module",
|
||||
"version": "1.6.1",
|
||||
"version": "1.6.4",
|
||||
"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=node20.0.0",
|
||||
@@ -13,18 +13,19 @@
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@actions/core": "^1.10.1",
|
||||
"@octokit/auth-app": "^6.0.1",
|
||||
"@octokit/auth-app": "^6.0.3",
|
||||
"@octokit/request": "^8.1.6",
|
||||
"p-retry": "^6.1.0"
|
||||
"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.8",
|
||||
"esbuild": "^0.19.11",
|
||||
"execa": "^8.0.1",
|
||||
"open-cli": "^7.2.0",
|
||||
"undici": "^5.28.2",
|
||||
"open-cli": "^8.0.0",
|
||||
"undici": "^6.2.1",
|
||||
"yaml": "^2.3.4"
|
||||
},
|
||||
"release": {
|
||||
|
||||
@@ -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);
|
||||
});
|
||||
+2
-1
@@ -72,6 +72,7 @@ x3WQZRiXlWejSMUAHuMwXrhGlltF3lw83+xAjnqsVp75kGS6OH61
|
||||
// Mock installation access token request
|
||||
const mockInstallationAccessToken =
|
||||
"ghs_16C7e42F292c6912E7710c838347Ae178B4a"; // This token is invalidated. It’s from https://docs.github.com/en/rest/apps/apps?apiVersion=2022-11-28#create-an-installation-access-token-for-an-app.
|
||||
const mockExpiresAt = "2016-07-11T22:14:10Z";
|
||||
mockPool
|
||||
.intercept({
|
||||
path: `/app/installations/${mockInstallationId}/access_tokens`,
|
||||
@@ -84,7 +85,7 @@ x3WQZRiXlWejSMUAHuMwXrhGlltF3lw83+xAjnqsVp75kGS6OH61
|
||||
})
|
||||
.reply(
|
||||
201,
|
||||
{ token: mockInstallationAccessToken },
|
||||
{ token: mockInstallationAccessToken, expires_at: mockExpiresAt },
|
||||
{ headers: { "content-type": "application/json" } }
|
||||
);
|
||||
|
||||
|
||||
@@ -0,0 +1,28 @@
|
||||
import { MockAgent, setGlobalDispatcher } from "undici";
|
||||
|
||||
// state variables are set as environment variables with the prefix STATE_
|
||||
// https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#sending-values-to-the-pre-and-post-actions
|
||||
process.env.STATE_token = "secret123";
|
||||
|
||||
// 1 hour in the future, not expired
|
||||
process.env.STATE_expiresAt = new Date(Date.now() + 1000 * 60 * 60).toISOString();
|
||||
|
||||
const mockAgent = new MockAgent();
|
||||
|
||||
setGlobalDispatcher(mockAgent);
|
||||
|
||||
// Provide the base url to the request
|
||||
const mockPool = mockAgent.get("https://api.github.com");
|
||||
|
||||
// intercept the request
|
||||
mockPool
|
||||
.intercept({
|
||||
path: "/installation/token",
|
||||
method: "DELETE",
|
||||
headers: {
|
||||
authorization: "token secret123",
|
||||
},
|
||||
})
|
||||
.reply(401);
|
||||
|
||||
await import("../post.js");
|
||||
@@ -0,0 +1,28 @@
|
||||
import { MockAgent, setGlobalDispatcher } from "undici";
|
||||
|
||||
// state variables are set as environment variables with the prefix STATE_
|
||||
// https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#sending-values-to-the-pre-and-post-actions
|
||||
process.env.STATE_token = "secret123";
|
||||
|
||||
// 1 hour in the past, expired
|
||||
process.env.STATE_expiresAt = new Date(Date.now() - 1000 * 60 * 60).toISOString();
|
||||
|
||||
const mockAgent = new MockAgent();
|
||||
|
||||
setGlobalDispatcher(mockAgent);
|
||||
|
||||
// Provide the base url to the request
|
||||
const mockPool = mockAgent.get("https://api.github.com");
|
||||
|
||||
// intercept the request
|
||||
mockPool
|
||||
.intercept({
|
||||
path: "/installation/token",
|
||||
method: "DELETE",
|
||||
headers: {
|
||||
authorization: "token secret123",
|
||||
},
|
||||
})
|
||||
.reply(204);
|
||||
|
||||
await import("../post.js");
|
||||
@@ -4,6 +4,9 @@ import { MockAgent, setGlobalDispatcher } from "undici";
|
||||
// https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#sending-values-to-the-pre-and-post-actions
|
||||
process.env.STATE_token = "secret123";
|
||||
|
||||
// 1 hour in the future, not expired
|
||||
process.env.STATE_expiresAt = new Date(Date.now() + 1000 * 60 * 60).toISOString();
|
||||
|
||||
const mockAgent = new MockAgent();
|
||||
|
||||
setGlobalDispatcher(mockAgent);
|
||||
|
||||
@@ -69,7 +69,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-set-repo-set-to-many.test.js
|
||||
|
||||
@@ -83,7 +85,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-set-repo-set-to-one.test.js
|
||||
|
||||
@@ -97,7 +101,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-set-to-org-repo-unset.test.js
|
||||
|
||||
@@ -111,7 +117,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-set-to-user-fail-response.test.js
|
||||
|
||||
@@ -126,7 +134,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-set-to-user-repo-unset.test.js
|
||||
|
||||
@@ -140,7 +150,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-unset-repo-set.test.js
|
||||
|
||||
@@ -154,7 +166,9 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## main-token-get-owner-unset-repo-unset.test.js
|
||||
|
||||
@@ -168,7 +182,29 @@ Generated by [AVA](https://avajs.dev).
|
||||
::add-mask::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a`
|
||||
::save-state name=token::ghs_16C7e42F292c6912E7710c838347Ae178B4a␊
|
||||
␊
|
||||
::set-output name=expiresAt::2016-07-11T22:14:10Z`
|
||||
|
||||
## post-revoke-token-fail-response.test.js
|
||||
|
||||
> stderr
|
||||
|
||||
''
|
||||
|
||||
> stdout
|
||||
|
||||
'::warning::Token revocation failed: '
|
||||
|
||||
## post-token-expired.test.js
|
||||
|
||||
> stderr
|
||||
|
||||
''
|
||||
|
||||
> stdout
|
||||
|
||||
'Token expired, skipping token revocation'
|
||||
|
||||
## post-token-set.test.js
|
||||
|
||||
|
||||
Binary file not shown.
Reference in New Issue
Block a user