| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  | import * as core from "@actions/core"; | 
					
						
							|  |  |  | 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-12-13 17:24:37 -05:00
										 |  |  | import { extractTar } from "./tar"; | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  | import * as utils from "./utils/actionUtils"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-13 06:48:02 +09: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()) { | 
					
						
							| 
									
										
										
										
											2019-11-21 14:37:54 -05:00
										 |  |  |             utils.logWarning( | 
					
						
							| 
									
										
										
										
											2019-11-13 10:54:39 -05: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 14:37:54 -05:00
										 |  |  |             return; | 
					
						
							| 
									
										
										
										
											2019-11-13 10:54:39 -05:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 14:33:41 -06: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 10:03:18 -06:00
										 |  |  |             const cacheEntry = await cacheHttpClient.getCacheEntry(keys); | 
					
						
							| 
									
										
										
										
											2020-01-06 13:05:50 -05:00
										 |  |  |             if (!cacheEntry?.archiveLocation) { | 
					
						
							| 
									
										
										
										
											2020-02-25 19:16:36 +00:00
										 |  |  |                 core.info(`Cache not found for input keys: ${keys.join(", ")}`); | 
					
						
							| 
									
										
										
										
											2019-11-04 10:03:18 -06: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
 | 
					
						
							| 
									
										
										
										
											2020-01-06 13:05:50 -05:00
										 |  |  |             await cacheHttpClient.downloadCache( | 
					
						
							|  |  |  |                 cacheEntry.archiveLocation, | 
					
						
							|  |  |  |                 archivePath | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-12-13 17:24:37 -05:00
										 |  |  |             await extractTar(archivePath, cachePath); | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             const isExactKeyMatch = utils.isExactKeyMatch( | 
					
						
							|  |  |  |                 primaryKey, | 
					
						
							|  |  |  |                 cacheEntry | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             utils.setCacheHitOutput(isExactKeyMatch); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             core.info( | 
					
						
							| 
									
										
										
										
											2019-11-04 10:03:18 -06:00
										 |  |  |                 `Cache restored from key: ${cacheEntry && cacheEntry.cacheKey}` | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  |             ); | 
					
						
							|  |  |  |         } catch (error) { | 
					
						
							| 
									
										
										
										
											2019-11-21 14:37:54 -05:00
										 |  |  |             utils.logWarning(error.message); | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  |             utils.setCacheHitOutput(false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } catch (error) { | 
					
						
							|  |  |  |         core.setFailed(error.message); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | run(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default run; |