You've already forked setup-dotnet
							
							
				mirror of
				https://github.com/actions/setup-dotnet.git
				synced 2025-10-25 20:55:08 +07:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5689bbdcd0 | |||
| 39bfcfef74 | |||
| 893aeb5420 | |||
| b90f08a647 | 
							
								
								
									
										1
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @ -1 +0,0 @@ | ||||
| .licenses/** -diff linguist-generated=true | ||||
							
								
								
									
										23
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
								
							| @ -1,23 +0,0 @@ | ||||
| --- | ||||
| name: Bug report | ||||
| about: Create a bug report | ||||
| title: '' | ||||
| labels: '' | ||||
| assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| ### Description | ||||
|  | ||||
| <!-- | ||||
| * Please share short description of the problem | ||||
|   --> | ||||
|  | ||||
| ### Details | ||||
|  | ||||
| <!-- | ||||
| * Include the relevant yaml, platform, and dotnet versions in use | ||||
| * If an error occurred on a public action, please share a link | ||||
| * Include any error messages received in text (search does not work for images) | ||||
| * Was this a regression from previous behavior? | ||||
|   --> | ||||
							
								
								
									
										5
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,5 +0,0 @@ | ||||
| blank_issues_enabled: true | ||||
| contact_links: | ||||
|   - name: .NET issues | ||||
|     url: https://github.com/dotnet/runtime#filing-issues | ||||
|     about: Issues with the runtime, class libraries, frameworks, and SDK should be addressed directly with the .NET team. Documentation on filing issues can be found here. | ||||
							
								
								
									
										6
									
								
								.github/csc.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/csc.json
									
									
									
									
										vendored
									
									
								
							| @ -4,13 +4,13 @@ | ||||
|             "owner": "csc", | ||||
|             "pattern": [ | ||||
|                 { | ||||
|                     "regexp": "^([^\\s].*)\\((\\d+)(?:,\\d+|,\\d+,\\d+)?\\):\\s+(error|warning)\\s+([a-zA-Z]+(?<!MSB)\\d+):\\s*(.*?)\\s+\\[(.*?)\\]$", | ||||
|                     "regexp": "^(?:\\s+\\d+\\>)?([^\\s].*)\\((\\d+|\\d+,\\d+|\\d+,\\d+,\\d+,\\d+)\\)\\s*:\\s+(error|warning|info)\\s+(\\w{1,2}\\d+)\\s*:\\s*(.*)(\\[(.+)\\/([^\\/]+)\\])$", | ||||
|                     "file": 1, | ||||
|                     "line": 2, | ||||
|                     "location": 2, | ||||
|                     "severity": 3, | ||||
|                     "code": 4, | ||||
|                     "message": 5, | ||||
|                     "fromPath": 6 | ||||
|                     "fromPath": 7 | ||||
|                 } | ||||
|             ] | ||||
|         } | ||||
|  | ||||
							
								
								
									
										20
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,20 +0,0 @@ | ||||
| name: Licensed | ||||
|  | ||||
| on: | ||||
|   push: {branches: main} | ||||
|   pull_request: {branches: main} | ||||
|  | ||||
| jobs: | ||||
|   test: | ||||
|     runs-on: ubuntu-latest | ||||
|     name: Check licenses | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - run: npm ci | ||||
|       - name: Install licensed | ||||
|         run: | | ||||
|           cd $RUNNER_TEMP | ||||
|           curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/2.12.2/licensed-2.12.2-linux-x64.tar.gz | ||||
|           sudo tar -xzf licensed.tar.gz | ||||
|           sudo mv licensed /usr/local/bin/licensed | ||||
|       - run: licensed status | ||||
							
								
								
									
										134
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										134
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,130 +1,26 @@ | ||||
| name: Main workflow | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|       - releases/* | ||||
|  | ||||
| on: [push] | ||||
| jobs: | ||||
|   build: | ||||
|   run: | ||||
|     name: Run | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|         operating-system: [ubuntu-latest, windows-latest] | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|     - name: Set Node.js 12 | ||||
|       uses: actions/setup-node@v1 | ||||
|       uses: actions/checkout@master | ||||
|  | ||||
|     - name: Set Node.js 10.x | ||||
|       uses: actions/setup-node@master | ||||
|       with: | ||||
|         node-version: 12.x | ||||
|     - run: npm ci | ||||
|     - run: npm run build | ||||
|     - run: npm run format-check | ||||
|     - run: npm test | ||||
|     - name: Verify no unstaged changes | ||||
|       if: runner.os != 'windows' | ||||
|       run: __tests__/verify-no-unstaged-changes.sh | ||||
|         version: 10.x | ||||
|  | ||||
|   test: | ||||
|     runs-on: ${{ matrix.operating-system }} | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Clear tool cache (macOS) | ||||
|         if: runner.os == 'macos' | ||||
|         run: | | ||||
|           echo $PATH | ||||
|           dotnet --info | ||||
|           rm -rf "/Users/runner/.dotnet" | ||||
|       - name: Clear tool cache (Ubuntu) | ||||
|         if: runner.os == 'linux' | ||||
|         run: | | ||||
|           echo $PATH | ||||
|           dotnet --info | ||||
|           rm -rf "/usr/share/dotnet" | ||||
|       - name: Clear tool cache (Windows) | ||||
|         if: runner.os == 'windows' | ||||
|         run: | | ||||
|           echo $env:PATH | ||||
|           dotnet --info | ||||
|           Remove-Item $env:LocalAppData\Microsoft\dotnet/*  -Recurse -Force -ErrorAction SilentlyContinue | ||||
|           Remove-Item "$env:ProgramFiles\dotnet/*"  -Recurse -Force -ErrorAction SilentlyContinue | ||||
|       # Side-by-side install of 2.2 and 3.1 used for the test project | ||||
|       - name: Setup dotnet 2.2.402 | ||||
|         uses: ./ | ||||
|         with: | ||||
|           dotnet-version: 2.2.402 | ||||
|       - name: Setup dotnet 3.1.201 | ||||
|         uses: ./ | ||||
|         with: | ||||
|           dotnet-version: 3.1.201 | ||||
|           # We are including this veriable to force the generation of the nuget config file to verify that it is created in the correct place | ||||
|           source-url: https://api.nuget.org/v3/index.json | ||||
|         env: | ||||
|           NUGET_AUTH_TOKEN: NOTATOKEN | ||||
|       - name: Verify dotnet | ||||
|         if: runner.os != 'windows' | ||||
|         run: __tests__/verify-dotnet.sh 3.1.201 2.2.402 | ||||
|       - name: Verify dotnet (Windows) | ||||
|         if: runner.os == 'windows' | ||||
|         run: __tests__/verify-dotnet.ps1 3.1.201 | ||||
|     - name: npm install | ||||
|       run: npm install | ||||
|  | ||||
|   test-proxy: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: | ||||
|       image: mcr.microsoft.com/dotnet/core/runtime-deps:3.0-bionic | ||||
|       options: --dns 127.0.0.1 | ||||
|     services: | ||||
|       squid-proxy: | ||||
|         image: datadog/squid:latest | ||||
|         ports: | ||||
|           - 3128:3128 | ||||
|     env: | ||||
|       https_proxy: http://squid-proxy:3128 | ||||
|       http_proxy: http://squid-proxy:3128 | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Clear tool cache | ||||
|         run: rm -rf "/usr/share/dotnet" | ||||
|       - name: Install curl | ||||
|         run: | | ||||
|           apt update | ||||
|           apt -y install curl | ||||
|       - name: Setup dotnet 3.1.201 | ||||
|         uses: ./ | ||||
|         with: | ||||
|           dotnet-version: 3.1.201 | ||||
|           source-url: https://api.nuget.org/v3/index.json | ||||
|         env: | ||||
|           NUGET_AUTH_TOKEN: NOTATOKEN | ||||
|       - name: Verify dotnet | ||||
|         run: __tests__/verify-dotnet.sh 3.1.201 | ||||
|     - name: Lint | ||||
|       run: npm run format-check | ||||
|  | ||||
|   test-bypass-proxy: | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       https_proxy: http://no-such-proxy:3128 | ||||
|       no_proxy: github.com,dotnetcli.blob.core.windows.net,download.visualstudio.microsoft.com,api.nuget.org,dotnetcli.azureedge.net | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Clear tool cache | ||||
|         run: rm -rf "/usr/share/dotnet" | ||||
|       - name: Setup dotnet 3.1.201 | ||||
|         uses: ./ | ||||
|         with: | ||||
|           dotnet-version: 3.1.201 | ||||
|           source-url: https://api.nuget.org/v3/index.json | ||||
|         env: | ||||
|           NUGET_AUTH_TOKEN: NOTATOKEN | ||||
|       - name: Verify dotnet | ||||
|         run: __tests__/verify-dotnet.sh 3.1.201 | ||||
|     - name: npm test | ||||
|       run: npm test | ||||
|  | ||||
							
								
								
									
										11
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,10 +1,6 @@ | ||||
| # dev dependencies are *not* checked in | ||||
| global.json | ||||
| lib/ | ||||
| node_modules/ | ||||
| # Explicitly not ignoring node_modules so that they are included in package downloaded by runner | ||||
| !node_modules/ | ||||
| __tests__/runner/* | ||||
| __tests__/sample-csproj/bin/ | ||||
| __tests__/sample-csproj/obj/ | ||||
|  | ||||
| # Rest of the file pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | ||||
| # Logs | ||||
| @ -94,6 +90,3 @@ typings/ | ||||
|  | ||||
| # DynamoDB Local files | ||||
| .dynamodb/ | ||||
|  | ||||
| # Ignore .vscode files | ||||
| .vscode/ | ||||
| @ -1,14 +0,0 @@ | ||||
| sources: | ||||
|   npm: true | ||||
|  | ||||
| allowed: | ||||
|   - apache-2.0 | ||||
|   - bsd-2-clause | ||||
|   - bsd-3-clause | ||||
|   - isc | ||||
|   - mit | ||||
|   - cc0-1.0 | ||||
|   - unlicense | ||||
|  | ||||
| reviewed: | ||||
|   npm: | ||||
| @ -1,20 +0,0 @@ | ||||
| --- | ||||
| name: "@actions/core" | ||||
| version: 1.2.5 | ||||
| type: npm | ||||
| summary: Actions core lib | ||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/core | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: |- | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright 2019 GitHub | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,30 +0,0 @@ | ||||
| --- | ||||
| name: "@actions/exec" | ||||
| version: 1.0.4 | ||||
| type: npm | ||||
| summary: Actions exec lib | ||||
| homepage: https://github.com/actions/toolkit/tree/master/packages/exec | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: Auto-generated MIT license text | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all | ||||
|     copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
|     SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,18 +0,0 @@ | ||||
| --- | ||||
| name: "@actions/github" | ||||
| version: 1.1.0 | ||||
| type: npm | ||||
| summary: Actions github lib | ||||
| homepage: https://github.com/actions/toolkit/tree/master/packages/github | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: |- | ||||
|     Copyright 2019 GitHub | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,32 +0,0 @@ | ||||
| --- | ||||
| name: "@actions/http-client" | ||||
| version: 1.0.8 | ||||
| type: npm | ||||
| summary: Actions Http Client | ||||
| homepage: https://github.com/actions/http-client#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     Actions Http Client for Node.js | ||||
|  | ||||
|     Copyright (c) GitHub, Inc. | ||||
|  | ||||
|     All rights reserved. | ||||
|  | ||||
|     MIT License | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and | ||||
|     associated documentation files (the "Software"), to deal in the Software without restriction, | ||||
|     including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||||
|     and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, | ||||
|     subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT | ||||
|     LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | ||||
|     NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | ||||
|     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | ||||
|     SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,30 +0,0 @@ | ||||
| --- | ||||
| name: "@actions/io" | ||||
| version: 1.0.2 | ||||
| type: npm | ||||
| summary: Actions io lib | ||||
| homepage: https://github.com/actions/toolkit/tree/master/packages/io | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: Auto-generated MIT license text | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all | ||||
|     copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
|     SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: "@octokit/endpoint" | ||||
| version: 5.3.5 | ||||
| type: npm | ||||
| summary: Turns REST API endpoints into generic request options | ||||
| homepage: https://github.com/octokit/endpoint.js#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License | ||||
|  | ||||
|     Copyright (c) 2018 Octokit contributors | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[MIT](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: "@octokit/graphql" | ||||
| version: 2.1.3 | ||||
| type: npm | ||||
| summary: GitHub GraphQL API client for browsers and Node | ||||
| homepage: https://github.com/octokit/graphql.js#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License | ||||
|  | ||||
|     Copyright (c) 2018 Octokit contributors | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[MIT](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: "@octokit/request-error" | ||||
| version: 1.0.4 | ||||
| type: npm | ||||
| summary: Error class for Octokit request errors | ||||
| homepage: https://github.com/octokit/request-error.js#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License | ||||
|  | ||||
|     Copyright (c) 2019 Octokit contributors | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[MIT](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,35 +0,0 @@ | ||||
| --- | ||||
| name: "@octokit/request" | ||||
| version: 5.1.0 | ||||
| type: npm | ||||
| summary: Send parameterized requests to GitHub’s APIs with sensible defaults in browsers | ||||
|   and Node | ||||
| homepage: https://github.com/octokit/request.js#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License | ||||
|  | ||||
|     Copyright (c) 2018 Octokit contributors | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[MIT](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,35 +0,0 @@ | ||||
| --- | ||||
| name: "@octokit/rest" | ||||
| version: 16.28.9 | ||||
| type: npm | ||||
| summary: GitHub REST API client for Node.js | ||||
| homepage: https://github.com/octokit/rest.js#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License | ||||
|  | ||||
|     Copyright (c) 2012 Cloud9 IDE, Inc. (Mike de Boer) | ||||
|     Copyright (c) 2017-2018 Octokit contributors | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[MIT](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,32 +0,0 @@ | ||||
| --- | ||||
| name: atob-lite | ||||
| version: 2.0.0 | ||||
| type: npm | ||||
| summary: Smallest/simplest possible means of using atob with both Node and browserify | ||||
| homepage: https://github.com/hughsk/atob-lite | ||||
| license: other | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: | | ||||
|     This software is released under the MIT license: | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of | ||||
|     this software and associated documentation files (the "Software"), to deal in | ||||
|     the Software without restriction, including without limitation the rights to | ||||
|     use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of | ||||
|     the Software, and to permit persons to whom the Software is furnished to do so, | ||||
|     subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all | ||||
|     copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS | ||||
|     FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR | ||||
|     COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER | ||||
|     IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | ||||
|     CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: MIT. See [LICENSE.md](http://github.com/hughsk/atob-lite/blob/master/LICENSE.md) | ||||
|     for details. | ||||
| notices: [] | ||||
| @ -1,214 +0,0 @@ | ||||
| --- | ||||
| name: before-after-hook | ||||
| version: 2.1.0 | ||||
| type: npm | ||||
| summary: asynchronous before/error/after hooks for internal functionality | ||||
| homepage: https://github.com/gr2m/before-after-hook#readme | ||||
| license: apache-2.0 | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: |2 | ||||
|                                      Apache License | ||||
|                                Version 2.0, January 2004 | ||||
|                             http://www.apache.org/licenses/ | ||||
|  | ||||
|        TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||
|  | ||||
|        1. Definitions. | ||||
|  | ||||
|           "License" shall mean the terms and conditions for use, reproduction, | ||||
|           and distribution as defined by Sections 1 through 9 of this document. | ||||
|  | ||||
|           "Licensor" shall mean the copyright owner or entity authorized by | ||||
|           the copyright owner that is granting the License. | ||||
|  | ||||
|           "Legal Entity" shall mean the union of the acting entity and all | ||||
|           other entities that control, are controlled by, or are under common | ||||
|           control with that entity. For the purposes of this definition, | ||||
|           "control" means (i) the power, direct or indirect, to cause the | ||||
|           direction or management of such entity, whether by contract or | ||||
|           otherwise, or (ii) ownership of fifty percent (50%) or more of the | ||||
|           outstanding shares, or (iii) beneficial ownership of such entity. | ||||
|  | ||||
|           "You" (or "Your") shall mean an individual or Legal Entity | ||||
|           exercising permissions granted by this License. | ||||
|  | ||||
|           "Source" form shall mean the preferred form for making modifications, | ||||
|           including but not limited to software source code, documentation | ||||
|           source, and configuration files. | ||||
|  | ||||
|           "Object" form shall mean any form resulting from mechanical | ||||
|           transformation or translation of a Source form, including but | ||||
|           not limited to compiled object code, generated documentation, | ||||
|           and conversions to other media types. | ||||
|  | ||||
|           "Work" shall mean the work of authorship, whether in Source or | ||||
|           Object form, made available under the License, as indicated by a | ||||
|           copyright notice that is included in or attached to the work | ||||
|           (an example is provided in the Appendix below). | ||||
|  | ||||
|           "Derivative Works" shall mean any work, whether in Source or Object | ||||
|           form, that is based on (or derived from) the Work and for which the | ||||
|           editorial revisions, annotations, elaborations, or other modifications | ||||
|           represent, as a whole, an original work of authorship. For the purposes | ||||
|           of this License, Derivative Works shall not include works that remain | ||||
|           separable from, or merely link (or bind by name) to the interfaces of, | ||||
|           the Work and Derivative Works thereof. | ||||
|  | ||||
|           "Contribution" shall mean any work of authorship, including | ||||
|           the original version of the Work and any modifications or additions | ||||
|           to that Work or Derivative Works thereof, that is intentionally | ||||
|           submitted to Licensor for inclusion in the Work by the copyright owner | ||||
|           or by an individual or Legal Entity authorized to submit on behalf of | ||||
|           the copyright owner. For the purposes of this definition, "submitted" | ||||
|           means any form of electronic, verbal, or written communication sent | ||||
|           to the Licensor or its representatives, including but not limited to | ||||
|           communication on electronic mailing lists, source code control systems, | ||||
|           and issue tracking systems that are managed by, or on behalf of, the | ||||
|           Licensor for the purpose of discussing and improving the Work, but | ||||
|           excluding communication that is conspicuously marked or otherwise | ||||
|           designated in writing by the copyright owner as "Not a Contribution." | ||||
|  | ||||
|           "Contributor" shall mean Licensor and any individual or Legal Entity | ||||
|           on behalf of whom a Contribution has been received by Licensor and | ||||
|           subsequently incorporated within the Work. | ||||
|  | ||||
|        2. Grant of Copyright License. Subject to the terms and conditions of | ||||
|           this License, each Contributor hereby grants to You a perpetual, | ||||
|           worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|           copyright license to reproduce, prepare Derivative Works of, | ||||
|           publicly display, publicly perform, sublicense, and distribute the | ||||
|           Work and such Derivative Works in Source or Object form. | ||||
|  | ||||
|        3. Grant of Patent License. Subject to the terms and conditions of | ||||
|           this License, each Contributor hereby grants to You a perpetual, | ||||
|           worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|           (except as stated in this section) patent license to make, have made, | ||||
|           use, offer to sell, sell, import, and otherwise transfer the Work, | ||||
|           where such license applies only to those patent claims licensable | ||||
|           by such Contributor that are necessarily infringed by their | ||||
|           Contribution(s) alone or by combination of their Contribution(s) | ||||
|           with the Work to which such Contribution(s) was submitted. If You | ||||
|           institute patent litigation against any entity (including a | ||||
|           cross-claim or counterclaim in a lawsuit) alleging that the Work | ||||
|           or a Contribution incorporated within the Work constitutes direct | ||||
|           or contributory patent infringement, then any patent licenses | ||||
|           granted to You under this License for that Work shall terminate | ||||
|           as of the date such litigation is filed. | ||||
|  | ||||
|        4. Redistribution. You may reproduce and distribute copies of the | ||||
|           Work or Derivative Works thereof in any medium, with or without | ||||
|           modifications, and in Source or Object form, provided that You | ||||
|           meet the following conditions: | ||||
|  | ||||
|           (a) You must give any other recipients of the Work or | ||||
|               Derivative Works a copy of this License; and | ||||
|  | ||||
|           (b) You must cause any modified files to carry prominent notices | ||||
|               stating that You changed the files; and | ||||
|  | ||||
|           (c) You must retain, in the Source form of any Derivative Works | ||||
|               that You distribute, all copyright, patent, trademark, and | ||||
|               attribution notices from the Source form of the Work, | ||||
|               excluding those notices that do not pertain to any part of | ||||
|               the Derivative Works; and | ||||
|  | ||||
|           (d) If the Work includes a "NOTICE" text file as part of its | ||||
|               distribution, then any Derivative Works that You distribute must | ||||
|               include a readable copy of the attribution notices contained | ||||
|               within such NOTICE file, excluding those notices that do not | ||||
|               pertain to any part of the Derivative Works, in at least one | ||||
|               of the following places: within a NOTICE text file distributed | ||||
|               as part of the Derivative Works; within the Source form or | ||||
|               documentation, if provided along with the Derivative Works; or, | ||||
|               within a display generated by the Derivative Works, if and | ||||
|               wherever such third-party notices normally appear. The contents | ||||
|               of the NOTICE file are for informational purposes only and | ||||
|               do not modify the License. You may add Your own attribution | ||||
|               notices within Derivative Works that You distribute, alongside | ||||
|               or as an addendum to the NOTICE text from the Work, provided | ||||
|               that such additional attribution notices cannot be construed | ||||
|               as modifying the License. | ||||
|  | ||||
|           You may add Your own copyright statement to Your modifications and | ||||
|           may provide additional or different license terms and conditions | ||||
|           for use, reproduction, or distribution of Your modifications, or | ||||
|           for any such Derivative Works as a whole, provided Your use, | ||||
|           reproduction, and distribution of the Work otherwise complies with | ||||
|           the conditions stated in this License. | ||||
|  | ||||
|        5. Submission of Contributions. Unless You explicitly state otherwise, | ||||
|           any Contribution intentionally submitted for inclusion in the Work | ||||
|           by You to the Licensor shall be under the terms and conditions of | ||||
|           this License, without any additional terms or conditions. | ||||
|           Notwithstanding the above, nothing herein shall supersede or modify | ||||
|           the terms of any separate license agreement you may have executed | ||||
|           with Licensor regarding such Contributions. | ||||
|  | ||||
|        6. Trademarks. This License does not grant permission to use the trade | ||||
|           names, trademarks, service marks, or product names of the Licensor, | ||||
|           except as required for reasonable and customary use in describing the | ||||
|           origin of the Work and reproducing the content of the NOTICE file. | ||||
|  | ||||
|        7. Disclaimer of Warranty. Unless required by applicable law or | ||||
|           agreed to in writing, Licensor provides the Work (and each | ||||
|           Contributor provides its Contributions) on an "AS IS" BASIS, | ||||
|           WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
|           implied, including, without limitation, any warranties or conditions | ||||
|           of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A | ||||
|           PARTICULAR PURPOSE. You are solely responsible for determining the | ||||
|           appropriateness of using or redistributing the Work and assume any | ||||
|           risks associated with Your exercise of permissions under this License. | ||||
|  | ||||
|        8. Limitation of Liability. In no event and under no legal theory, | ||||
|           whether in tort (including negligence), contract, or otherwise, | ||||
|           unless required by applicable law (such as deliberate and grossly | ||||
|           negligent acts) or agreed to in writing, shall any Contributor be | ||||
|           liable to You for damages, including any direct, indirect, special, | ||||
|           incidental, or consequential damages of any character arising as a | ||||
|           result of this License or out of the use or inability to use the | ||||
|           Work (including but not limited to damages for loss of goodwill, | ||||
|           work stoppage, computer failure or malfunction, or any and all | ||||
|           other commercial damages or losses), even if such Contributor | ||||
|           has been advised of the possibility of such damages. | ||||
|  | ||||
|        9. Accepting Warranty or Additional Liability. While redistributing | ||||
|           the Work or Derivative Works thereof, You may choose to offer, | ||||
|           and charge a fee for, acceptance of support, warranty, indemnity, | ||||
|           or other liability obligations and/or rights consistent with this | ||||
|           License. However, in accepting such obligations, You may act only | ||||
|           on Your own behalf and on Your sole responsibility, not on behalf | ||||
|           of any other Contributor, and only if You agree to indemnify, | ||||
|           defend, and hold each Contributor harmless for any liability | ||||
|           incurred by, or claims asserted against, such Contributor by reason | ||||
|           of your accepting any such warranty or additional liability. | ||||
|  | ||||
|        END OF TERMS AND CONDITIONS | ||||
|  | ||||
|        APPENDIX: How to apply the Apache License to your work. | ||||
|  | ||||
|           To apply the Apache License to your work, attach the following | ||||
|           boilerplate notice, with the fields enclosed by brackets "{}" | ||||
|           replaced with your own identifying information. (Don't include | ||||
|           the brackets!)  The text should be enclosed in the appropriate | ||||
|           comment syntax for the file format. We also recommend that a | ||||
|           file or class name and description of purpose be included on the | ||||
|           same "printed page" as the copyright notice for easier | ||||
|           identification within third-party archives. | ||||
|  | ||||
|        Copyright 2018 Gregor Martynus and other contributors. | ||||
|  | ||||
|        Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|        you may not use this file except in compliance with the License. | ||||
|        You may obtain a copy of the License at | ||||
|  | ||||
|            http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|        Unless required by applicable law or agreed to in writing, software | ||||
|        distributed under the License is distributed on an "AS IS" BASIS, | ||||
|        WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|        See the License for the specific language governing permissions and | ||||
|        limitations under the License. | ||||
| - sources: README.md | ||||
|   text: "[Apache 2.0](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,32 +0,0 @@ | ||||
| --- | ||||
| name: btoa-lite | ||||
| version: 1.0.0 | ||||
| type: npm | ||||
| summary: Smallest/simplest possible means of using btoa with both Node and browserify | ||||
| homepage: https://github.com/hughsk/btoa-lite | ||||
| license: other | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: | | ||||
|     This software is released under the MIT license: | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of | ||||
|     this software and associated documentation files (the "Software"), to deal in | ||||
|     the Software without restriction, including without limitation the rights to | ||||
|     use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of | ||||
|     the Software, and to permit persons to whom the Software is furnished to do so, | ||||
|     subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all | ||||
|     copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS | ||||
|     FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR | ||||
|     COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER | ||||
|     IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | ||||
|     CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: MIT. See [LICENSE.md](http://github.com/hughsk/btoa-lite/blob/master/LICENSE.md) | ||||
|     for details. | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: cross-spawn | ||||
| version: 6.0.5 | ||||
| type: npm | ||||
| summary: Cross platform child_process#spawn and child_process#spawnSync | ||||
| homepage: https://github.com/moxystudio/node-cross-spawn | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2018 Made With MOXY Lda <hello@moxy.studio> | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: Released under the [MIT License](http://www.opensource.org/licenses/mit-license.php). | ||||
| notices: [] | ||||
| @ -1,28 +0,0 @@ | ||||
| --- | ||||
| name: deprecation | ||||
| version: 2.3.1 | ||||
| type: npm | ||||
| summary: Log a deprecation message with stack | ||||
| homepage: https://github.com/gr2m/deprecation#readme | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Gregor Martynus and contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[ISC](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: end-of-stream | ||||
| version: 1.4.1 | ||||
| type: npm | ||||
| summary: Call a callback when a readable/writable/duplex stream has completed or failed. | ||||
| homepage: https://github.com/mafintosh/end-of-stream | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: |- | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2014 Mathias Buus | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: MIT | ||||
| notices: [] | ||||
| @ -1,22 +0,0 @@ | ||||
| --- | ||||
| name: execa | ||||
| version: 1.0.0 | ||||
| type: npm | ||||
| summary: A better `child_process` | ||||
| homepage: https://github.com/sindresorhus/execa#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,27 +0,0 @@ | ||||
| --- | ||||
| name: fast-xml-parser | ||||
| version: 3.17.4 | ||||
| type: npm | ||||
| summary: Validate XML or Parse XML to JS/JSON very fast without C/C++ based libraries | ||||
| homepage: https://github.com/NaturalIntelligence/fast-xml-parser#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: "MIT License\n\nCopyright (c) 2017 Amit Kumar Gupta\n\nPermission is hereby | ||||
|     granted, free of charge, to any person obtaining a copy\nof this software and | ||||
|     associated documentation files (the \"Software\"), to deal\nin the Software without | ||||
|     restriction, including without limitation the rights\nto use, copy, modify, merge, | ||||
|     publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit | ||||
|     persons to whom the Software is\nfurnished to do so, subject to the following | ||||
|     conditions:\n\nIf you use this library in a public repository then you give us | ||||
|     the right to mention your company name and logo in user's list without further | ||||
|     permission required, but you can request them to be taken down within 30 days. | ||||
|     \n\nThe above copyright notice and this permission notice shall be included in | ||||
|     all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED | ||||
|     \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT | ||||
|     LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE | ||||
|     AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE | ||||
|     FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, | ||||
|     TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR | ||||
|     THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n" | ||||
| notices: [] | ||||
| @ -1,22 +0,0 @@ | ||||
| --- | ||||
| name: get-stream | ||||
| version: 4.1.0 | ||||
| type: npm | ||||
| summary: Get a stream as a string, buffer, or array | ||||
| homepage: https://github.com/sindresorhus/get-stream#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,40 +0,0 @@ | ||||
| --- | ||||
| name: is-plain-object | ||||
| version: 3.0.0 | ||||
| type: npm | ||||
| summary: Returns true if an object was created by the `Object` constructor. | ||||
| homepage: https://github.com/jonschlinkert/is-plain-object | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2014-2017, Jon Schlinkert. | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: |- | ||||
|     Copyright © 2019, [Jon Schlinkert](https://github.com/jonschlinkert). | ||||
|     Released under the [MIT License](LICENSE). | ||||
|  | ||||
|     *** | ||||
|  | ||||
|     _This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on April 28, 2019._ | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: is-stream | ||||
| version: 1.1.0 | ||||
| type: npm | ||||
| summary: Check if something is a Node.js stream | ||||
| homepage: https://github.com/sindresorhus/is-stream#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,26 +0,0 @@ | ||||
| --- | ||||
| name: isexe | ||||
| version: 2.0.0 | ||||
| type: npm | ||||
| summary: Minimal module to check if a file is executable. | ||||
| homepage: https://github.com/isaacs/isexe#readme | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Isaac Z. Schlueter and Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,40 +0,0 @@ | ||||
| --- | ||||
| name: isobject | ||||
| version: 4.0.0 | ||||
| type: npm | ||||
| summary: Returns true if the value is an object and not an array or null. | ||||
| homepage: https://github.com/jonschlinkert/isobject | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: |- | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2014-2017, Jon Schlinkert. | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: |- | ||||
|     Copyright © 2019, [Jon Schlinkert](https://github.com/jonschlinkert). | ||||
|     Released under the [MIT License](LICENSE). | ||||
|  | ||||
|     *** | ||||
|  | ||||
|     _This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on April 28, 2019._ | ||||
| notices: [] | ||||
| @ -1,58 +0,0 @@ | ||||
| --- | ||||
| name: lodash.get | ||||
| version: 4.4.2 | ||||
| type: npm | ||||
| summary: The lodash method `_.get` exported as a module. | ||||
| homepage: https://lodash.com/ | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     Copyright jQuery Foundation and other contributors <https://jquery.org/> | ||||
|  | ||||
|     Based on Underscore.js, copyright Jeremy Ashkenas, | ||||
|     DocumentCloud and Investigative Reporters & Editors <http://underscorejs.org/> | ||||
|  | ||||
|     This software consists of voluntary contributions made by many | ||||
|     individuals. For exact contribution history, see the revision history | ||||
|     available at https://github.com/lodash/lodash | ||||
|  | ||||
|     The following license applies to all parts of this software except as | ||||
|     documented below: | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining | ||||
|     a copy of this software and associated documentation files (the | ||||
|     "Software"), to deal in the Software without restriction, including | ||||
|     without limitation the rights to use, copy, modify, merge, publish, | ||||
|     distribute, sublicense, and/or sell copies of the Software, and to | ||||
|     permit persons to whom the Software is furnished to do so, subject to | ||||
|     the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be | ||||
|     included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
|     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||||
|     MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||||
|     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||||
|     LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||||
|     OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||||
|     WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Copyright and related rights for sample code are waived via CC0. Sample | ||||
|     code is defined as all source code displayed within the prose of the | ||||
|     documentation. | ||||
|  | ||||
|     CC0: http://creativecommons.org/publicdomain/zero/1.0/ | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Files located in the node_modules and vendor directories are externally | ||||
|     maintained libraries used by this software which have their own | ||||
|     licenses; we recommend you read them, as their terms may differ from the | ||||
|     terms above. | ||||
| notices: [] | ||||
| @ -1,58 +0,0 @@ | ||||
| --- | ||||
| name: lodash.set | ||||
| version: 4.3.2 | ||||
| type: npm | ||||
| summary: The lodash method `_.set` exported as a module. | ||||
| homepage: https://lodash.com/ | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     Copyright jQuery Foundation and other contributors <https://jquery.org/> | ||||
|  | ||||
|     Based on Underscore.js, copyright Jeremy Ashkenas, | ||||
|     DocumentCloud and Investigative Reporters & Editors <http://underscorejs.org/> | ||||
|  | ||||
|     This software consists of voluntary contributions made by many | ||||
|     individuals. For exact contribution history, see the revision history | ||||
|     available at https://github.com/lodash/lodash | ||||
|  | ||||
|     The following license applies to all parts of this software except as | ||||
|     documented below: | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining | ||||
|     a copy of this software and associated documentation files (the | ||||
|     "Software"), to deal in the Software without restriction, including | ||||
|     without limitation the rights to use, copy, modify, merge, publish, | ||||
|     distribute, sublicense, and/or sell copies of the Software, and to | ||||
|     permit persons to whom the Software is furnished to do so, subject to | ||||
|     the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be | ||||
|     included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
|     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||||
|     MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||||
|     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||||
|     LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||||
|     OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||||
|     WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Copyright and related rights for sample code are waived via CC0. Sample | ||||
|     code is defined as all source code displayed within the prose of the | ||||
|     documentation. | ||||
|  | ||||
|     CC0: http://creativecommons.org/publicdomain/zero/1.0/ | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Files located in the node_modules and vendor directories are externally | ||||
|     maintained libraries used by this software which have their own | ||||
|     licenses; we recommend you read them, as their terms may differ from the | ||||
|     terms above. | ||||
| notices: [] | ||||
| @ -1,58 +0,0 @@ | ||||
| --- | ||||
| name: lodash.uniq | ||||
| version: 4.5.0 | ||||
| type: npm | ||||
| summary: The lodash method `_.uniq` exported as a module. | ||||
| homepage: https://lodash.com/ | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     Copyright jQuery Foundation and other contributors <https://jquery.org/> | ||||
|  | ||||
|     Based on Underscore.js, copyright Jeremy Ashkenas, | ||||
|     DocumentCloud and Investigative Reporters & Editors <http://underscorejs.org/> | ||||
|  | ||||
|     This software consists of voluntary contributions made by many | ||||
|     individuals. For exact contribution history, see the revision history | ||||
|     available at https://github.com/lodash/lodash | ||||
|  | ||||
|     The following license applies to all parts of this software except as | ||||
|     documented below: | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining | ||||
|     a copy of this software and associated documentation files (the | ||||
|     "Software"), to deal in the Software without restriction, including | ||||
|     without limitation the rights to use, copy, modify, merge, publish, | ||||
|     distribute, sublicense, and/or sell copies of the Software, and to | ||||
|     permit persons to whom the Software is furnished to do so, subject to | ||||
|     the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be | ||||
|     included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
|     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||||
|     MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||||
|     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||||
|     LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||||
|     OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||||
|     WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Copyright and related rights for sample code are waived via CC0. Sample | ||||
|     code is defined as all source code displayed within the prose of the | ||||
|     documentation. | ||||
|  | ||||
|     CC0: http://creativecommons.org/publicdomain/zero/1.0/ | ||||
|  | ||||
|     ==== | ||||
|  | ||||
|     Files located in the node_modules and vendor directories are externally | ||||
|     maintained libraries used by this software which have their own | ||||
|     licenses; we recommend you read them, as their terms may differ from the | ||||
|     terms above. | ||||
| notices: [] | ||||
| @ -1,22 +0,0 @@ | ||||
| --- | ||||
| name: macos-release | ||||
| version: 2.3.0 | ||||
| type: npm | ||||
| summary: Get the name and version of a macOS release from the Darwin version | ||||
| homepage: https://github.com/sindresorhus/macos-release#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,32 +0,0 @@ | ||||
| --- | ||||
| name: nice-try | ||||
| version: 1.0.5 | ||||
| type: npm | ||||
| summary: Tries to execute a function and discards any error that occurs | ||||
| homepage: https://github.com/electerious/nice-try | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2018 Tobias Reich | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,56 +0,0 @@ | ||||
| --- | ||||
| name: node-fetch | ||||
| version: 2.6.1 | ||||
| type: npm | ||||
| summary: A light-weight module that brings window.fetch to node.js | ||||
| homepage: https://github.com/bitinn/node-fetch | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: |+ | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2016 David Frank | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all | ||||
|     copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
|     SOFTWARE. | ||||
|  | ||||
| - sources: README.md | ||||
|   text: |- | ||||
|     MIT | ||||
|  | ||||
|     [npm-image]: https://flat.badgen.net/npm/v/node-fetch | ||||
|     [npm-url]: https://www.npmjs.com/package/node-fetch | ||||
|     [travis-image]: https://flat.badgen.net/travis/bitinn/node-fetch | ||||
|     [travis-url]: https://travis-ci.org/bitinn/node-fetch | ||||
|     [codecov-image]: https://flat.badgen.net/codecov/c/github/bitinn/node-fetch/master | ||||
|     [codecov-url]: https://codecov.io/gh/bitinn/node-fetch | ||||
|     [install-size-image]: https://flat.badgen.net/packagephobia/install/node-fetch | ||||
|     [install-size-url]: https://packagephobia.now.sh/result?p=node-fetch | ||||
|     [discord-image]: https://img.shields.io/discord/619915844268326952?color=%237289DA&label=Discord&style=flat-square | ||||
|     [discord-url]: https://discord.gg/Zxbndcm | ||||
|     [opencollective-image]: https://opencollective.com/node-fetch/backers.svg | ||||
|     [opencollective-url]: https://opencollective.com/node-fetch | ||||
|     [whatwg-fetch]: https://fetch.spec.whatwg.org/ | ||||
|     [response-init]: https://fetch.spec.whatwg.org/#responseinit | ||||
|     [node-readable]: https://nodejs.org/api/stream.html#stream_readable_streams | ||||
|     [mdn-headers]: https://developer.mozilla.org/en-US/docs/Web/API/Headers | ||||
|     [LIMITS.md]: https://github.com/bitinn/node-fetch/blob/master/LIMITS.md | ||||
|     [ERROR-HANDLING.md]: https://github.com/bitinn/node-fetch/blob/master/ERROR-HANDLING.md | ||||
|     [UPGRADE-GUIDE.md]: https://github.com/bitinn/node-fetch/blob/master/UPGRADE-GUIDE.md | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: npm-run-path | ||||
| version: 2.0.2 | ||||
| type: npm | ||||
| summary: Get your PATH prepended with locally installed binaries | ||||
| homepage: https://github.com/sindresorhus/npm-run-path#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,35 +0,0 @@ | ||||
| --- | ||||
| name: octokit-pagination-methods | ||||
| version: 1.1.0 | ||||
| type: npm | ||||
| summary: Legacy Octokit pagination methods from v15 | ||||
| homepage: https://github.com/gr2m/octokit-pagination-methods#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License | ||||
|  | ||||
|     Copyright (c) 2012 Cloud9 IDE, Inc. (Mike de Boer) | ||||
|     Copyright (c) 2017-2018 Octokit contributors | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[MIT](LICENSE)" | ||||
| notices: [] | ||||
| @ -1,26 +0,0 @@ | ||||
| --- | ||||
| name: once | ||||
| version: 1.4.0 | ||||
| type: npm | ||||
| summary: Run a function exactly one time | ||||
| homepage: https://github.com/isaacs/once#readme | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Isaac Z. Schlueter and Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,22 +0,0 @@ | ||||
| --- | ||||
| name: os-name | ||||
| version: 3.1.0 | ||||
| type: npm | ||||
| summary: 'Get the name of the current operating system. Example: macOS Sierra' | ||||
| homepage: https://github.com/sindresorhus/os-name#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,35 +0,0 @@ | ||||
| --- | ||||
| name: p-finally | ||||
| version: 1.0.0 | ||||
| type: npm | ||||
| summary: "`Promise#finally()` ponyfill - Invoked when the promise is settled regardless | ||||
|   of outcome" | ||||
| homepage: https://github.com/sindresorhus/p-finally#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: path-key | ||||
| version: 2.0.1 | ||||
| type: npm | ||||
| summary: Get the PATH environment variable key cross-platform | ||||
| homepage: https://github.com/sindresorhus/path-key#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: pump | ||||
| version: 3.0.0 | ||||
| type: npm | ||||
| summary: pipe streams together and close all of them if one of them closes | ||||
| homepage: https://github.com/mafintosh/pump#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: |- | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2014 Mathias Buus | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: MIT | ||||
| notices: [] | ||||
| @ -1,26 +0,0 @@ | ||||
| --- | ||||
| name: semver | ||||
| version: 5.7.0 | ||||
| type: npm | ||||
| summary: The semantic version parser used by npm. | ||||
| homepage: https://github.com/npm/node-semver#readme | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Isaac Z. Schlueter and Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,26 +0,0 @@ | ||||
| --- | ||||
| name: semver | ||||
| version: 6.3.0 | ||||
| type: npm | ||||
| summary: The semantic version parser used by npm. | ||||
| homepage: https://github.com/npm/node-semver#readme | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Isaac Z. Schlueter and Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: shebang-command | ||||
| version: 1.2.0 | ||||
| type: npm | ||||
| summary: Get the command from a shebang | ||||
| homepage: https://github.com/kevva/shebang-command#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Kevin Martensson <kevinmartensson@gmail.com> (github.com/kevva) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Kevin Martensson](http://github.com/kevva) | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: shebang-regex | ||||
| version: 1.0.0 | ||||
| type: npm | ||||
| summary: Regular expression for matching a shebang | ||||
| homepage: https://github.com/sindresorhus/shebang-regex#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](http://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,27 +0,0 @@ | ||||
| --- | ||||
| name: signal-exit | ||||
| version: 3.0.2 | ||||
| type: npm | ||||
| summary: when you want to fire an event no matter how a process exits. | ||||
| homepage: https://github.com/tapjs/signal-exit | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE.txt | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) 2015, Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software | ||||
|     for any purpose with or without fee is hereby granted, provided | ||||
|     that the above copyright notice and this permission notice | ||||
|     appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES | ||||
|     OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE | ||||
|     LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES | ||||
|     OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, | ||||
|     WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, | ||||
|     ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,34 +0,0 @@ | ||||
| --- | ||||
| name: strip-eof | ||||
| version: 1.0.0 | ||||
| type: npm | ||||
| summary: Strip the End-Of-File (EOF) character from a string/buffer | ||||
| homepage: https://github.com/sindresorhus/strip-eof#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](http://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,35 +0,0 @@ | ||||
| --- | ||||
| name: tunnel | ||||
| version: 0.0.6 | ||||
| type: npm | ||||
| summary: Node HTTP/HTTPS Agents for tunneling proxies | ||||
| homepage: https://github.com/koichik/node-tunnel/ | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The MIT License (MIT) | ||||
|  | ||||
|     Copyright (c) 2012 Koichi Kobayashi | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|     of this software and associated documentation files (the "Software"), to deal | ||||
|     in the Software without restriction, including without limitation the rights | ||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|     copies of the Software, and to permit persons to whom the Software is | ||||
|     furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in | ||||
|     all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|     THE SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: Licensed under the [MIT](https://github.com/koichik/node-tunnel/blob/master/LICENSE) | ||||
|     license. | ||||
| notices: [] | ||||
| @ -1,20 +0,0 @@ | ||||
| --- | ||||
| name: universal-user-agent | ||||
| version: 2.1.0 | ||||
| type: npm | ||||
| summary: Get a user agent string in both browser and node | ||||
| homepage: https://github.com/gr2m/universal-user-agent#readme | ||||
| license: other | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: | | ||||
|     # [ISC License](https://spdx.org/licenses/ISC) | ||||
|  | ||||
|     Copyright (c) 2018, Gregor Martynus (https://github.com/gr2m) | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[ISC](LICENSE.md)" | ||||
| notices: [] | ||||
| @ -1,20 +0,0 @@ | ||||
| --- | ||||
| name: universal-user-agent | ||||
| version: 4.0.0 | ||||
| type: npm | ||||
| summary: Get a user agent string in both browser and node | ||||
| homepage: https://github.com/gr2m/universal-user-agent#readme | ||||
| license: other | ||||
| licenses: | ||||
| - sources: LICENSE.md | ||||
|   text: | | ||||
|     # [ISC License](https://spdx.org/licenses/ISC) | ||||
|  | ||||
|     Copyright (c) 2018, Gregor Martynus (https://github.com/gr2m) | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| - sources: README.md | ||||
|   text: "[ISC](LICENSE.md)" | ||||
| notices: [] | ||||
| @ -1,27 +0,0 @@ | ||||
| --- | ||||
| name: which | ||||
| version: 1.3.1 | ||||
| type: npm | ||||
| summary: Like which(1) unix command. Find the first instance of an executable in the | ||||
|   PATH. | ||||
| homepage: https://github.com/isaacs/node-which#readme | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Isaac Z. Schlueter and Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,23 +0,0 @@ | ||||
| --- | ||||
| name: windows-release | ||||
| version: 3.2.0 | ||||
| type: npm | ||||
| summary: 'Get the name of a Windows version from the release number: `5.1.2600` → | ||||
|   `XP`' | ||||
| homepage: https://github.com/sindresorhus/windows-release#readme | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: license | ||||
|   text: | | ||||
|     MIT License | ||||
|  | ||||
|     Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com) | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| - sources: readme.md | ||||
|   text: MIT © [Sindre Sorhus](https://sindresorhus.com) | ||||
| notices: [] | ||||
| @ -1,26 +0,0 @@ | ||||
| --- | ||||
| name: wrappy | ||||
| version: 1.0.2 | ||||
| type: npm | ||||
| summary: Callback wrapping utility | ||||
| homepage: https://github.com/npm/wrappy | ||||
| license: isc | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: | | ||||
|     The ISC License | ||||
|  | ||||
|     Copyright (c) Isaac Z. Schlueter and Contributors | ||||
|  | ||||
|     Permission to use, copy, modify, and/or distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||
|     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| notices: [] | ||||
| @ -1,24 +0,0 @@ | ||||
| --- | ||||
| name: xmlbuilder | ||||
| version: 13.0.2 | ||||
| type: npm | ||||
| summary: An XML builder for node.js | ||||
| homepage: http://github.com/oozcitak/xmlbuilder-js | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|   text: "The MIT License (MIT)\r\n\r\nCopyright (c) 2013 Ozgur Ozcitak\r\n\r\nPermission | ||||
|     is hereby granted, free of charge, to any person obtaining a copy\r\nof this software | ||||
|     and associated documentation files (the \"Software\"), to deal\r\nin the Software | ||||
|     without restriction, including without limitation the rights\r\nto use, copy, | ||||
|     modify, merge, publish, distribute, sublicense, and/or sell\r\ncopies of the Software, | ||||
|     and to permit persons to whom the Software is\r\nfurnished to do so, subject to | ||||
|     the following conditions:\r\n\r\nThe above copyright notice and this permission | ||||
|     notice shall be included in\r\nall copies or substantial portions of the Software.\r\n\r\nTHE | ||||
|     SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\nIMPLIED, | ||||
|     INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\nFITNESS FOR | ||||
|     A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\nAUTHORS OR | ||||
|     COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\nLIABILITY, WHETHER | ||||
|     IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\nOUT OF OR IN CONNECTION | ||||
|     WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\nTHE SOFTWARE.\r\n" | ||||
| notices: [] | ||||
							
								
								
									
										87
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										87
									
								
								README.md
									
									
									
									
									
								
							| @ -4,17 +4,10 @@ | ||||
|   <a href="https://github.com/actions/setup-dotnet"><img alt="GitHub Actions status" src="https://github.com/actions/setup-dotnet/workflows/Main%20workflow/badge.svg"></a> | ||||
| </p> | ||||
|  | ||||
| This action sets up a [dotnet core cli](https://github.com/dotnet/cli) environment for use in actions by: | ||||
| This action sets up a dotnet environment for use in actions by: | ||||
|  | ||||
| - optionally downloading and caching a version of dotnet by SDK version and adding to PATH | ||||
| - registering problem matchers for error output | ||||
| - setting up authentication to private package sources like GitHub Packages | ||||
|  | ||||
| Please Note: GitHub hosted runners have some versions of the .NET SDK | ||||
| preinstalled. Installed versions are subject to change. Please refer to the | ||||
| documentation | ||||
| [software installed on github hosted runners](https://help.github.com/en/actions/reference/software-installed-on-github-hosted-runners) | ||||
| for .NET SDK versions that are currently available. | ||||
|  | ||||
| # Usage | ||||
|  | ||||
| @ -23,10 +16,10 @@ See [action.yml](action.yml) | ||||
| Basic: | ||||
| ```yaml | ||||
| steps: | ||||
| - uses: actions/checkout@main | ||||
| - uses: actions/checkout@master | ||||
| - uses: actions/setup-dotnet@v1 | ||||
|   with: | ||||
|     dotnet-version: '3.1.x' # SDK Version to use; x will use the latest version of the 3.1 channel | ||||
|     dotnet-version: '2.2.103' # SDK Version to use. | ||||
| - run: dotnet build <my project> | ||||
| ``` | ||||
|  | ||||
| @ -34,13 +27,13 @@ Matrix Testing: | ||||
| ```yaml | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
|     runs-on: ubuntu-16.04 | ||||
|     strategy: | ||||
|       matrix: | ||||
|         dotnet: [ '2.2.103', '3.0', '3.1.x' ] | ||||
|         dotnet: [ '2.2.103', '3.0.100-preview8-013656', '4.5.1' ] | ||||
|     name: Dotnet ${{ matrix.dotnet }} sample | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/checkout@master | ||||
|       - name: Setup dotnet | ||||
|         uses: actions/setup-dotnet@v1 | ||||
|         with: | ||||
| @ -48,74 +41,6 @@ jobs: | ||||
|       - run: dotnet build <my project> | ||||
| ``` | ||||
|  | ||||
| Side by Side Testing: | ||||
| ```yaml | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
|     name: Dotnet Side by Side testing sample | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - name: Setup dotnet | ||||
|         uses: actions/setup-dotnet@v1 | ||||
|         with: | ||||
|           dotnet-version: '2.2.103' | ||||
|       - name: Setup dotnet | ||||
|         uses: actions/setup-dotnet@v1 | ||||
|         with: | ||||
|           dotnet-version: '3.1.x' | ||||
|       - run: dotnet build <my project> | ||||
|       - run: dotnet test <my project> | ||||
| ``` | ||||
|  | ||||
| Authentication for nuget feeds: | ||||
| ```yaml | ||||
| steps: | ||||
| - uses: actions/checkout@v2 | ||||
| # Authenticates packages to push to GPR | ||||
| - uses: actions/setup-dotnet@v1 | ||||
|   with: | ||||
|     dotnet-version: '3.1.x' # SDK Version to use. | ||||
|     source-url: https://nuget.pkg.github.com/<owner>/index.json | ||||
|   env: | ||||
|     NUGET_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} | ||||
| - run: dotnet build <my project> | ||||
| - name: Create the package | ||||
|   run: dotnet pack --configuration Release <my project> | ||||
|  - name: Publish the package to GPR | ||||
|   run: dotnet nuget push <my project>/bin/Release/*.nupkg | ||||
|  | ||||
| # Authticates packages to push to Azure Artifacts | ||||
| - uses: actions/setup-dotnet@v1 | ||||
|   with: | ||||
|     source-url: https://pkgs.dev.azure.com/<your-organization>/_packaging/<your-feed-name>/nuget/v3/index.json | ||||
|   env: | ||||
|     NUGET_AUTH_TOKEN: ${{secrets.AZURE_DEVOPS_PAT}} # Note, create a secret with this name in Settings | ||||
| - name: Publish the package to Azure Artifacts | ||||
|   run: dotnet nuget push <my project>/bin/Release/*.nupkg | ||||
| ``` | ||||
|  | ||||
| ## Environment Variables to use with dotnet | ||||
|  | ||||
| Some environment variables may be necessary for your particular case or to improve logging. Some examples are listed below, but the full list with complete details can be found here: https://docs.microsoft.com/en-us/dotnet/core/tools/dotnet#environment-variables | ||||
|  | ||||
| - DOTNET_NOLOGO - removes logo and telemetry message from first run of dotnet cli (default: false) | ||||
| - DOTNET_CLI_TELEMETRY_OPTOUT - opt-out of telemetry being sent to Microsoft (default: false) | ||||
| - DOTNET_MULTILEVEL_LOOKUP - configures whether the global install location is used as a fall-back (default: true) | ||||
|  | ||||
| Example usage: | ||||
| ```yaml | ||||
| build: | ||||
|   runs-on: ubuntu-latest | ||||
|   env: | ||||
|     DOTNET_NOLOGO: true | ||||
|   steps: | ||||
|     - uses: actions/checkout@main | ||||
|     - uses: actions/setup-dotnet@v1 | ||||
|       with: | ||||
|         dotnet-version: '3.1.100' # SDK Version to use. | ||||
| ``` | ||||
|  | ||||
| # License | ||||
|  | ||||
| The scripts and documentation in this project are released under the [MIT License](LICENSE) | ||||
|  | ||||
| @ -1,185 +0,0 @@ | ||||
| // Jest Snapshot v1, https://goo.gl/fbAQLP | ||||
|  | ||||
| exports[`authutil tests Existing config not in repo root, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSourceCredentials> | ||||
|     <GPR> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </GPR> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ Azure Artifacts source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSourceCredentials> | ||||
|     <AzureArtifacts> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </AzureArtifacts> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ GPR source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSourceCredentials> | ||||
|     <GPR> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </GPR> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ no GPR sources, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSources> | ||||
|     <add key=\\"Source\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </packageSources> | ||||
|   <packageSourceCredentials> | ||||
|     <Source> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </Source> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ no sources, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSources> | ||||
|     <add key=\\"Source\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </packageSources> | ||||
|   <packageSourceCredentials> | ||||
|     <Source> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </Source> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ only Azure Artifacts source, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSourceCredentials> | ||||
|     <AzureArtifacts> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </AzureArtifacts> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ only GPR source, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSourceCredentials> | ||||
|     <GPR> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </GPR> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests Existing config w/ two GPR sources, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com\\"/> | ||||
|   </config> | ||||
|   <packageSourceCredentials> | ||||
|     <GPR-GitHub> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </GPR-GitHub> | ||||
|     <GPR-Actions> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </GPR-Actions> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests No existing config, sets up a full NuGet.config with URL and other owner/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/otherorg/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSources> | ||||
|     <add key=\\"Source\\" value=\\"https://nuget.pkg.github.com/otherorg/index.json\\"/> | ||||
|   </packageSources> | ||||
|   <packageSourceCredentials> | ||||
|     <Source> | ||||
|       <add key=\\"Username\\" value=\\"otherorg\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </Source> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests No existing config, sets up a full NuGet.config with URL and token for other source 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSources> | ||||
|     <add key=\\"Source\\" value=\\"https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json\\"/> | ||||
|   </packageSources> | ||||
|   <packageSourceCredentials> | ||||
|     <Source> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </Source> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
|  | ||||
| exports[`authutil tests No existing config, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | ||||
| "<?xml version=\\"1.0\\"?> | ||||
| <configuration> | ||||
|   <config> | ||||
|     <add key=\\"defaultPushSource\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </config> | ||||
|   <packageSources> | ||||
|     <add key=\\"Source\\" value=\\"https://nuget.pkg.github.com/OwnerName/index.json\\"/> | ||||
|   </packageSources> | ||||
|   <packageSourceCredentials> | ||||
|     <Source> | ||||
|       <add key=\\"Username\\" value=\\"OwnerName\\"/> | ||||
|       <add key=\\"ClearTextPassword\\" value=\\"TEST_FAKE_AUTH_TOKEN\\"/> | ||||
|     </Source> | ||||
|   </packageSourceCredentials> | ||||
| </configuration>" | ||||
| `; | ||||
| @ -1,340 +0,0 @@ | ||||
| import io = require('@actions/io'); | ||||
| import fs = require('fs'); | ||||
| import path = require('path'); | ||||
|  | ||||
| const fakeSourcesDirForTesting = path.join( | ||||
|   __dirname, | ||||
|   'runner', | ||||
|   path.join( | ||||
|     Math.random() | ||||
|       .toString(36) | ||||
|       .substring(7) | ||||
|   ), | ||||
|   's' | ||||
| ); | ||||
|  | ||||
| const invalidNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?>`; | ||||
|  | ||||
| const emptyNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
| </configuration>`; | ||||
|  | ||||
| const nugetorgNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| const gprnugetorgNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="GPR" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||
|     <add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| const gprNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="GPR" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| const twogprNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="GPR-GitHub" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||
|     <add key="GPR-Actions" value="https://nuget.pkg.github.com/actions/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| const spaceNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="GPR GitHub" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| const azureartifactsNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="AzureArtifacts" value="https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| const azureartifactsnugetorgNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||
| <configuration> | ||||
|   <packageSources> | ||||
|     <add key="AzureArtifacts" value="https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json" protocolVersion="3" /> | ||||
|     <add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" /> | ||||
|   </packageSources> | ||||
| </configuration>`; | ||||
|  | ||||
| // We want a NuGet.config one level above the sources directory, so it doesn't trample a user's NuGet.config but is still picked up by NuGet/dotnet. | ||||
| const nugetConfigFile = path.join(fakeSourcesDirForTesting, '../nuget.config'); | ||||
|  | ||||
| process.env['GITHUB_REPOSITORY'] = 'OwnerName/repo'; | ||||
| import * as auth from '../src/authutil'; | ||||
|  | ||||
| describe('authutil tests', () => { | ||||
|   beforeEach(async () => { | ||||
|     await io.rmRF(fakeSourcesDirForTesting); | ||||
|     await io.mkdirP(fakeSourcesDirForTesting); | ||||
|   }, 30000); | ||||
|  | ||||
|   afterAll(async () => { | ||||
|     await io.rmRF(fakeSourcesDirForTesting); | ||||
|   }, 30000); | ||||
|  | ||||
|   beforeEach(() => { | ||||
|     if (fs.existsSync(nugetConfigFile)) { | ||||
|       fs.unlinkSync(nugetConfigFile); | ||||
|     } | ||||
|     process.env['INPUT_OWNER'] = ''; | ||||
|     process.env['NUGET_AUTH_TOKEN'] = ''; | ||||
|   }); | ||||
|  | ||||
|   it('No existing config, sets up a full NuGet.config with URL and user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('No existing config, auth token environment variable not provided, throws', async () => { | ||||
|     let thrown = false; | ||||
|     try { | ||||
|       await auth.configAuthentication( | ||||
|         'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|         '', | ||||
|         fakeSourcesDirForTesting | ||||
|       ); | ||||
|     } catch { | ||||
|       thrown = true; | ||||
|     } | ||||
|     expect(thrown).toBe(true); | ||||
|   }); | ||||
|  | ||||
|   it('No existing config, sets up a full NuGet.config with URL and other owner/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     process.env['INPUT_OWNER'] = 'otherorg'; | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/otherorg/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config (invalid), tries to parse an invalid NuGet.config and throws', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, invalidNuGetConfig); | ||||
|     let thrown = false; | ||||
|     try { | ||||
|       await auth.configAuthentication( | ||||
|         'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|         '', | ||||
|         fakeSourcesDirForTesting | ||||
|       ); | ||||
|     } catch { | ||||
|       thrown = true; | ||||
|     } | ||||
|     expect(thrown).toBe(true); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ no sources, sets up a full NuGet.config with URL and user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, emptyNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ no GPR sources, sets up a full NuGet.config with URL and user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, nugetorgNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ only GPR source, sets up a partial NuGet.config user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, gprNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ GPR source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, gprnugetorgNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ two GPR sources, sets up a partial NuGet.config user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, twogprNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ spaces in key, throws for now', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, spaceNuGetConfig); | ||||
|     let thrown = false; | ||||
|     try { | ||||
|       await auth.configAuthentication( | ||||
|         'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|         '', | ||||
|         fakeSourcesDirForTesting | ||||
|       ); | ||||
|     } catch { | ||||
|       thrown = true; | ||||
|     } | ||||
|     expect(thrown).toBe(true); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config not in repo root, sets up a partial NuGet.config user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigDirectory: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'subfolder' | ||||
|     ); | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       inputNuGetConfigDirectory, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.mkdirSync(inputNuGetConfigDirectory, {recursive: true}); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, gprNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||
|       'subfolder/nuget.config', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ only Azure Artifacts source, sets up a partial NuGet.config user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, azureartifactsNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('Existing config w/ Azure Artifacts source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     const inputNuGetConfigPath: string = path.join( | ||||
|       fakeSourcesDirForTesting, | ||||
|       'nuget.config' | ||||
|     ); | ||||
|     fs.writeFileSync(inputNuGetConfigPath, azureartifactsnugetorgNuGetConfig); | ||||
|     await auth.configAuthentication( | ||||
|       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
|  | ||||
|   it('No existing config, sets up a full NuGet.config with URL and token for other source', async () => { | ||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||
|     await auth.configAuthentication( | ||||
|       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', | ||||
|       '', | ||||
|       fakeSourcesDirForTesting | ||||
|     ); | ||||
|     expect(fs.existsSync(nugetConfigFile)).toBe(true); | ||||
|     expect( | ||||
|       fs.readFileSync(nugetConfigFile, {encoding: 'utf8'}) | ||||
|     ).toMatchSnapshot(); | ||||
|   }); | ||||
| }); | ||||
| @ -1,23 +0,0 @@ | ||||
| import fs = require('fs'); | ||||
|  | ||||
| describe('csc tests', () => { | ||||
|   it('Valid regular expression', async () => { | ||||
|     var cscFile = require('../.github/csc.json'); | ||||
|     var regex = cscFile['problemMatcher'][0]['pattern'][0]['regexp']; | ||||
|  | ||||
|     console.log(regex); | ||||
|     var re = new RegExp(regex); | ||||
|  | ||||
|     // Ideally we would verify that this | ||||
|     var stringsToMatch = [ | ||||
|       'Program.cs(10,79): error CS1002: ; expected [/Users/zacharyeisinger/Documents/repo/setup-dotnet/__tests__/sample-broken-csproj/sample.csproj]', | ||||
|       "S:\\Msbuild\\src\\Build\\Evaluation\\ExpressionShredder.cs(33,7): error CS1003: Syntax error, ',' expected [S:\\msbuild\\src\\Build\\Microsoft.Build.csproj > Properties:prop]" | ||||
|     ]; | ||||
|  | ||||
|     stringsToMatch.forEach(string => { | ||||
|       var matchStr = string.match(re); | ||||
|       console.log(matchStr); | ||||
|       expect(matchStr).toEqual(expect.anything()); | ||||
|     }); | ||||
|   }, 10000); | ||||
| }); | ||||
| @ -2,81 +2,19 @@ import io = require('@actions/io'); | ||||
| import fs = require('fs'); | ||||
| import os = require('os'); | ||||
| import path = require('path'); | ||||
| import hc = require('@actions/http-client'); | ||||
|  | ||||
| import each from 'jest-each'; | ||||
| import httpClient = require('typed-rest-client/HttpClient'); | ||||
|  | ||||
| const toolDir = path.join(__dirname, 'runner', 'tools'); | ||||
| const tempDir = path.join(__dirname, 'runner', 'temp'); | ||||
|  | ||||
| process.env['RUNNER_TOOL_CACHE'] = toolDir; | ||||
| process.env['RUNNER_TEMP'] = tempDir; | ||||
| import * as setup from '../src/setup-dotnet'; | ||||
| import * as installer from '../src/installer'; | ||||
|  | ||||
| const IS_WINDOWS = process.platform === 'win32'; | ||||
|  | ||||
| describe('version tests', () => { | ||||
|   each(['3.1.999', '3.1.101-preview.3']).test( | ||||
|     "Exact version '%s' should be the same", | ||||
|     vers => { | ||||
|       let versInfo = new installer.DotNetVersionInfo(vers); | ||||
|  | ||||
|       expect(versInfo.isExactVersion()).toBe(true); | ||||
|       expect(versInfo.version()).toBe(vers); | ||||
|     } | ||||
|   ); | ||||
|  | ||||
|   each([ | ||||
|     ['3.1.x', '3.1'], | ||||
|     ['1.1.*', '1.1'], | ||||
|     ['2.0', '2.0'] | ||||
|   ]).test("Generic version '%s' should be '%s'", (vers, resVers) => { | ||||
|     let versInfo = new installer.DotNetVersionInfo(vers); | ||||
|  | ||||
|     expect(versInfo.isExactVersion()).toBe(false); | ||||
|     expect(versInfo.version()).toBe(resVers); | ||||
|   }); | ||||
|  | ||||
|   each([ | ||||
|     '', | ||||
|     '.', | ||||
|     '..', | ||||
|     ' . ', | ||||
|     '. ', | ||||
|     ' .', | ||||
|     ' . . ', | ||||
|     ' .. ', | ||||
|     ' .  ', | ||||
|     '-1.-1', | ||||
|     '-1', | ||||
|     '-1.-1.-1', | ||||
|     '..3', | ||||
|     '1..3', | ||||
|     '1..', | ||||
|     '.2.3', | ||||
|     '.2.x', | ||||
|     '1', | ||||
|     '2.x', | ||||
|     '*.*.1', | ||||
|     '*.1', | ||||
|     '*.', | ||||
|     '1.2.', | ||||
|     '1.2.-abc', | ||||
|     'a.b', | ||||
|     'a.b.c', | ||||
|     'a.b.c-preview', | ||||
|     ' 0 . 1 . 2 ' | ||||
|   ]).test("Malformed version '%s' should throw", vers => { | ||||
|     expect(() => new installer.DotNetVersionInfo(vers)).toThrow(); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| describe('installer tests', () => { | ||||
|   beforeAll(async () => { | ||||
|     process.env.RUNNER_TOOL_CACHE = toolDir; | ||||
|     process.env.DOTNET_INSTALL_DIR = toolDir; | ||||
|     process.env.RUNNER_TEMP = tempDir; | ||||
|     await io.rmRF(toolDir); | ||||
|     await io.rmRF(tempDir); | ||||
|   }); | ||||
| @ -88,74 +26,18 @@ describe('installer tests', () => { | ||||
|     } catch { | ||||
|       console.log('Failed to remove test directories'); | ||||
|     } | ||||
|   }, 30000); | ||||
|  | ||||
|   it('Resolving a normal generic version works', async () => { | ||||
|     const dotnetInstaller = new installer.DotnetCoreInstaller('3.1.x'); | ||||
|     let versInfo = await dotnetInstaller.resolveVersion( | ||||
|       new installer.DotNetVersionInfo('3.1.x') | ||||
|     ); | ||||
|  | ||||
|     expect(versInfo.startsWith('3.1.')); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Resolving a nonexistent generic version fails', async () => { | ||||
|     const dotnetInstaller = new installer.DotnetCoreInstaller('999.1.x'); | ||||
|     try { | ||||
|       await dotnetInstaller.resolveVersion( | ||||
|         new installer.DotNetVersionInfo('999.1.x') | ||||
|       ); | ||||
|       fail(); | ||||
|     } catch { | ||||
|       expect(true); | ||||
|     } | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Resolving a exact stable version works', async () => { | ||||
|     const dotnetInstaller = new installer.DotnetCoreInstaller('3.1.201'); | ||||
|     let versInfo = await dotnetInstaller.resolveVersion( | ||||
|       new installer.DotNetVersionInfo('3.1.201') | ||||
|     ); | ||||
|  | ||||
|     expect(versInfo).toBe('3.1.201'); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Resolving a exact preview version works', async () => { | ||||
|     const dotnetInstaller = new installer.DotnetCoreInstaller( | ||||
|       '5.0.0-preview.6' | ||||
|     ); | ||||
|     let versInfo = await dotnetInstaller.resolveVersion( | ||||
|       new installer.DotNetVersionInfo('5.0.0-preview.6') | ||||
|     ); | ||||
|  | ||||
|     expect(versInfo).toBe('5.0.0-preview.6'); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Acquires version of dotnet if no matching version is installed', async () => { | ||||
|     await getDotnet('3.1.201'); | ||||
|     expect(fs.existsSync(path.join(toolDir, 'sdk', '3.1.201'))).toBe(true); | ||||
|     if (IS_WINDOWS) { | ||||
|       expect(fs.existsSync(path.join(toolDir, 'dotnet.exe'))).toBe(true); | ||||
|     } else { | ||||
|       expect(fs.existsSync(path.join(toolDir, 'dotnet'))).toBe(true); | ||||
|     } | ||||
|   }, 400000); //This needs some time to download on "slower" internet connections | ||||
|     await getDotnet('2.2.104'); | ||||
|     const dotnetDir = path.join(toolDir, 'dncs', '2.2.104', os.arch()); | ||||
|  | ||||
|   it('Acquires version of dotnet from global.json if no matching version is installed', async () => { | ||||
|     const globalJsonPath = path.join(process.cwd(), 'global.json'); | ||||
|     const jsonContents = `{${os.EOL}"sdk": {${os.EOL}"version": "3.1.201"${os.EOL}}${os.EOL}}`; | ||||
|     if (!fs.existsSync(globalJsonPath)) { | ||||
|       fs.writeFileSync(globalJsonPath, jsonContents); | ||||
|     } | ||||
|     await setup.run(); | ||||
|  | ||||
|     expect(fs.existsSync(path.join(toolDir, 'sdk', '3.1.201'))).toBe(true); | ||||
|     expect(fs.existsSync(`${dotnetDir}.complete`)).toBe(true); | ||||
|     if (IS_WINDOWS) { | ||||
|       expect(fs.existsSync(path.join(toolDir, 'dotnet.exe'))).toBe(true); | ||||
|       expect(fs.existsSync(path.join(dotnetDir, 'dotnet.exe'))).toBe(true); | ||||
|     } else { | ||||
|       expect(fs.existsSync(path.join(toolDir, 'dotnet'))).toBe(true); | ||||
|       expect(fs.existsSync(path.join(dotnetDir, 'dotnet'))).toBe(true); | ||||
|     } | ||||
|     fs.unlinkSync(globalJsonPath); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Throws if no location contains correct dotnet version', async () => { | ||||
| @ -166,17 +48,40 @@ describe('installer tests', () => { | ||||
|       thrown = true; | ||||
|     } | ||||
|     expect(thrown).toBe(true); | ||||
|   }, 30000); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Uses version of dotnet installed in cache', async () => { | ||||
|     const dotnetDir: string = path.join(toolDir, 'dncs', '250.0.0', os.arch()); | ||||
|     await io.mkdirP(dotnetDir); | ||||
|     fs.writeFileSync(`${dotnetDir}.complete`, 'hello'); | ||||
|     // This will throw if it doesn't find it in the cache (because no such version exists) | ||||
|     await getDotnet('250.0.0'); | ||||
|     return; | ||||
|   }); | ||||
|  | ||||
|   it('Doesnt use version of dotnet that was only partially installed in cache', async () => { | ||||
|     const dotnetDir: string = path.join(toolDir, 'dncs', '251.0.0', os.arch()); | ||||
|     await io.mkdirP(dotnetDir); | ||||
|     let thrown = false; | ||||
|     try { | ||||
|       // This will throw if it doesn't find it in the cache (because no such version exists) | ||||
|       await getDotnet('251.0.0'); | ||||
|     } catch { | ||||
|       thrown = true; | ||||
|     } | ||||
|     expect(thrown).toBe(true); | ||||
|     return; | ||||
|   }); | ||||
|  | ||||
|   it('Uses an up to date bash download script', async () => { | ||||
|     const httpCallbackClient = new hc.HttpClient('setup-dotnet-test', [], { | ||||
|       allowRetries: true, | ||||
|       maxRetries: 3 | ||||
|     }); | ||||
|     const response: hc.HttpClientResponse = await httpCallbackClient.get( | ||||
|     var httpCallbackClient = new httpClient.HttpClient( | ||||
|       'setup-dotnet-test', | ||||
|       [], | ||||
|       {} | ||||
|     ); | ||||
|     const response: httpClient.HttpClientResponse = await httpCallbackClient.get( | ||||
|       'https://dot.net/v1/dotnet-install.sh' | ||||
|     ); | ||||
|     expect(response.message.statusCode).toBe(200); | ||||
|     const upToDateContents: string = await response.readBody(); | ||||
|     const currentContents: string = fs | ||||
|       .readFileSync( | ||||
| @ -186,17 +91,17 @@ describe('installer tests', () => { | ||||
|     expect(normalizeFileContents(currentContents)).toBe( | ||||
|       normalizeFileContents(upToDateContents) | ||||
|     ); | ||||
|   }, 30000); | ||||
|   }, 100000); | ||||
|  | ||||
|   it('Uses an up to date powershell download script', async () => { | ||||
|     var httpCallbackClient = new hc.HttpClient('setup-dotnet-test', [], { | ||||
|       allowRetries: true, | ||||
|       maxRetries: 3 | ||||
|     }); | ||||
|     const response: hc.HttpClientResponse = await httpCallbackClient.get( | ||||
|     var httpCallbackClient = new httpClient.HttpClient( | ||||
|       'setup-dotnet-test', | ||||
|       [], | ||||
|       {} | ||||
|     ); | ||||
|     const response: httpClient.HttpClientResponse = await httpCallbackClient.get( | ||||
|       'https://dot.net/v1/dotnet-install.ps1' | ||||
|     ); | ||||
|     expect(response.message.statusCode).toBe(200); | ||||
|     const upToDateContents: string = await response.readBody(); | ||||
|     const currentContents: string = fs | ||||
|       .readFileSync( | ||||
| @ -206,7 +111,7 @@ describe('installer tests', () => { | ||||
|     expect(normalizeFileContents(currentContents)).toBe( | ||||
|       normalizeFileContents(upToDateContents) | ||||
|     ); | ||||
|   }, 30000); | ||||
|   }, 100000); | ||||
| }); | ||||
|  | ||||
| function normalizeFileContents(contents: string): string { | ||||
|  | ||||
| @ -1,15 +0,0 @@ | ||||
| using Microsoft.VisualStudio.TestTools.UnitTesting; | ||||
| using System; | ||||
|  | ||||
| namespace sample_csproj | ||||
| { | ||||
|     [TestClass] | ||||
|     public class Program | ||||
|     { | ||||
|         [TestMethod] | ||||
|         public void TestMethod1() | ||||
|         { | ||||
|             Console.WriteLine("Hello, World!"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @ -1,18 +0,0 @@ | ||||
| <Project Sdk="Microsoft.NET.Sdk"> | ||||
|  | ||||
|   <PropertyGroup> | ||||
|     <TargetFrameworks>netcoreapp3.1;netcoreapp2.2</TargetFrameworks> | ||||
|     <RootNamespace>sample_csproj</RootNamespace> | ||||
|  | ||||
|     <IsPackable>false</IsPackable> | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <!-- These packages will be downloaded over the network for testing proxy settings --> | ||||
|     <PackageReference Include="Microsoft.NET.Test.Sdk" Version="16.5.0" /> | ||||
|     <PackageReference Include="MSTest.TestAdapter" Version="2.1.0" /> | ||||
|     <PackageReference Include="MSTest.TestFramework" Version="2.1.0" /> | ||||
|     <PackageReference Include="coverlet.collector" Version="1.2.0" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
| </Project> | ||||
| @ -1,48 +0,0 @@ | ||||
| import io = require('@actions/io'); | ||||
| import fs = require('fs'); | ||||
| import os = require('os'); | ||||
| import path = require('path'); | ||||
|  | ||||
| const toolDir = path.join(__dirname, 'runner', 'tools2'); | ||||
| const tempDir = path.join(__dirname, 'runner', 'temp2'); | ||||
|  | ||||
| import * as setup from '../src/setup-dotnet'; | ||||
|  | ||||
| const IS_WINDOWS = process.platform === 'win32'; | ||||
|  | ||||
| describe('setup-dotnet tests', () => { | ||||
|   beforeAll(async () => { | ||||
|     process.env.RUNNER_TOOL_CACHE = toolDir; | ||||
|     process.env.DOTNET_INSTALL_DIR = toolDir; | ||||
|     process.env.RUNNER_TEMP = tempDir; | ||||
|     await io.rmRF(toolDir); | ||||
|     await io.rmRF(tempDir); | ||||
|   }); | ||||
|  | ||||
|   afterAll(async () => { | ||||
|     try { | ||||
|       await io.rmRF(path.join(process.cwd(), 'global.json')); | ||||
|       await io.rmRF(toolDir); | ||||
|       await io.rmRF(tempDir); | ||||
|     } catch { | ||||
|       console.log('Failed to remove test directories'); | ||||
|     } | ||||
|   }, 30000); | ||||
|  | ||||
|   it('Acquires version of dotnet if no matching version is installed', async () => { | ||||
|     const globalJsonPath = path.join(process.cwd(), 'global.json'); | ||||
|     const jsonContents = `{${os.EOL}"sdk": {${os.EOL}"version": "3.1.201"${os.EOL}}${os.EOL}}`; | ||||
|     if (!fs.existsSync(globalJsonPath)) { | ||||
|       fs.writeFileSync(globalJsonPath, jsonContents); | ||||
|     } | ||||
|     await setup.run(); | ||||
|  | ||||
|     expect(fs.existsSync(path.join(toolDir, 'sdk', '3.1.201'))).toBe(true); | ||||
|     if (IS_WINDOWS) { | ||||
|       expect(fs.existsSync(path.join(toolDir, 'dotnet.exe'))).toBe(true); | ||||
|     } else { | ||||
|       expect(fs.existsSync(path.join(toolDir, 'dotnet'))).toBe(true); | ||||
|     } | ||||
|     fs.unlinkSync(globalJsonPath); | ||||
|   }, 100000); | ||||
| }); | ||||
| @ -1,58 +0,0 @@ | ||||
| if (!$args[0]) | ||||
| { | ||||
|   throw "Must supply dotnet version argument" | ||||
| } | ||||
|  | ||||
| if (-Not (Test-Path "../nuget.config")) | ||||
| { | ||||
|   throw "nuget file not generated correctly" | ||||
| } | ||||
|  | ||||
| $dotnet = Get-Command dotnet | Select-Object -First 1 | ForEach-Object { $_.Path } | ||||
| Write-Host "Found '$dotnet'" | ||||
|  | ||||
| $version = & $dotnet --version | Out-String | ForEach-Object { $_.Trim() } | ||||
| Write-Host "Version $version" | ||||
| if ($version -ne $args[0]) | ||||
| { | ||||
|   Write-Host "PATH='$env:path'" | ||||
|   throw "Unexpected version" | ||||
| } | ||||
|  | ||||
| if ($args[1]) | ||||
| { | ||||
|   # SDKs are listed on multiple lines with the path afterwards in square brackets | ||||
|   $version = & $dotnet --list-sdks | ForEach-Object { $_.SubString(0, $_.IndexOf('[')).Trim() } | ||||
|   Write-Host "Version $version" | ||||
|   if (-not ($version -contains $args[1])) | ||||
|   { | ||||
|     Write-Host "PATH='$env:path'" | ||||
|     throw "Unexpected version" | ||||
|   } | ||||
| } | ||||
|  | ||||
| Write-Host "Building sample csproj" | ||||
| & $dotnet build __tests__/sample-csproj/ --no-cache | ||||
| if ($LASTEXITCODE -ne 0) | ||||
| { | ||||
|   throw "Unexpected exit code $LASTEXITCODE" | ||||
| } | ||||
|  | ||||
| Write-Host "Testing compiled app" | ||||
| $sample_output = "$(dotnet test __tests__/sample-csproj/ --no-build)" | ||||
| Write-Host "Sample output: $sample_output" | ||||
| # For Side-by-Side installs we want to run the tests twice, for a single install the tests will run once | ||||
| if ($args[1]) | ||||
| { | ||||
|   if ($sample_output -notlike "*Test Run Successful.*Test Run Successful.*") | ||||
|   { | ||||
|     throw "Unexpected output" | ||||
|   } | ||||
| } | ||||
| else | ||||
| { | ||||
|   if ($sample_output -notlike "*Test Run Successful.*") | ||||
|   { | ||||
|     throw "Unexpected output" | ||||
|   } | ||||
| } | ||||
| @ -1,44 +0,0 @@ | ||||
| if [ -z "$1" ]; then | ||||
|   echo "Must supply dotnet version argument" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| if [ ! -f "../nuget.config" ]; then | ||||
|   echo "nuget file not generated correctly" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| dotnet_version="$(dotnet --version)" | ||||
| echo "Found dotnet version '$dotnet_version'" | ||||
| if [ -z "$(echo $dotnet_version | grep $1)" ]; then | ||||
|   echo "Unexpected version" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| if [ -n "$2" ]; then | ||||
|   dotnet_version="$(dotnet --list-sdks)" | ||||
|   echo "Found dotnet version '$dotnet_version'" | ||||
|   if [ -z "$(echo $dotnet_version | grep $2)" ]; then | ||||
|     echo "Unexpected version" | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| echo "Building sample csproj" | ||||
| dotnet build __tests__/sample-csproj/ --no-cache || exit 1 | ||||
|  | ||||
| echo "Testing compiled app" | ||||
| sample_output=$(dotnet test __tests__/sample-csproj/ --no-build) | ||||
| echo "Sample output: $sample_output" | ||||
| # For Side-by-Side installs we want to run the tests twice, for a single install the tests will run once | ||||
| if [ -n "$2" ]; then | ||||
|   if [ -z "$(echo $sample_output | grep "Test Run Successful.*Test Run Successful.")" ]; then | ||||
|     echo "Unexpected output" | ||||
|     exit 1 | ||||
|   fi | ||||
| else | ||||
|   if [ -z "$(echo $sample_output | grep "Test Run Successful.")" ]; then | ||||
|     echo "Unexpected output" | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
| @ -1,17 +0,0 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| if [[ "$(git status --porcelain)" != "" ]]; then | ||||
|     echo ---------------------------------------- | ||||
|     echo git status | ||||
|     echo ---------------------------------------- | ||||
|     git status | ||||
|     echo ---------------------------------------- | ||||
|     echo git diff | ||||
|     echo ---------------------------------------- | ||||
|     git diff | ||||
|     echo ---------------------------------------- | ||||
|     echo Troubleshooting | ||||
|     echo ---------------------------------------- | ||||
|     echo "::error::Unstaged changes detected. Locally try running: git clean -ffdx && npm ci && npm run pre-checkin" | ||||
|     exit 1 | ||||
| fi | ||||
							
								
								
									
										23
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								action.yml
									
									
									
									
									
								
							| @ -1,18 +1,13 @@ | ||||
| name: 'Setup .NET Core SDK' | ||||
| description: 'Set up a specific version of the .NET Core CLI in the PATH and set up authentication to a private NuGet repository' | ||||
| name: 'Setup Dotnet environment' | ||||
| description: 'Setup a Dotnet environment and add it to the PATH, additionally providing proxy support' | ||||
| author: 'GitHub' | ||||
| branding: | ||||
|   icon: play | ||||
|   color: green | ||||
| inputs: | ||||
| inputs:  | ||||
|   dotnet-version: | ||||
|     description: 'SDK version to use. Examples: 2.2.104, 3.1, 3.1.x' | ||||
|   source-url: | ||||
|     description: 'Optional package source for which to set up authentication. Will consult any existing NuGet.config in the root of the repo and provide a temporary NuGet.config using the NUGET_AUTH_TOKEN environment variable as a ClearTextPassword' | ||||
|   owner: | ||||
|     description: 'Optional OWNER for using packages from GitHub Package Registry organizations/users other than the current repository''s owner. Only used if a GPR URL is also provided in source-url' | ||||
|   config-file: | ||||
|     description: 'Optional NuGet.config location, if your NuGet.config isn''t located in the root of the repo.' | ||||
|     description: 'SDK version to use. E.g. 2.2.104' | ||||
| # Deprecated option, do not use. Will not be supported after October 1, 2019 | ||||
|   version: | ||||
|     description: 'Deprecated. Use dotnet-version instead. Will not be supported after October 1, 2019' | ||||
|     deprecationMessage: 'The version property will not be supported after October 1, 2019. Use dotnet-version instead' | ||||
| runs: | ||||
|   using: 'node12' | ||||
|   main: 'dist/index.js' | ||||
|   main: 'lib/setup-dotnet.js' | ||||
|  | ||||
							
								
								
									
										21987
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										21987
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,24 +1,17 @@ | ||||
| # Contributors | ||||
|  | ||||
| Thank you for contributing! This action is targetted around setting up the dotnet cli and related sdks for GitHub actions. As part of that we use proxy settings (for self-hosted runners) and set-up nuget authentication for private feeds. | ||||
|  | ||||
| If you would like to contribute there are a few things to consider: | ||||
| # Checkin | ||||
|  | ||||
| ## Commands to use | ||||
| - Do checkin source (src) | ||||
| - Do checkin build output (lib) | ||||
| - Do checkin runtime node_modules | ||||
| - Do not checkin  | ||||
|  | ||||
| - npm run build - Compiles the action into a single js file at dist/index.js (Please check in the changes made by this command) | ||||
| - npm run test - Runs all tests under __tests__ | ||||
| - npm run format - Runs formatting required to pass the lint test (Please check in the changes made by this command) | ||||
| - npm run update-installers - Updates the install-dotnet scripts in externals (Please check in the changes made by this command) | ||||
| # Adding a dev dependency | ||||
|  | ||||
| ## To check in or not to check in | ||||
| Remember to update .gitignore.   | ||||
|  | ||||
| - Do check in source (src) | ||||
| - Do check in index file (dist) | ||||
| - Do check in updates to install-dotnet scripts (externals) | ||||
| - Do not check in build output (lib) | ||||
| - Do not check in runtime (node_modules) | ||||
| # Updating toolkit dependency | ||||
|  | ||||
| ## Writing tests | ||||
|  | ||||
| With any contribution please take time to consider how this can be tested to maintain high quality. Current tests can be found in the folder __tests__ for examples. | ||||
| Until released publically, update tgz packages in toolkit | ||||
							
								
								
									
										192
									
								
								externals/get-os-distro.sh
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										192
									
								
								externals/get-os-distro.sh
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,192 @@ | ||||
| #!/usr/bin/env bash | ||||
| # Copyright (c) .NET Foundation and contributors. All rights reserved. | ||||
| # Licensed under the MIT license. See LICENSE file in the project root for full license information. | ||||
| # | ||||
|  | ||||
| # Stop script on NZEC | ||||
| set -e | ||||
| # Stop script if unbound variable found (use ${var:-} if intentional) | ||||
| set -u | ||||
| # By default cmd1 | cmd2 returns exit code of cmd2 regardless of cmd1 success | ||||
| # This is causing it to fail | ||||
| set -o pipefail | ||||
|  | ||||
| # Use in the the functions: eval $invocation | ||||
| invocation='say_verbose "Calling: ${yellow:-}${FUNCNAME[0]} ${green:-}$*${normal:-}"' | ||||
|  | ||||
| # standard output may be used as a return value in the functions | ||||
| # we need a way to write text on the screen in the functions so that | ||||
| # it won't interfere with the return value. | ||||
| # Exposing stream 3 as a pipe to standard output of the script itself | ||||
| exec 3>&1 | ||||
|  | ||||
| say_err() { | ||||
|     printf "%b\n" "get-os-distro: Error: $1" >&2 | ||||
| } | ||||
|  | ||||
| # This platform list is finite - if the SDK/Runtime has supported Linux distribution-specific assets, | ||||
| #   then and only then should the Linux distribution appear in this list. | ||||
| # Adding a Linux distribution to this list does not imply distribution-specific support. | ||||
| get_legacy_os_name_from_platform() { | ||||
|  | ||||
|     platform="$1" | ||||
|     case "$platform" in | ||||
|         "centos.7") | ||||
|             echo "centos" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "debian.8") | ||||
|             echo "debian" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "fedora.23") | ||||
|             echo "fedora.23" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "fedora.27") | ||||
|             echo "fedora.27" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "fedora.24") | ||||
|             echo "fedora.24" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "opensuse.13.2") | ||||
|             echo "opensuse.13.2" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "opensuse.42.1") | ||||
|             echo "opensuse.42.1" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "opensuse.42.3") | ||||
|             echo "opensuse.42.3" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "rhel.7"*) | ||||
|             echo "rhel" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "ubuntu.14.04") | ||||
|             echo "ubuntu" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "ubuntu.16.04") | ||||
|             echo "ubuntu.16.04" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "ubuntu.16.10") | ||||
|             echo "ubuntu.16.10" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "ubuntu.18.04") | ||||
|             echo "ubuntu.18.04" | ||||
|             return 0 | ||||
|             ;; | ||||
|         "alpine.3.4.3") | ||||
|             echo "alpine" | ||||
|             return 0 | ||||
|             ;; | ||||
|     esac | ||||
|     return 1 | ||||
| } | ||||
|  | ||||
| get_linux_platform_name() { | ||||
|  | ||||
|     if [ -e /etc/os-release ]; then | ||||
|         . /etc/os-release | ||||
|         echo "$ID.$VERSION_ID" | ||||
|         return 0 | ||||
|     elif [ -e /etc/redhat-release ]; then | ||||
|         local redhatRelease=$(</etc/redhat-release) | ||||
|         if [[ $redhatRelease == "CentOS release 6."* || $redhatRelease == "Red Hat Enterprise Linux Server release 6."* ]]; then | ||||
|             echo "rhel.6" | ||||
|             return 0 | ||||
|         fi | ||||
|     fi | ||||
|  | ||||
|     say_err "Linux specific platform name and version could not be detected: UName = $uname" | ||||
|     return 1 | ||||
| } | ||||
|  | ||||
| get_current_os_name() { | ||||
|  | ||||
|     local uname=$(uname) | ||||
|     if [ "$uname" = "Darwin" ]; then | ||||
|         echo "mac" | ||||
|         return 0 | ||||
|     elif [ "$uname" = "Linux" ]; then | ||||
|         local linux_platform_name | ||||
|         linux_platform_name="$(get_linux_platform_name)" || { echo "linux" && return 0 ; } | ||||
|  | ||||
|         if [[ $linux_platform_name == "rhel.6" ]]; then | ||||
|             echo "$linux_platform_name" | ||||
|             return 0 | ||||
|         elif [[ $linux_platform_name == alpine* ]]; then | ||||
|             echo "linux-musl" | ||||
|             return 0 | ||||
|         else | ||||
|             echo "linux" | ||||
|             return 0 | ||||
|         fi | ||||
|     fi | ||||
|  | ||||
|     say_err "OS name could not be detected: UName = $uname" | ||||
|     return 1 | ||||
| } | ||||
|  | ||||
| get_legacy_os_name() { | ||||
|  | ||||
|     local uname=$(uname) | ||||
|     if [ "$uname" = "Darwin" ]; then | ||||
|         echo "mac" | ||||
|         return 0 | ||||
|     else | ||||
|         if [ -e /etc/os-release ]; then | ||||
|             . /etc/os-release | ||||
|             os=$(get_legacy_os_name_from_platform "$ID.$VERSION_ID" || echo "") | ||||
|             if [ -n "$os" ]; then | ||||
|                 echo "$os" | ||||
|                 return 0 | ||||
|             fi | ||||
|         fi | ||||
|     fi | ||||
|  | ||||
|     say_err "Distribution specific OS name and version could not be detected: UName = $uname" | ||||
|     return 1 | ||||
| } | ||||
|  | ||||
| get_machine_architecture() { | ||||
|  | ||||
|     if command -v uname > /dev/null; then | ||||
|         CPUName=$(uname -m) | ||||
|         case $CPUName in | ||||
|         armv7l) | ||||
|             echo "arm" | ||||
|             return 0 | ||||
|             ;; | ||||
|         aarch64) | ||||
|             echo "arm64" | ||||
|             return 0 | ||||
|             ;; | ||||
|         esac | ||||
|     fi | ||||
|  | ||||
|     # Always default to 'x64' | ||||
|     echo "x64" | ||||
|     return 0 | ||||
| } | ||||
|  | ||||
| osName=$(get_current_os_name || echo "") | ||||
| legacyOsName=$(get_legacy_os_name || echo "") | ||||
| arch=$(get_machine_architecture || echo "") | ||||
|  | ||||
| primaryName="$osName-$arch" | ||||
| legacyName="$legacyOsName" | ||||
|  | ||||
| echo "Primary:$primaryName" | ||||
| echo "Legacy:$legacyName" | ||||
|  | ||||
| if [ -z "$osName" ] && [ -z "$legacyOsName" ];then | ||||
|     exit 1 | ||||
| fi | ||||
							
								
								
									
										18
									
								
								externals/get-os-platform.ps1
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								externals/get-os-platform.ps1
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | ||||
| function Get-Machine-Architecture() | ||||
| { | ||||
|     # possible values: AMD64, IA64, x86 | ||||
|     return $ENV:PROCESSOR_ARCHITECTURE | ||||
| } | ||||
|  | ||||
| function Get-CLIArchitecture-From-Architecture([string]$Architecture) | ||||
| { | ||||
|     switch ($Architecture.ToLower()) | ||||
|     { | ||||
|         { ($_ -eq "amd64") -or ($_ -eq "x64") } { return "x64" } | ||||
|         { $_ -eq "x86" } { return "x86" } | ||||
|         default { throw "Architecture not supported. If you think this is a bug, please report it at https://github.com/dotnet/cli/issues" } | ||||
|     } | ||||
| } | ||||
|  | ||||
| $CLIArchitecture = Get-CLIArchitecture-From-Architecture $(Get-Machine-Architecture) | ||||
| Write-Output "Primary:win-$CLIArchitecture" | ||||
							
								
								
									
										1549
									
								
								externals/install-dotnet.ps1
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1549
									
								
								externals/install-dotnet.ps1
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										216
									
								
								externals/install-dotnet.sh
									
									
									
									
										vendored
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										216
									
								
								externals/install-dotnet.sh
									
									
									
									
										vendored
									
									
										
										
										Executable file → Normal file
									
								
							| @ -144,11 +144,11 @@ get_linux_platform_name() { | ||||
|     else | ||||
|         if [ -e /etc/os-release ]; then | ||||
|             . /etc/os-release | ||||
|             echo "$ID${VERSION_ID:+.${VERSION_ID}}" | ||||
|             echo "$ID.$VERSION_ID" | ||||
|             return 0 | ||||
|         elif [ -e /etc/redhat-release ]; then | ||||
|             local redhatRelease=$(</etc/redhat-release) | ||||
|             if [[ $redhatRelease == "CentOS release 6."* || $redhatRelease == "Red Hat Enterprise Linux "*" release 6."* ]]; then | ||||
|             if [[ $redhatRelease == "CentOS release 6."* || $redhatRelease == "Red Hat Enterprise Linux Server release 6."* ]]; then | ||||
|                 echo "rhel.6" | ||||
|                 return 0 | ||||
|             fi | ||||
| @ -159,10 +159,6 @@ get_linux_platform_name() { | ||||
|     return 1 | ||||
| } | ||||
|  | ||||
| is_musl_based_distro() { | ||||
|     (ldd --version 2>&1 || true) | grep -q musl | ||||
| } | ||||
|  | ||||
| get_current_os_name() { | ||||
|     eval $invocation | ||||
|  | ||||
| @ -172,15 +168,15 @@ get_current_os_name() { | ||||
|         return 0 | ||||
|     elif [ "$uname" = "FreeBSD" ]; then | ||||
|         echo "freebsd" | ||||
|         return 0 | ||||
|         return 0         | ||||
|     elif [ "$uname" = "Linux" ]; then | ||||
|         local linux_platform_name | ||||
|         linux_platform_name="$(get_linux_platform_name)" || { echo "linux" && return 0 ; } | ||||
|  | ||||
|         if [ "$linux_platform_name" = "rhel.6" ]; then | ||||
|         if [[ $linux_platform_name == "rhel.6" ]]; then | ||||
|             echo $linux_platform_name | ||||
|             return 0 | ||||
|         elif is_musl_based_distro; then | ||||
|         elif [[ $linux_platform_name == alpine* ]]; then | ||||
|             echo "linux-musl" | ||||
|             return 0 | ||||
|         else | ||||
| @ -206,7 +202,7 @@ get_legacy_os_name() { | ||||
|     else | ||||
|         if [ -e /etc/os-release ]; then | ||||
|             . /etc/os-release | ||||
|             os=$(get_legacy_os_name_from_platform "$ID${VERSION_ID:+.${VERSION_ID}}" || echo "") | ||||
|             os=$(get_legacy_os_name_from_platform "$ID.$VERSION_ID" || echo "") | ||||
|             if [ -n "$os" ]; then | ||||
|                 echo "$os" | ||||
|                 return 0 | ||||
| @ -249,29 +245,20 @@ check_pre_reqs() { | ||||
|     fi | ||||
|  | ||||
|     if [ "$(uname)" = "Linux" ]; then | ||||
|         if is_musl_based_distro; then | ||||
|             if ! command -v scanelf > /dev/null; then | ||||
|                 say_warning "scanelf not found, please install pax-utils package." | ||||
|                 return 0 | ||||
|             fi | ||||
|             LDCONFIG_COMMAND="scanelf --ldpath -BF '%f'" | ||||
|             [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep libintl)" ] && say_warning "Unable to locate libintl. Probable prerequisite missing; install libintl (or gettext)." | ||||
|         if [ ! -x "$(command -v ldconfig)" ]; then | ||||
|             echo "ldconfig is not in PATH, trying /sbin/ldconfig." | ||||
|             LDCONFIG_COMMAND="/sbin/ldconfig" | ||||
|         else | ||||
|             if [ ! -x "$(command -v ldconfig)" ]; then | ||||
|                 say_verbose "ldconfig is not in PATH, trying /sbin/ldconfig." | ||||
|                 LDCONFIG_COMMAND="/sbin/ldconfig" | ||||
|             else | ||||
|                 LDCONFIG_COMMAND="ldconfig" | ||||
|             fi | ||||
|             local librarypath=${LD_LIBRARY_PATH:-} | ||||
|             LDCONFIG_COMMAND="$LDCONFIG_COMMAND -NXv ${librarypath//:/ }" | ||||
|             LDCONFIG_COMMAND="ldconfig" | ||||
|         fi | ||||
|  | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep zlib)" ] && say_warning "Unable to locate zlib. Probable prerequisite missing; install zlib." | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep ssl)" ] && say_warning "Unable to locate libssl. Probable prerequisite missing; install libssl." | ||||
|         local librarypath=${LD_LIBRARY_PATH:-} | ||||
|         LDCONFIG_COMMAND="$LDCONFIG_COMMAND -NXv ${librarypath//:/ }" | ||||
|  | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep libunwind)" ] && say_warning "Unable to locate libunwind. Probable prerequisite missing; install libunwind." | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep libssl)" ] && say_warning "Unable to locate libssl. Probable prerequisite missing; install libssl." | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep libicu)" ] && say_warning "Unable to locate libicu. Probable prerequisite missing; install libicu." | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep lttng)" ] && say_warning "Unable to locate liblttng. Probable prerequisite missing; install libcurl." | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep libcurl)" ] && say_warning "Unable to locate libcurl. Probable prerequisite missing; install libcurl." | ||||
|         [ -z "$($LDCONFIG_COMMAND 2>/dev/null | grep -F libcurl.so)" ] && say_warning "Unable to locate libcurl. Probable prerequisite missing; install libcurl." | ||||
|     fi | ||||
|  | ||||
|     return 0 | ||||
| @ -373,7 +360,7 @@ get_normalized_architecture_from_architecture() { | ||||
|             ;; | ||||
|     esac | ||||
|  | ||||
|     say_err "Architecture \`$architecture\` not supported. If you think this is a bug, report it at https://github.com/dotnet/sdk/issues" | ||||
|     say_err "Architecture \`$architecture\` not supported. If you think this is a bug, report it at https://github.com/dotnet/cli/issues" | ||||
|     return 1 | ||||
| } | ||||
|  | ||||
| @ -448,53 +435,11 @@ get_latest_version_info() { | ||||
|     return $? | ||||
| } | ||||
|  | ||||
| # args: | ||||
| # json_file - $1 | ||||
| parse_jsonfile_for_version() { | ||||
|     eval $invocation | ||||
|  | ||||
|     local json_file="$1" | ||||
|     if [ ! -f "$json_file" ]; then | ||||
|         say_err "Unable to find \`$json_file\`" | ||||
|         return 1 | ||||
|     fi | ||||
|  | ||||
|     sdk_section=$(cat $json_file | awk '/"sdk"/,/}/') | ||||
|     if [ -z "$sdk_section" ]; then | ||||
|         say_err "Unable to parse the SDK node in \`$json_file\`" | ||||
|         return 1 | ||||
|     fi | ||||
|  | ||||
|     sdk_list=$(echo $sdk_section | awk -F"[{}]" '{print $2}') | ||||
|     sdk_list=${sdk_list//[\" ]/} | ||||
|     sdk_list=${sdk_list//,/$'\n'} | ||||
|     sdk_list="$(echo -e "${sdk_list}" | tr -d '[[:space:]]')" | ||||
|  | ||||
|     local version_info="" | ||||
|     while read -r line; do | ||||
|       IFS=: | ||||
|       while read -r key value; do | ||||
|         if [[ "$key" == "version" ]]; then | ||||
|           version_info=$value | ||||
|         fi | ||||
|       done <<< "$line" | ||||
|     done <<< "$sdk_list" | ||||
|     if [ -z "$version_info" ]; then | ||||
|         say_err "Unable to find the SDK:version node in \`$json_file\`" | ||||
|         return 1 | ||||
|     fi | ||||
|  | ||||
|     unset IFS; | ||||
|     echo "$version_info" | ||||
|     return 0 | ||||
| } | ||||
|  | ||||
| # args: | ||||
| # azure_feed - $1 | ||||
| # channel - $2 | ||||
| # normalized_architecture - $3 | ||||
| # version - $4 | ||||
| # json_file - $5 | ||||
| get_specific_version_from_version() { | ||||
|     eval $invocation | ||||
|  | ||||
| @ -502,35 +447,27 @@ get_specific_version_from_version() { | ||||
|     local channel="$2" | ||||
|     local normalized_architecture="$3" | ||||
|     local version="$(to_lowercase "$4")" | ||||
|     local json_file="$5" | ||||
|  | ||||
|     if [ -z "$json_file" ]; then | ||||
|         case "$version" in | ||||
|             latest) | ||||
|                 local version_info | ||||
|                 version_info="$(get_latest_version_info "$azure_feed" "$channel" "$normalized_architecture" false)" || return 1 | ||||
|                 say_verbose "get_specific_version_from_version: version_info=$version_info" | ||||
|                 echo "$version_info" | get_version_from_version_info | ||||
|                 return 0 | ||||
|                 ;; | ||||
|             coherent) | ||||
|                 local version_info | ||||
|                 version_info="$(get_latest_version_info "$azure_feed" "$channel" "$normalized_architecture" true)" || return 1 | ||||
|                 say_verbose "get_specific_version_from_version: version_info=$version_info" | ||||
|                 echo "$version_info" | get_version_from_version_info | ||||
|                 return 0 | ||||
|                 ;; | ||||
|             *) | ||||
|                 echo "$version" | ||||
|                 return 0 | ||||
|                 ;; | ||||
|         esac | ||||
|     else | ||||
|         local version_info | ||||
|         version_info="$(parse_jsonfile_for_version "$json_file")" || return 1 | ||||
|         echo "$version_info" | ||||
|         return 0 | ||||
|     fi | ||||
|     case "$version" in | ||||
|         latest) | ||||
|             local version_info | ||||
|             version_info="$(get_latest_version_info "$azure_feed" "$channel" "$normalized_architecture" false)" || return 1 | ||||
|             say_verbose "get_specific_version_from_version: version_info=$version_info" | ||||
|             echo "$version_info" | get_version_from_version_info | ||||
|             return 0 | ||||
|             ;; | ||||
|         coherent) | ||||
|             local version_info | ||||
|             version_info="$(get_latest_version_info "$azure_feed" "$channel" "$normalized_architecture" true)" || return 1 | ||||
|             say_verbose "get_specific_version_from_version: version_info=$version_info" | ||||
|             echo "$version_info" | get_version_from_version_info | ||||
|             return 0 | ||||
|             ;; | ||||
|         *) | ||||
|             echo "$version" | ||||
|             return 0 | ||||
|             ;; | ||||
|     esac | ||||
| } | ||||
|  | ||||
| # args: | ||||
| @ -621,6 +558,24 @@ resolve_installation_path() { | ||||
|     return 0 | ||||
| } | ||||
|  | ||||
| # args: | ||||
| # install_root - $1 | ||||
| get_installed_version_info() { | ||||
|     eval $invocation | ||||
|  | ||||
|     local install_root="$1" | ||||
|     local version_file="$(combine_paths "$install_root" "$local_version_file_relative_path")" | ||||
|     say_verbose "Local version file: $version_file" | ||||
|     if [ ! -z "$version_file" ] | [ -r "$version_file" ]; then | ||||
|         local version_info="$(cat "$version_file")" | ||||
|         echo "$version_info" | ||||
|         return 0 | ||||
|     fi | ||||
|  | ||||
|     say_verbose "Local version file not found." | ||||
|     return 0 | ||||
| } | ||||
|  | ||||
| # args: | ||||
| # relative_or_absolute_path - $1 | ||||
| get_absolute_path() { | ||||
| @ -645,7 +600,7 @@ copy_files_or_dirs_from_list() { | ||||
|     local osname="$(get_current_os_name)" | ||||
|     local override_switch=$( | ||||
|         if [ "$override" = false ]; then | ||||
|             if [ "$osname" = "linux-musl" ]; then | ||||
|             if [[ "$osname" == "linux-musl" ]]; then | ||||
|                 printf -- "-u"; | ||||
|             else | ||||
|                 printf -- "-n"; | ||||
| @ -657,9 +612,6 @@ copy_files_or_dirs_from_list() { | ||||
|         local target="$out_path/$path" | ||||
|         if [ "$override" = true ] || (! ([ -d "$target" ] || [ -e "$target" ])); then | ||||
|             mkdir -p "$out_path/$(dirname "$path")" | ||||
|             if [ -d "$target" ]; then | ||||
|                 rm -rf "$target" | ||||
|             fi | ||||
|             cp -R $override_switch "$root_path/$path" "$target" | ||||
|         fi | ||||
|     done | ||||
| @ -728,12 +680,11 @@ downloadcurl() { | ||||
|     # Append feed_credential as late as possible before calling curl to avoid logging feed_credential | ||||
|     remote_path="${remote_path}${feed_credential}" | ||||
|  | ||||
|     local curl_options="--retry 20 --retry-delay 2 --connect-timeout 15 -sSL -f --create-dirs " | ||||
|     local failed=false | ||||
|     if [ -z "$out_path" ]; then | ||||
|         curl $curl_options "$remote_path" || failed=true | ||||
|         curl --retry 10 -sSL -f --create-dirs "$remote_path" || failed=true | ||||
|     else | ||||
|         curl $curl_options -o "$out_path" "$remote_path" || failed=true | ||||
|         curl --retry 10 -sSL -f --create-dirs -o "$out_path" "$remote_path" || failed=true | ||||
|     fi | ||||
|     if [ "$failed" = true ]; then | ||||
|         say_verbose "Curl download failed" | ||||
| @ -749,12 +700,12 @@ downloadwget() { | ||||
|  | ||||
|     # Append feed_credential as late as possible before calling wget to avoid logging feed_credential | ||||
|     remote_path="${remote_path}${feed_credential}" | ||||
|     local wget_options="--tries 20 --waitretry 2 --connect-timeout 15 " | ||||
|  | ||||
|     local failed=false | ||||
|     if [ -z "$out_path" ]; then | ||||
|         wget -q $wget_options -O - "$remote_path" || failed=true | ||||
|         wget -q --tries 10 -O - "$remote_path" || failed=true | ||||
|     else | ||||
|         wget $wget_options -O "$out_path" "$remote_path" || failed=true | ||||
|         wget --tries 10 -O "$out_path" "$remote_path" || failed=true | ||||
|     fi | ||||
|     if [ "$failed" = true ]; then | ||||
|         say_verbose "Wget download failed" | ||||
| @ -770,7 +721,7 @@ calculate_vars() { | ||||
|     normalized_architecture="$(get_normalized_architecture_from_architecture "$architecture")" | ||||
|     say_verbose "normalized_architecture=$normalized_architecture" | ||||
|  | ||||
|     specific_version="$(get_specific_version_from_version "$azure_feed" "$channel" "$normalized_architecture" "$version" "$json_file")" | ||||
|     specific_version="$(get_specific_version_from_version "$azure_feed" "$channel" "$normalized_architecture" "$version")" | ||||
|     say_verbose "specific_version=$specific_version" | ||||
|     if [ -z "$specific_version" ]; then | ||||
|         say_err "Could not resolve version information." | ||||
| @ -855,27 +806,13 @@ install_dotnet() { | ||||
|     say "Extracting zip from $download_link" | ||||
|     extract_dotnet_package "$zip_path" "$install_root" | ||||
|  | ||||
|     #  Check if the SDK version is installed; if not, fail the installation. | ||||
|     # if the version contains "RTM" or "servicing"; check if a 'release-type' SDK version is installed. | ||||
|     if [[ $specific_version == *"rtm"* || $specific_version == *"servicing"* ]]; then | ||||
|         IFS='-' | ||||
|         read -ra verArr <<< "$specific_version" | ||||
|         release_version="${verArr[0]}" | ||||
|         unset IFS; | ||||
|         say_verbose "Checking installation: version = $release_version" | ||||
|         if is_dotnet_package_installed "$install_root" "$asset_relative_path" "$release_version"; then | ||||
|             return 0 | ||||
|         fi | ||||
|     #  Check if the SDK version is now installed; if not, fail the installation. | ||||
|     if ! is_dotnet_package_installed "$install_root" "$asset_relative_path" "$specific_version"; then | ||||
|         say_err "\`$asset_name\` with version = $specific_version failed to install with an unknown error." | ||||
|         return 1 | ||||
|     fi | ||||
|  | ||||
|     #  Check if the standard SDK version is installed. | ||||
|     say_verbose "Checking installation: version = $specific_version" | ||||
|     if is_dotnet_package_installed "$install_root" "$asset_relative_path" "$specific_version"; then | ||||
|         return 0 | ||||
|     fi | ||||
|  | ||||
|     say_err "\`$asset_name\` with version = $specific_version failed to install with an unknown error." | ||||
|     return 1 | ||||
|     return 0 | ||||
| } | ||||
|  | ||||
| args=("$@") | ||||
| @ -886,7 +823,6 @@ temporary_file_template="${TMPDIR:-/tmp}/dotnet.XXXXXXXXX" | ||||
|  | ||||
| channel="LTS" | ||||
| version="Latest" | ||||
| json_file="" | ||||
| install_dir="<auto>" | ||||
| architecture="<auto>" | ||||
| dry_run=false | ||||
| @ -932,9 +868,6 @@ do | ||||
|             runtime="$1" | ||||
|             if [[ "$runtime" != "dotnet" ]] && [[ "$runtime" != "aspnetcore" ]]; then | ||||
|                 say_err "Unsupported value for --runtime: '$1'. Valid values are 'dotnet' and 'aspnetcore'." | ||||
|                 if [[ "$runtime" == "windowsdesktop" ]]; then | ||||
|                     say_err "WindowsDesktop archives are manufactured for Windows platforms only." | ||||
|                 fi | ||||
|                 exit 1 | ||||
|             fi | ||||
|             ;; | ||||
| @ -973,10 +906,6 @@ do | ||||
|             runtime_id="$1" | ||||
|             non_dynamic_parameters+=" $name "\""$1"\""" | ||||
|             ;; | ||||
|         --jsonfile|-[Jj][Ss]on[Ff]ile) | ||||
|             shift | ||||
|             json_file="$1" | ||||
|             ;; | ||||
|         --skip-non-versioned-files|-[Ss]kip[Nn]on[Vv]ersioned[Ff]iles) | ||||
|             override_non_versioned_files=false | ||||
|             non_dynamic_parameters+=" $name" | ||||
| @ -1018,25 +947,22 @@ do | ||||
|             echo "          Possible values:" | ||||
|             echo "          - dotnet     - the Microsoft.NETCore.App shared runtime" | ||||
|             echo "          - aspnetcore - the Microsoft.AspNetCore.App shared runtime" | ||||
|             echo "  --skip-non-versioned-files         Skips non-versioned files if they already exist, such as the dotnet executable." | ||||
|             echo "      -SkipNonVersionedFiles" | ||||
|             echo "  --dry-run,-DryRun                  Do not perform installation. Display download link." | ||||
|             echo "  --no-path, -NoPath                 Do not set PATH for the current process." | ||||
|             echo "  --verbose,-Verbose                 Display diagnostics information." | ||||
|             echo "  --azure-feed,-AzureFeed            Azure feed location. Defaults to $azure_feed, This parameter typically is not changed by the user." | ||||
|             echo "  --uncached-feed,-UncachedFeed      Uncached feed location. This parameter typically is not changed by the user." | ||||
|             echo "  --feed-credential,-FeedCredential  Azure feed shared access token. This parameter typically is not specified." | ||||
|             echo "  --skip-non-versioned-files         Skips non-versioned files if they already exist, such as the dotnet executable." | ||||
|             echo "      -SkipNonVersionedFiles" | ||||
|             echo "  --no-cdn,-NoCdn                    Disable downloading from the Azure CDN, and use the uncached feed directly." | ||||
|             echo "  --jsonfile <JSONFILE>              Determines the SDK version from a user specified global.json file." | ||||
|             echo "                                     Note: global.json must have a value for 'SDK:Version'" | ||||
|             echo "  --feed-credential,-FeedCredential  Azure feed shared access token. This parameter typically is not specified." | ||||
|             echo "  --runtime-id                       Installs the .NET Tools for the given platform (use linux-x64 for portable linux)." | ||||
|             echo "      -RuntimeId" | ||||
|             echo "  -?,--?,-h,--help,-Help             Shows this help message" | ||||
|             echo "" | ||||
|             echo "Obsolete parameters:" | ||||
|             echo "  --shared-runtime                   The recommended alternative is '--runtime dotnet'." | ||||
|             echo "                                     This parameter is obsolete and may be removed in a future version of this script." | ||||
|             echo "                                     Installs just the shared runtime bits, not the entire SDK." | ||||
|             echo "      -SharedRuntime                 Installs just the shared runtime bits, not the entire SDK." | ||||
|             echo "" | ||||
|             echo "Install Location:" | ||||
|             echo "  Location is chosen in following order:" | ||||
|  | ||||
							
								
								
									
										309
									
								
								lib/installer.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										309
									
								
								lib/installer.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,309 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| // Load tempDirectory before it gets wiped by tool-cache | ||||
| let tempDirectory = process.env['RUNNER_TEMPDIRECTORY'] || ''; | ||||
| const core = __importStar(require("@actions/core")); | ||||
| const exec = __importStar(require("@actions/exec")); | ||||
| const io = __importStar(require("@actions/io")); | ||||
| const tc = __importStar(require("@actions/tool-cache")); | ||||
| const httpClient = require("typed-rest-client/HttpClient"); | ||||
| const fs_1 = require("fs"); | ||||
| const os = __importStar(require("os")); | ||||
| const path = __importStar(require("path")); | ||||
| const semver = __importStar(require("semver")); | ||||
| const util = __importStar(require("util")); | ||||
| const IS_WINDOWS = process.platform === 'win32'; | ||||
| if (!tempDirectory) { | ||||
|     let baseLocation; | ||||
|     if (IS_WINDOWS) { | ||||
|         // On windows use the USERPROFILE env variable | ||||
|         baseLocation = process.env['USERPROFILE'] || 'C:\\'; | ||||
|     } | ||||
|     else { | ||||
|         if (process.platform === 'darwin') { | ||||
|             baseLocation = '/Users'; | ||||
|         } | ||||
|         else { | ||||
|             baseLocation = '/home'; | ||||
|         } | ||||
|     } | ||||
|     tempDirectory = path.join(baseLocation, 'actions', 'temp'); | ||||
| } | ||||
| class DotnetCoreInstaller { | ||||
|     constructor(version) { | ||||
|         if (semver.valid(semver.clean(version) || '') == null) { | ||||
|             throw 'Implicit version not permitted'; | ||||
|         } | ||||
|         this.version = version; | ||||
|         this.cachedToolName = 'dncs'; | ||||
|         this.arch = 'x64'; | ||||
|     } | ||||
|     installDotnet() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             // Check cache | ||||
|             let toolPath; | ||||
|             let osSuffixes = yield this.detectMachineOS(); | ||||
|             let parts = osSuffixes[0].split('-'); | ||||
|             if (parts.length > 1) { | ||||
|                 this.arch = parts[1]; | ||||
|             } | ||||
|             toolPath = this.getLocalTool(); | ||||
|             if (!toolPath) { | ||||
|                 // download, extract, cache | ||||
|                 console.log('Getting a download url', this.version); | ||||
|                 let downloadUrls = yield this.getDownloadUrls(osSuffixes, this.version); | ||||
|                 toolPath = yield this.downloadAndInstall(downloadUrls); | ||||
|             } | ||||
|             else { | ||||
|                 console.log('Using cached tool'); | ||||
|             } | ||||
|             // Need to set this so that .NET Core global tools find the right locations. | ||||
|             core.exportVariable('DOTNET_ROOT', path.join(toolPath, '../..')); | ||||
|             // Prepend the tools path. instructs the agent to prepend for future tasks | ||||
|             core.addPath(toolPath); | ||||
|         }); | ||||
|     } | ||||
|     getLocalTool() { | ||||
|         console.log('Checking tool cache'); | ||||
|         return tc.find(this.cachedToolName, this.version, this.arch); | ||||
|     } | ||||
|     detectMachineOS() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             let osSuffix = []; | ||||
|             let output = ''; | ||||
|             let resultCode = 0; | ||||
|             if (IS_WINDOWS) { | ||||
|                 let escapedScript = path | ||||
|                     .join(__dirname, '..', 'externals', 'get-os-platform.ps1') | ||||
|                     .replace(/'/g, "''"); | ||||
|                 let command = `& '${escapedScript}'`; | ||||
|                 const powershellPath = yield io.which('powershell', true); | ||||
|                 resultCode = yield exec.exec(`"${powershellPath}"`, [ | ||||
|                     '-NoLogo', | ||||
|                     '-Sta', | ||||
|                     '-NoProfile', | ||||
|                     '-NonInteractive', | ||||
|                     '-ExecutionPolicy', | ||||
|                     'Unrestricted', | ||||
|                     '-Command', | ||||
|                     command | ||||
|                 ], { | ||||
|                     listeners: { | ||||
|                         stdout: (data) => { | ||||
|                             output += data.toString(); | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
|             else { | ||||
|                 let scriptPath = path.join(__dirname, '..', 'externals', 'get-os-distro.sh'); | ||||
|                 fs_1.chmodSync(scriptPath, '777'); | ||||
|                 const toolPath = yield io.which(scriptPath, true); | ||||
|                 resultCode = yield exec.exec(`"${toolPath}"`, [], { | ||||
|                     listeners: { | ||||
|                         stdout: (data) => { | ||||
|                             output += data.toString(); | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
|             if (resultCode != 0) { | ||||
|                 throw `Failed to detect os with result code ${resultCode}. Output: ${output}`; | ||||
|             } | ||||
|             let index; | ||||
|             if ((index = output.indexOf('Primary:')) >= 0) { | ||||
|                 let primary = output.substr(index + 'Primary:'.length).split(os.EOL)[0]; | ||||
|                 osSuffix.push(primary); | ||||
|             } | ||||
|             if ((index = output.indexOf('Legacy:')) >= 0) { | ||||
|                 let legacy = output.substr(index + 'Legacy:'.length).split(os.EOL)[0]; | ||||
|                 osSuffix.push(legacy); | ||||
|             } | ||||
|             if (osSuffix.length == 0) { | ||||
|                 throw 'Could not detect platform'; | ||||
|             } | ||||
|             return osSuffix; | ||||
|         }); | ||||
|     } | ||||
|     downloadAndInstall(downloadUrls) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             let downloaded = false; | ||||
|             let downloadPath = ''; | ||||
|             for (const url of downloadUrls) { | ||||
|                 try { | ||||
|                     downloadPath = yield tc.downloadTool(url); | ||||
|                     downloaded = true; | ||||
|                     break; | ||||
|                 } | ||||
|                 catch (error) { | ||||
|                     console.log('Could Not Download', url, JSON.stringify(error)); | ||||
|                 } | ||||
|             } | ||||
|             if (!downloaded) { | ||||
|                 throw 'Failed to download package'; | ||||
|             } | ||||
|             // extract | ||||
|             console.log('Extracting Package', downloadPath); | ||||
|             let extPath = IS_WINDOWS | ||||
|                 ? yield tc.extractZip(downloadPath) | ||||
|                 : yield tc.extractTar(downloadPath); | ||||
|             // cache tool | ||||
|             console.log('Caching tool'); | ||||
|             let cachedDir = yield tc.cacheDir(extPath, this.cachedToolName, this.version, this.arch); | ||||
|             console.log('Successfully installed', this.version); | ||||
|             return cachedDir; | ||||
|         }); | ||||
|     } | ||||
|     // OsSuffixes - The suffix which is a part of the file name ex- linux-x64, windows-x86 | ||||
|     // Type - SDK / Runtime | ||||
|     // Version - Version of the SDK/Runtime | ||||
|     getDownloadUrls(osSuffixes, version) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             let downloadUrls = []; | ||||
|             let releasesJSON = yield this.getReleasesJson(); | ||||
|             core.debug('Releases: ' + releasesJSON); | ||||
|             let releasesInfo = JSON.parse(yield releasesJSON.readBody()); | ||||
|             releasesInfo = releasesInfo.filter((releaseInfo) => { | ||||
|                 return (releaseInfo['version-sdk'] === version || | ||||
|                     releaseInfo['version-sdk-display'] === version); | ||||
|             }); | ||||
|             if (releasesInfo.length != 0) { | ||||
|                 let release = releasesInfo[0]; | ||||
|                 let blobUrl = release['blob-sdk']; | ||||
|                 let dlcUrl = release['dlc--sdk']; | ||||
|                 let fileName = release['sdk-' + osSuffixes[0]] | ||||
|                     ? release['sdk-' + osSuffixes[0]] | ||||
|                     : release['sdk-' + osSuffixes[1]]; | ||||
|                 if (!!fileName) { | ||||
|                     fileName = fileName.trim(); | ||||
|                     // For some latest version, the filename itself can be full download url. | ||||
|                     // Do a very basic check for url(instead of regex) as the url is only for downloading and | ||||
|                     // is coming from .net core releases json and not some ransom user input | ||||
|                     if (fileName.toLowerCase().startsWith('https://')) { | ||||
|                         downloadUrls.push(fileName); | ||||
|                     } | ||||
|                     else { | ||||
|                         if (!!blobUrl) { | ||||
|                             downloadUrls.push(util.format('%s%s', blobUrl.trim(), fileName)); | ||||
|                         } | ||||
|                         if (!!dlcUrl) { | ||||
|                             downloadUrls.push(util.format('%s%s', dlcUrl.trim(), fileName)); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 else { | ||||
|                     throw `The specified version's download links are not correctly formed in the supported versions document => ${DotNetCoreReleasesUrl}`; | ||||
|                 } | ||||
|             } | ||||
|             else { | ||||
|                 console.log(`Could not fetch download information for version ${version}`); | ||||
|                 downloadUrls = yield this.getFallbackDownloadUrls(version); | ||||
|             } | ||||
|             if (downloadUrls.length == 0) { | ||||
|                 throw `Could not construct download URL. Please ensure that specified version ${version} is valid.`; | ||||
|             } | ||||
|             core.debug(`Got download urls ${downloadUrls}`); | ||||
|             return downloadUrls; | ||||
|         }); | ||||
|     } | ||||
|     getReleasesJson() { | ||||
|         var httpCallbackClient = new httpClient.HttpClient('setup-dotnet', [], {}); | ||||
|         return httpCallbackClient.get(DotNetCoreReleasesUrl); | ||||
|     } | ||||
|     getFallbackDownloadUrls(version) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             let primaryUrlSearchString; | ||||
|             let legacyUrlSearchString; | ||||
|             let output = ''; | ||||
|             let resultCode = 0; | ||||
|             if (IS_WINDOWS) { | ||||
|                 let escapedScript = path | ||||
|                     .join(__dirname, '..', 'externals', 'install-dotnet.ps1') | ||||
|                     .replace(/'/g, "''"); | ||||
|                 let command = `& '${escapedScript}' -Version ${version} -DryRun`; | ||||
|                 const powershellPath = yield io.which('powershell', true); | ||||
|                 resultCode = yield exec.exec(`"${powershellPath}"`, [ | ||||
|                     '-NoLogo', | ||||
|                     '-Sta', | ||||
|                     '-NoProfile', | ||||
|                     '-NonInteractive', | ||||
|                     '-ExecutionPolicy', | ||||
|                     'Unrestricted', | ||||
|                     '-Command', | ||||
|                     command | ||||
|                 ], { | ||||
|                     listeners: { | ||||
|                         stdout: (data) => { | ||||
|                             output += data.toString(); | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|                 primaryUrlSearchString = 'dotnet-install: Primary named payload URL: '; | ||||
|                 legacyUrlSearchString = 'dotnet-install: Legacy named payload URL: '; | ||||
|             } | ||||
|             else { | ||||
|                 let escapedScript = path | ||||
|                     .join(__dirname, '..', 'externals', 'install-dotnet.sh') | ||||
|                     .replace(/'/g, "''"); | ||||
|                 fs_1.chmodSync(escapedScript, '777'); | ||||
|                 const scriptPath = yield io.which(escapedScript, true); | ||||
|                 resultCode = yield exec.exec(`"${scriptPath}"`, ['--version', version, '--dry-run'], { | ||||
|                     listeners: { | ||||
|                         stdout: (data) => { | ||||
|                             output += data.toString(); | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|                 primaryUrlSearchString = 'dotnet-install: Primary named payload URL: '; | ||||
|                 legacyUrlSearchString = 'dotnet-install: Legacy named payload URL: '; | ||||
|             } | ||||
|             if (resultCode != 0) { | ||||
|                 throw `Failed to get download urls with result code ${resultCode}. ${output}`; | ||||
|             } | ||||
|             let primaryUrl = ''; | ||||
|             let legacyUrl = ''; | ||||
|             if (!!output && output.length > 0) { | ||||
|                 let lines = output.split(os.EOL); | ||||
|                 // Fallback to \n if initial split doesn't work (not consistent across versions) | ||||
|                 if (lines.length === 1) { | ||||
|                     lines = output.split('\n'); | ||||
|                 } | ||||
|                 if (!!lines && lines.length > 0) { | ||||
|                     lines.forEach((line) => { | ||||
|                         if (!line) { | ||||
|                             return; | ||||
|                         } | ||||
|                         var primarySearchStringIndex = line.indexOf(primaryUrlSearchString); | ||||
|                         if (primarySearchStringIndex > -1) { | ||||
|                             primaryUrl = line.substring(primarySearchStringIndex + primaryUrlSearchString.length); | ||||
|                             return; | ||||
|                         } | ||||
|                         var legacySearchStringIndex = line.indexOf(legacyUrlSearchString); | ||||
|                         if (legacySearchStringIndex > -1) { | ||||
|                             legacyUrl = line.substring(legacySearchStringIndex + legacyUrlSearchString.length); | ||||
|                             return; | ||||
|                         } | ||||
|                     }); | ||||
|                 } | ||||
|             } | ||||
|             return [primaryUrl, legacyUrl]; | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| exports.DotnetCoreInstaller = DotnetCoreInstaller; | ||||
| const DotNetCoreReleasesUrl = 'https://raw.githubusercontent.com/dotnet/core/master/release-notes/releases.json'; | ||||
							
								
								
									
										45
									
								
								lib/setup-dotnet.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								lib/setup-dotnet.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||||
|     result["default"] = mod; | ||||
|     return result; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const core = __importStar(require("@actions/core")); | ||||
| const installer = __importStar(require("./installer")); | ||||
| const path = __importStar(require("path")); | ||||
| function run() { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         try { | ||||
|             // | ||||
|             // Version is optional.  If supplied, install / use from the tool cache | ||||
|             // If not supplied then task is still used to setup proxy, auth, etc... | ||||
|             // | ||||
|             let version = core.getInput('version'); | ||||
|             if (!version) { | ||||
|                 version = core.getInput('dotnet-version'); | ||||
|             } | ||||
|             if (version) { | ||||
|                 const dotnetInstaller = new installer.DotnetCoreInstaller(version); | ||||
|                 yield dotnetInstaller.installDotnet(); | ||||
|             } | ||||
|             // TODO: setup proxy from runner proxy config | ||||
|             const matchersPath = path.join(__dirname, '..', '.github'); | ||||
|             console.log(`##[add-matcher]${path.join(matchersPath, 'csc.json')}`); | ||||
|         } | ||||
|         catch (error) { | ||||
|             core.setFailed(error.message); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| run(); | ||||
							
								
								
									
										7
									
								
								node_modules/@actions/core/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/core/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| Copyright 2019 GitHub | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
							
								
								
									
										81
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,81 @@ | ||||
| # `@actions/core` | ||||
|  | ||||
| > Core functions for setting results, logging, registering secrets and exporting variables across actions | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| #### Inputs/Outputs | ||||
|  | ||||
| You can use this library to get inputs or set outputs: | ||||
|  | ||||
| ``` | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| const myInput = core.getInput('inputName', { required: true }); | ||||
|  | ||||
| // Do stuff | ||||
|  | ||||
| core.setOutput('outputKey', 'outputVal'); | ||||
| ``` | ||||
|  | ||||
| #### Exporting variables/secrets | ||||
|  | ||||
| You can also export variables and secrets for future steps. Variables get set in the environment automatically, while secrets must be scoped into the environment from a workflow using `{{ secret.FOO }}`. Secrets will also be masked from the logs: | ||||
|  | ||||
| ``` | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| // Do stuff | ||||
|  | ||||
| core.exportVariable('envVar', 'Val'); | ||||
| core.exportSecret('secretVar', variableWithSecretValue); | ||||
| ``` | ||||
|  | ||||
| #### PATH Manipulation | ||||
|  | ||||
| You can explicitly add items to the path for all remaining steps in a workflow: | ||||
|  | ||||
| ``` | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| core.addPath('pathToTool'); | ||||
| ``` | ||||
|  | ||||
| #### Exit codes | ||||
|  | ||||
| You should use this library to set the failing exit code for your action: | ||||
|  | ||||
| ``` | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| try { | ||||
|   // Do stuff | ||||
| } | ||||
| catch (err) { | ||||
|   // setFailed logs the message and sets a failing exit code | ||||
|   core.setFailed(`Action failed with error ${err}`); | ||||
| } | ||||
|  | ||||
| ``` | ||||
|  | ||||
| #### Logging | ||||
|  | ||||
| Finally, this library provides some utilities for logging: | ||||
|  | ||||
| ``` | ||||
| const core = require('@actions/core'); | ||||
|  | ||||
| const myInput = core.getInput('input'); | ||||
| try { | ||||
|   core.debug('Inside try block'); | ||||
|    | ||||
|   if (!myInput) { | ||||
|     core.warning('myInput wasnt set'); | ||||
|   } | ||||
|    | ||||
|   // Do stuff | ||||
| } | ||||
| catch (err) { | ||||
|   core.error('Error ${err}, action may still succeed though'); | ||||
| } | ||||
| ``` | ||||
							
								
								
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | ||||
| interface CommandProperties { | ||||
|     [key: string]: string; | ||||
| } | ||||
| /** | ||||
|  * Commands | ||||
|  * | ||||
|  * Command Format: | ||||
|  *   ##[name key=value;key=value]message | ||||
|  * | ||||
|  * Examples: | ||||
|  *   ##[warning]This is the user warning message | ||||
|  *   ##[set-secret name=mypassword]definatelyNotAPassword! | ||||
|  */ | ||||
| export declare function issueCommand(command: string, properties: CommandProperties, message: string): void; | ||||
| export declare function issue(name: string, message: string): void; | ||||
| export {}; | ||||
							
								
								
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const os = require("os"); | ||||
| /** | ||||
|  * Commands | ||||
|  * | ||||
|  * Command Format: | ||||
|  *   ##[name key=value;key=value]message | ||||
|  * | ||||
|  * Examples: | ||||
|  *   ##[warning]This is the user warning message | ||||
|  *   ##[set-secret name=mypassword]definatelyNotAPassword! | ||||
|  */ | ||||
| function issueCommand(command, properties, message) { | ||||
|     const cmd = new Command(command, properties, message); | ||||
|     process.stdout.write(cmd.toString() + os.EOL); | ||||
| } | ||||
| exports.issueCommand = issueCommand; | ||||
| function issue(name, message) { | ||||
|     issueCommand(name, {}, message); | ||||
| } | ||||
| exports.issue = issue; | ||||
| const CMD_PREFIX = '##['; | ||||
| class Command { | ||||
|     constructor(command, properties, message) { | ||||
|         if (!command) { | ||||
|             command = 'missing.command'; | ||||
|         } | ||||
|         this.command = command; | ||||
|         this.properties = properties; | ||||
|         this.message = message; | ||||
|     } | ||||
|     toString() { | ||||
|         let cmdStr = CMD_PREFIX + this.command; | ||||
|         if (this.properties && Object.keys(this.properties).length > 0) { | ||||
|             cmdStr += ' '; | ||||
|             for (const key in this.properties) { | ||||
|                 if (this.properties.hasOwnProperty(key)) { | ||||
|                     const val = this.properties[key]; | ||||
|                     if (val) { | ||||
|                         // safely append the val - avoid blowing up when attempting to | ||||
|                         // call .replace() if message is not a string for some reason | ||||
|                         cmdStr += `${key}=${escape(`${val || ''}`)};`; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         cmdStr += ']'; | ||||
|         // safely append the message - avoid blowing up when attempting to | ||||
|         // call .replace() if message is not a string for some reason | ||||
|         const message = `${this.message || ''}`; | ||||
|         cmdStr += escapeData(message); | ||||
|         return cmdStr; | ||||
|     } | ||||
| } | ||||
| function escapeData(s) { | ||||
|     return s.replace(/\r/g, '%0D').replace(/\n/g, '%0A'); | ||||
| } | ||||
| function escape(s) { | ||||
|     return s | ||||
|         .replace(/\r/g, '%0D') | ||||
|         .replace(/\n/g, '%0A') | ||||
|         .replace(/]/g, '%5D') | ||||
|         .replace(/;/g, '%3B'); | ||||
| } | ||||
| //# sourceMappingURL=command.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"command.js","sourceRoot":"","sources":["../src/command.ts"],"names":[],"mappings":";;AAAA,yBAAwB;AAQxB;;;;;;;;;GASG;AACH,SAAgB,YAAY,CAC1B,OAAe,EACf,UAA6B,EAC7B,OAAe;IAEf,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAA;IACrD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AAC/C,CAAC;AAPD,oCAOC;AAED,SAAgB,KAAK,CAAC,IAAY,EAAE,OAAe;IACjD,YAAY,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACjC,CAAC;AAFD,sBAEC;AAED,MAAM,UAAU,GAAG,KAAK,CAAA;AAExB,MAAM,OAAO;IAKX,YAAY,OAAe,EAAE,UAA6B,EAAE,OAAe;QACzE,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,GAAG,iBAAiB,CAAA;SAC5B;QAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,MAAM,GAAG,UAAU,GAAG,IAAI,CAAC,OAAO,CAAA;QAEtC,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9D,MAAM,IAAI,GAAG,CAAA;YACb,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjC,IAAI,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;oBACvC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;oBAChC,IAAI,GAAG,EAAE;wBACP,8DAA8D;wBAC9D,6DAA6D;wBAC7D,MAAM,IAAI,GAAG,GAAG,IAAI,MAAM,CAAC,GAAG,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAA;qBAC9C;iBACF;aACF;SACF;QAED,MAAM,IAAI,GAAG,CAAA;QAEb,kEAAkE;QAClE,6DAA6D;QAC7D,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,CAAA;QACvC,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,CAAA;QAE7B,OAAO,MAAM,CAAA;IACf,CAAC;CACF;AAED,SAAS,UAAU,CAAC,CAAS;IAC3B,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;AACtD,CAAC;AAED,SAAS,MAAM,CAAC,CAAS;IACvB,OAAO,CAAC;SACL,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;SACpB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;AACzB,CAAC"} | ||||
							
								
								
									
										73
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,73 @@ | ||||
| /** | ||||
|  * Interface for getInput options | ||||
|  */ | ||||
| export interface InputOptions { | ||||
|     /** Optional. Whether the input is required. If required and not present, will throw. Defaults to false */ | ||||
|     required?: boolean; | ||||
| } | ||||
| /** | ||||
|  * The code to exit an action | ||||
|  */ | ||||
| export declare enum ExitCode { | ||||
|     /** | ||||
|      * A code indicating that the action was successful | ||||
|      */ | ||||
|     Success = 0, | ||||
|     /** | ||||
|      * A code indicating that the action was a failure | ||||
|      */ | ||||
|     Failure = 1 | ||||
| } | ||||
| /** | ||||
|  * sets env variable for this action and future actions in the job | ||||
|  * @param name the name of the variable to set | ||||
|  * @param val the value of the variable | ||||
|  */ | ||||
| export declare function exportVariable(name: string, val: string): void; | ||||
| /** | ||||
|  * exports the variable and registers a secret which will get masked from logs | ||||
|  * @param name the name of the variable to set | ||||
|  * @param val value of the secret | ||||
|  */ | ||||
| export declare function exportSecret(name: string, val: string): void; | ||||
| /** | ||||
|  * Prepends inputPath to the PATH (for this action and future actions) | ||||
|  * @param inputPath | ||||
|  */ | ||||
| export declare function addPath(inputPath: string): void; | ||||
| /** | ||||
|  * Gets the value of an input.  The value is also trimmed. | ||||
|  * | ||||
|  * @param     name     name of the input to get | ||||
|  * @param     options  optional. See InputOptions. | ||||
|  * @returns   string | ||||
|  */ | ||||
| export declare function getInput(name: string, options?: InputOptions): string; | ||||
| /** | ||||
|  * Sets the value of an output. | ||||
|  * | ||||
|  * @param     name     name of the output to set | ||||
|  * @param     value    value to store | ||||
|  */ | ||||
| export declare function setOutput(name: string, value: string): void; | ||||
| /** | ||||
|  * Sets the action status to failed. | ||||
|  * When the action exits it will be with an exit code of 1 | ||||
|  * @param message add error issue message | ||||
|  */ | ||||
| export declare function setFailed(message: string): void; | ||||
| /** | ||||
|  * Writes debug message to user log | ||||
|  * @param message debug message | ||||
|  */ | ||||
| export declare function debug(message: string): void; | ||||
| /** | ||||
|  * Adds an error issue | ||||
|  * @param message error issue message | ||||
|  */ | ||||
| export declare function error(message: string): void; | ||||
| /** | ||||
|  * Adds an warning issue | ||||
|  * @param message warning issue message | ||||
|  */ | ||||
| export declare function warning(message: string): void; | ||||
							
								
								
									
										116
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,116 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const command_1 = require("./command"); | ||||
| const path = require("path"); | ||||
| /** | ||||
|  * The code to exit an action | ||||
|  */ | ||||
| var ExitCode; | ||||
| (function (ExitCode) { | ||||
|     /** | ||||
|      * A code indicating that the action was successful | ||||
|      */ | ||||
|     ExitCode[ExitCode["Success"] = 0] = "Success"; | ||||
|     /** | ||||
|      * A code indicating that the action was a failure | ||||
|      */ | ||||
|     ExitCode[ExitCode["Failure"] = 1] = "Failure"; | ||||
| })(ExitCode = exports.ExitCode || (exports.ExitCode = {})); | ||||
| //----------------------------------------------------------------------- | ||||
| // Variables | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * sets env variable for this action and future actions in the job | ||||
|  * @param name the name of the variable to set | ||||
|  * @param val the value of the variable | ||||
|  */ | ||||
| function exportVariable(name, val) { | ||||
|     process.env[name] = val; | ||||
|     command_1.issueCommand('set-env', { name }, val); | ||||
| } | ||||
| exports.exportVariable = exportVariable; | ||||
| /** | ||||
|  * exports the variable and registers a secret which will get masked from logs | ||||
|  * @param name the name of the variable to set | ||||
|  * @param val value of the secret | ||||
|  */ | ||||
| function exportSecret(name, val) { | ||||
|     exportVariable(name, val); | ||||
|     command_1.issueCommand('set-secret', {}, val); | ||||
| } | ||||
| exports.exportSecret = exportSecret; | ||||
| /** | ||||
|  * Prepends inputPath to the PATH (for this action and future actions) | ||||
|  * @param inputPath | ||||
|  */ | ||||
| function addPath(inputPath) { | ||||
|     command_1.issueCommand('add-path', {}, inputPath); | ||||
|     process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`; | ||||
| } | ||||
| exports.addPath = addPath; | ||||
| /** | ||||
|  * Gets the value of an input.  The value is also trimmed. | ||||
|  * | ||||
|  * @param     name     name of the input to get | ||||
|  * @param     options  optional. See InputOptions. | ||||
|  * @returns   string | ||||
|  */ | ||||
| function getInput(name, options) { | ||||
|     const val = process.env[`INPUT_${name.replace(' ', '_').toUpperCase()}`] || ''; | ||||
|     if (options && options.required && !val) { | ||||
|         throw new Error(`Input required and not supplied: ${name}`); | ||||
|     } | ||||
|     return val.trim(); | ||||
| } | ||||
| exports.getInput = getInput; | ||||
| /** | ||||
|  * Sets the value of an output. | ||||
|  * | ||||
|  * @param     name     name of the output to set | ||||
|  * @param     value    value to store | ||||
|  */ | ||||
| function setOutput(name, value) { | ||||
|     command_1.issueCommand('set-output', { name }, value); | ||||
| } | ||||
| exports.setOutput = setOutput; | ||||
| //----------------------------------------------------------------------- | ||||
| // Results | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * Sets the action status to failed. | ||||
|  * When the action exits it will be with an exit code of 1 | ||||
|  * @param message add error issue message | ||||
|  */ | ||||
| function setFailed(message) { | ||||
|     process.exitCode = ExitCode.Failure; | ||||
|     error(message); | ||||
| } | ||||
| exports.setFailed = setFailed; | ||||
| //----------------------------------------------------------------------- | ||||
| // Logging Commands | ||||
| //----------------------------------------------------------------------- | ||||
| /** | ||||
|  * Writes debug message to user log | ||||
|  * @param message debug message | ||||
|  */ | ||||
| function debug(message) { | ||||
|     command_1.issueCommand('debug', {}, message); | ||||
| } | ||||
| exports.debug = debug; | ||||
| /** | ||||
|  * Adds an error issue | ||||
|  * @param message error issue message | ||||
|  */ | ||||
| function error(message) { | ||||
|     command_1.issue('error', message); | ||||
| } | ||||
| exports.error = error; | ||||
| /** | ||||
|  * Adds an warning issue | ||||
|  * @param message warning issue message | ||||
|  */ | ||||
| function warning(message) { | ||||
|     command_1.issue('warning', message); | ||||
| } | ||||
| exports.warning = warning; | ||||
| //# sourceMappingURL=core.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"core.js","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":";;AAAA,uCAA6C;AAE7C,6BAA4B;AAU5B;;GAEG;AACH,IAAY,QAUX;AAVD,WAAY,QAAQ;IAClB;;OAEG;IACH,6CAAW,CAAA;IAEX;;OAEG;IACH,6CAAW,CAAA;AACb,CAAC,EAVW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAUnB;AAED,yEAAyE;AACzE,YAAY;AACZ,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,cAAc,CAAC,IAAY,EAAE,GAAW;IACtD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,CAAA;IACvB,sBAAY,CAAC,SAAS,EAAE,EAAC,IAAI,EAAC,EAAE,GAAG,CAAC,CAAA;AACtC,CAAC;AAHD,wCAGC;AAED;;;;GAIG;AACH,SAAgB,YAAY,CAAC,IAAY,EAAE,GAAW;IACpD,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;IACzB,sBAAY,CAAC,YAAY,EAAE,EAAE,EAAE,GAAG,CAAC,CAAA;AACrC,CAAC;AAHD,oCAGC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,SAAiB;IACvC,sBAAY,CAAC,UAAU,EAAE,EAAE,EAAE,SAAS,CAAC,CAAA;IACvC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,GAAG,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAA;AAC7E,CAAC;AAHD,0BAGC;AAED;;;;;;GAMG;AACH,SAAgB,QAAQ,CAAC,IAAY,EAAE,OAAsB;IAC3D,MAAM,GAAG,GACP,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAI,EAAE,CAAA;IACpE,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,GAAG,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,oCAAoC,IAAI,EAAE,CAAC,CAAA;KAC5D;IAED,OAAO,GAAG,CAAC,IAAI,EAAE,CAAA;AACnB,CAAC;AARD,4BAQC;AAED;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,IAAY,EAAE,KAAa;IACnD,sBAAY,CAAC,YAAY,EAAE,EAAC,IAAI,EAAC,EAAE,KAAK,CAAC,CAAA;AAC3C,CAAC;AAFD,8BAEC;AAED,yEAAyE;AACzE,UAAU;AACV,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,SAAS,CAAC,OAAe;IACvC,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAA;IACnC,KAAK,CAAC,OAAO,CAAC,CAAA;AAChB,CAAC;AAHD,8BAGC;AAED,yEAAyE;AACzE,mBAAmB;AACnB,yEAAyE;AAEzE;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,sBAAY,CAAC,OAAO,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACpC,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,eAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;AACzB,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,OAAe;IACrC,eAAK,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;AAC3B,CAAC;AAFD,0BAEC"} | ||||
							
								
								
									
										64
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,64 @@ | ||||
| { | ||||
|   "_from": "@actions/core@^1.0.0", | ||||
|   "_id": "@actions/core@1.0.0", | ||||
|   "_inBundle": false, | ||||
|   "_integrity": "sha512-aMIlkx96XH4E/2YZtEOeyrYQfhlas9jIRkfGPqMwXD095Rdkzo4lB6ZmbxPQSzD+e1M+Xsm98ZhuSMYGv/AlqA==", | ||||
|   "_location": "/@actions/core", | ||||
|   "_phantomChildren": {}, | ||||
|   "_requested": { | ||||
|     "type": "range", | ||||
|     "registry": true, | ||||
|     "raw": "@actions/core@^1.0.0", | ||||
|     "name": "@actions/core", | ||||
|     "escapedName": "@actions%2fcore", | ||||
|     "scope": "@actions", | ||||
|     "rawSpec": "^1.0.0", | ||||
|     "saveSpec": null, | ||||
|     "fetchSpec": "^1.0.0" | ||||
|   }, | ||||
|   "_requiredBy": [ | ||||
|     "/", | ||||
|     "/@actions/tool-cache" | ||||
|   ], | ||||
|   "_resolved": "https://registry.npmjs.org/@actions/core/-/core-1.0.0.tgz", | ||||
|   "_shasum": "4a090a2e958cc300b9ea802331034d5faf42d239", | ||||
|   "_spec": "@actions/core@^1.0.0", | ||||
|   "_where": "C:\\Users\\damccorm\\Documents\\setup-dotnet", | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/actions/toolkit/issues" | ||||
|   }, | ||||
|   "bundleDependencies": false, | ||||
|   "deprecated": false, | ||||
|   "description": "Actions core lib", | ||||
|   "devDependencies": { | ||||
|     "@types/node": "^12.0.2" | ||||
|   }, | ||||
|   "directories": { | ||||
|     "lib": "lib", | ||||
|     "test": "__tests__" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "lib" | ||||
|   ], | ||||
|   "gitHead": "a40bce7c8d382aa3dbadaa327acbc696e9390e55", | ||||
|   "homepage": "https://github.com/actions/toolkit/tree/master/packages/core", | ||||
|   "keywords": [ | ||||
|     "core", | ||||
|     "actions" | ||||
|   ], | ||||
|   "license": "MIT", | ||||
|   "main": "lib/core.js", | ||||
|   "name": "@actions/core", | ||||
|   "publishConfig": { | ||||
|     "access": "public" | ||||
|   }, | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "git+https://github.com/actions/toolkit.git" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: run tests from root\" && exit 1", | ||||
|     "tsc": "tsc" | ||||
|   }, | ||||
|   "version": "1.0.0" | ||||
| } | ||||
							
								
								
									
										7
									
								
								node_modules/@actions/exec/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/exec/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| Copyright 2019 GitHub | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
							
								
								
									
										60
									
								
								node_modules/@actions/exec/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								node_modules/@actions/exec/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| # `@actions/exec` | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| #### Basic | ||||
|  | ||||
| You can use this package to execute your tools on the command line in a cross platform way: | ||||
|  | ||||
| ``` | ||||
| const exec = require('@actions/exec'); | ||||
|  | ||||
| await exec.exec('node index.js'); | ||||
| ``` | ||||
|  | ||||
| #### Args | ||||
|  | ||||
| You can also pass in arg arrays: | ||||
|  | ||||
| ``` | ||||
| const exec = require('@actions/exec'); | ||||
|  | ||||
| await exec.exec('node', ['index.js', 'foo=bar']); | ||||
| ``` | ||||
|  | ||||
| #### Output/options | ||||
|  | ||||
| Capture output or specify [other options](https://github.com/actions/toolkit/blob/d9347d4ab99fd507c0b9104b2cf79fb44fcc827d/packages/exec/src/interfaces.ts#L5): | ||||
|  | ||||
| ``` | ||||
| const exec = require('@actions/exec'); | ||||
|  | ||||
| const myOutput = ''; | ||||
| const myError = ''; | ||||
|  | ||||
| const options = {}; | ||||
| options.listeners = { | ||||
|   stdout: (data: Buffer) => { | ||||
|     myOutput += data.toString(); | ||||
|   }, | ||||
|   stderr: (data: Buffer) => { | ||||
|     myError += data.toString(); | ||||
|   } | ||||
| }; | ||||
| options.cwd = './lib'; | ||||
|  | ||||
| await exec.exec('node', ['index.js', 'foo=bar'], options); | ||||
| ``` | ||||
|  | ||||
| #### Exec tools not in the PATH | ||||
|  | ||||
| You can use it in conjunction with the `which` function from `@actions/io` to execute tools that are not in the PATH: | ||||
|  | ||||
| ``` | ||||
| const exec = require('@actions/exec'); | ||||
| const io = require('@actions/io'); | ||||
|  | ||||
| const pythonPath: string = await io.which('python', true) | ||||
|  | ||||
| await exec.exec(`"${pythonPath}"`, ['main.py']); | ||||
| ``` | ||||
							
								
								
									
										12
									
								
								node_modules/@actions/exec/lib/exec.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								node_modules/@actions/exec/lib/exec.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| import * as im from './interfaces'; | ||||
| /** | ||||
|  * Exec a command. | ||||
|  * Output will be streamed to the live console. | ||||
|  * Returns promise with return code | ||||
|  * | ||||
|  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped. | ||||
|  * @param     args               optional arguments for tool. Escaping is handled by the lib. | ||||
|  * @param     options            optional exec options.  See ExecOptions | ||||
|  * @returns   Promise<number>    exit code | ||||
|  */ | ||||
| export declare function exec(commandLine: string, args?: string[], options?: im.ExecOptions): Promise<number>; | ||||
							
								
								
									
										36
									
								
								node_modules/@actions/exec/lib/exec.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								node_modules/@actions/exec/lib/exec.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,36 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const tr = require("./toolrunner"); | ||||
| /** | ||||
|  * Exec a command. | ||||
|  * Output will be streamed to the live console. | ||||
|  * Returns promise with return code | ||||
|  * | ||||
|  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped. | ||||
|  * @param     args               optional arguments for tool. Escaping is handled by the lib. | ||||
|  * @param     options            optional exec options.  See ExecOptions | ||||
|  * @returns   Promise<number>    exit code | ||||
|  */ | ||||
| function exec(commandLine, args, options) { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         const commandArgs = tr.argStringToArray(commandLine); | ||||
|         if (commandArgs.length === 0) { | ||||
|             throw new Error(`Parameter 'commandLine' cannot be null or empty.`); | ||||
|         } | ||||
|         // Path to tool to execute should be first arg | ||||
|         const toolPath = commandArgs[0]; | ||||
|         args = commandArgs.slice(1).concat(args || []); | ||||
|         const runner = new tr.ToolRunner(toolPath, args, options); | ||||
|         return runner.exec(); | ||||
|     }); | ||||
| } | ||||
| exports.exec = exec; | ||||
| //# sourceMappingURL=exec.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/exec.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/exec.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"exec.js","sourceRoot":"","sources":["../src/exec.ts"],"names":[],"mappings":";;;;;;;;;;AACA,mCAAkC;AAElC;;;;;;;;;GASG;AACH,SAAsB,IAAI,CACxB,WAAmB,EACnB,IAAe,EACf,OAAwB;;QAExB,MAAM,WAAW,GAAG,EAAE,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAA;QACpD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;SACpE;QACD,8CAA8C;QAC9C,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAA;QAC/B,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;QAC9C,MAAM,MAAM,GAAkB,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,CAAA;QACxE,OAAO,MAAM,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;CAAA;AAdD,oBAcC"} | ||||
							
								
								
									
										35
									
								
								node_modules/@actions/exec/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								node_modules/@actions/exec/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | ||||
| /// <reference types="node" /> | ||||
| import * as stream from 'stream'; | ||||
| /** | ||||
|  * Interface for exec options | ||||
|  */ | ||||
| export interface ExecOptions { | ||||
|     /** optional working directory.  defaults to current */ | ||||
|     cwd?: string; | ||||
|     /** optional envvar dictionary.  defaults to current process's env */ | ||||
|     env?: { | ||||
|         [key: string]: string; | ||||
|     }; | ||||
|     /** optional.  defaults to false */ | ||||
|     silent?: boolean; | ||||
|     /** optional out stream to use. Defaults to process.stdout */ | ||||
|     outStream?: stream.Writable; | ||||
|     /** optional err stream to use. Defaults to process.stderr */ | ||||
|     errStream?: stream.Writable; | ||||
|     /** optional. whether to skip quoting/escaping arguments if needed.  defaults to false. */ | ||||
|     windowsVerbatimArguments?: boolean; | ||||
|     /** optional.  whether to fail if output to stderr.  defaults to false */ | ||||
|     failOnStdErr?: boolean; | ||||
|     /** optional.  defaults to failing on non zero.  ignore will not fail leaving it up to the caller */ | ||||
|     ignoreReturnCode?: boolean; | ||||
|     /** optional. How long in ms to wait for STDIO streams to close after the exit event of the process before terminating. defaults to 10000 */ | ||||
|     delay?: number; | ||||
|     /** optional. Listeners for output. Callback functions that will be called on these events */ | ||||
|     listeners?: { | ||||
|         stdout?: (data: Buffer) => void; | ||||
|         stderr?: (data: Buffer) => void; | ||||
|         stdline?: (data: string) => void; | ||||
|         errline?: (data: string) => void; | ||||
|         debug?: (data: string) => void; | ||||
|     }; | ||||
| } | ||||
							
								
								
									
										3
									
								
								node_modules/@actions/exec/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								node_modules/@actions/exec/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=interfaces.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../src/interfaces.ts"],"names":[],"mappings":""} | ||||
							
								
								
									
										37
									
								
								node_modules/@actions/exec/lib/toolrunner.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								node_modules/@actions/exec/lib/toolrunner.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | ||||
| /// <reference types="node" /> | ||||
| import * as events from 'events'; | ||||
| import * as im from './interfaces'; | ||||
| export declare class ToolRunner extends events.EventEmitter { | ||||
|     constructor(toolPath: string, args?: string[], options?: im.ExecOptions); | ||||
|     private toolPath; | ||||
|     private args; | ||||
|     private options; | ||||
|     private _debug; | ||||
|     private _getCommandString; | ||||
|     private _processLineBuffer; | ||||
|     private _getSpawnFileName; | ||||
|     private _getSpawnArgs; | ||||
|     private _endsWith; | ||||
|     private _isCmdFile; | ||||
|     private _windowsQuoteCmdArg; | ||||
|     private _uvQuoteCmdArg; | ||||
|     private _cloneExecOptions; | ||||
|     private _getSpawnOptions; | ||||
|     /** | ||||
|      * Exec a tool. | ||||
|      * Output will be streamed to the live console. | ||||
|      * Returns promise with return code | ||||
|      * | ||||
|      * @param     tool     path to tool to exec | ||||
|      * @param     options  optional exec options.  See ExecOptions | ||||
|      * @returns   number | ||||
|      */ | ||||
|     exec(): Promise<number>; | ||||
| } | ||||
| /** | ||||
|  * Convert an arg string to an array of args. Handles escaping | ||||
|  * | ||||
|  * @param    argString   string of arguments | ||||
|  * @returns  string[]    array of arguments | ||||
|  */ | ||||
| export declare function argStringToArray(argString: string): string[]; | ||||
							
								
								
									
										573
									
								
								node_modules/@actions/exec/lib/toolrunner.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										573
									
								
								node_modules/@actions/exec/lib/toolrunner.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,573 @@ | ||||
| "use strict"; | ||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||
|     return new (P || (P = Promise))(function (resolve, reject) { | ||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||
|         function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } | ||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||
|     }); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| const os = require("os"); | ||||
| const events = require("events"); | ||||
| const child = require("child_process"); | ||||
| /* eslint-disable @typescript-eslint/unbound-method */ | ||||
| const IS_WINDOWS = process.platform === 'win32'; | ||||
| /* | ||||
|  * Class for running command line tools. Handles quoting and arg parsing in a platform agnostic way. | ||||
|  */ | ||||
| class ToolRunner extends events.EventEmitter { | ||||
|     constructor(toolPath, args, options) { | ||||
|         super(); | ||||
|         if (!toolPath) { | ||||
|             throw new Error("Parameter 'toolPath' cannot be null or empty."); | ||||
|         } | ||||
|         this.toolPath = toolPath; | ||||
|         this.args = args || []; | ||||
|         this.options = options || {}; | ||||
|     } | ||||
|     _debug(message) { | ||||
|         if (this.options.listeners && this.options.listeners.debug) { | ||||
|             this.options.listeners.debug(message); | ||||
|         } | ||||
|     } | ||||
|     _getCommandString(options, noPrefix) { | ||||
|         const toolPath = this._getSpawnFileName(); | ||||
|         const args = this._getSpawnArgs(options); | ||||
|         let cmd = noPrefix ? '' : '[command]'; // omit prefix when piped to a second tool | ||||
|         if (IS_WINDOWS) { | ||||
|             // Windows + cmd file | ||||
|             if (this._isCmdFile()) { | ||||
|                 cmd += toolPath; | ||||
|                 for (const a of args) { | ||||
|                     cmd += ` ${a}`; | ||||
|                 } | ||||
|             } | ||||
|             // Windows + verbatim | ||||
|             else if (options.windowsVerbatimArguments) { | ||||
|                 cmd += `"${toolPath}"`; | ||||
|                 for (const a of args) { | ||||
|                     cmd += ` ${a}`; | ||||
|                 } | ||||
|             } | ||||
|             // Windows (regular) | ||||
|             else { | ||||
|                 cmd += this._windowsQuoteCmdArg(toolPath); | ||||
|                 for (const a of args) { | ||||
|                     cmd += ` ${this._windowsQuoteCmdArg(a)}`; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             // OSX/Linux - this can likely be improved with some form of quoting. | ||||
|             // creating processes on Unix is fundamentally different than Windows. | ||||
|             // on Unix, execvp() takes an arg array. | ||||
|             cmd += toolPath; | ||||
|             for (const a of args) { | ||||
|                 cmd += ` ${a}`; | ||||
|             } | ||||
|         } | ||||
|         return cmd; | ||||
|     } | ||||
|     _processLineBuffer(data, strBuffer, onLine) { | ||||
|         try { | ||||
|             let s = strBuffer + data.toString(); | ||||
|             let n = s.indexOf(os.EOL); | ||||
|             while (n > -1) { | ||||
|                 const line = s.substring(0, n); | ||||
|                 onLine(line); | ||||
|                 // the rest of the string ... | ||||
|                 s = s.substring(n + os.EOL.length); | ||||
|                 n = s.indexOf(os.EOL); | ||||
|             } | ||||
|             strBuffer = s; | ||||
|         } | ||||
|         catch (err) { | ||||
|             // streaming lines to console is best effort.  Don't fail a build. | ||||
|             this._debug(`error processing line. Failed with error ${err}`); | ||||
|         } | ||||
|     } | ||||
|     _getSpawnFileName() { | ||||
|         if (IS_WINDOWS) { | ||||
|             if (this._isCmdFile()) { | ||||
|                 return process.env['COMSPEC'] || 'cmd.exe'; | ||||
|             } | ||||
|         } | ||||
|         return this.toolPath; | ||||
|     } | ||||
|     _getSpawnArgs(options) { | ||||
|         if (IS_WINDOWS) { | ||||
|             if (this._isCmdFile()) { | ||||
|                 let argline = `/D /S /C "${this._windowsQuoteCmdArg(this.toolPath)}`; | ||||
|                 for (const a of this.args) { | ||||
|                     argline += ' '; | ||||
|                     argline += options.windowsVerbatimArguments | ||||
|                         ? a | ||||
|                         : this._windowsQuoteCmdArg(a); | ||||
|                 } | ||||
|                 argline += '"'; | ||||
|                 return [argline]; | ||||
|             } | ||||
|         } | ||||
|         return this.args; | ||||
|     } | ||||
|     _endsWith(str, end) { | ||||
|         return str.endsWith(end); | ||||
|     } | ||||
|     _isCmdFile() { | ||||
|         const upperToolPath = this.toolPath.toUpperCase(); | ||||
|         return (this._endsWith(upperToolPath, '.CMD') || | ||||
|             this._endsWith(upperToolPath, '.BAT')); | ||||
|     } | ||||
|     _windowsQuoteCmdArg(arg) { | ||||
|         // for .exe, apply the normal quoting rules that libuv applies | ||||
|         if (!this._isCmdFile()) { | ||||
|             return this._uvQuoteCmdArg(arg); | ||||
|         } | ||||
|         // otherwise apply quoting rules specific to the cmd.exe command line parser. | ||||
|         // the libuv rules are generic and are not designed specifically for cmd.exe | ||||
|         // command line parser. | ||||
|         // | ||||
|         // for a detailed description of the cmd.exe command line parser, refer to | ||||
|         // http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912 | ||||
|         // need quotes for empty arg | ||||
|         if (!arg) { | ||||
|             return '""'; | ||||
|         } | ||||
|         // determine whether the arg needs to be quoted | ||||
|         const cmdSpecialChars = [ | ||||
|             ' ', | ||||
|             '\t', | ||||
|             '&', | ||||
|             '(', | ||||
|             ')', | ||||
|             '[', | ||||
|             ']', | ||||
|             '{', | ||||
|             '}', | ||||
|             '^', | ||||
|             '=', | ||||
|             ';', | ||||
|             '!', | ||||
|             "'", | ||||
|             '+', | ||||
|             ',', | ||||
|             '`', | ||||
|             '~', | ||||
|             '|', | ||||
|             '<', | ||||
|             '>', | ||||
|             '"' | ||||
|         ]; | ||||
|         let needsQuotes = false; | ||||
|         for (const char of arg) { | ||||
|             if (cmdSpecialChars.some(x => x === char)) { | ||||
|                 needsQuotes = true; | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|         // short-circuit if quotes not needed | ||||
|         if (!needsQuotes) { | ||||
|             return arg; | ||||
|         } | ||||
|         // the following quoting rules are very similar to the rules that by libuv applies. | ||||
|         // | ||||
|         // 1) wrap the string in quotes | ||||
|         // | ||||
|         // 2) double-up quotes - i.e. " => "" | ||||
|         // | ||||
|         //    this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately | ||||
|         //    doesn't work well with a cmd.exe command line. | ||||
|         // | ||||
|         //    note, replacing " with "" also works well if the arg is passed to a downstream .NET console app. | ||||
|         //    for example, the command line: | ||||
|         //          foo.exe "myarg:""my val""" | ||||
|         //    is parsed by a .NET console app into an arg array: | ||||
|         //          [ "myarg:\"my val\"" ] | ||||
|         //    which is the same end result when applying libuv quoting rules. although the actual | ||||
|         //    command line from libuv quoting rules would look like: | ||||
|         //          foo.exe "myarg:\"my val\"" | ||||
|         // | ||||
|         // 3) double-up slashes that preceed a quote, | ||||
|         //    e.g.  hello \world    => "hello \world" | ||||
|         //          hello\"world    => "hello\\""world" | ||||
|         //          hello\\"world   => "hello\\\\""world" | ||||
|         //          hello world\    => "hello world\\" | ||||
|         // | ||||
|         //    technically this is not required for a cmd.exe command line, or the batch argument parser. | ||||
|         //    the reasons for including this as a .cmd quoting rule are: | ||||
|         // | ||||
|         //    a) this is optimized for the scenario where the argument is passed from the .cmd file to an | ||||
|         //       external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule. | ||||
|         // | ||||
|         //    b) it's what we've been doing previously (by deferring to node default behavior) and we | ||||
|         //       haven't heard any complaints about that aspect. | ||||
|         // | ||||
|         // note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be | ||||
|         // escaped when used on the command line directly - even though within a .cmd file % can be escaped | ||||
|         // by using %%. | ||||
|         // | ||||
|         // the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts | ||||
|         // the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing. | ||||
|         // | ||||
|         // one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would | ||||
|         // often work, since it is unlikely that var^ would exist, and the ^ character is removed when the | ||||
|         // variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args | ||||
|         // to an external program. | ||||
|         // | ||||
|         // an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file. | ||||
|         // % can be escaped within a .cmd file. | ||||
|         let reverse = '"'; | ||||
|         let quoteHit = true; | ||||
|         for (let i = arg.length; i > 0; i--) { | ||||
|             // walk the string in reverse | ||||
|             reverse += arg[i - 1]; | ||||
|             if (quoteHit && arg[i - 1] === '\\') { | ||||
|                 reverse += '\\'; // double the slash | ||||
|             } | ||||
|             else if (arg[i - 1] === '"') { | ||||
|                 quoteHit = true; | ||||
|                 reverse += '"'; // double the quote | ||||
|             } | ||||
|             else { | ||||
|                 quoteHit = false; | ||||
|             } | ||||
|         } | ||||
|         reverse += '"'; | ||||
|         return reverse | ||||
|             .split('') | ||||
|             .reverse() | ||||
|             .join(''); | ||||
|     } | ||||
|     _uvQuoteCmdArg(arg) { | ||||
|         // Tool runner wraps child_process.spawn() and needs to apply the same quoting as | ||||
|         // Node in certain cases where the undocumented spawn option windowsVerbatimArguments | ||||
|         // is used. | ||||
|         // | ||||
|         // Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV, | ||||
|         // see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details), | ||||
|         // pasting copyright notice from Node within this function: | ||||
|         // | ||||
|         //      Copyright Joyent, Inc. and other Node contributors. All rights reserved. | ||||
|         // | ||||
|         //      Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|         //      of this software and associated documentation files (the "Software"), to | ||||
|         //      deal in the Software without restriction, including without limitation the | ||||
|         //      rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||
|         //      sell copies of the Software, and to permit persons to whom the Software is | ||||
|         //      furnished to do so, subject to the following conditions: | ||||
|         // | ||||
|         //      The above copyright notice and this permission notice shall be included in | ||||
|         //      all copies or substantial portions of the Software. | ||||
|         // | ||||
|         //      THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|         //      IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|         //      FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|         //      AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|         //      LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
|         //      FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | ||||
|         //      IN THE SOFTWARE. | ||||
|         if (!arg) { | ||||
|             // Need double quotation for empty argument | ||||
|             return '""'; | ||||
|         } | ||||
|         if (!arg.includes(' ') && !arg.includes('\t') && !arg.includes('"')) { | ||||
|             // No quotation needed | ||||
|             return arg; | ||||
|         } | ||||
|         if (!arg.includes('"') && !arg.includes('\\')) { | ||||
|             // No embedded double quotes or backslashes, so I can just wrap | ||||
|             // quote marks around the whole thing. | ||||
|             return `"${arg}"`; | ||||
|         } | ||||
|         // Expected input/output: | ||||
|         //   input : hello"world | ||||
|         //   output: "hello\"world" | ||||
|         //   input : hello""world | ||||
|         //   output: "hello\"\"world" | ||||
|         //   input : hello\world | ||||
|         //   output: hello\world | ||||
|         //   input : hello\\world | ||||
|         //   output: hello\\world | ||||
|         //   input : hello\"world | ||||
|         //   output: "hello\\\"world" | ||||
|         //   input : hello\\"world | ||||
|         //   output: "hello\\\\\"world" | ||||
|         //   input : hello world\ | ||||
|         //   output: "hello world\\" - note the comment in libuv actually reads "hello world\" | ||||
|         //                             but it appears the comment is wrong, it should be "hello world\\" | ||||
|         let reverse = '"'; | ||||
|         let quoteHit = true; | ||||
|         for (let i = arg.length; i > 0; i--) { | ||||
|             // walk the string in reverse | ||||
|             reverse += arg[i - 1]; | ||||
|             if (quoteHit && arg[i - 1] === '\\') { | ||||
|                 reverse += '\\'; | ||||
|             } | ||||
|             else if (arg[i - 1] === '"') { | ||||
|                 quoteHit = true; | ||||
|                 reverse += '\\'; | ||||
|             } | ||||
|             else { | ||||
|                 quoteHit = false; | ||||
|             } | ||||
|         } | ||||
|         reverse += '"'; | ||||
|         return reverse | ||||
|             .split('') | ||||
|             .reverse() | ||||
|             .join(''); | ||||
|     } | ||||
|     _cloneExecOptions(options) { | ||||
|         options = options || {}; | ||||
|         const result = { | ||||
|             cwd: options.cwd || process.cwd(), | ||||
|             env: options.env || process.env, | ||||
|             silent: options.silent || false, | ||||
|             windowsVerbatimArguments: options.windowsVerbatimArguments || false, | ||||
|             failOnStdErr: options.failOnStdErr || false, | ||||
|             ignoreReturnCode: options.ignoreReturnCode || false, | ||||
|             delay: options.delay || 10000 | ||||
|         }; | ||||
|         result.outStream = options.outStream || process.stdout; | ||||
|         result.errStream = options.errStream || process.stderr; | ||||
|         return result; | ||||
|     } | ||||
|     _getSpawnOptions(options, toolPath) { | ||||
|         options = options || {}; | ||||
|         const result = {}; | ||||
|         result.cwd = options.cwd; | ||||
|         result.env = options.env; | ||||
|         result['windowsVerbatimArguments'] = | ||||
|             options.windowsVerbatimArguments || this._isCmdFile(); | ||||
|         if (options.windowsVerbatimArguments) { | ||||
|             result.argv0 = `"${toolPath}"`; | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
|     /** | ||||
|      * Exec a tool. | ||||
|      * Output will be streamed to the live console. | ||||
|      * Returns promise with return code | ||||
|      * | ||||
|      * @param     tool     path to tool to exec | ||||
|      * @param     options  optional exec options.  See ExecOptions | ||||
|      * @returns   number | ||||
|      */ | ||||
|     exec() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             return new Promise((resolve, reject) => { | ||||
|                 this._debug(`exec tool: ${this.toolPath}`); | ||||
|                 this._debug('arguments:'); | ||||
|                 for (const arg of this.args) { | ||||
|                     this._debug(`   ${arg}`); | ||||
|                 } | ||||
|                 const optionsNonNull = this._cloneExecOptions(this.options); | ||||
|                 if (!optionsNonNull.silent && optionsNonNull.outStream) { | ||||
|                     optionsNonNull.outStream.write(this._getCommandString(optionsNonNull) + os.EOL); | ||||
|                 } | ||||
|                 const state = new ExecState(optionsNonNull, this.toolPath); | ||||
|                 state.on('debug', (message) => { | ||||
|                     this._debug(message); | ||||
|                 }); | ||||
|                 const fileName = this._getSpawnFileName(); | ||||
|                 const cp = child.spawn(fileName, this._getSpawnArgs(optionsNonNull), this._getSpawnOptions(this.options, fileName)); | ||||
|                 const stdbuffer = ''; | ||||
|                 if (cp.stdout) { | ||||
|                     cp.stdout.on('data', (data) => { | ||||
|                         if (this.options.listeners && this.options.listeners.stdout) { | ||||
|                             this.options.listeners.stdout(data); | ||||
|                         } | ||||
|                         if (!optionsNonNull.silent && optionsNonNull.outStream) { | ||||
|                             optionsNonNull.outStream.write(data); | ||||
|                         } | ||||
|                         this._processLineBuffer(data, stdbuffer, (line) => { | ||||
|                             if (this.options.listeners && this.options.listeners.stdline) { | ||||
|                                 this.options.listeners.stdline(line); | ||||
|                             } | ||||
|                         }); | ||||
|                     }); | ||||
|                 } | ||||
|                 const errbuffer = ''; | ||||
|                 if (cp.stderr) { | ||||
|                     cp.stderr.on('data', (data) => { | ||||
|                         state.processStderr = true; | ||||
|                         if (this.options.listeners && this.options.listeners.stderr) { | ||||
|                             this.options.listeners.stderr(data); | ||||
|                         } | ||||
|                         if (!optionsNonNull.silent && | ||||
|                             optionsNonNull.errStream && | ||||
|                             optionsNonNull.outStream) { | ||||
|                             const s = optionsNonNull.failOnStdErr | ||||
|                                 ? optionsNonNull.errStream | ||||
|                                 : optionsNonNull.outStream; | ||||
|                             s.write(data); | ||||
|                         } | ||||
|                         this._processLineBuffer(data, errbuffer, (line) => { | ||||
|                             if (this.options.listeners && this.options.listeners.errline) { | ||||
|                                 this.options.listeners.errline(line); | ||||
|                             } | ||||
|                         }); | ||||
|                     }); | ||||
|                 } | ||||
|                 cp.on('error', (err) => { | ||||
|                     state.processError = err.message; | ||||
|                     state.processExited = true; | ||||
|                     state.processClosed = true; | ||||
|                     state.CheckComplete(); | ||||
|                 }); | ||||
|                 cp.on('exit', (code) => { | ||||
|                     state.processExitCode = code; | ||||
|                     state.processExited = true; | ||||
|                     this._debug(`Exit code ${code} received from tool '${this.toolPath}'`); | ||||
|                     state.CheckComplete(); | ||||
|                 }); | ||||
|                 cp.on('close', (code) => { | ||||
|                     state.processExitCode = code; | ||||
|                     state.processExited = true; | ||||
|                     state.processClosed = true; | ||||
|                     this._debug(`STDIO streams have closed for tool '${this.toolPath}'`); | ||||
|                     state.CheckComplete(); | ||||
|                 }); | ||||
|                 state.on('done', (error, exitCode) => { | ||||
|                     if (stdbuffer.length > 0) { | ||||
|                         this.emit('stdline', stdbuffer); | ||||
|                     } | ||||
|                     if (errbuffer.length > 0) { | ||||
|                         this.emit('errline', errbuffer); | ||||
|                     } | ||||
|                     cp.removeAllListeners(); | ||||
|                     if (error) { | ||||
|                         reject(error); | ||||
|                     } | ||||
|                     else { | ||||
|                         resolve(exitCode); | ||||
|                     } | ||||
|                 }); | ||||
|             }); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| exports.ToolRunner = ToolRunner; | ||||
| /** | ||||
|  * Convert an arg string to an array of args. Handles escaping | ||||
|  * | ||||
|  * @param    argString   string of arguments | ||||
|  * @returns  string[]    array of arguments | ||||
|  */ | ||||
| function argStringToArray(argString) { | ||||
|     const args = []; | ||||
|     let inQuotes = false; | ||||
|     let escaped = false; | ||||
|     let arg = ''; | ||||
|     function append(c) { | ||||
|         // we only escape double quotes. | ||||
|         if (escaped && c !== '"') { | ||||
|             arg += '\\'; | ||||
|         } | ||||
|         arg += c; | ||||
|         escaped = false; | ||||
|     } | ||||
|     for (let i = 0; i < argString.length; i++) { | ||||
|         const c = argString.charAt(i); | ||||
|         if (c === '"') { | ||||
|             if (!escaped) { | ||||
|                 inQuotes = !inQuotes; | ||||
|             } | ||||
|             else { | ||||
|                 append(c); | ||||
|             } | ||||
|             continue; | ||||
|         } | ||||
|         if (c === '\\' && escaped) { | ||||
|             append(c); | ||||
|             continue; | ||||
|         } | ||||
|         if (c === '\\' && inQuotes) { | ||||
|             escaped = true; | ||||
|             continue; | ||||
|         } | ||||
|         if (c === ' ' && !inQuotes) { | ||||
|             if (arg.length > 0) { | ||||
|                 args.push(arg); | ||||
|                 arg = ''; | ||||
|             } | ||||
|             continue; | ||||
|         } | ||||
|         append(c); | ||||
|     } | ||||
|     if (arg.length > 0) { | ||||
|         args.push(arg.trim()); | ||||
|     } | ||||
|     return args; | ||||
| } | ||||
| exports.argStringToArray = argStringToArray; | ||||
| class ExecState extends events.EventEmitter { | ||||
|     constructor(options, toolPath) { | ||||
|         super(); | ||||
|         this.processClosed = false; // tracks whether the process has exited and stdio is closed | ||||
|         this.processError = ''; | ||||
|         this.processExitCode = 0; | ||||
|         this.processExited = false; // tracks whether the process has exited | ||||
|         this.processStderr = false; // tracks whether stderr was written to | ||||
|         this.delay = 10000; // 10 seconds | ||||
|         this.done = false; | ||||
|         this.timeout = null; | ||||
|         if (!toolPath) { | ||||
|             throw new Error('toolPath must not be empty'); | ||||
|         } | ||||
|         this.options = options; | ||||
|         this.toolPath = toolPath; | ||||
|         if (options.delay) { | ||||
|             this.delay = options.delay; | ||||
|         } | ||||
|     } | ||||
|     CheckComplete() { | ||||
|         if (this.done) { | ||||
|             return; | ||||
|         } | ||||
|         if (this.processClosed) { | ||||
|             this._setResult(); | ||||
|         } | ||||
|         else if (this.processExited) { | ||||
|             this.timeout = setTimeout(ExecState.HandleTimeout, this.delay, this); | ||||
|         } | ||||
|     } | ||||
|     _debug(message) { | ||||
|         this.emit('debug', message); | ||||
|     } | ||||
|     _setResult() { | ||||
|         // determine whether there is an error | ||||
|         let error; | ||||
|         if (this.processExited) { | ||||
|             if (this.processError) { | ||||
|                 error = new Error(`There was an error when attempting to execute the process '${this.toolPath}'. This may indicate the process failed to start. Error: ${this.processError}`); | ||||
|             } | ||||
|             else if (this.processExitCode !== 0 && !this.options.ignoreReturnCode) { | ||||
|                 error = new Error(`The process '${this.toolPath}' failed with exit code ${this.processExitCode}`); | ||||
|             } | ||||
|             else if (this.processStderr && this.options.failOnStdErr) { | ||||
|                 error = new Error(`The process '${this.toolPath}' failed because one or more lines were written to the STDERR stream`); | ||||
|             } | ||||
|         } | ||||
|         // clear the timeout | ||||
|         if (this.timeout) { | ||||
|             clearTimeout(this.timeout); | ||||
|             this.timeout = null; | ||||
|         } | ||||
|         this.done = true; | ||||
|         this.emit('done', error, this.processExitCode); | ||||
|     } | ||||
|     static HandleTimeout(state) { | ||||
|         if (state.done) { | ||||
|             return; | ||||
|         } | ||||
|         if (!state.processClosed && state.processExited) { | ||||
|             const message = `The STDIO streams did not close within ${state.delay / | ||||
|                 1000} seconds of the exit event from process '${state.toolPath}'. This may indicate a child process inherited the STDIO streams and has not yet exited.`; | ||||
|             state._debug(message); | ||||
|         } | ||||
|         state._setResult(); | ||||
|     } | ||||
| } | ||||
| //# sourceMappingURL=toolrunner.js.map | ||||
							
								
								
									
										1
									
								
								node_modules/@actions/exec/lib/toolrunner.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/exec/lib/toolrunner.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										64
									
								
								node_modules/@actions/exec/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								node_modules/@actions/exec/package.json
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,64 @@ | ||||
| { | ||||
|   "_from": "@actions/exec@^1.0.0", | ||||
|   "_id": "@actions/exec@1.0.0", | ||||
|   "_inBundle": false, | ||||
|   "_integrity": "sha512-nquH0+XKng+Ll7rZfCojN7NWSbnGh+ltwUJhzfbLkmOJgxocGX2/yXcZLMyT9fa7+tByEow/NSTrBExNlEj9fw==", | ||||
|   "_location": "/@actions/exec", | ||||
|   "_phantomChildren": {}, | ||||
|   "_requested": { | ||||
|     "type": "range", | ||||
|     "registry": true, | ||||
|     "raw": "@actions/exec@^1.0.0", | ||||
|     "name": "@actions/exec", | ||||
|     "escapedName": "@actions%2fexec", | ||||
|     "scope": "@actions", | ||||
|     "rawSpec": "^1.0.0", | ||||
|     "saveSpec": null, | ||||
|     "fetchSpec": "^1.0.0" | ||||
|   }, | ||||
|   "_requiredBy": [ | ||||
|     "/", | ||||
|     "/@actions/tool-cache" | ||||
|   ], | ||||
|   "_resolved": "https://registry.npmjs.org/@actions/exec/-/exec-1.0.0.tgz", | ||||
|   "_shasum": "70c8b698c9baa02965c07da5f0b185ca56f0a955", | ||||
|   "_spec": "@actions/exec@^1.0.0", | ||||
|   "_where": "C:\\Users\\damccorm\\Documents\\setup-dotnet", | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/actions/toolkit/issues" | ||||
|   }, | ||||
|   "bundleDependencies": false, | ||||
|   "deprecated": false, | ||||
|   "description": "Actions exec lib", | ||||
|   "devDependencies": { | ||||
|     "@actions/io": "^1.0.0" | ||||
|   }, | ||||
|   "directories": { | ||||
|     "lib": "lib", | ||||
|     "test": "__tests__" | ||||
|   }, | ||||
|   "files": [ | ||||
|     "lib" | ||||
|   ], | ||||
|   "gitHead": "a40bce7c8d382aa3dbadaa327acbc696e9390e55", | ||||
|   "homepage": "https://github.com/actions/toolkit/tree/master/packages/exec", | ||||
|   "keywords": [ | ||||
|     "exec", | ||||
|     "actions" | ||||
|   ], | ||||
|   "license": "MIT", | ||||
|   "main": "lib/exec.js", | ||||
|   "name": "@actions/exec", | ||||
|   "publishConfig": { | ||||
|     "access": "public" | ||||
|   }, | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "git+https://github.com/actions/toolkit.git" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: run tests from root\" && exit 1", | ||||
|     "tsc": "tsc" | ||||
|   }, | ||||
|   "version": "1.0.0" | ||||
| } | ||||
							
								
								
									
										7
									
								
								node_modules/@actions/io/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/io/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| Copyright 2019 GitHub | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
							
								
								
									
										53
									
								
								node_modules/@actions/io/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								node_modules/@actions/io/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| # `@actions/io` | ||||
|  | ||||
| > Core functions for cli filesystem scenarios | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| #### mkdir -p | ||||
|  | ||||
| Recursively make a directory. Follows rules specified in [man mkdir](https://linux.die.net/man/1/mkdir) with the `-p` option specified: | ||||
|  | ||||
| ``` | ||||
| const io = require('@actions/io'); | ||||
|  | ||||
| await io.mkdirP('path/to/make'); | ||||
| ``` | ||||
|  | ||||
| #### cp/mv | ||||
|  | ||||
| Copy or move files or folders. Follows rules specified in [man cp](https://linux.die.net/man/1/cp) and [man mv](https://linux.die.net/man/1/mv): | ||||
|  | ||||
| ``` | ||||
| const io = require('@actions/io'); | ||||
|  | ||||
| // Recursive must be true for directories | ||||
| const options = { recursive: true, force: false } | ||||
|  | ||||
| await io.cp('path/to/directory', 'path/to/dest', options); | ||||
| await io.mv('path/to/file', 'path/to/dest'); | ||||
| ``` | ||||
|  | ||||
| #### rm -rf | ||||
|  | ||||
| Remove a file or folder recursively. Follows rules specified in [man rm](https://linux.die.net/man/1/rm) with the `-r` and `-f` rules specified. | ||||
|  | ||||
| ``` | ||||
| const io = require('@actions/io'); | ||||
|  | ||||
| await io.rmRF('path/to/directory'); | ||||
| await io.rmRF('path/to/file'); | ||||
| ``` | ||||
|  | ||||
| #### which | ||||
|  | ||||
| Get the path to a tool and resolves via paths. Follows the rules specified in [man which](https://linux.die.net/man/1/which). | ||||
|  | ||||
| ``` | ||||
| const exec = require('@actions/exec'); | ||||
| const io = require('@actions/io'); | ||||
|  | ||||
| const pythonPath: string = await io.which('python', true) | ||||
|  | ||||
| await exec.exec(`"${pythonPath}"`, ['main.py']); | ||||
| ``` | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	