mirror of
https://github.com/github/codeql-action.git
synced 2025-12-29 02:30:11 +08:00
149 lines
8.2 KiB
JavaScript
149 lines
8.2 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());
|
|
});
|
|
};
|
|
var __importStar = (this && this.__importStar) || function (mod) {
|
|
if (mod && mod.__esModule) return mod;
|
|
var result = {};
|
|
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
result["default"] = mod;
|
|
return result;
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
const core = __importStar(require("@actions/core"));
|
|
const upload_specification_1 = require("./upload-specification");
|
|
const upload_http_client_1 = require("./upload-http-client");
|
|
const utils_1 = require("./utils");
|
|
const download_http_client_1 = require("./download-http-client");
|
|
const download_specification_1 = require("./download-specification");
|
|
const config_variables_1 = require("./config-variables");
|
|
const path_1 = require("path");
|
|
class DefaultArtifactClient {
|
|
/**
|
|
* Constructs a DefaultArtifactClient
|
|
*/
|
|
static create() {
|
|
return new DefaultArtifactClient();
|
|
}
|
|
/**
|
|
* Uploads an artifact
|
|
*/
|
|
uploadArtifact(name, files, rootDirectory, options) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
utils_1.checkArtifactName(name);
|
|
// Get specification for the files being uploaded
|
|
const uploadSpecification = upload_specification_1.getUploadSpecification(name, rootDirectory, files);
|
|
const uploadResponse = {
|
|
artifactName: name,
|
|
artifactItems: [],
|
|
size: 0,
|
|
failedItems: []
|
|
};
|
|
const uploadHttpClient = new upload_http_client_1.UploadHttpClient();
|
|
if (uploadSpecification.length === 0) {
|
|
core.warning(`No files found that can be uploaded`);
|
|
}
|
|
else {
|
|
// Create an entry for the artifact in the file container
|
|
const response = yield uploadHttpClient.createArtifactInFileContainer(name, options);
|
|
if (!response.fileContainerResourceUrl) {
|
|
core.debug(response.toString());
|
|
throw new Error('No URL provided by the Artifact Service to upload an artifact to');
|
|
}
|
|
core.debug(`Upload Resource URL: ${response.fileContainerResourceUrl}`);
|
|
// Upload each of the files that were found concurrently
|
|
const uploadResult = yield uploadHttpClient.uploadArtifactToFileContainer(response.fileContainerResourceUrl, uploadSpecification, options);
|
|
// Update the size of the artifact to indicate we are done uploading
|
|
// The uncompressed size is used for display when downloading a zip of the artifact from the UI
|
|
yield uploadHttpClient.patchArtifactSize(uploadResult.totalSize, name);
|
|
core.info(`Finished uploading artifact ${name}. Reported size is ${uploadResult.uploadSize} bytes. There were ${uploadResult.failedItems.length} items that failed to upload`);
|
|
uploadResponse.artifactItems = uploadSpecification.map(item => item.absoluteFilePath);
|
|
uploadResponse.size = uploadResult.uploadSize;
|
|
uploadResponse.failedItems = uploadResult.failedItems;
|
|
}
|
|
return uploadResponse;
|
|
});
|
|
}
|
|
downloadArtifact(name, path, options) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const downloadHttpClient = new download_http_client_1.DownloadHttpClient();
|
|
const artifacts = yield downloadHttpClient.listArtifacts();
|
|
if (artifacts.count === 0) {
|
|
throw new Error(`Unable to find any artifacts for the associated workflow`);
|
|
}
|
|
const artifactToDownload = artifacts.value.find(artifact => {
|
|
return artifact.name === name;
|
|
});
|
|
if (!artifactToDownload) {
|
|
throw new Error(`Unable to find an artifact with the name: ${name}`);
|
|
}
|
|
const items = yield downloadHttpClient.getContainerItems(artifactToDownload.name, artifactToDownload.fileContainerResourceUrl);
|
|
if (!path) {
|
|
path = config_variables_1.getWorkSpaceDirectory();
|
|
}
|
|
path = path_1.normalize(path);
|
|
path = path_1.resolve(path);
|
|
// During upload, empty directories are rejected by the remote server so there should be no artifacts that consist of only empty directories
|
|
const downloadSpecification = download_specification_1.getDownloadSpecification(name, items.value, path, (options === null || options === void 0 ? void 0 : options.createArtifactFolder) || false);
|
|
if (downloadSpecification.filesToDownload.length === 0) {
|
|
core.info(`No downloadable files were found for the artifact: ${artifactToDownload.name}`);
|
|
}
|
|
else {
|
|
// Create all necessary directories recursively before starting any download
|
|
yield utils_1.createDirectoriesForArtifact(downloadSpecification.directoryStructure);
|
|
core.info('Directory structure has been setup for the artifact');
|
|
yield utils_1.createEmptyFilesForArtifact(downloadSpecification.emptyFilesToCreate);
|
|
yield downloadHttpClient.downloadSingleArtifact(downloadSpecification.filesToDownload);
|
|
}
|
|
return {
|
|
artifactName: name,
|
|
downloadPath: downloadSpecification.rootDownloadLocation
|
|
};
|
|
});
|
|
}
|
|
downloadAllArtifacts(path) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const downloadHttpClient = new download_http_client_1.DownloadHttpClient();
|
|
const response = [];
|
|
const artifacts = yield downloadHttpClient.listArtifacts();
|
|
if (artifacts.count === 0) {
|
|
core.info('Unable to find any artifacts for the associated workflow');
|
|
return response;
|
|
}
|
|
if (!path) {
|
|
path = config_variables_1.getWorkSpaceDirectory();
|
|
}
|
|
path = path_1.normalize(path);
|
|
path = path_1.resolve(path);
|
|
let downloadedArtifacts = 0;
|
|
while (downloadedArtifacts < artifacts.count) {
|
|
const currentArtifactToDownload = artifacts.value[downloadedArtifacts];
|
|
downloadedArtifacts += 1;
|
|
// Get container entries for the specific artifact
|
|
const items = yield downloadHttpClient.getContainerItems(currentArtifactToDownload.name, currentArtifactToDownload.fileContainerResourceUrl);
|
|
const downloadSpecification = download_specification_1.getDownloadSpecification(currentArtifactToDownload.name, items.value, path, true);
|
|
if (downloadSpecification.filesToDownload.length === 0) {
|
|
core.info(`No downloadable files were found for any artifact ${currentArtifactToDownload.name}`);
|
|
}
|
|
else {
|
|
yield utils_1.createDirectoriesForArtifact(downloadSpecification.directoryStructure);
|
|
yield utils_1.createEmptyFilesForArtifact(downloadSpecification.emptyFilesToCreate);
|
|
yield downloadHttpClient.downloadSingleArtifact(downloadSpecification.filesToDownload);
|
|
}
|
|
response.push({
|
|
artifactName: currentArtifactToDownload.name,
|
|
downloadPath: downloadSpecification.rootDownloadLocation
|
|
});
|
|
}
|
|
return response;
|
|
});
|
|
}
|
|
}
|
|
exports.DefaultArtifactClient = DefaultArtifactClient;
|
|
//# sourceMappingURL=artifact-client.js.map
|