2019-10-30 14:48:49 -04:00
|
|
|
import * as core from "@actions/core";
|
|
|
|
import { exec } from "@actions/exec";
|
|
|
|
import * as io from "@actions/io";
|
|
|
|
import * as path from "path";
|
|
|
|
import * as cacheHttpClient from "./cacheHttpClient";
|
2019-11-13 10:54:39 -05:00
|
|
|
import { Events, Inputs, State } from "./constants";
|
2019-10-30 14:48:49 -04:00
|
|
|
import * as utils from "./utils/actionUtils";
|
|
|
|
|
2019-11-12 16:48:02 -05:00
|
|
|
async function run(): Promise<void> {
|
2019-10-30 14:48:49 -04:00
|
|
|
try {
|
|
|
|
// Validate inputs, this can cause task failure
|
2019-11-13 10:54:39 -05:00
|
|
|
if (!utils.isValidEvent()) {
|
|
|
|
core.setFailed(
|
|
|
|
`Event Validation Error: The event type ${
|
|
|
|
process.env[Events.Key]
|
|
|
|
} is not supported. Only ${utils
|
|
|
|
.getSupportedEvents()
|
|
|
|
.join(", ")} events are supported at this time.`
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-11-14 17:14:16 -05:00
|
|
|
const cachePath = utils.resolvePath(
|
2019-10-30 14:48:49 -04:00
|
|
|
core.getInput(Inputs.Path, { required: true })
|
|
|
|
);
|
|
|
|
core.debug(`Cache Path: ${cachePath}`);
|
|
|
|
|
|
|
|
const primaryKey = core.getInput(Inputs.Key, { required: true });
|
|
|
|
core.saveState(State.CacheKey, primaryKey);
|
|
|
|
|
2019-11-05 15:33:41 -05:00
|
|
|
const restoreKeys = core
|
|
|
|
.getInput(Inputs.RestoreKeys)
|
|
|
|
.split("\n")
|
|
|
|
.filter(x => x !== "");
|
2019-10-30 14:48:49 -04:00
|
|
|
const keys = [primaryKey, ...restoreKeys];
|
|
|
|
|
|
|
|
core.debug("Resolved Keys:");
|
|
|
|
core.debug(JSON.stringify(keys));
|
|
|
|
|
|
|
|
if (keys.length > 10) {
|
|
|
|
core.setFailed(
|
|
|
|
`Key Validation Error: Keys are limited to a maximum of 10.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
for (const key of keys) {
|
|
|
|
if (key.length > 512) {
|
|
|
|
core.setFailed(
|
|
|
|
`Key Validation Error: ${key} cannot be larger than 512 characters.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const regex = /^[^,]*$/;
|
|
|
|
if (!regex.test(key)) {
|
|
|
|
core.setFailed(
|
|
|
|
`Key Validation Error: ${key} cannot contain commas.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2019-11-04 11:03:18 -05:00
|
|
|
const cacheEntry = await cacheHttpClient.getCacheEntry(keys);
|
|
|
|
if (!cacheEntry) {
|
|
|
|
core.info(
|
2019-11-05 15:33:41 -05:00
|
|
|
`Cache not found for input keys: ${keys.join(", ")}.`
|
2019-11-04 11:03:18 -05:00
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-11-14 17:14:16 -05:00
|
|
|
const archivePath = path.join(
|
2019-10-30 14:48:49 -04:00
|
|
|
await utils.createTempDirectory(),
|
|
|
|
"cache.tgz"
|
|
|
|
);
|
|
|
|
core.debug(`Archive Path: ${archivePath}`);
|
|
|
|
|
|
|
|
// Store the cache result
|
|
|
|
utils.setCacheState(cacheEntry);
|
|
|
|
|
|
|
|
// Download the cache from the cache entry
|
|
|
|
await cacheHttpClient.downloadCache(cacheEntry, archivePath);
|
|
|
|
|
2019-11-06 13:41:45 -05:00
|
|
|
const archiveFileSize = utils.getArchiveFileSize(archivePath);
|
2019-11-13 11:00:46 -05:00
|
|
|
core.info(
|
|
|
|
`Cache Size: ~${Math.round(
|
|
|
|
archiveFileSize / (1024 * 1024)
|
|
|
|
)} MB (${archiveFileSize} B)`
|
|
|
|
);
|
2019-11-06 13:41:45 -05:00
|
|
|
|
2019-11-15 10:25:57 -05:00
|
|
|
// Create directory to extract tar into
|
|
|
|
await io.mkdirP(cachePath);
|
2019-10-30 14:48:49 -04:00
|
|
|
|
|
|
|
// http://man7.org/linux/man-pages/man1/tar.1.html
|
|
|
|
// tar [-options] <name of the tar archive> [files or directories which to add into archive]
|
|
|
|
const IS_WINDOWS = process.platform === "win32";
|
2019-11-14 17:14:16 -05:00
|
|
|
const args = IS_WINDOWS
|
|
|
|
? [
|
|
|
|
"-xz",
|
|
|
|
"--force-local",
|
|
|
|
"-f",
|
|
|
|
archivePath.replace(/\\/g, "/"),
|
|
|
|
"-C",
|
|
|
|
cachePath.replace(/\\/g, "/")
|
|
|
|
]
|
|
|
|
: ["-xz", "-f", archivePath, "-C", cachePath];
|
2019-10-30 14:48:49 -04:00
|
|
|
|
|
|
|
const tarPath = await io.which("tar", true);
|
|
|
|
core.debug(`Tar Path: ${tarPath}`);
|
|
|
|
|
|
|
|
await exec(`"${tarPath}"`, args);
|
|
|
|
|
|
|
|
const isExactKeyMatch = utils.isExactKeyMatch(
|
|
|
|
primaryKey,
|
|
|
|
cacheEntry
|
|
|
|
);
|
|
|
|
utils.setCacheHitOutput(isExactKeyMatch);
|
|
|
|
|
|
|
|
core.info(
|
2019-11-04 11:03:18 -05:00
|
|
|
`Cache restored from key: ${cacheEntry && cacheEntry.cacheKey}`
|
2019-10-30 14:48:49 -04:00
|
|
|
);
|
|
|
|
} catch (error) {
|
|
|
|
core.warning(error.message);
|
|
|
|
utils.setCacheHitOutput(false);
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
core.setFailed(error.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
run();
|
|
|
|
|
|
|
|
export default run;
|