2019-10-30 19:48:49 +01:00
|
|
|
import * as core from "@actions/core";
|
|
|
|
import * as path from "path";
|
|
|
|
import * as cacheHttpClient from "./cacheHttpClient";
|
2019-11-13 16:54:39 +01:00
|
|
|
import { Events, Inputs, State } from "./constants";
|
2019-12-13 23:24:37 +01:00
|
|
|
import { extractTar } from "./tar";
|
2019-10-30 19:48:49 +01:00
|
|
|
import * as utils from "./utils/actionUtils";
|
|
|
|
|
2019-11-12 22:48:02 +01:00
|
|
|
async function run(): Promise<void> {
|
2019-10-30 19:48:49 +01:00
|
|
|
try {
|
|
|
|
// Validate inputs, this can cause task failure
|
2019-11-13 16:54:39 +01:00
|
|
|
if (!utils.isValidEvent()) {
|
2019-11-21 20:37:54 +01:00
|
|
|
utils.logWarning(
|
2019-11-13 16:54:39 +01:00
|
|
|
`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-21 20:37:54 +01:00
|
|
|
return;
|
2019-11-13 16:54:39 +01:00
|
|
|
}
|
|
|
|
|
2019-11-14 23:14:16 +01:00
|
|
|
const cachePath = utils.resolvePath(
|
2019-10-30 19:48:49 +01: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 21:33:41 +01:00
|
|
|
const restoreKeys = core
|
|
|
|
.getInput(Inputs.RestoreKeys)
|
|
|
|
.split("\n")
|
|
|
|
.filter(x => x !== "");
|
2019-10-30 19:48:49 +01: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 17:03:18 +01:00
|
|
|
const cacheEntry = await cacheHttpClient.getCacheEntry(keys);
|
2020-01-06 19:05:50 +01:00
|
|
|
if (!cacheEntry?.archiveLocation) {
|
2020-02-25 20:16:36 +01:00
|
|
|
core.info(`Cache not found for input keys: ${keys.join(", ")}`);
|
2019-11-04 17:03:18 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-11-14 23:14:16 +01:00
|
|
|
const archivePath = path.join(
|
2019-10-30 19:48:49 +01: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
|
2020-01-06 19:05:50 +01:00
|
|
|
await cacheHttpClient.downloadCache(
|
|
|
|
cacheEntry.archiveLocation,
|
|
|
|
archivePath
|
|
|
|
);
|
2019-10-30 19:48:49 +01:00
|
|
|
|
2019-11-06 19:41:45 +01:00
|
|
|
const archiveFileSize = utils.getArchiveFileSize(archivePath);
|
2019-11-13 17:00:46 +01:00
|
|
|
core.info(
|
|
|
|
`Cache Size: ~${Math.round(
|
|
|
|
archiveFileSize / (1024 * 1024)
|
|
|
|
)} MB (${archiveFileSize} B)`
|
|
|
|
);
|
2019-11-06 19:41:45 +01:00
|
|
|
|
2019-12-13 23:24:37 +01:00
|
|
|
await extractTar(archivePath, cachePath);
|
2019-10-30 19:48:49 +01:00
|
|
|
|
|
|
|
const isExactKeyMatch = utils.isExactKeyMatch(
|
|
|
|
primaryKey,
|
|
|
|
cacheEntry
|
|
|
|
);
|
|
|
|
utils.setCacheHitOutput(isExactKeyMatch);
|
|
|
|
|
|
|
|
core.info(
|
2019-11-04 17:03:18 +01:00
|
|
|
`Cache restored from key: ${cacheEntry && cacheEntry.cacheKey}`
|
2019-10-30 19:48:49 +01:00
|
|
|
);
|
|
|
|
} catch (error) {
|
2019-11-21 20:37:54 +01:00
|
|
|
utils.logWarning(error.message);
|
2019-10-30 19:48:49 +01:00
|
|
|
utils.setCacheHitOutput(false);
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
core.setFailed(error.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
run();
|
|
|
|
|
|
|
|
export default run;
|