2022-12-21 22:08:44 +08:00
|
|
|
import * as cache from "@actions/cache";
|
|
|
|
import * as core from "@actions/core";
|
|
|
|
|
|
|
|
import { Events, Inputs, Outputs, State } from "./constants";
|
|
|
|
import { IStateProvider } from "./stateProvider";
|
|
|
|
import * as utils from "./utils/actionUtils";
|
|
|
|
|
|
|
|
async function restoreImpl(
|
|
|
|
stateProvider: IStateProvider
|
|
|
|
): Promise<string | undefined> {
|
|
|
|
try {
|
|
|
|
if (!utils.isCacheFeatureAvailable()) {
|
|
|
|
core.setOutput(Outputs.CacheHit, "false");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate inputs, this can cause task failure
|
|
|
|
if (!utils.isValidEvent()) {
|
|
|
|
utils.logWarning(
|
|
|
|
`Event Validation Error: The event type ${
|
|
|
|
process.env[Events.Key]
|
|
|
|
} is not supported because it's not tied to a branch or tag ref.`
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const primaryKey = core.getInput(Inputs.Key, { required: true });
|
|
|
|
stateProvider.setState(State.CachePrimaryKey, primaryKey);
|
|
|
|
|
|
|
|
const restoreKeys = utils.getInputAsArray(Inputs.RestoreKeys);
|
|
|
|
const cachePaths = utils.getInputAsArray(Inputs.Path, {
|
|
|
|
required: true
|
|
|
|
});
|
2023-01-05 19:19:13 +08:00
|
|
|
const enableCrossOsArchive = utils.getInputAsBool(
|
|
|
|
Inputs.EnableCrossOsArchive
|
|
|
|
);
|
2023-01-30 19:10:58 +08:00
|
|
|
const failOnCacheMiss = utils.getInputAsBool(Inputs.FailOnCacheMiss);
|
2023-03-09 20:30:28 +08:00
|
|
|
const lookupOnly = utils.getInputAsBool(Inputs.LookupOnly);
|
2022-12-21 22:08:44 +08:00
|
|
|
|
|
|
|
const cacheKey = await cache.restoreCache(
|
|
|
|
cachePaths,
|
|
|
|
primaryKey,
|
2023-01-05 19:19:13 +08:00
|
|
|
restoreKeys,
|
2023-03-09 20:30:28 +08:00
|
|
|
{ lookupOnly: lookupOnly },
|
2023-01-05 19:19:13 +08:00
|
|
|
enableCrossOsArchive
|
2022-12-21 22:08:44 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
if (!cacheKey) {
|
2023-01-30 19:10:58 +08:00
|
|
|
if (failOnCacheMiss) {
|
|
|
|
throw new Error(
|
|
|
|
`Failed to restore cache entry. Exiting as fail-on-cache-miss is set. Input key: ${primaryKey}`
|
|
|
|
);
|
|
|
|
}
|
2022-12-21 22:08:44 +08:00
|
|
|
core.info(
|
|
|
|
`Cache not found for input keys: ${[
|
|
|
|
primaryKey,
|
|
|
|
...restoreKeys
|
|
|
|
].join(", ")}`
|
|
|
|
);
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Store the matched cache key in states
|
|
|
|
stateProvider.setState(State.CacheMatchedKey, cacheKey);
|
|
|
|
|
|
|
|
const isExactKeyMatch = utils.isExactKeyMatch(
|
|
|
|
core.getInput(Inputs.Key, { required: true }),
|
|
|
|
cacheKey
|
|
|
|
);
|
|
|
|
|
|
|
|
core.setOutput(Outputs.CacheHit, isExactKeyMatch.toString());
|
2023-03-09 20:30:28 +08:00
|
|
|
if (lookupOnly) {
|
|
|
|
core.info(`Cache found and can be restored from key: ${cacheKey}`);
|
|
|
|
} else {
|
|
|
|
core.info(`Cache restored from key: ${cacheKey}`);
|
|
|
|
}
|
2022-12-21 22:08:44 +08:00
|
|
|
|
|
|
|
return cacheKey;
|
|
|
|
} catch (error: unknown) {
|
|
|
|
core.setFailed((error as Error).message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default restoreImpl;
|