| 
									
										
										
										
											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-21 14:37:54 -05:00
										 |  |  | import { Events, Inputs, State } from "./constants"; | 
					
						
							| 
									
										
										
										
											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 { | 
					
						
							| 
									
										
										
										
											2019-11-21 14:37:54 -05:00
										 |  |  |         if (!utils.isValidEvent()) { | 
					
						
							|  |  |  |             utils.logWarning( | 
					
						
							|  |  |  |                 `Event Validation Error: The event type ${ | 
					
						
							|  |  |  |                     process.env[Events.Key] | 
					
						
							|  |  |  |                 } is not supported. Only ${utils | 
					
						
							|  |  |  |                     .getSupportedEvents() | 
					
						
							|  |  |  |                     .join(", ")} events are supported at this time.`
 | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  |         const state = utils.getCacheState(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Inputs are re-evaluted before the post action, so we want the original key used for restore
 | 
					
						
							|  |  |  |         const primaryKey = core.getState(State.CacheKey); | 
					
						
							|  |  |  |         if (!primaryKey) { | 
					
						
							| 
									
										
										
										
											2019-11-21 14:37:54 -05:00
										 |  |  |             utils.logWarning(`Error retrieving key from state.`); | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (utils.isExactKeyMatch(primaryKey, state)) { | 
					
						
							|  |  |  |             core.info( | 
					
						
							|  |  |  |                 `Cache hit occurred on the primary key ${primaryKey}, not saving cache.` | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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}`); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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}`); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // 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 | 
					
						
							|  |  |  |             ? [ | 
					
						
							|  |  |  |                   "-cz", | 
					
						
							|  |  |  |                   "--force-local", | 
					
						
							|  |  |  |                   "-f", | 
					
						
							|  |  |  |                   archivePath.replace(/\\/g, "/"), | 
					
						
							|  |  |  |                   "-C", | 
					
						
							|  |  |  |                   cachePath.replace(/\\/g, "/"), | 
					
						
							|  |  |  |                   "." | 
					
						
							|  |  |  |               ] | 
					
						
							|  |  |  |             : ["-cz", "-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); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 15:24:22 -05:00
										 |  |  |         const fileSizeLimit = 400 * 1024 * 1024; // 400MB
 | 
					
						
							| 
									
										
										
										
											2019-11-14 17:14:16 -05:00
										 |  |  |         const archiveFileSize = utils.getArchiveFileSize(archivePath); | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  |         core.debug(`File Size: ${archiveFileSize}`); | 
					
						
							|  |  |  |         if (archiveFileSize > fileSizeLimit) { | 
					
						
							| 
									
										
										
										
											2019-11-21 14:37:54 -05:00
										 |  |  |             utils.logWarning( | 
					
						
							| 
									
										
										
										
											2019-11-13 11:00:46 -05:00
										 |  |  |                 `Cache size of ~${Math.round( | 
					
						
							|  |  |  |                     archiveFileSize / (1024 * 1024) | 
					
						
							|  |  |  |                 )} MB (${archiveFileSize} B) is over the 400MB limit, not saving cache.`
 | 
					
						
							| 
									
										
										
										
											2019-10-30 14:48:49 -04:00
										 |  |  |             ); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-14 17:14:16 -05:00
										 |  |  |         await cacheHttpClient.saveCache(primaryKey, archivePath); | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | run(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default run; |