100 lines
4.7 KiB
JavaScript
100 lines
4.7 KiB
JavaScript
"use strict";
|
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
});
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
const util = require("util");
|
|
const fs = require("fs");
|
|
const httpClient = require("typed-rest-client/HttpClient");
|
|
const core = require("@actions/core");
|
|
var httpCallbackClient = new httpClient.HttpClient('GITHUB_RUNNER', null, {});
|
|
class WebRequest {
|
|
}
|
|
exports.WebRequest = WebRequest;
|
|
class WebResponse {
|
|
}
|
|
exports.WebResponse = WebResponse;
|
|
class WebRequestOptions {
|
|
}
|
|
exports.WebRequestOptions = WebRequestOptions;
|
|
function sendRequest(request, options) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
let i = 0;
|
|
let retryCount = options && options.retryCount ? options.retryCount : 5;
|
|
let retryIntervalInSeconds = options && options.retryIntervalInSeconds ? options.retryIntervalInSeconds : 2;
|
|
let retriableErrorCodes = options && options.retriableErrorCodes ? options.retriableErrorCodes : ["ETIMEDOUT", "ECONNRESET", "ENOTFOUND", "ESOCKETTIMEDOUT", "ECONNREFUSED", "EHOSTUNREACH", "EPIPE", "EA_AGAIN"];
|
|
let retriableStatusCodes = options && options.retriableStatusCodes ? options.retriableStatusCodes : [408, 409, 500, 502, 503, 504];
|
|
let timeToWait = retryIntervalInSeconds;
|
|
while (true) {
|
|
try {
|
|
if (request.body && typeof (request.body) !== 'string' && !request.body["readable"]) {
|
|
request.body = fs.createReadStream(request.body["path"]);
|
|
}
|
|
let response = yield sendRequestInternal(request);
|
|
if (retriableStatusCodes.indexOf(response.statusCode) != -1 && ++i < retryCount) {
|
|
core.debug(util.format("Encountered a retriable status code: %s. Message: '%s'.", response.statusCode, response.statusMessage));
|
|
yield sleepFor(timeToWait);
|
|
timeToWait = timeToWait * retryIntervalInSeconds + retryIntervalInSeconds;
|
|
continue;
|
|
}
|
|
return response;
|
|
}
|
|
catch (error) {
|
|
if (retriableErrorCodes.indexOf(error.code) != -1 && ++i < retryCount) {
|
|
core.debug(util.format("Encountered a retriable error:%s. Message: %s.", error.code, error.message));
|
|
yield sleepFor(timeToWait);
|
|
timeToWait = timeToWait * retryIntervalInSeconds + retryIntervalInSeconds;
|
|
}
|
|
else {
|
|
if (error.code) {
|
|
core.debug("error code =" + error.code);
|
|
}
|
|
throw error;
|
|
}
|
|
}
|
|
}
|
|
});
|
|
}
|
|
exports.sendRequest = sendRequest;
|
|
function sleepFor(sleepDurationInSeconds) {
|
|
return new Promise((resolve, reject) => {
|
|
setTimeout(resolve, sleepDurationInSeconds * 1000);
|
|
});
|
|
}
|
|
exports.sleepFor = sleepFor;
|
|
function sendRequestInternal(request) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
core.debug(util.format("[%s]%s", request.method, request.uri));
|
|
var response = yield httpCallbackClient.request(request.method, request.uri, request.body, request.headers);
|
|
return yield toWebResponse(response);
|
|
});
|
|
}
|
|
function toWebResponse(response) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
var res = new WebResponse();
|
|
if (response) {
|
|
res.statusCode = response.message.statusCode;
|
|
res.statusMessage = response.message.statusMessage;
|
|
res.headers = response.message.headers;
|
|
var body = yield response.readBody();
|
|
if (body) {
|
|
try {
|
|
res.body = JSON.parse(body);
|
|
}
|
|
catch (error) {
|
|
core.debug("Could not parse response: " + JSON.stringify(error));
|
|
core.debug("Response: " + JSON.stringify(res.body));
|
|
res.body = body;
|
|
}
|
|
}
|
|
}
|
|
return res;
|
|
});
|
|
}
|