mirror of
				https://gitea.com/actions/checkout.git
				synced 2025-10-25 07:16:32 +00:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			2bcd7c6585
			...
			3292e202f3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 3292e202f3 | ||
|   | e4894fca20 | 
| @@ -872,8 +872,53 @@ async function setup(testName: string): Promise<void> { | |||||||
|         return true |         return true | ||||||
|       } |       } | ||||||
|     ), |     ), | ||||||
|  |     tryConfigUnsetValue: jest.fn( | ||||||
|  |       async (key: string, value: string, globalConfig?: boolean): Promise<boolean> => { | ||||||
|  |         const configPath = globalConfig | ||||||
|  |           ? path.join(git.env['HOME'] || tempHomedir, '.gitconfig') | ||||||
|  |           : localGitConfigPath | ||||||
|  |         let content = await fs.promises.readFile(configPath) | ||||||
|  |         let lines = content | ||||||
|  |           .toString() | ||||||
|  |           .split('\n') | ||||||
|  |           .filter(x => x) | ||||||
|  |           .filter(x => !(x.startsWith(key) && x.includes(value))) | ||||||
|  |         await fs.promises.writeFile(configPath, lines.join('\n')) | ||||||
|  |         return true | ||||||
|  |       } | ||||||
|  |     ), | ||||||
|     tryDisableAutomaticGarbageCollection: jest.fn(), |     tryDisableAutomaticGarbageCollection: jest.fn(), | ||||||
|     tryGetFetchUrl: jest.fn(), |     tryGetFetchUrl: jest.fn(), | ||||||
|  |     tryGetConfigValues: jest.fn( | ||||||
|  |       async (key: string, globalConfig?: boolean): Promise<string[]> => { | ||||||
|  |         const configPath = globalConfig | ||||||
|  |           ? path.join(git.env['HOME'] || tempHomedir, '.gitconfig') | ||||||
|  |           : localGitConfigPath | ||||||
|  |         const content = await fs.promises.readFile(configPath) | ||||||
|  |         const lines = content | ||||||
|  |           .toString() | ||||||
|  |           .split('\n') | ||||||
|  |           .filter(x => x && x.startsWith(key)) | ||||||
|  |           .map(x => x.substring(key.length).trim()) | ||||||
|  |         return lines | ||||||
|  |       } | ||||||
|  |     ), | ||||||
|  |     tryGetConfigKeys: jest.fn( | ||||||
|  |       async (pattern: string, globalConfig?: boolean): Promise<string[]> => { | ||||||
|  |         const configPath = globalConfig | ||||||
|  |           ? path.join(git.env['HOME'] || tempHomedir, '.gitconfig') | ||||||
|  |           : localGitConfigPath | ||||||
|  |         const content = await fs.promises.readFile(configPath) | ||||||
|  |         const lines = content | ||||||
|  |           .toString() | ||||||
|  |           .split('\n') | ||||||
|  |           .filter(x => x) | ||||||
|  |         const keys = lines | ||||||
|  |           .filter(x => new RegExp(pattern).test(x.split(' ')[0])) | ||||||
|  |           .map(x => x.split(' ')[0]) | ||||||
|  |         return [...new Set(keys)] // Remove duplicates | ||||||
|  |       } | ||||||
|  |     ), | ||||||
|     tryReset: jest.fn(), |     tryReset: jest.fn(), | ||||||
|     version: jest.fn() |     version: jest.fn() | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -493,12 +493,15 @@ async function setup(testName: string): Promise<void> { | |||||||
|       return true |       return true | ||||||
|     }), |     }), | ||||||
|     tryConfigUnset: jest.fn(), |     tryConfigUnset: jest.fn(), | ||||||
|  |     tryConfigUnsetValue: jest.fn(), | ||||||
|     tryDisableAutomaticGarbageCollection: jest.fn(), |     tryDisableAutomaticGarbageCollection: jest.fn(), | ||||||
|     tryGetFetchUrl: jest.fn(async () => { |     tryGetFetchUrl: jest.fn(async () => { | ||||||
|       // Sanity check - this function shouldn't be called when the .git directory doesn't exist |       // Sanity check - this function shouldn't be called when the .git directory doesn't exist | ||||||
|       await fs.promises.stat(path.join(repositoryPath, '.git')) |       await fs.promises.stat(path.join(repositoryPath, '.git')) | ||||||
|       return repositoryUrl |       return repositoryUrl | ||||||
|     }), |     }), | ||||||
|  |     tryGetConfigValues: jest.fn(), | ||||||
|  |     tryGetConfigKeys: jest.fn(), | ||||||
|     tryReset: jest.fn(async () => { |     tryReset: jest.fn(async () => { | ||||||
|       return true |       return true | ||||||
|     }), |     }), | ||||||
|   | |||||||
| @@ -17,7 +17,7 @@ fi | |||||||
|  |  | ||||||
| echo "Testing persisted credential" | echo "Testing persisted credential" | ||||||
| pushd ./submodules-recursive/submodule-level-1/submodule-level-2 | pushd ./submodules-recursive/submodule-level-1/submodule-level-2 | ||||||
| git config --local --name-only --get-regexp '^includeIf\.' && git fetch | git config --local --name-only --get-regexp http.+extraheader && git fetch | ||||||
| if [ "$?" != "0" ]; then | if [ "$?" != "0" ]; then | ||||||
|     echo "Failed to validate persisted credential" |     echo "Failed to validate persisted credential" | ||||||
|     popd |     popd | ||||||
|   | |||||||
| @@ -17,7 +17,7 @@ fi | |||||||
|  |  | ||||||
| echo "Testing persisted credential" | echo "Testing persisted credential" | ||||||
| pushd ./submodules-true/submodule-level-1 | pushd ./submodules-true/submodule-level-1 | ||||||
| git config --local --name-only --get-regexp '^includeIf\.' && git fetch | git config --local --name-only --get-regexp http.+extraheader && git fetch | ||||||
| if [ "$?" != "0" ]; then | if [ "$?" != "0" ]; then | ||||||
|     echo "Failed to validate persisted credential" |     echo "Failed to validate persisted credential" | ||||||
|     popd |     popd | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										69
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							| @@ -474,13 +474,31 @@ class GitAuthHelper { | |||||||
|             // Remove HTTP extra header
 |             // Remove HTTP extra header
 | ||||||
|             yield this.removeGitConfig(this.tokenConfigKey); |             yield this.removeGitConfig(this.tokenConfigKey); | ||||||
|             yield this.removeSubmoduleGitConfig(this.tokenConfigKey); |             yield this.removeSubmoduleGitConfig(this.tokenConfigKey); | ||||||
|             // Remove includeIf
 |             // Remove includeIf entries that point to git-credentials-*.config files
 | ||||||
|             for (const includeKey of this.credentialsIncludeKeys) { |             // This is more aggressive than tracking keys, but necessary since cleanup
 | ||||||
|                 yield this.removeGitConfig(includeKey); |             // runs in a post-step where this.credentialsIncludeKeys is empty
 | ||||||
|  |             try { | ||||||
|  |                 // Get all includeIf.gitdir keys
 | ||||||
|  |                 const keys = yield this.git.tryGetConfigKeys('^includeIf\\.gitdir:'); | ||||||
|  |                 for (const key of keys) { | ||||||
|  |                     // Get all values for this key
 | ||||||
|  |                     const values = yield this.git.tryGetConfigValues(key); | ||||||
|  |                     if (values.length > 0) { | ||||||
|  |                         // Remove only values that match git-credentials-<uuid>.config pattern
 | ||||||
|  |                         for (const value of values) { | ||||||
|  |                             if (/git-credentials-[0-9a-f-]+\.config$/i.test(value)) { | ||||||
|  |                                 yield this.git.tryConfigUnsetValue(key, value); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             catch (err) { | ||||||
|  |                 // Ignore errors - this is cleanup code
 | ||||||
|  |                 core.debug(`Error during includeIf cleanup: ${err}`); | ||||||
|             } |             } | ||||||
|             this.credentialsIncludeKeys = []; |  | ||||||
|             // Remove submodule includeIf
 |             // Remove submodule includeIf
 | ||||||
|             yield this.git.submoduleForeach(`sh -c "git config --local --get-regexp '^includeIf\\.' && git config --local --remove-section includeIf || :"`, true); |             yield this.git.submoduleForeach(`sh -c "git config --local --get-regexp '^includeif\\.' && git config --local --remove-section includeif || :"`, true); | ||||||
|             // Remove credentials config file
 |             // Remove credentials config file
 | ||||||
|             if (this.credentialsConfigPath) { |             if (this.credentialsConfigPath) { | ||||||
|                 try { |                 try { | ||||||
| @@ -922,6 +940,18 @@ class GitCommandManager { | |||||||
|             return output.exitCode === 0; |             return output.exitCode === 0; | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  |     tryConfigUnsetValue(configKey, configValue, globalConfig) { | ||||||
|  |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |             const output = yield this.execGit([ | ||||||
|  |                 'config', | ||||||
|  |                 globalConfig ? '--global' : '--local', | ||||||
|  |                 '--unset', | ||||||
|  |                 configKey, | ||||||
|  |                 configValue | ||||||
|  |             ], true); | ||||||
|  |             return output.exitCode === 0; | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|     tryDisableAutomaticGarbageCollection() { |     tryDisableAutomaticGarbageCollection() { | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             const output = yield this.execGit(['config', '--local', 'gc.auto', '0'], true); |             const output = yield this.execGit(['config', '--local', 'gc.auto', '0'], true); | ||||||
| @@ -941,6 +971,35 @@ class GitCommandManager { | |||||||
|             return stdout; |             return stdout; | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  |     tryGetConfigValues(configKey, globalConfig) { | ||||||
|  |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |             const output = yield this.execGit([ | ||||||
|  |                 'config', | ||||||
|  |                 globalConfig ? '--global' : '--local', | ||||||
|  |                 '--get-all', | ||||||
|  |                 configKey | ||||||
|  |             ], true); | ||||||
|  |             if (output.exitCode !== 0) { | ||||||
|  |                 return []; | ||||||
|  |             } | ||||||
|  |             return output.stdout.trim().split('\n').filter(value => value.trim()); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |     tryGetConfigKeys(pattern, globalConfig) { | ||||||
|  |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |             const output = yield this.execGit([ | ||||||
|  |                 'config', | ||||||
|  |                 globalConfig ? '--global' : '--local', | ||||||
|  |                 '--name-only', | ||||||
|  |                 '--get-regexp', | ||||||
|  |                 pattern | ||||||
|  |             ], true); | ||||||
|  |             if (output.exitCode !== 0) { | ||||||
|  |                 return []; | ||||||
|  |             } | ||||||
|  |             return output.stdout.trim().split('\n').filter(key => key.trim()); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|     tryReset() { |     tryReset() { | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             const output = yield this.execGit(['reset', '--hard', 'HEAD'], true); |             const output = yield this.execGit(['reset', '--hard', 'HEAD'], true); | ||||||
|   | |||||||
| @@ -448,15 +448,33 @@ class GitAuthHelper { | |||||||
|     await this.removeGitConfig(this.tokenConfigKey) |     await this.removeGitConfig(this.tokenConfigKey) | ||||||
|     await this.removeSubmoduleGitConfig(this.tokenConfigKey) |     await this.removeSubmoduleGitConfig(this.tokenConfigKey) | ||||||
|  |  | ||||||
|     // Remove includeIf |     // Remove includeIf entries that point to git-credentials-*.config files | ||||||
|     for (const includeKey of this.credentialsIncludeKeys) { |     // This is more aggressive than tracking keys, but necessary since cleanup | ||||||
|       await this.removeGitConfig(includeKey) |     // runs in a post-step where this.credentialsIncludeKeys is empty | ||||||
|  |     try { | ||||||
|  |       // Get all includeIf.gitdir keys | ||||||
|  |       const keys = await this.git.tryGetConfigKeys('^includeIf\\.gitdir:') | ||||||
|  |        | ||||||
|  |       for (const key of keys) { | ||||||
|  |         // Get all values for this key | ||||||
|  |         const values = await this.git.tryGetConfigValues(key) | ||||||
|  |         if (values.length > 0) { | ||||||
|  |           // Remove only values that match git-credentials-<uuid>.config pattern | ||||||
|  |           for (const value of values) { | ||||||
|  |             if (/git-credentials-[0-9a-f-]+\.config$/i.test(value)) { | ||||||
|  |               await this.git.tryConfigUnsetValue(key, value) | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } catch (err) { | ||||||
|  |       // Ignore errors - this is cleanup code | ||||||
|  |       core.debug(`Error during includeIf cleanup: ${err}`) | ||||||
|     } |     } | ||||||
|     this.credentialsIncludeKeys = [] |  | ||||||
|  |  | ||||||
|     // Remove submodule includeIf |     // Remove submodule includeIf | ||||||
|     await this.git.submoduleForeach( |     await this.git.submoduleForeach( | ||||||
|       `sh -c "git config --local --get-regexp '^includeIf\\.' && git config --local --remove-section includeIf || :"`, |       `sh -c "git config --local --get-regexp '^includeif\\.' && git config --local --remove-section includeif || :"`, | ||||||
|       true |       true | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -60,8 +60,11 @@ export interface IGitCommandManager { | |||||||
|   tagExists(pattern: string): Promise<boolean> |   tagExists(pattern: string): Promise<boolean> | ||||||
|   tryClean(): Promise<boolean> |   tryClean(): Promise<boolean> | ||||||
|   tryConfigUnset(configKey: string, globalConfig?: boolean): Promise<boolean> |   tryConfigUnset(configKey: string, globalConfig?: boolean): Promise<boolean> | ||||||
|  |   tryConfigUnsetValue(configKey: string, configValue: string, globalConfig?: boolean): Promise<boolean> | ||||||
|   tryDisableAutomaticGarbageCollection(): Promise<boolean> |   tryDisableAutomaticGarbageCollection(): Promise<boolean> | ||||||
|   tryGetFetchUrl(): Promise<string> |   tryGetFetchUrl(): Promise<string> | ||||||
|  |   tryGetConfigValues(configKey: string, globalConfig?: boolean): Promise<string[]> | ||||||
|  |   tryGetConfigKeys(pattern: string, globalConfig?: boolean): Promise<string[]> | ||||||
|   tryReset(): Promise<boolean> |   tryReset(): Promise<boolean> | ||||||
|   version(): Promise<GitVersion> |   version(): Promise<GitVersion> | ||||||
| } | } | ||||||
| @@ -462,6 +465,24 @@ class GitCommandManager { | |||||||
|     return output.exitCode === 0 |     return output.exitCode === 0 | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   async tryConfigUnsetValue( | ||||||
|  |     configKey: string, | ||||||
|  |     configValue: string, | ||||||
|  |     globalConfig?: boolean | ||||||
|  |   ): Promise<boolean> { | ||||||
|  |     const output = await this.execGit( | ||||||
|  |       [ | ||||||
|  |         'config', | ||||||
|  |         globalConfig ? '--global' : '--local', | ||||||
|  |         '--unset', | ||||||
|  |         configKey, | ||||||
|  |         configValue | ||||||
|  |       ], | ||||||
|  |       true | ||||||
|  |     ) | ||||||
|  |     return output.exitCode === 0 | ||||||
|  |   } | ||||||
|  |  | ||||||
|   async tryDisableAutomaticGarbageCollection(): Promise<boolean> { |   async tryDisableAutomaticGarbageCollection(): Promise<boolean> { | ||||||
|     const output = await this.execGit( |     const output = await this.execGit( | ||||||
|       ['config', '--local', 'gc.auto', '0'], |       ['config', '--local', 'gc.auto', '0'], | ||||||
| @@ -488,6 +509,49 @@ class GitCommandManager { | |||||||
|     return stdout |     return stdout | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   async tryGetConfigValues( | ||||||
|  |     configKey: string, | ||||||
|  |     globalConfig?: boolean | ||||||
|  |   ): Promise<string[]> { | ||||||
|  |     const output = await this.execGit( | ||||||
|  |       [ | ||||||
|  |         'config', | ||||||
|  |         globalConfig ? '--global' : '--local', | ||||||
|  |         '--get-all', | ||||||
|  |         configKey | ||||||
|  |       ], | ||||||
|  |       true | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     if (output.exitCode !== 0) { | ||||||
|  |       return [] | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return output.stdout.trim().split('\n').filter(value => value.trim()) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   async tryGetConfigKeys( | ||||||
|  |     pattern: string, | ||||||
|  |     globalConfig?: boolean | ||||||
|  |   ): Promise<string[]> { | ||||||
|  |     const output = await this.execGit( | ||||||
|  |       [ | ||||||
|  |         'config', | ||||||
|  |         globalConfig ? '--global' : '--local', | ||||||
|  |         '--name-only', | ||||||
|  |         '--get-regexp', | ||||||
|  |         pattern | ||||||
|  |       ], | ||||||
|  |       true | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     if (output.exitCode !== 0) { | ||||||
|  |       return [] | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return output.stdout.trim().split('\n').filter(key => key.trim()) | ||||||
|  |   } | ||||||
|  |  | ||||||
|   async tryReset(): Promise<boolean> { |   async tryReset(): Promise<boolean> { | ||||||
|     const output = await this.execGit(['reset', '--hard', 'HEAD'], true) |     const output = await this.execGit(['reset', '--hard', 'HEAD'], true) | ||||||
|     return output.exitCode === 0 |     return output.exitCode === 0 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user