mirror of
				https://github.com/actions/checkout.git
				synced 2025-10-25 23:04:08 +08:00 
			
		
		
		
	Compare commits
	
		
			19 Commits
		
	
	
		
			v3.1.0
			...
			vmjoseph/s
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | af5130cb88 | ||
|   | 8e555ec39e | ||
|   | b99f9d0aba | ||
|   | a9f581070e | ||
|   | d2e9d8b595 | ||
|   | 25424e8595 | ||
|   | bac1bcfa81 | ||
|   | 1f9aeb9f74 | ||
|   | 9679ac6b68 | ||
|   | f1764260c3 | ||
|   | 9684017cd6 | ||
|   | 5788ebd085 | ||
|   | ad19603e6b | ||
|   | 2c24b08d98 | ||
|   | 9634409d1e | ||
|   | bf085276ce | ||
|   | 5c3ccc22eb | ||
|   | 1f9a0c22da | ||
|   | 8230315d06 | 
							
								
								
									
										2
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -142,7 +142,7 @@ jobs: | ||||
|       options: --dns 127.0.0.1 | ||||
|     services: | ||||
|       squid-proxy: | ||||
|         image: datadog/squid:latest | ||||
|         image: ubuntu/squid:latest | ||||
|         ports: | ||||
|           - 3128:3128 | ||||
|     env: | ||||
|   | ||||
							
								
								
									
										30
									
								
								.github/workflows/update-main-version.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.github/workflows/update-main-version.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| name: Update Main Version | ||||
| run-name: Move ${{ github.event.inputs.main_version }} to ${{ github.event.inputs.target }} | ||||
|  | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       target: | ||||
|         description: The tag or reference to use | ||||
|         required: true | ||||
|       main_version: | ||||
|         type: choice | ||||
|         description: The main version to update | ||||
|         options: | ||||
|           - v3 | ||||
|  | ||||
| jobs: | ||||
|   tag: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v3 | ||||
|       with: | ||||
|         fetch-depth: 0 | ||||
|     - name: Git config | ||||
|       run: | | ||||
|         git config user.name github-actions | ||||
|         git config user.email github-actions@github.com | ||||
|     - name: Tag new target | ||||
|       run: git tag -f ${{ github.event.inputs.main_version }} ${{ github.event.inputs.target }} | ||||
|     - name: Push new tag | ||||
|       run: git push origin ${{ github.event.inputs.main_version }} --force | ||||
							
								
								
									
										28
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| # Contributing | ||||
|  | ||||
| ## Submitting a pull request | ||||
|  | ||||
| 1. Fork and clone the repository | ||||
| 1. Configure and install the dependencies: `npm install` | ||||
| 1. Create a new branch: `git checkout -b my-branch-name` | ||||
| 1. Make your change, add tests, and make sure the tests still pass: `npm run test` | ||||
| 1. Make sure your code is correctly formatted: `npm run format` | ||||
| 1. Update `dist/index.js` using `npm run build`. This creates a single javascript file that is used as an entrypoint for the action | ||||
| 1. Push to your fork and submit a pull request | ||||
| 1. Pat yourself on the back and wait for your pull request to be reviewed and merged | ||||
|  | ||||
| Here are a few things you can do that will increase the likelihood of your pull request being accepted: | ||||
|  | ||||
| - Write tests. | ||||
| - Keep your change as focused as possible. If there are multiple changes you would like to make that are not dependent upon each other, consider submitting them as separate pull requests. | ||||
|  | ||||
| ## Resources | ||||
|  | ||||
| - [How to Contribute to Open Source](https://opensource.guide/how-to-contribute/) | ||||
| - [Using Pull Requests](https://help.github.com/articles/about-pull-requests/) | ||||
| - [GitHub Help](https://help.github.com) | ||||
| - [Writing good commit messages](http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html) | ||||
|  | ||||
| Thanks! :heart: :heart: :heart: | ||||
|  | ||||
| GitHub Actions Team :octocat: | ||||
| @@ -1,6 +1,4 @@ | ||||
| <p align="center"> | ||||
|   <a href="https://github.com/actions/checkout"><img alt="GitHub Actions status" src="https://github.com/actions/checkout/workflows/test-local/badge.svg"></a> | ||||
| </p> | ||||
| [](https://github.com/actions/checkout/actions/workflows/test.yml) | ||||
|  | ||||
| # Checkout V3 | ||||
|  | ||||
|   | ||||
							
								
								
									
										57
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										57
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							| @@ -4710,7 +4710,7 @@ module.exports = require("punycode"); | ||||
| /***/ 215: | ||||
| /***/ (function(module) { | ||||
| 
 | ||||
| module.exports = {"name":"@octokit/rest","version":"16.43.1","publishConfig":{"access":"public"},"description":"GitHub REST API client for Node.js","keywords":["octokit","github","rest","api-client"],"author":"Gregor Martynus (https://github.com/gr2m)","contributors":[{"name":"Mike de Boer","email":"info@mikedeboer.nl"},{"name":"Fabian Jakobs","email":"fabian@c9.io"},{"name":"Joe Gallo","email":"joe@brassafrax.com"},{"name":"Gregor Martynus","url":"https://github.com/gr2m"}],"repository":"https://github.com/octokit/rest.js","dependencies":{"@octokit/auth-token":"^2.4.0","@octokit/plugin-paginate-rest":"^1.1.1","@octokit/plugin-request-log":"^1.0.0","@octokit/plugin-rest-endpoint-methods":"2.4.0","@octokit/request":"^5.2.0","@octokit/request-error":"^1.0.2","atob-lite":"^2.0.0","before-after-hook":"^2.0.0","btoa-lite":"^1.0.0","deprecation":"^2.0.0","lodash.get":"^4.4.2","lodash.set":"^4.3.2","lodash.uniq":"^4.5.0","octokit-pagination-methods":"^1.1.0","once":"^1.4.0","universal-user-agent":"^4.0.0"},"devDependencies":{"@gimenete/type-writer":"^0.1.3","@octokit/auth":"^1.1.1","@octokit/fixtures-server":"^5.0.6","@octokit/graphql":"^4.2.0","@types/node":"^13.1.0","bundlesize":"^0.18.0","chai":"^4.1.2","compression-webpack-plugin":"^3.1.0","cypress":"^3.0.0","glob":"^7.1.2","http-proxy-agent":"^4.0.0","lodash.camelcase":"^4.3.0","lodash.merge":"^4.6.1","lodash.upperfirst":"^4.3.1","lolex":"^5.1.2","mkdirp":"^1.0.0","mocha":"^7.0.1","mustache":"^4.0.0","nock":"^11.3.3","npm-run-all":"^4.1.2","nyc":"^15.0.0","prettier":"^1.14.2","proxy":"^1.0.0","semantic-release":"^17.0.0","sinon":"^8.0.0","sinon-chai":"^3.0.0","sort-keys":"^4.0.0","string-to-arraybuffer":"^1.0.0","string-to-jsdoc-comment":"^1.0.0","typescript":"^3.3.1","webpack":"^4.0.0","webpack-bundle-analyzer":"^3.0.0","webpack-cli":"^3.0.0"},"types":"index.d.ts","scripts":{"coverage":"nyc report --reporter=html && open coverage/index.html","lint":"prettier --check '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","lint:fix":"prettier --write '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","pretest":"npm run -s lint","test":"nyc mocha test/mocha-node-setup.js \"test/*/**/*-test.js\"","test:browser":"cypress run --browser chrome","build":"npm-run-all build:*","build:ts":"npm run -s update-endpoints:typescript","prebuild:browser":"mkdirp dist/","build:browser":"npm-run-all build:browser:*","build:browser:development":"webpack --mode development --entry . --output-library=Octokit --output=./dist/octokit-rest.js --profile --json > dist/bundle-stats.json","build:browser:production":"webpack --mode production --entry . --plugin=compression-webpack-plugin --output-library=Octokit --output-path=./dist --output-filename=octokit-rest.min.js --devtool source-map","generate-bundle-report":"webpack-bundle-analyzer dist/bundle-stats.json --mode=static --no-open --report dist/bundle-report.html","update-endpoints":"npm-run-all update-endpoints:*","update-endpoints:fetch-json":"node scripts/update-endpoints/fetch-json","update-endpoints:typescript":"node scripts/update-endpoints/typescript","prevalidate:ts":"npm run -s build:ts","validate:ts":"tsc --target es6 --noImplicitAny index.d.ts","postvalidate:ts":"tsc --noEmit --target es6 test/typescript-validate.ts","start-fixtures-server":"octokit-fixtures-server"},"license":"MIT","files":["index.js","index.d.ts","lib","plugins"],"nyc":{"ignore":["test"]},"release":{"publish":["@semantic-release/npm",{"path":"@semantic-release/github","assets":["dist/*","!dist/*.map.gz"]}]},"bundlesize":[{"path":"./dist/octokit-rest.min.js.gz","maxSize":"33 kB"}]}; | ||||
| module.exports = {"_args":[["@octokit/rest@16.43.1","/workspaces/checkout"]],"_from":"@octokit/rest@16.43.1","_id":"@octokit/rest@16.43.1","_inBundle":false,"_integrity":"sha512-gfFKwRT/wFxq5qlNjnW2dh+qh74XgTQ2B179UX5K1HYCluioWj8Ndbgqw2PVqa1NnVJkGHp2ovMpVn/DImlmkw==","_location":"/@octokit/rest","_phantomChildren":{"@octokit/types":"2.14.0","deprecation":"2.3.1","once":"1.4.0"},"_requested":{"type":"version","registry":true,"raw":"@octokit/rest@16.43.1","name":"@octokit/rest","escapedName":"@octokit%2frest","scope":"@octokit","rawSpec":"16.43.1","saveSpec":null,"fetchSpec":"16.43.1"},"_requiredBy":["/@actions/github"],"_resolved":"https://registry.npmjs.org/@octokit/rest/-/rest-16.43.1.tgz","_spec":"16.43.1","_where":"/workspaces/checkout","author":{"name":"Gregor Martynus","url":"https://github.com/gr2m"},"bugs":{"url":"https://github.com/octokit/rest.js/issues"},"bundlesize":[{"path":"./dist/octokit-rest.min.js.gz","maxSize":"33 kB"}],"contributors":[{"name":"Mike de Boer","email":"info@mikedeboer.nl"},{"name":"Fabian Jakobs","email":"fabian@c9.io"},{"name":"Joe Gallo","email":"joe@brassafrax.com"},{"name":"Gregor Martynus","url":"https://github.com/gr2m"}],"dependencies":{"@octokit/auth-token":"^2.4.0","@octokit/plugin-paginate-rest":"^1.1.1","@octokit/plugin-request-log":"^1.0.0","@octokit/plugin-rest-endpoint-methods":"2.4.0","@octokit/request":"^5.2.0","@octokit/request-error":"^1.0.2","atob-lite":"^2.0.0","before-after-hook":"^2.0.0","btoa-lite":"^1.0.0","deprecation":"^2.0.0","lodash.get":"^4.4.2","lodash.set":"^4.3.2","lodash.uniq":"^4.5.0","octokit-pagination-methods":"^1.1.0","once":"^1.4.0","universal-user-agent":"^4.0.0"},"description":"GitHub REST API client for Node.js","devDependencies":{"@gimenete/type-writer":"^0.1.3","@octokit/auth":"^1.1.1","@octokit/fixtures-server":"^5.0.6","@octokit/graphql":"^4.2.0","@types/node":"^13.1.0","bundlesize":"^0.18.0","chai":"^4.1.2","compression-webpack-plugin":"^3.1.0","cypress":"^3.0.0","glob":"^7.1.2","http-proxy-agent":"^4.0.0","lodash.camelcase":"^4.3.0","lodash.merge":"^4.6.1","lodash.upperfirst":"^4.3.1","lolex":"^5.1.2","mkdirp":"^1.0.0","mocha":"^7.0.1","mustache":"^4.0.0","nock":"^11.3.3","npm-run-all":"^4.1.2","nyc":"^15.0.0","prettier":"^1.14.2","proxy":"^1.0.0","semantic-release":"^17.0.0","sinon":"^8.0.0","sinon-chai":"^3.0.0","sort-keys":"^4.0.0","string-to-arraybuffer":"^1.0.0","string-to-jsdoc-comment":"^1.0.0","typescript":"^3.3.1","webpack":"^4.0.0","webpack-bundle-analyzer":"^3.0.0","webpack-cli":"^3.0.0"},"files":["index.js","index.d.ts","lib","plugins"],"homepage":"https://github.com/octokit/rest.js#readme","keywords":["octokit","github","rest","api-client"],"license":"MIT","name":"@octokit/rest","nyc":{"ignore":["test"]},"publishConfig":{"access":"public"},"release":{"publish":["@semantic-release/npm",{"path":"@semantic-release/github","assets":["dist/*","!dist/*.map.gz"]}]},"repository":{"type":"git","url":"git+https://github.com/octokit/rest.js.git"},"scripts":{"build":"npm-run-all build:*","build:browser":"npm-run-all build:browser:*","build:browser:development":"webpack --mode development --entry . --output-library=Octokit --output=./dist/octokit-rest.js --profile --json > dist/bundle-stats.json","build:browser:production":"webpack --mode production --entry . --plugin=compression-webpack-plugin --output-library=Octokit --output-path=./dist --output-filename=octokit-rest.min.js --devtool source-map","build:ts":"npm run -s update-endpoints:typescript","coverage":"nyc report --reporter=html && open coverage/index.html","generate-bundle-report":"webpack-bundle-analyzer dist/bundle-stats.json --mode=static --no-open --report dist/bundle-report.html","lint":"prettier --check '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","lint:fix":"prettier --write '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","postvalidate:ts":"tsc --noEmit --target es6 test/typescript-validate.ts","prebuild:browser":"mkdirp dist/","pretest":"npm run -s lint","prevalidate:ts":"npm run -s build:ts","start-fixtures-server":"octokit-fixtures-server","test":"nyc mocha test/mocha-node-setup.js \"test/*/**/*-test.js\"","test:browser":"cypress run --browser chrome","update-endpoints":"npm-run-all update-endpoints:*","update-endpoints:fetch-json":"node scripts/update-endpoints/fetch-json","update-endpoints:typescript":"node scripts/update-endpoints/typescript","validate:ts":"tsc --target es6 --noImplicitAny index.d.ts"},"types":"index.d.ts","version":"16.43.1"}; | ||||
| 
 | ||||
| /***/ }), | ||||
| 
 | ||||
| @@ -7121,7 +7121,9 @@ class GitAuthHelper { | ||||
|                 // Configure a placeholder value. This approach avoids the credential being captured
 | ||||
|                 // by process creation audit events, which are commonly logged. For more information,
 | ||||
|                 // refer to https://docs.microsoft.com/en-us/windows-server/identity/ad-ds/manage/component-updates/command-line-process-auditing
 | ||||
|                 const output = yield this.git.submoduleForeach(`git config --local '${this.tokenConfigKey}' '${this.tokenPlaceholderConfigValue}' && git config --local --show-origin --name-only --get-regexp remote.origin.url`, this.settings.nestedSubmodules); | ||||
|                 const output = yield this.git.submoduleForeach( | ||||
|                 // wrap the pipeline in quotes to make sure it's handled properly by submoduleForeach, rather than just the first part of the pipeline
 | ||||
|                 `sh -c "git config --local '${this.tokenConfigKey}' '${this.tokenPlaceholderConfigValue}' && git config --local --show-origin --name-only --get-regexp remote.origin.url"`, this.settings.nestedSubmodules); | ||||
|                 // Replace the placeholder
 | ||||
|                 const configPaths = output.match(/(?<=(^|\n)file:)[^\t]+(?=\tremote\.origin\.url)/g) || []; | ||||
|                 for (const configPath of configPaths) { | ||||
| @@ -7288,7 +7290,9 @@ class GitAuthHelper { | ||||
|                 } | ||||
|             } | ||||
|             const pattern = regexpHelper.escape(configKey); | ||||
|             yield this.git.submoduleForeach(`git config --local --name-only --get-regexp '${pattern}' && git config --local --unset-all '${configKey}' || :`, true); | ||||
|             yield this.git.submoduleForeach( | ||||
|             // wrap the pipeline in quotes to make sure it's handled properly by submoduleForeach, rather than just the first part of the pipeline
 | ||||
|             `sh -c "git config --local --name-only --get-regexp '${pattern}' && git config --local --unset-all '${configKey}' || :"`, true); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| @@ -7384,6 +7388,7 @@ class GitCommandManager { | ||||
|     branchList(remote) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             const result = []; | ||||
|             const stderr = []; | ||||
|             // Note, this implementation uses "rev-parse --symbolic-full-name" because the output from
 | ||||
|             // "branch --list" is more difficult when in a detached HEAD state.
 | ||||
|             // Note, this implementation uses "rev-parse --symbolic-full-name" because there is a bug
 | ||||
| @@ -7395,7 +7400,15 @@ class GitCommandManager { | ||||
|             else { | ||||
|                 args.push('--branches'); | ||||
|             } | ||||
|             const output = yield this.execGit(args); | ||||
|             const listeners = { | ||||
|                 stderr: (data) => { | ||||
|                     stderr.push(data.toString()); | ||||
|                 }, | ||||
|                 errline: (line) => { | ||||
|                     stderr.push(line); | ||||
|                 } | ||||
|             }; | ||||
|             const output = yield this.execGit(args, false, false, listeners); | ||||
|             for (let branch of output.stdout.trim().split('\n')) { | ||||
|                 branch = branch.trim(); | ||||
|                 if (branch) { | ||||
| @@ -7408,6 +7421,7 @@ class GitCommandManager { | ||||
|                     result.push(branch); | ||||
|                 } | ||||
|             } | ||||
|             core.info(stderr.join('\n')); | ||||
|             return result; | ||||
|         }); | ||||
|     } | ||||
| @@ -7657,7 +7671,7 @@ class GitCommandManager { | ||||
|             return result; | ||||
|         }); | ||||
|     } | ||||
|     execGit(args, allowAllExitCodes = false, silent = false) { | ||||
|     execGit(args, allowAllExitCodes = false, silent = false, customListeners = {}) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             fshelper.directoryExistsSync(this.workingDirectory, true); | ||||
|             const result = new GitOutput(); | ||||
| @@ -7668,20 +7682,43 @@ class GitCommandManager { | ||||
|             for (const key of Object.keys(this.gitEnv)) { | ||||
|                 env[key] = this.gitEnv[key]; | ||||
|             } | ||||
|             const defaultListener = { | ||||
|                 stdout: (data) => { | ||||
|                     stdout.push(data.toString()); | ||||
|                 } | ||||
|             }; | ||||
|             // const listeners = Object.keys(customListeners) < 0 ? customListeners : {stdout: (data: Buffer) => {
 | ||||
|             //   stdout.push(data.toString())
 | ||||
|             // }}
 | ||||
|             const listenersD = Object.assign(Object.assign({}, customListeners), defaultListener); | ||||
|             const stdout = []; | ||||
|             // let temp = ''
 | ||||
|             // let temp2 = ''
 | ||||
|             const options = { | ||||
|                 cwd: this.workingDirectory, | ||||
|                 env, | ||||
|                 silent, | ||||
|                 ignoreReturnCode: allowAllExitCodes, | ||||
|                 listeners: { | ||||
|                     stdout: (data) => { | ||||
|                         stdout.push(data.toString()); | ||||
|                     } | ||||
|                 } | ||||
|                 listeners: listenersD | ||||
|                 // ,
 | ||||
|                 // errStream: new stream.Writable({
 | ||||
|                 //   write(chunk, _, next) {
 | ||||
|                 //     temp += chunk.toString()
 | ||||
|                 //     next()
 | ||||
|                 //   }
 | ||||
|                 // }),
 | ||||
|                 // outStream: new stream.Writable({
 | ||||
|                 //   write(chunk, _, next) {
 | ||||
|                 //     temp2 += chunk.toString()
 | ||||
|                 //     next()
 | ||||
|                 //   }
 | ||||
|                 // })
 | ||||
|             }; | ||||
|             result.exitCode = yield exec.exec(`"${this.gitPath}"`, args, options); | ||||
|             result.stdout = stdout.join(''); | ||||
|             // core.info(temp.length.toString())
 | ||||
|             // core.info(temp2.length.toString())
 | ||||
|             core.info(result.stdout); | ||||
|             return result; | ||||
|         }); | ||||
|     } | ||||
|   | ||||
							
								
								
									
										13
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										13
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -5906,6 +5906,11 @@ | ||||
|       "integrity": "sha512-qcLvDUPf8DSIMWarHT2ptgcqrYg62n3vPA7vhrOF24d8UNzbUBaHu2CySiENR3nEDzYgaN60071t0F6KLYMQ7Q==", | ||||
|       "dev": true | ||||
|     }, | ||||
|     "emitter-component": { | ||||
|       "version": "1.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/emitter-component/-/emitter-component-1.1.1.tgz", | ||||
|       "integrity": "sha512-G+mpdiAySMuB7kesVRLuyvYRqDmshB7ReKEVuyBPkzQlmiDiLrt7hHHIy4Aff552bgknVN7B2/d3lzhGO5dvpQ==" | ||||
|     }, | ||||
|     "emittery": { | ||||
|       "version": "0.8.1", | ||||
|       "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", | ||||
| @@ -16487,6 +16492,14 @@ | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "stream": { | ||||
|       "version": "0.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/stream/-/stream-0.0.2.tgz", | ||||
|       "integrity": "sha512-gCq3NDI2P35B2n6t76YJuOp7d6cN/C7Rt0577l91wllh0sY9ZBuw9KaSGqH/b0hzn3CWWJbpbW0W0WvQ1H/Q7g==", | ||||
|       "requires": { | ||||
|         "emitter-component": "^1.1.1" | ||||
|       } | ||||
|     }, | ||||
|     "string-length": { | ||||
|       "version": "4.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", | ||||
|   | ||||
| @@ -33,6 +33,7 @@ | ||||
|     "@actions/github": "^2.2.0", | ||||
|     "@actions/io": "^1.0.1", | ||||
|     "@actions/tool-cache": "^1.1.2", | ||||
|     "stream": "0.0.2", | ||||
|     "uuid": "^3.3.3" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|   | ||||
| @@ -157,7 +157,8 @@ class GitAuthHelper { | ||||
|       // by process creation audit events, which are commonly logged. For more information, | ||||
|       // refer to https://docs.microsoft.com/en-us/windows-server/identity/ad-ds/manage/component-updates/command-line-process-auditing | ||||
|       const output = await this.git.submoduleForeach( | ||||
|         `git config --local '${this.tokenConfigKey}' '${this.tokenPlaceholderConfigValue}' && git config --local --show-origin --name-only --get-regexp remote.origin.url`, | ||||
|         // wrap the pipeline in quotes to make sure it's handled properly by submoduleForeach, rather than just the first part of the pipeline | ||||
|         `sh -c "git config --local '${this.tokenConfigKey}' '${this.tokenPlaceholderConfigValue}' && git config --local --show-origin --name-only --get-regexp remote.origin.url"`, | ||||
|         this.settings.nestedSubmodules | ||||
|       ) | ||||
|  | ||||
| @@ -365,7 +366,8 @@ class GitAuthHelper { | ||||
|  | ||||
|     const pattern = regexpHelper.escape(configKey) | ||||
|     await this.git.submoduleForeach( | ||||
|       `git config --local --name-only --get-regexp '${pattern}' && git config --local --unset-all '${configKey}' || :`, | ||||
|       // wrap the pipeline in quotes to make sure it's handled properly by submoduleForeach, rather than just the first part of the pipeline | ||||
|       `sh -c "git config --local --name-only --get-regexp '${pattern}' && git config --local --unset-all '${configKey}' || :"`, | ||||
|       true | ||||
|     ) | ||||
|   } | ||||
|   | ||||
| @@ -7,6 +7,7 @@ import * as refHelper from './ref-helper' | ||||
| import * as regexpHelper from './regexp-helper' | ||||
| import * as retryHelper from './retry-helper' | ||||
| import {GitVersion} from './git-version' | ||||
| import stream, {Writable} from 'stream' | ||||
|  | ||||
| // Auth header not supported before 2.9 | ||||
| // Wire protocol v2 not supported before 2.18 | ||||
| @@ -91,6 +92,7 @@ class GitCommandManager { | ||||
|  | ||||
|   async branchList(remote: boolean): Promise<string[]> { | ||||
|     const result: string[] = [] | ||||
|     const stderr: string[] = [] | ||||
|  | ||||
|     // Note, this implementation uses "rev-parse --symbolic-full-name" because the output from | ||||
|     // "branch --list" is more difficult when in a detached HEAD state. | ||||
| @@ -104,7 +106,15 @@ class GitCommandManager { | ||||
|       args.push('--branches') | ||||
|     } | ||||
|  | ||||
|     const output = await this.execGit(args) | ||||
|     const listeners = { | ||||
|       stderr: (data: Buffer) => { | ||||
|         stderr.push(data.toString()) | ||||
|       }, | ||||
|       errline: (line: string) => { | ||||
|         stderr.push(line) | ||||
|       } | ||||
|     } | ||||
|     const output = await this.execGit(args, false, false, listeners) | ||||
|  | ||||
|     for (let branch of output.stdout.trim().split('\n')) { | ||||
|       branch = branch.trim() | ||||
| @@ -118,7 +128,7 @@ class GitCommandManager { | ||||
|         result.push(branch) | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     core.info(stderr.join('\n')) | ||||
|     return result | ||||
|   } | ||||
|  | ||||
| @@ -395,7 +405,8 @@ class GitCommandManager { | ||||
|   private async execGit( | ||||
|     args: string[], | ||||
|     allowAllExitCodes = false, | ||||
|     silent = false | ||||
|     silent = false, | ||||
|     customListeners = {} | ||||
|   ): Promise<GitOutput> { | ||||
|     fshelper.directoryExistsSync(this.workingDirectory, true) | ||||
|  | ||||
| @@ -408,23 +419,45 @@ class GitCommandManager { | ||||
|     for (const key of Object.keys(this.gitEnv)) { | ||||
|       env[key] = this.gitEnv[key] | ||||
|     } | ||||
|  | ||||
|     const defaultListener = { | ||||
|       stdout: (data: Buffer) => { | ||||
|         stdout.push(data.toString()) | ||||
|       } | ||||
|     } | ||||
|     // const listeners = Object.keys(customListeners) < 0 ? customListeners : {stdout: (data: Buffer) => { | ||||
|     //   stdout.push(data.toString()) | ||||
|     // }} | ||||
|     const listenersD = {...customListeners, ...defaultListener} | ||||
|     const stdout: string[] = [] | ||||
|  | ||||
|     // let temp = '' | ||||
|     // let temp2 = '' | ||||
|     const options = { | ||||
|       cwd: this.workingDirectory, | ||||
|       env, | ||||
|       silent, | ||||
|       ignoreReturnCode: allowAllExitCodes, | ||||
|       listeners: { | ||||
|         stdout: (data: Buffer) => { | ||||
|           stdout.push(data.toString()) | ||||
|         } | ||||
|       } | ||||
|       listeners: listenersD | ||||
|       // , | ||||
|       // errStream: new stream.Writable({ | ||||
|       //   write(chunk, _, next) { | ||||
|       //     temp += chunk.toString() | ||||
|       //     next() | ||||
|       //   } | ||||
|       // }), | ||||
|  | ||||
|       // outStream: new stream.Writable({ | ||||
|       //   write(chunk, _, next) { | ||||
|       //     temp2 += chunk.toString() | ||||
|       //     next() | ||||
|       //   } | ||||
|       // }) | ||||
|     } | ||||
|  | ||||
|     result.exitCode = await exec.exec(`"${this.gitPath}"`, args, options) | ||||
|     result.stdout = stdout.join('') | ||||
|     // core.info(temp.length.toString()) | ||||
|     // core.info(temp2.length.toString()) | ||||
|     core.info(result.stdout) | ||||
|     return result | ||||
|   } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user