mirror of
				https://github.com/actions/checkout.git
				synced 2025-10-30 23:10:31 +00:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | dcd71f6466 | ||
|   | add3486cc3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5126516654 | ||
|   | d50f8ea767 | ||
|   | 2d1c1198e7 | 
							
								
								
									
										2
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							| @@ -22,7 +22,7 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v2 |       - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       - name: Set Node.js 16.x |       - name: Set Node.js 16.x | ||||||
|         uses: actions/setup-node@v1 |         uses: actions/setup-node@v1 | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @@ -39,7 +39,7 @@ jobs: | |||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout repository |     - name: Checkout repository | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|     - name: Initialize CodeQL |     - name: Initialize CodeQL | ||||||
|       uses: github/codeql-action/init@v1 |       uses: github/codeql-action/init@v1 | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,6 +9,6 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     name: Check licenses |     name: Check licenses | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v2 |       - uses: actions/checkout@v3 | ||||||
|       - run: npm ci |       - run: npm ci | ||||||
|       - run: npm run licensed-check |       - run: npm run licensed-check | ||||||
							
								
								
									
										8
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,7 +14,7 @@ jobs: | |||||||
|       - uses: actions/setup-node@v1 |       - uses: actions/setup-node@v1 | ||||||
|         with: |         with: | ||||||
|           node-version: 16.x |           node-version: 16.x | ||||||
|       - uses: actions/checkout@v2 |       - uses: actions/checkout@v3 | ||||||
|       - run: npm ci |       - run: npm ci | ||||||
|       - run: npm run build |       - run: npm run build | ||||||
|       - run: npm run format-check |       - run: npm run format-check | ||||||
| @@ -32,7 +32,7 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       # Clone this repo |       # Clone this repo | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v2 |         uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       # Basic checkout |       # Basic checkout | ||||||
|       - name: Checkout basic |       - name: Checkout basic | ||||||
| @@ -150,7 +150,7 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       # Clone this repo |       # Clone this repo | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v2 |         uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       # Basic checkout using git |       # Basic checkout using git | ||||||
|       - name: Checkout basic |       - name: Checkout basic | ||||||
| @@ -182,7 +182,7 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       # Clone this repo |       # Clone this repo | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v2 |         uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       # Basic checkout using git |       # Basic checkout using git | ||||||
|       - name: Checkout basic |       - name: Checkout basic | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.licenses/npm/node-fetch.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/node-fetch.dep.yml
									
									
									
										generated
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: node-fetch | name: node-fetch | ||||||
| version: 2.6.5 | version: 2.6.7 | ||||||
| type: npm | type: npm | ||||||
| summary: A light-weight module that brings window.fetch to node.js | summary: A light-weight module that brings window.fetch to node.js | ||||||
| homepage: https://github.com/bitinn/node-fetch | homepage: https://github.com/bitinn/node-fetch | ||||||
|   | |||||||
| @@ -1,10 +1,17 @@ | |||||||
| # Changelog | # Changelog | ||||||
|  |  | ||||||
|  | ## v3.0.1 | ||||||
|  | - [Fixed an issue where checkout failed to run in container jobs due to the new git setting `safe.directory`](https://github.com/actions/checkout/pull/762) | ||||||
|  | - [Bumped various npm package versions](https://github.com/actions/checkout/pull/744) | ||||||
|  |  | ||||||
|  | ## v3.0.0 | ||||||
|  |  | ||||||
|  | - [Update to node 16](https://github.com/actions/checkout/pull/689) | ||||||
|  |  | ||||||
| ## v2.3.1 | ## v2.3.1 | ||||||
|  |  | ||||||
| - [Fix default branch resolution for .wiki and when using SSH](https://github.com/actions/checkout/pull/284) | - [Fix default branch resolution for .wiki and when using SSH](https://github.com/actions/checkout/pull/284) | ||||||
|  |  | ||||||
|  |  | ||||||
| ## v2.3.0 | ## v2.3.0 | ||||||
|  |  | ||||||
| - [Fallback to the default branch](https://github.com/actions/checkout/pull/278) | - [Fallback to the default branch](https://github.com/actions/checkout/pull/278) | ||||||
|   | |||||||
| @@ -643,10 +643,11 @@ describe('git-auth-helper tests', () => { | |||||||
|     expect(gitConfigContent.indexOf('http.')).toBeLessThan(0) |     expect(gitConfigContent.indexOf('http.')).toBeLessThan(0) | ||||||
|   }) |   }) | ||||||
|  |  | ||||||
|   const removeGlobalAuth_removesOverride = 'removeGlobalAuth removes override' |   const removeGlobalConfig_removesOverride = | ||||||
|   it(removeGlobalAuth_removesOverride, async () => { |     'removeGlobalConfig removes override' | ||||||
|  |   it(removeGlobalConfig_removesOverride, async () => { | ||||||
|     // Arrange |     // Arrange | ||||||
|     await setup(removeGlobalAuth_removesOverride) |     await setup(removeGlobalConfig_removesOverride) | ||||||
|     const authHelper = gitAuthHelper.createAuthHelper(git, settings) |     const authHelper = gitAuthHelper.createAuthHelper(git, settings) | ||||||
|     await authHelper.configureAuth() |     await authHelper.configureAuth() | ||||||
|     await authHelper.configureGlobalAuth() |     await authHelper.configureGlobalAuth() | ||||||
| @@ -655,7 +656,7 @@ describe('git-auth-helper tests', () => { | |||||||
|     await fs.promises.stat(path.join(git.env['HOME'], '.gitconfig')) |     await fs.promises.stat(path.join(git.env['HOME'], '.gitconfig')) | ||||||
|  |  | ||||||
|     // Act |     // Act | ||||||
|     await authHelper.removeGlobalAuth() |     await authHelper.removeGlobalConfig() | ||||||
|  |  | ||||||
|     // Assert |     // Assert | ||||||
|     expect(git.env['HOME']).toBeUndefined() |     expect(git.env['HOME']).toBeUndefined() | ||||||
|   | |||||||
							
								
								
									
										201
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										201
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							| @@ -6572,9 +6572,13 @@ class GitAuthHelper { | |||||||
|             yield this.configureToken(); |             yield this.configureToken(); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|     configureGlobalAuth() { |     configureTempGlobalConfig(repositoryPath) { | ||||||
|         var _a; |         var _a, _b; | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |             // Already setup global config
 | ||||||
|  |             if (((_a = this.temporaryHomePath) === null || _a === void 0 ? void 0 : _a.length) > 0) { | ||||||
|  |                 return path.join(this.temporaryHomePath, '.gitconfig'); | ||||||
|  |             } | ||||||
|             // Create a temp home directory
 |             // Create a temp home directory
 | ||||||
|             const runnerTemp = process.env['RUNNER_TEMP'] || ''; |             const runnerTemp = process.env['RUNNER_TEMP'] || ''; | ||||||
|             assert.ok(runnerTemp, 'RUNNER_TEMP is not defined'); |             assert.ok(runnerTemp, 'RUNNER_TEMP is not defined'); | ||||||
| @@ -6590,7 +6594,7 @@ class GitAuthHelper { | |||||||
|                 configExists = true; |                 configExists = true; | ||||||
|             } |             } | ||||||
|             catch (err) { |             catch (err) { | ||||||
|                 if (((_a = err) === null || _a === void 0 ? void 0 : _a.code) !== 'ENOENT') { |                 if (((_b = err) === null || _b === void 0 ? void 0 : _b.code) !== 'ENOENT') { | ||||||
|                     throw err; |                     throw err; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -6601,10 +6605,25 @@ class GitAuthHelper { | |||||||
|             else { |             else { | ||||||
|                 yield fs.promises.writeFile(newGitConfigPath, ''); |                 yield fs.promises.writeFile(newGitConfigPath, ''); | ||||||
|             } |             } | ||||||
|  |             // Override HOME
 | ||||||
|  |             core.info(`Temporarily overriding HOME='${this.temporaryHomePath}' before making global git config changes`); | ||||||
|  |             this.git.setEnvironmentVariable('HOME', this.temporaryHomePath); | ||||||
|  |             // Setup the workspace as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | ||||||
|  |             // Otherwise all git commands we run in a container fail
 | ||||||
|  |             core.info(`Adding working directory to the temporary git global config as a safe directory`); | ||||||
|  |             yield this.git | ||||||
|  |                 .config('safe.directory', repositoryPath !== null && repositoryPath !== void 0 ? repositoryPath : this.settings.repositoryPath, true, true) | ||||||
|  |                 .catch(error => { | ||||||
|  |                 core.info(`Failed to initialize safe directory with error: ${error}`); | ||||||
|  |             }); | ||||||
|  |             return newGitConfigPath; | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |     configureGlobalAuth() { | ||||||
|  |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |             // 'configureTempGlobalConfig' noops if already set, just returns the path
 | ||||||
|  |             const newGitConfigPath = yield this.configureTempGlobalConfig(); | ||||||
|             try { |             try { | ||||||
|                 // Override HOME
 |  | ||||||
|                 core.info(`Temporarily overriding HOME='${this.temporaryHomePath}' before making global git config changes`); |  | ||||||
|                 this.git.setEnvironmentVariable('HOME', this.temporaryHomePath); |  | ||||||
|                 // Configure the token
 |                 // Configure the token
 | ||||||
|                 yield this.configureToken(newGitConfigPath, true); |                 yield this.configureToken(newGitConfigPath, true); | ||||||
|                 // Configure HTTPS instead of SSH
 |                 // Configure HTTPS instead of SSH
 | ||||||
| @@ -6657,11 +6676,14 @@ class GitAuthHelper { | |||||||
|             yield this.removeToken(); |             yield this.removeToken(); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|     removeGlobalAuth() { |     removeGlobalConfig() { | ||||||
|  |         var _a; | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             core.debug(`Unsetting HOME override`); |             if (((_a = this.temporaryHomePath) === null || _a === void 0 ? void 0 : _a.length) > 0) { | ||||||
|             this.git.removeEnvironmentVariable('HOME'); |                 core.debug(`Unsetting HOME override`); | ||||||
|             yield io.rmRF(this.temporaryHomePath); |                 this.git.removeEnvironmentVariable('HOME'); | ||||||
|  |                 yield io.rmRF(this.temporaryHomePath); | ||||||
|  |             } | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|     configureSsh() { |     configureSsh() { | ||||||
| @@ -7326,40 +7348,48 @@ function getSource(settings) { | |||||||
|         core.startGroup('Getting Git version info'); |         core.startGroup('Getting Git version info'); | ||||||
|         const git = yield getGitCommandManager(settings); |         const git = yield getGitCommandManager(settings); | ||||||
|         core.endGroup(); |         core.endGroup(); | ||||||
|         // Prepare existing directory, otherwise recreate
 |         let authHelper = null; | ||||||
|         if (isExisting) { |  | ||||||
|             yield gitDirectoryHelper.prepareExistingDirectory(git, settings.repositoryPath, repositoryUrl, settings.clean, settings.ref); |  | ||||||
|         } |  | ||||||
|         if (!git) { |  | ||||||
|             // Downloading using REST API
 |  | ||||||
|             core.info(`The repository will be downloaded using the GitHub REST API`); |  | ||||||
|             core.info(`To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH`); |  | ||||||
|             if (settings.submodules) { |  | ||||||
|                 throw new Error(`Input 'submodules' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.`); |  | ||||||
|             } |  | ||||||
|             else if (settings.sshKey) { |  | ||||||
|                 throw new Error(`Input 'ssh-key' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.`); |  | ||||||
|             } |  | ||||||
|             yield githubApiHelper.downloadRepository(settings.authToken, settings.repositoryOwner, settings.repositoryName, settings.ref, settings.commit, settings.repositoryPath); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         // Save state for POST action
 |  | ||||||
|         stateHelper.setRepositoryPath(settings.repositoryPath); |  | ||||||
|         // Initialize the repository
 |  | ||||||
|         if (!fsHelper.directoryExistsSync(path.join(settings.repositoryPath, '.git'))) { |  | ||||||
|             core.startGroup('Initializing the repository'); |  | ||||||
|             yield git.init(); |  | ||||||
|             yield git.remoteAdd('origin', repositoryUrl); |  | ||||||
|             core.endGroup(); |  | ||||||
|         } |  | ||||||
|         // Disable automatic garbage collection
 |  | ||||||
|         core.startGroup('Disabling automatic garbage collection'); |  | ||||||
|         if (!(yield git.tryDisableAutomaticGarbageCollection())) { |  | ||||||
|             core.warning(`Unable to turn off git automatic garbage collection. The git fetch operation may trigger garbage collection and cause a delay.`); |  | ||||||
|         } |  | ||||||
|         core.endGroup(); |  | ||||||
|         const authHelper = gitAuthHelper.createAuthHelper(git, settings); |  | ||||||
|         try { |         try { | ||||||
|  |             if (git) { | ||||||
|  |                 authHelper = gitAuthHelper.createAuthHelper(git, settings); | ||||||
|  |                 yield authHelper.configureTempGlobalConfig(); | ||||||
|  |             } | ||||||
|  |             // Prepare existing directory, otherwise recreate
 | ||||||
|  |             if (isExisting) { | ||||||
|  |                 yield gitDirectoryHelper.prepareExistingDirectory(git, settings.repositoryPath, repositoryUrl, settings.clean, settings.ref); | ||||||
|  |             } | ||||||
|  |             if (!git) { | ||||||
|  |                 // Downloading using REST API
 | ||||||
|  |                 core.info(`The repository will be downloaded using the GitHub REST API`); | ||||||
|  |                 core.info(`To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH`); | ||||||
|  |                 if (settings.submodules) { | ||||||
|  |                     throw new Error(`Input 'submodules' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.`); | ||||||
|  |                 } | ||||||
|  |                 else if (settings.sshKey) { | ||||||
|  |                     throw new Error(`Input 'ssh-key' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.`); | ||||||
|  |                 } | ||||||
|  |                 yield githubApiHelper.downloadRepository(settings.authToken, settings.repositoryOwner, settings.repositoryName, settings.ref, settings.commit, settings.repositoryPath); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // Save state for POST action
 | ||||||
|  |             stateHelper.setRepositoryPath(settings.repositoryPath); | ||||||
|  |             // Initialize the repository
 | ||||||
|  |             if (!fsHelper.directoryExistsSync(path.join(settings.repositoryPath, '.git'))) { | ||||||
|  |                 core.startGroup('Initializing the repository'); | ||||||
|  |                 yield git.init(); | ||||||
|  |                 yield git.remoteAdd('origin', repositoryUrl); | ||||||
|  |                 core.endGroup(); | ||||||
|  |             } | ||||||
|  |             // Disable automatic garbage collection
 | ||||||
|  |             core.startGroup('Disabling automatic garbage collection'); | ||||||
|  |             if (!(yield git.tryDisableAutomaticGarbageCollection())) { | ||||||
|  |                 core.warning(`Unable to turn off git automatic garbage collection. The git fetch operation may trigger garbage collection and cause a delay.`); | ||||||
|  |             } | ||||||
|  |             core.endGroup(); | ||||||
|  |             // If we didn't initialize it above, do it now
 | ||||||
|  |             if (!authHelper) { | ||||||
|  |                 authHelper = gitAuthHelper.createAuthHelper(git, settings); | ||||||
|  |             } | ||||||
|             // Configure auth
 |             // Configure auth
 | ||||||
|             core.startGroup('Setting up auth'); |             core.startGroup('Setting up auth'); | ||||||
|             yield authHelper.configureAuth(); |             yield authHelper.configureAuth(); | ||||||
| @@ -7415,27 +7445,21 @@ function getSource(settings) { | |||||||
|             core.endGroup(); |             core.endGroup(); | ||||||
|             // Submodules
 |             // Submodules
 | ||||||
|             if (settings.submodules) { |             if (settings.submodules) { | ||||||
|                 try { |                 // Temporarily override global config
 | ||||||
|                     // Temporarily override global config
 |                 core.startGroup('Setting up auth for fetching submodules'); | ||||||
|                     core.startGroup('Setting up auth for fetching submodules'); |                 yield authHelper.configureGlobalAuth(); | ||||||
|                     yield authHelper.configureGlobalAuth(); |                 core.endGroup(); | ||||||
|  |                 // Checkout submodules
 | ||||||
|  |                 core.startGroup('Fetching submodules'); | ||||||
|  |                 yield git.submoduleSync(settings.nestedSubmodules); | ||||||
|  |                 yield git.submoduleUpdate(settings.fetchDepth, settings.nestedSubmodules); | ||||||
|  |                 yield git.submoduleForeach('git config --local gc.auto 0', settings.nestedSubmodules); | ||||||
|  |                 core.endGroup(); | ||||||
|  |                 // Persist credentials
 | ||||||
|  |                 if (settings.persistCredentials) { | ||||||
|  |                     core.startGroup('Persisting credentials for submodules'); | ||||||
|  |                     yield authHelper.configureSubmoduleAuth(); | ||||||
|                     core.endGroup(); |                     core.endGroup(); | ||||||
|                     // Checkout submodules
 |  | ||||||
|                     core.startGroup('Fetching submodules'); |  | ||||||
|                     yield git.submoduleSync(settings.nestedSubmodules); |  | ||||||
|                     yield git.submoduleUpdate(settings.fetchDepth, settings.nestedSubmodules); |  | ||||||
|                     yield git.submoduleForeach('git config --local gc.auto 0', settings.nestedSubmodules); |  | ||||||
|                     core.endGroup(); |  | ||||||
|                     // Persist credentials
 |  | ||||||
|                     if (settings.persistCredentials) { |  | ||||||
|                         core.startGroup('Persisting credentials for submodules'); |  | ||||||
|                         yield authHelper.configureSubmoduleAuth(); |  | ||||||
|                         core.endGroup(); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|                 finally { |  | ||||||
|                     // Remove temporary global config override
 |  | ||||||
|                     yield authHelper.removeGlobalAuth(); |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             // Get commit information
 |             // Get commit information
 | ||||||
| @@ -7447,10 +7471,13 @@ function getSource(settings) { | |||||||
|         } |         } | ||||||
|         finally { |         finally { | ||||||
|             // Remove auth
 |             // Remove auth
 | ||||||
|             if (!settings.persistCredentials) { |             if (authHelper) { | ||||||
|                 core.startGroup('Removing auth'); |                 if (!settings.persistCredentials) { | ||||||
|                 yield authHelper.removeAuth(); |                     core.startGroup('Removing auth'); | ||||||
|                 core.endGroup(); |                     yield authHelper.removeAuth(); | ||||||
|  |                     core.endGroup(); | ||||||
|  |                 } | ||||||
|  |                 authHelper.removeGlobalConfig(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
| @@ -7472,7 +7499,13 @@ function cleanup(repositoryPath) { | |||||||
|         } |         } | ||||||
|         // Remove auth
 |         // Remove auth
 | ||||||
|         const authHelper = gitAuthHelper.createAuthHelper(git); |         const authHelper = gitAuthHelper.createAuthHelper(git); | ||||||
|         yield authHelper.removeAuth(); |         try { | ||||||
|  |             yield authHelper.configureTempGlobalConfig(repositoryPath); | ||||||
|  |             yield authHelper.removeAuth(); | ||||||
|  |         } | ||||||
|  |         finally { | ||||||
|  |             yield authHelper.removeGlobalConfig(); | ||||||
|  |         } | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.cleanup = cleanup; | exports.cleanup = cleanup; | ||||||
| @@ -10195,7 +10228,7 @@ Object.defineProperty(Response.prototype, Symbol.toStringTag, { | |||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const INTERNALS$2 = Symbol('Request internals'); | const INTERNALS$2 = Symbol('Request internals'); | ||||||
| const URL = whatwgUrl.URL; | const URL = Url.URL || whatwgUrl.URL; | ||||||
| 
 | 
 | ||||||
| // fix an issue where "format", "parse" aren't a named export for node <10
 | // fix an issue where "format", "parse" aren't a named export for node <10
 | ||||||
| const parse_url = Url.parse; | const parse_url = Url.parse; | ||||||
| @@ -10458,9 +10491,17 @@ AbortError.prototype = Object.create(Error.prototype); | |||||||
| AbortError.prototype.constructor = AbortError; | AbortError.prototype.constructor = AbortError; | ||||||
| AbortError.prototype.name = 'AbortError'; | AbortError.prototype.name = 'AbortError'; | ||||||
| 
 | 
 | ||||||
|  | const URL$1 = Url.URL || whatwgUrl.URL; | ||||||
|  | 
 | ||||||
| // fix an issue where "PassThrough", "resolve" aren't a named export for node <10
 | // fix an issue where "PassThrough", "resolve" aren't a named export for node <10
 | ||||||
| const PassThrough$1 = Stream.PassThrough; | const PassThrough$1 = Stream.PassThrough; | ||||||
| const resolve_url = Url.resolve; | 
 | ||||||
|  | const isDomainOrSubdomain = function isDomainOrSubdomain(destination, original) { | ||||||
|  | 	const orig = new URL$1(original).hostname; | ||||||
|  | 	const dest = new URL$1(destination).hostname; | ||||||
|  | 
 | ||||||
|  | 	return orig === dest || orig[orig.length - dest.length - 1] === '.' && orig.endsWith(dest); | ||||||
|  | }; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Fetch function |  * Fetch function | ||||||
| @@ -10548,7 +10589,19 @@ function fetch(url, opts) { | |||||||
| 				const location = headers.get('Location'); | 				const location = headers.get('Location'); | ||||||
| 
 | 
 | ||||||
| 				// HTTP fetch step 5.3
 | 				// HTTP fetch step 5.3
 | ||||||
| 				const locationURL = location === null ? null : resolve_url(request.url, location); | 				let locationURL = null; | ||||||
|  | 				try { | ||||||
|  | 					locationURL = location === null ? null : new URL$1(location, request.url).toString(); | ||||||
|  | 				} catch (err) { | ||||||
|  | 					// error here can only be invalid URL in Location: header
 | ||||||
|  | 					// do not throw when options.redirect == manual
 | ||||||
|  | 					// let the user extract the errorneous redirect URL
 | ||||||
|  | 					if (request.redirect !== 'manual') { | ||||||
|  | 						reject(new FetchError(`uri requested responds with an invalid redirect URL: ${location}`, 'invalid-redirect')); | ||||||
|  | 						finalize(); | ||||||
|  | 						return; | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
| 
 | 
 | ||||||
| 				// HTTP fetch step 5.5
 | 				// HTTP fetch step 5.5
 | ||||||
| 				switch (request.redirect) { | 				switch (request.redirect) { | ||||||
| @@ -10596,6 +10649,12 @@ function fetch(url, opts) { | |||||||
| 							size: request.size | 							size: request.size | ||||||
| 						}; | 						}; | ||||||
| 
 | 
 | ||||||
|  | 						if (!isDomainOrSubdomain(request.url, locationURL)) { | ||||||
|  | 							for (const name of ['authorization', 'www-authenticate', 'cookie', 'cookie2']) { | ||||||
|  | 								requestOpts.headers.delete(name); | ||||||
|  | 							} | ||||||
|  | 						} | ||||||
|  | 
 | ||||||
| 						// HTTP-redirect fetch step 9
 | 						// HTTP-redirect fetch step 9
 | ||||||
| 						if (res.statusCode !== 303 && request.body && getTotalBytes(request) === null) { | 						if (res.statusCode !== 303 && request.body && getTotalBytes(request) === null) { | ||||||
| 							reject(new FetchError('Cannot follow redirect with body being a readable stream', 'unsupported-redirect')); | 							reject(new FetchError('Cannot follow redirect with body being a readable stream', 'unsupported-redirect')); | ||||||
|   | |||||||
							
								
								
									
										74
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										74
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -1929,12 +1929,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -3325,12 +3319,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -5389,12 +5377,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -7714,12 +7696,6 @@ | |||||||
|             "minimist": "^1.2.5" |             "minimist": "^1.2.5" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "semver": { |         "semver": { | ||||||
|           "version": "6.3.0", |           "version": "6.3.0", | ||||||
|           "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", |           "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", | ||||||
| @@ -9368,12 +9344,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -11389,12 +11359,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -12940,12 +12904,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -13700,12 +13658,6 @@ | |||||||
|             "picomatch": "^2.2.3" |             "picomatch": "^2.2.3" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -14633,12 +14585,6 @@ | |||||||
|           "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", |           "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", | ||||||
|           "dev": true |           "dev": true | ||||||
|         }, |         }, | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         }, |  | ||||||
|         "normalize-path": { |         "normalize-path": { | ||||||
|           "version": "3.0.0", |           "version": "3.0.0", | ||||||
|           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", |           "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", | ||||||
| @@ -15730,14 +15676,6 @@ | |||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "minimist": "^1.2.0" |         "minimist": "^1.2.0" | ||||||
|       }, |  | ||||||
|       "dependencies": { |  | ||||||
|         "minimist": { |  | ||||||
|           "version": "1.2.5", |  | ||||||
|           "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |  | ||||||
|           "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |  | ||||||
|           "dev": true |  | ||||||
|         } |  | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "kleur": { |     "kleur": { | ||||||
| @@ -15934,9 +15872,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "minimist": { |     "minimist": { | ||||||
|       "version": "1.2.5", |       "version": "1.2.6", | ||||||
|       "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", |       "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", | ||||||
|       "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", |       "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "ms": { |     "ms": { | ||||||
| @@ -15957,9 +15895,9 @@ | |||||||
|       "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" |       "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" | ||||||
|     }, |     }, | ||||||
|     "node-fetch": { |     "node-fetch": { | ||||||
|       "version": "2.6.5", |       "version": "2.6.7", | ||||||
|       "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.5.tgz", |       "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", | ||||||
|       "integrity": "sha512-mmlIVHJEu5rnIxgEgez6b9GgWXbkZj5YZ7fx+2r94a2E+Uirsp6HsPTPlomfdHtpt/B0cdKviwkoaM6pyvUOpQ==", |       "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "whatwg-url": "^5.0.0" |         "whatwg-url": "^5.0.0" | ||||||
|       }, |       }, | ||||||
|   | |||||||
| @@ -19,8 +19,9 @@ export interface IGitAuthHelper { | |||||||
|   configureAuth(): Promise<void> |   configureAuth(): Promise<void> | ||||||
|   configureGlobalAuth(): Promise<void> |   configureGlobalAuth(): Promise<void> | ||||||
|   configureSubmoduleAuth(): Promise<void> |   configureSubmoduleAuth(): Promise<void> | ||||||
|  |   configureTempGlobalConfig(repositoryPath?: string): Promise<string> | ||||||
|   removeAuth(): Promise<void> |   removeAuth(): Promise<void> | ||||||
|   removeGlobalAuth(): Promise<void> |   removeGlobalConfig(): Promise<void> | ||||||
| } | } | ||||||
|  |  | ||||||
| export function createAuthHelper( | export function createAuthHelper( | ||||||
| @@ -80,7 +81,11 @@ class GitAuthHelper { | |||||||
|     await this.configureToken() |     await this.configureToken() | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   async configureGlobalAuth(): Promise<void> { |   async configureTempGlobalConfig(repositoryPath?: string): Promise<string> { | ||||||
|  |     // Already setup global config | ||||||
|  |     if (this.temporaryHomePath?.length > 0) { | ||||||
|  |       return path.join(this.temporaryHomePath, '.gitconfig') | ||||||
|  |     } | ||||||
|     // Create a temp home directory |     // Create a temp home directory | ||||||
|     const runnerTemp = process.env['RUNNER_TEMP'] || '' |     const runnerTemp = process.env['RUNNER_TEMP'] || '' | ||||||
|     assert.ok(runnerTemp, 'RUNNER_TEMP is not defined') |     assert.ok(runnerTemp, 'RUNNER_TEMP is not defined') | ||||||
| @@ -110,13 +115,34 @@ class GitAuthHelper { | |||||||
|       await fs.promises.writeFile(newGitConfigPath, '') |       await fs.promises.writeFile(newGitConfigPath, '') | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     try { |     // Override HOME | ||||||
|       // Override HOME |     core.info( | ||||||
|       core.info( |       `Temporarily overriding HOME='${this.temporaryHomePath}' before making global git config changes` | ||||||
|         `Temporarily overriding HOME='${this.temporaryHomePath}' before making global git config changes` |     ) | ||||||
|       ) |     this.git.setEnvironmentVariable('HOME', this.temporaryHomePath) | ||||||
|       this.git.setEnvironmentVariable('HOME', this.temporaryHomePath) |  | ||||||
|  |  | ||||||
|  |     // Setup the workspace as a safe directory, so if we pass this into a container job with a different user it doesn't fail | ||||||
|  |     // Otherwise all git commands we run in a container fail | ||||||
|  |     core.info( | ||||||
|  |       `Adding working directory to the temporary git global config as a safe directory` | ||||||
|  |     ) | ||||||
|  |     await this.git | ||||||
|  |       .config( | ||||||
|  |         'safe.directory', | ||||||
|  |         repositoryPath ?? this.settings.repositoryPath, | ||||||
|  |         true, | ||||||
|  |         true | ||||||
|  |       ) | ||||||
|  |       .catch(error => { | ||||||
|  |         core.info(`Failed to initialize safe directory with error: ${error}`) | ||||||
|  |       }) | ||||||
|  |     return newGitConfigPath | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async configureGlobalAuth(): Promise<void> { | ||||||
|  |     // 'configureTempGlobalConfig' noops if already set, just returns the path | ||||||
|  |     const newGitConfigPath = await this.configureTempGlobalConfig() | ||||||
|  |     try { | ||||||
|       // Configure the token |       // Configure the token | ||||||
|       await this.configureToken(newGitConfigPath, true) |       await this.configureToken(newGitConfigPath, true) | ||||||
|  |  | ||||||
| @@ -181,10 +207,12 @@ class GitAuthHelper { | |||||||
|     await this.removeToken() |     await this.removeToken() | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   async removeGlobalAuth(): Promise<void> { |   async removeGlobalConfig(): Promise<void> { | ||||||
|     core.debug(`Unsetting HOME override`) |     if (this.temporaryHomePath?.length > 0) { | ||||||
|     this.git.removeEnvironmentVariable('HOME') |       core.debug(`Unsetting HOME override`) | ||||||
|     await io.rmRF(this.temporaryHomePath) |       this.git.removeEnvironmentVariable('HOME') | ||||||
|  |       await io.rmRF(this.temporaryHomePath) | ||||||
|  |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   private async configureSsh(): Promise<void> { |   private async configureSsh(): Promise<void> { | ||||||
|   | |||||||
| @@ -36,68 +36,77 @@ export async function getSource(settings: IGitSourceSettings): Promise<void> { | |||||||
|   const git = await getGitCommandManager(settings) |   const git = await getGitCommandManager(settings) | ||||||
|   core.endGroup() |   core.endGroup() | ||||||
|  |  | ||||||
|   // Prepare existing directory, otherwise recreate |   let authHelper: gitAuthHelper.IGitAuthHelper | null = null | ||||||
|   if (isExisting) { |   try { | ||||||
|     await gitDirectoryHelper.prepareExistingDirectory( |     if (git) { | ||||||
|       git, |       authHelper = gitAuthHelper.createAuthHelper(git, settings) | ||||||
|       settings.repositoryPath, |       await authHelper.configureTempGlobalConfig() | ||||||
|       repositoryUrl, |     } | ||||||
|       settings.clean, |  | ||||||
|       settings.ref |  | ||||||
|     ) |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if (!git) { |     // Prepare existing directory, otherwise recreate | ||||||
|     // Downloading using REST API |     if (isExisting) { | ||||||
|     core.info(`The repository will be downloaded using the GitHub REST API`) |       await gitDirectoryHelper.prepareExistingDirectory( | ||||||
|     core.info( |         git, | ||||||
|       `To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH` |         settings.repositoryPath, | ||||||
|     ) |         repositoryUrl, | ||||||
|     if (settings.submodules) { |         settings.clean, | ||||||
|       throw new Error( |         settings.ref | ||||||
|         `Input 'submodules' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.` |  | ||||||
|       ) |  | ||||||
|     } else if (settings.sshKey) { |  | ||||||
|       throw new Error( |  | ||||||
|         `Input 'ssh-key' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.` |  | ||||||
|       ) |       ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     await githubApiHelper.downloadRepository( |     if (!git) { | ||||||
|       settings.authToken, |       // Downloading using REST API | ||||||
|       settings.repositoryOwner, |       core.info(`The repository will be downloaded using the GitHub REST API`) | ||||||
|       settings.repositoryName, |       core.info( | ||||||
|       settings.ref, |         `To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH` | ||||||
|       settings.commit, |       ) | ||||||
|       settings.repositoryPath |       if (settings.submodules) { | ||||||
|     ) |         throw new Error( | ||||||
|     return |           `Input 'submodules' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.` | ||||||
|   } |         ) | ||||||
|  |       } else if (settings.sshKey) { | ||||||
|  |         throw new Error( | ||||||
|  |           `Input 'ssh-key' not supported when falling back to download using the GitHub REST API. To create a local Git repository instead, add Git ${gitCommandManager.MinimumGitVersion} or higher to the PATH.` | ||||||
|  |         ) | ||||||
|  |       } | ||||||
|  |  | ||||||
|   // Save state for POST action |       await githubApiHelper.downloadRepository( | ||||||
|   stateHelper.setRepositoryPath(settings.repositoryPath) |         settings.authToken, | ||||||
|  |         settings.repositoryOwner, | ||||||
|  |         settings.repositoryName, | ||||||
|  |         settings.ref, | ||||||
|  |         settings.commit, | ||||||
|  |         settings.repositoryPath | ||||||
|  |       ) | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  |  | ||||||
|   // Initialize the repository |     // Save state for POST action | ||||||
|   if ( |     stateHelper.setRepositoryPath(settings.repositoryPath) | ||||||
|     !fsHelper.directoryExistsSync(path.join(settings.repositoryPath, '.git')) |  | ||||||
|   ) { |     // Initialize the repository | ||||||
|     core.startGroup('Initializing the repository') |     if ( | ||||||
|     await git.init() |       !fsHelper.directoryExistsSync(path.join(settings.repositoryPath, '.git')) | ||||||
|     await git.remoteAdd('origin', repositoryUrl) |     ) { | ||||||
|  |       core.startGroup('Initializing the repository') | ||||||
|  |       await git.init() | ||||||
|  |       await git.remoteAdd('origin', repositoryUrl) | ||||||
|  |       core.endGroup() | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Disable automatic garbage collection | ||||||
|  |     core.startGroup('Disabling automatic garbage collection') | ||||||
|  |     if (!(await git.tryDisableAutomaticGarbageCollection())) { | ||||||
|  |       core.warning( | ||||||
|  |         `Unable to turn off git automatic garbage collection. The git fetch operation may trigger garbage collection and cause a delay.` | ||||||
|  |       ) | ||||||
|  |     } | ||||||
|     core.endGroup() |     core.endGroup() | ||||||
|   } |  | ||||||
|  |  | ||||||
|   // Disable automatic garbage collection |     // If we didn't initialize it above, do it now | ||||||
|   core.startGroup('Disabling automatic garbage collection') |     if (!authHelper) { | ||||||
|   if (!(await git.tryDisableAutomaticGarbageCollection())) { |       authHelper = gitAuthHelper.createAuthHelper(git, settings) | ||||||
|     core.warning( |     } | ||||||
|       `Unable to turn off git automatic garbage collection. The git fetch operation may trigger garbage collection and cause a delay.` |  | ||||||
|     ) |  | ||||||
|   } |  | ||||||
|   core.endGroup() |  | ||||||
|  |  | ||||||
|   const authHelper = gitAuthHelper.createAuthHelper(git, settings) |  | ||||||
|   try { |  | ||||||
|     // Configure auth |     // Configure auth | ||||||
|     core.startGroup('Setting up auth') |     core.startGroup('Setting up auth') | ||||||
|     await authHelper.configureAuth() |     await authHelper.configureAuth() | ||||||
| @@ -170,34 +179,26 @@ export async function getSource(settings: IGitSourceSettings): Promise<void> { | |||||||
|  |  | ||||||
|     // Submodules |     // Submodules | ||||||
|     if (settings.submodules) { |     if (settings.submodules) { | ||||||
|       try { |       // Temporarily override global config | ||||||
|         // Temporarily override global config |       core.startGroup('Setting up auth for fetching submodules') | ||||||
|         core.startGroup('Setting up auth for fetching submodules') |       await authHelper.configureGlobalAuth() | ||||||
|         await authHelper.configureGlobalAuth() |       core.endGroup() | ||||||
|         core.endGroup() |  | ||||||
|  |  | ||||||
|         // Checkout submodules |       // Checkout submodules | ||||||
|         core.startGroup('Fetching submodules') |       core.startGroup('Fetching submodules') | ||||||
|         await git.submoduleSync(settings.nestedSubmodules) |       await git.submoduleSync(settings.nestedSubmodules) | ||||||
|         await git.submoduleUpdate( |       await git.submoduleUpdate(settings.fetchDepth, settings.nestedSubmodules) | ||||||
|           settings.fetchDepth, |       await git.submoduleForeach( | ||||||
|           settings.nestedSubmodules |         'git config --local gc.auto 0', | ||||||
|         ) |         settings.nestedSubmodules | ||||||
|         await git.submoduleForeach( |       ) | ||||||
|           'git config --local gc.auto 0', |       core.endGroup() | ||||||
|           settings.nestedSubmodules |  | ||||||
|         ) |  | ||||||
|         core.endGroup() |  | ||||||
|  |  | ||||||
|         // Persist credentials |       // Persist credentials | ||||||
|         if (settings.persistCredentials) { |       if (settings.persistCredentials) { | ||||||
|           core.startGroup('Persisting credentials for submodules') |         core.startGroup('Persisting credentials for submodules') | ||||||
|           await authHelper.configureSubmoduleAuth() |         await authHelper.configureSubmoduleAuth() | ||||||
|           core.endGroup() |         core.endGroup() | ||||||
|         } |  | ||||||
|       } finally { |  | ||||||
|         // Remove temporary global config override |  | ||||||
|         await authHelper.removeGlobalAuth() |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -218,10 +219,13 @@ export async function getSource(settings: IGitSourceSettings): Promise<void> { | |||||||
|     ) |     ) | ||||||
|   } finally { |   } finally { | ||||||
|     // Remove auth |     // Remove auth | ||||||
|     if (!settings.persistCredentials) { |     if (authHelper) { | ||||||
|       core.startGroup('Removing auth') |       if (!settings.persistCredentials) { | ||||||
|       await authHelper.removeAuth() |         core.startGroup('Removing auth') | ||||||
|       core.endGroup() |         await authHelper.removeAuth() | ||||||
|  |         core.endGroup() | ||||||
|  |       } | ||||||
|  |       authHelper.removeGlobalConfig() | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -244,7 +248,12 @@ export async function cleanup(repositoryPath: string): Promise<void> { | |||||||
|  |  | ||||||
|   // Remove auth |   // Remove auth | ||||||
|   const authHelper = gitAuthHelper.createAuthHelper(git) |   const authHelper = gitAuthHelper.createAuthHelper(git) | ||||||
|   await authHelper.removeAuth() |   try { | ||||||
|  |     await authHelper.configureTempGlobalConfig(repositoryPath) | ||||||
|  |     await authHelper.removeAuth() | ||||||
|  |   } finally { | ||||||
|  |     await authHelper.removeGlobalConfig() | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| async function getGitCommandManager( | async function getGitCommandManager( | ||||||
|   | |||||||
| @@ -5,4 +5,4 @@ set -e | |||||||
| src/misc/licensed-download.sh | src/misc/licensed-download.sh | ||||||
|  |  | ||||||
| echo 'Running: licensed cached' | echo 'Running: licensed cached' | ||||||
| _temp/licensed-3.3.1/licensed status | _temp/licensed-3.6.0/licensed status | ||||||
| @@ -2,23 +2,23 @@ | |||||||
|  |  | ||||||
| set -e | set -e | ||||||
|  |  | ||||||
| if [ ! -f _temp/licensed-3.3.1.done ]; then | if [ ! -f _temp/licensed-3.6.0.done ]; then | ||||||
|   echo 'Clearing temp' |   echo 'Clearing temp' | ||||||
|   rm -rf _temp/licensed-3.3.1 || true |   rm -rf _temp/licensed-3.6.0 || true | ||||||
|  |  | ||||||
|   echo 'Downloading licensed' |   echo 'Downloading licensed' | ||||||
|   mkdir -p _temp/licensed-3.3.1 |   mkdir -p _temp/licensed-3.6.0 | ||||||
|   pushd _temp/licensed-3.3.1 |   pushd _temp/licensed-3.6.0 | ||||||
|   if [[ "$OSTYPE" == "darwin"* ]]; then |   if [[ "$OSTYPE" == "darwin"* ]]; then | ||||||
|     curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.3.1/licensed-3.3.1-darwin-x64.tar.gz |     curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.6.0/licensed-3.6.0-darwin-x64.tar.gz | ||||||
|   else |   else | ||||||
|     curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.3.1/licensed-3.3.1-linux-x64.tar.gz |     curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.6.0/licensed-3.6.0-linux-x64.tar.gz | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   echo 'Extracting licenesed' |   echo 'Extracting licenesed' | ||||||
|   tar -xzf licensed.tar.gz |   tar -xzf licensed.tar.gz | ||||||
|   popd |   popd | ||||||
|   touch _temp/licensed-3.3.1.done |   touch _temp/licensed-3.6.0.done | ||||||
| else | else | ||||||
|   echo 'Licensed already downloaded' |   echo 'Licensed already downloaded' | ||||||
| fi | fi | ||||||
|   | |||||||
| @@ -5,4 +5,4 @@ set -e | |||||||
| src/misc/licensed-download.sh | src/misc/licensed-download.sh | ||||||
|  |  | ||||||
| echo 'Running: licensed cached' | echo 'Running: licensed cached' | ||||||
| _temp/licensed-3.3.1/licensed cache | _temp/licensed-3.6.0/licensed cache | ||||||
		Reference in New Issue
	
	Block a user