You've already forked setup-dotnet
							
							
				mirror of
				https://github.com/actions/setup-dotnet.git
				synced 2025-10-26 05:05:08 +07:00 
			
		
		
		
	Compare commits
	
		
			7 Commits
		
	
	
		
			v3.2.0
			...
			remove-cdn
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 603ff3ab1c | |||
| d284574c05 | |||
| bac33b41f7 | |||
| f56a6a6861 | |||
| fb81433816 | |||
| 9798ae12d7 | |||
| aab9aab748 | 
| @ -1,6 +0,0 @@ | |||||||
| # Ignore list |  | ||||||
| /* |  | ||||||
|  |  | ||||||
| # Do not ignore these folders: |  | ||||||
| !__tests__/ |  | ||||||
| !src/ |  | ||||||
							
								
								
									
										51
									
								
								.eslintrc.js
									
									
									
									
									
								
							
							
						
						
									
										51
									
								
								.eslintrc.js
									
									
									
									
									
								
							| @ -1,51 +0,0 @@ | |||||||
| // This is a reusable configuration file copied from https://github.com/actions/reusable-workflows/tree/main/reusable-configurations. Please don't make changes to this file as it's the subject of an automatic update. |  | ||||||
| module.exports = { |  | ||||||
|   extends: [ |  | ||||||
|     'eslint:recommended', |  | ||||||
|     'plugin:@typescript-eslint/recommended', |  | ||||||
|     'plugin:eslint-plugin-jest/recommended', |  | ||||||
|     'eslint-config-prettier' |  | ||||||
|   ], |  | ||||||
|   parser: '@typescript-eslint/parser', |  | ||||||
|   plugins: ['@typescript-eslint', 'eslint-plugin-node', 'eslint-plugin-jest'], |  | ||||||
|   rules: { |  | ||||||
|     '@typescript-eslint/no-require-imports': 'error', |  | ||||||
|     '@typescript-eslint/no-non-null-assertion': 'off', |  | ||||||
|     '@typescript-eslint/no-explicit-any': 'off', |  | ||||||
|     '@typescript-eslint/no-empty-function': 'off', |  | ||||||
|     '@typescript-eslint/ban-ts-comment': [ |  | ||||||
|       'error', |  | ||||||
|       { |  | ||||||
|         'ts-ignore': 'allow-with-description' |  | ||||||
|       } |  | ||||||
|     ], |  | ||||||
|     'no-console': 'error', |  | ||||||
|     'yoda': 'error', |  | ||||||
|     'prefer-const': [ |  | ||||||
|       'error', |  | ||||||
|       { |  | ||||||
|         destructuring: 'all' |  | ||||||
|       } |  | ||||||
|     ], |  | ||||||
|     'no-control-regex': 'off', |  | ||||||
|     'no-constant-condition': ['error', {checkLoops: false}], |  | ||||||
|     'node/no-extraneous-import': 'error' |  | ||||||
|   }, |  | ||||||
|   overrides: [ |  | ||||||
|     { |  | ||||||
|       files: ['**/*{test,spec}.ts'], |  | ||||||
|       rules: { |  | ||||||
|         '@typescript-eslint/no-unused-vars': 'off', |  | ||||||
|         'jest/no-standalone-expect': 'off', |  | ||||||
|         'jest/no-conditional-expect': 'off', |  | ||||||
|         'no-console': 'off', |  | ||||||
|  |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   env: { |  | ||||||
|     node: true, |  | ||||||
|     es6: true, |  | ||||||
|     'jest/globals': true |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
							
								
								
									
										1
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @ -1,2 +1 @@ | |||||||
| * text=auto eol=lf |  | ||||||
| .licenses/** -diff linguist-generated=true | .licenses/** -diff linguist-generated=true | ||||||
							
								
								
									
										2
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
								
							| @ -1 +1 @@ | |||||||
| * @actions/setup-actions-team | * @actions/virtual-environments-owners | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								.github/workflows/basic-validation.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.github/workflows/basic-validation.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,17 +0,0 @@ | |||||||
| name: Basic validation |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   pull_request: |  | ||||||
|     paths-ignore: |  | ||||||
|       - '**.md' |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
|       - releases/* |  | ||||||
|     paths-ignore: |  | ||||||
|       - '**.md' |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   call-basic-validation: |  | ||||||
|     name: Basic validation |  | ||||||
|     uses: actions/reusable-workflows/.github/workflows/basic-validation.yml@main |  | ||||||
							
								
								
									
										41
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										41
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,3 +1,8 @@ | |||||||
|  | # `dist/index.js` is a special file in Actions. | ||||||
|  | # When you reference an action with `uses:` in a workflow, | ||||||
|  | # `index.js` is the code that will run. | ||||||
|  | # For our project, we generate this file through a build process from other source files. | ||||||
|  | # We need to make sure the checked-in `index.js` actually matches what we expect it to be. | ||||||
| name: Check dist/ | name: Check dist/ | ||||||
|  |  | ||||||
| on: | on: | ||||||
| @ -12,6 +17,36 @@ on: | |||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   call-check-dist: |   check-dist: | ||||||
|     name: Check dist/ |     runs-on: ubuntu-latest | ||||||
|     uses: actions/reusable-workflows/.github/workflows/check-dist.yml@main |  | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|  |       - name: Set Node.js 16 | ||||||
|  |         uses: actions/setup-node@v3 | ||||||
|  |         with: | ||||||
|  |           node-version: 16.x | ||||||
|  |           cache: npm | ||||||
|  |  | ||||||
|  |       - name: Install dependencies | ||||||
|  |         run: npm ci --ignore-scripts | ||||||
|  |  | ||||||
|  |       - name: Rebuild the dist/ directory | ||||||
|  |         run: npm run build | ||||||
|  |  | ||||||
|  |       - name: Compare the expected and actual dist/ directories | ||||||
|  |         run: | | ||||||
|  |           if [ "$(git diff --ignore-space-at-eol dist/ | wc -l)" -gt "0" ]; then | ||||||
|  |             echo "Detected uncommitted changes after build.  See status below:" | ||||||
|  |             git diff | ||||||
|  |             exit 1 | ||||||
|  |           fi | ||||||
|  |         id: diff | ||||||
|  |  | ||||||
|  |       # If index.js was different than expected, upload the expected version as an artifact | ||||||
|  |       - uses: actions/upload-artifact@v4 | ||||||
|  |         if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||||
|  |         with: | ||||||
|  |           name: dist | ||||||
|  |           path: dist/ | ||||||
|  | |||||||
							
								
								
									
										66
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										66
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,14 +1,70 @@ | |||||||
| name: CodeQL analysis | # For most projects, this workflow file will not need changing; you simply need | ||||||
|  | # to commit it to your repository. | ||||||
|  | # | ||||||
|  | # You may wish to alter this file to override the set of languages analyzed, | ||||||
|  | # or to provide custom queries or build logic. | ||||||
|  | # | ||||||
|  | # ******** NOTE ******** | ||||||
|  | # We have attempted to detect the languages in your repository. Please check | ||||||
|  | # the `language` matrix defined below to confirm you have the correct set of | ||||||
|  | # supported CodeQL languages. | ||||||
|  | # | ||||||
|  | name: "CodeQL" | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ main ] |     branches: [ main ] | ||||||
|   pull_request: |   pull_request: | ||||||
|  |     # The branches below must be a subset of the branches above | ||||||
|     branches: [ main ] |     branches: [ main ] | ||||||
|   schedule: |   schedule: | ||||||
|     - cron: '0 3 * * 0' |     - cron: '23 19 * * 0' | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   call-codeQL-analysis: |   analyze: | ||||||
|     name: CodeQL analysis |     name: Analyze | ||||||
|     uses: actions/reusable-workflows/.github/workflows/codeql-analysis.yml@main |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       actions: read | ||||||
|  |       contents: read | ||||||
|  |       security-events: write | ||||||
|  |  | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         language: [ 'javascript' ] | ||||||
|  |         # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ] | ||||||
|  |         # Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout repository | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|  |     # Initializes the CodeQL tools for scanning. | ||||||
|  |     - name: Initialize CodeQL | ||||||
|  |       uses: github/codeql-action/init@v2 | ||||||
|  |       with: | ||||||
|  |         languages: ${{ matrix.language }} | ||||||
|  |         # If you wish to specify custom queries, you can do so here or in a config file. | ||||||
|  |         # By default, queries listed here will override any specified in a config file. | ||||||
|  |         # Prefix the list here with "+" to use these queries and those in the config file. | ||||||
|  |         # queries: ./path/to/local/query, your-org/your-repo/queries@main | ||||||
|  |  | ||||||
|  |     # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). | ||||||
|  |     # If this step fails, then you should remove it and run the build manually (see below) | ||||||
|  |     - name: Autobuild | ||||||
|  |       uses: github/codeql-action/autobuild@v2 | ||||||
|  |  | ||||||
|  |     # ℹ️ Command-line programs to run using the OS shell. | ||||||
|  |     # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun | ||||||
|  |  | ||||||
|  |     # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines | ||||||
|  |     #    and modify them (or add more) to build your code if your project | ||||||
|  |     #    uses a compiled language | ||||||
|  |  | ||||||
|  |     #- run: | | ||||||
|  |     #   make bootstrap | ||||||
|  |     #   make release | ||||||
|  |  | ||||||
|  |     - name: Perform CodeQL Analysis | ||||||
|  |       uses: github/codeql-action/analyze@v2 | ||||||
|  | |||||||
							
								
								
									
										428
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										428
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,428 +0,0 @@ | |||||||
| name: e2e tests |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   pull_request: |  | ||||||
|     paths-ignore: |  | ||||||
|       - '**.md' |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
|       - releases/* |  | ||||||
|     paths-ignore: |  | ||||||
|       - '**.md' |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   test-setup-multiple-versions: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Setup dotnet 2.2.402, 3.1.404 and 3.0.x |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: | |  | ||||||
|             2.2.402 |  | ||||||
|             3.1.404 |  | ||||||
|             3.0.x |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^2.2.402$", "^3.1.404$", "^3.0" |  | ||||||
|  |  | ||||||
|   test-setup-full-version: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       # 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 variable 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 |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^3.1.201$", "^2.2.402$" -CheckNugetConfig |  | ||||||
|  |  | ||||||
|   test-setup-without-patch-version: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       # 2.0, 3.0, 5.0 needs to be in single quotes to interpret as a string instead of as an integer |  | ||||||
|       - name: Setup dotnet '3.1' |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: '3.1' |  | ||||||
|       - name: Setup dotnet '2.2' |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: '2.2' |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^3.1", "^2.2" |  | ||||||
|  |  | ||||||
|   test-setup-prerelease-version: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Setup dotnet '3.1.100-preview1-014459' |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: '3.1.100-preview1-014459' |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "3.1.100-preview1-014459" |  | ||||||
|  |  | ||||||
|   test-setup-latest-patch-version: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Setup dotnet 3.1.x |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 3.1.x |  | ||||||
|       - name: Setup dotnet 2.2.X |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 2.2.X |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^2.2", "^3.1" |  | ||||||
|  |  | ||||||
|   test-ABCxx-syntax: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|  |  | ||||||
|       - name: Setup dotnet 6.0.4xx |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: '6.0.4xx' |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^6\.0\.4\d{2}" |  | ||||||
|  |  | ||||||
|   test-setup-with-wildcard: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Setup dotnet 3.1.* |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 3.1.* |  | ||||||
|       - name: Setup dotnet 2.2.* |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 2.2.* |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^3.1", "^2.2" |  | ||||||
|  |  | ||||||
|   test-setup-global-json-specified-and-version: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Write global.json |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           mkdir subdirectory |  | ||||||
|           echo '{"sdk":{"version": "2.2.207","rollForward": "latestFeature"}}' > ./subdirectory/global.json |  | ||||||
|       - name: Setup dotnet |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 3.1 |  | ||||||
|           global-json-file: ./subdirectory/global.json |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^2.2", "^3.1" |  | ||||||
|  |  | ||||||
|   test-setup-global-json-only: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Write global.json |  | ||||||
|         shell: bash |  | ||||||
|         run: | |  | ||||||
|           mkdir subdirectory |  | ||||||
|           echo '{"sdk":{"version": "2.2.207","rollForward": "latestFeature"}}' > ./subdirectory/global.json |  | ||||||
|       - name: Setup dotnet |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           global-json-file: ./subdirectory/global.json |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^2.2" |  | ||||||
|  |  | ||||||
|   test-setup-with-dotnet-quality: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|  |  | ||||||
|       - name: Setup dotnet 7.0 with preview quality |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: '7.0' |  | ||||||
|           dotnet-quality: 'preview' |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^7\.0\.\d+-" |  | ||||||
|  |  | ||||||
|   test-setup-with-cache: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] |  | ||||||
|     env: |  | ||||||
|       NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Copy NuGet lock file to root |  | ||||||
|         shell: bash |  | ||||||
|         run: cp ./__tests__/e2e-test-csproj/packages.lock.json ./packages.lock.json |  | ||||||
|       - name: Setup .NET Core 3.1 |  | ||||||
|         id: setup-dotnet |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 3.1 |  | ||||||
|           cache: true |  | ||||||
|       - name: Verify Cache |  | ||||||
|         if: steps.setup-dotnet.outputs.cache-hit == 'true' |  | ||||||
|         shell: bash |  | ||||||
|         run: if [[ -e ${NUGET_PACKAGES} ]]; then exit 0; else exit 1; fi |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^3.1" |  | ||||||
|  |  | ||||||
|   test-setup-with-cache-dependency-path: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] |  | ||||||
|     env: |  | ||||||
|       NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Setup .NET Core 3.1 |  | ||||||
|         id: setup-dotnet |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 3.1 |  | ||||||
|           cache: true |  | ||||||
|           cache-dependency-path: './__tests__/e2e-test-csproj/packages.lock.json' |  | ||||||
|       - name: Verify Cache |  | ||||||
|         if: steps.setup-dotnet.outputs.cache-hit == 'true' |  | ||||||
|         shell: bash |  | ||||||
|         run: if [[ -e ${NUGET_PACKAGES} ]]; then exit 0; else exit 1; fi |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^3.1" |  | ||||||
|  |  | ||||||
|   test-dotnet-version-output-during-single-version-installation: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|  |  | ||||||
|       - name: Setup dotnet 6.0.401 |  | ||||||
|         uses: ./ |  | ||||||
|         id: step1 |  | ||||||
|         with: |  | ||||||
|           dotnet-version: '6.0.401' |  | ||||||
|  |  | ||||||
|       - name: Verify value of the dotnet-version output |  | ||||||
|         shell: pwsh |  | ||||||
|         run: | |  | ||||||
|           $version = & dotnet --version |  | ||||||
|           Write-Host "Installed version: $version" |  | ||||||
|           if (-not ($version -eq '${{steps.step1.outputs.dotnet-version}}')) { throw "Unexpected output value" } |  | ||||||
|  |  | ||||||
|   test-dotnet-version-output-during-multiple-version-installation: |  | ||||||
|     runs-on: ${{ matrix.operating-system }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|  |  | ||||||
|       - name: Setup dotnet 6.0.401, 5.0.408, 7.0.100-rc.1.22431.12 |  | ||||||
|         uses: ./ |  | ||||||
|         id: step2 |  | ||||||
|         with: |  | ||||||
|           dotnet-version: | |  | ||||||
|             7.0.100-rc.1.22431.12 |  | ||||||
|             6.0.401 |  | ||||||
|             5.0.408 |  | ||||||
|  |  | ||||||
|       - name: Verify value of the dotnet-version output |  | ||||||
|         shell: pwsh |  | ||||||
|         run: | |  | ||||||
|           $version = "7.0.100-rc.1.22431.12" |  | ||||||
|           if (-not ($version -eq '${{steps.step2.outputs.dotnet-version}}')) { throw "Unexpected output value" } |  | ||||||
|  |  | ||||||
|   test-proxy: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     container: |  | ||||||
|       image: ubuntu:latest |  | ||||||
|       options: --dns 127.0.0.1 |  | ||||||
|     services: |  | ||||||
|       squid-proxy: |  | ||||||
|         image: ubuntu/squid:latest |  | ||||||
|         ports: |  | ||||||
|           - 3128:3128 |  | ||||||
|     env: |  | ||||||
|       https_proxy: http://squid-proxy:3128 |  | ||||||
|       http_proxy: http://squid-proxy:3128 |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Install Powershell |  | ||||||
|         run: | |  | ||||||
|           apt-get update |  | ||||||
|           apt-get install -y wget apt-transport-https software-properties-common |  | ||||||
|           wget -q "https://packages.microsoft.com/config/ubuntu/$(lsb_release -rs)/packages-microsoft-prod.deb" |  | ||||||
|           dpkg -i packages-microsoft-prod.deb |  | ||||||
|           rm packages-microsoft-prod.deb |  | ||||||
|           apt-get update |  | ||||||
|           apt-get install -y powershell |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - name: Setup dotnet 6.0 |  | ||||||
|         uses: ./ |  | ||||||
|         with: |  | ||||||
|           dotnet-version: 6.0 |  | ||||||
|           source-url: https://api.nuget.org/v3/index.json |  | ||||||
|         env: |  | ||||||
|           NUGET_AUTH_TOKEN: NOTATOKEN |  | ||||||
|       - name: Verify dotnet |  | ||||||
|         shell: pwsh |  | ||||||
|         run: | |  | ||||||
|           __tests__/verify-dotnet.ps1 -Patterns "^6.0" -CheckNugetConfig |  | ||||||
|  |  | ||||||
|   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@v3 |  | ||||||
|       - name: Clear toolcache |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} |  | ||||||
|       - 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 |  | ||||||
|         shell: pwsh |  | ||||||
|         run: __tests__/verify-dotnet.ps1 -Patterns "^3.1.201$" -CheckNugetConfig |  | ||||||
							
								
								
									
										16
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							| @ -10,6 +10,16 @@ on: | |||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   call-licensed: |   test: | ||||||
|     name: Licensed |     runs-on: ubuntu-latest | ||||||
|     uses: actions/reusable-workflows/.github/workflows/licensed.yml@main |     name: Check licenses | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |       - run: npm ci --ignore-scripts | ||||||
|  |       - name: Install licensed | ||||||
|  |         run: | | ||||||
|  |           cd $RUNNER_TEMP | ||||||
|  |           curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.4.4/licensed-3.4.4-linux-x64.tar.gz | ||||||
|  |           sudo tar -xzf licensed.tar.gz | ||||||
|  |           sudo mv licensed /usr/local/bin/licensed | ||||||
|  |       - run: licensed status | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| name: Release new action version | name: Release new action version | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   release: |   release: | ||||||
|     types: [released] |     types: [released] | ||||||
| @ -23,7 +22,7 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|     - name: Update the ${{ env.TAG_NAME }} tag |     - name: Update the ${{ env.TAG_NAME }} tag | ||||||
|       id: update-major-tag |       id: update-major-tag | ||||||
|         uses: actions/publish-action@v0.2.2 |       uses: actions/publish-action@v0.1.0 | ||||||
|       with: |       with: | ||||||
|         source-tag: ${{ env.TAG_NAME }} |         source-tag: ${{ env.TAG_NAME }} | ||||||
|         slack-webhook: ${{ secrets.SLACK_WEBHOOK }} |         slack-webhook: ${{ secrets.SLACK_WEBHOOK }} | ||||||
							
								
								
									
										10
									
								
								.github/workflows/test-dotnet.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/test-dotnet.yml
									
									
									
									
										vendored
									
									
								
							| @ -17,8 +17,8 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macOS-latest] |         operating-system: [ubuntu-22.04, windows-latest, macOS-latest] | ||||||
|         dotnet-version: ['2.1', '2.2', '3.0', '3.1', '5.0', '6.0', '7.0', '8.0'] |         dotnet-version: ['2.1', '2.2', '3.0', '3.1', '5.0'] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -29,7 +29,9 @@ jobs: | |||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
|           dotnet-version: ${{ matrix.dotnet-version }} |           dotnet-version: ${{ matrix.dotnet-version }} | ||||||
|       - name: Verify installed version |       - name: Check installed version | ||||||
|         shell: pwsh |         shell: pwsh | ||||||
|         run: | |         run: | | ||||||
|           __tests__/verify-dotnet.ps1 -Patterns "^${{ matrix.dotnet-version }}" |           $version = & dotnet --version | ||||||
|  |           Write-Host "Installed version: $version" | ||||||
|  |           if (-not $version.StartsWith("${{ matrix.dotnet-version }}")) { throw "Unexpected version" } | ||||||
							
								
								
									
										11
									
								
								.github/workflows/update-config-files.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/workflows/update-config-files.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,11 +0,0 @@ | |||||||
| name: Update configuration files |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   schedule: |  | ||||||
|     - cron: '0 3 * * 0' |  | ||||||
|   workflow_dispatch: |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   call-update-configuration-files: |  | ||||||
|     name: Update configuration files |  | ||||||
|     uses: actions/reusable-workflows/.github/workflows/update-config-files.yml@main |  | ||||||
							
								
								
									
										244
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,244 @@ | |||||||
|  | name: Main workflow | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   pull_request: | ||||||
|  |     paths-ignore: | ||||||
|  |       - '**.md' | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |       - releases/* | ||||||
|  |     paths-ignore: | ||||||
|  |       - '**.md' | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-latest, windows-latest, macOS-latest] | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout | ||||||
|  |       uses: actions/checkout@v3 | ||||||
|  |     - name: Set Node.js 16 | ||||||
|  |       uses: actions/setup-node@v3 | ||||||
|  |       with: | ||||||
|  |         node-version: 16.x | ||||||
|  |         cache: npm | ||||||
|  |     - run: npm ci --ignore-scripts | ||||||
|  |     - 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 | ||||||
|  |  | ||||||
|  |   test-setup-multiple-versions: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-22.04, windows-latest, macOS-latest] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear toolcache | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} | ||||||
|  |       - name: Setup dotnet 2.2.402 and 3.1.404 | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: | | ||||||
|  |             2.2.402 | ||||||
|  |             3.1.404 | ||||||
|  |             3.0.x | ||||||
|  |       - name: Verify dotnet | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/verify-dotnet.ps1 2.2.402 3.1.404 '3.0' | ||||||
|  |  | ||||||
|  |   test-setup-full-version: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-22.04, windows-latest, macos-13] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear toolcache | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} | ||||||
|  |       # 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 nuget config file | ||||||
|  |         shell: pwsh | ||||||
|  |         run: | | ||||||
|  |           if (-Not (Test-Path "../nuget.config")) { throw "nuget file not generated correctly" } | ||||||
|  |       - name: Verify dotnet | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/verify-dotnet.ps1 3.1.201 2.2.402 | ||||||
|  |  | ||||||
|  |   test-setup-without-patch-version: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-22.04, windows-latest, macOS-latest] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear toolcache | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} | ||||||
|  |       # 2.0, 3.0, 5.0 needs to be in single quotes to interpret as a string instead of as an integer | ||||||
|  |       - name: Setup dotnet '3.1' | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: '3.1' | ||||||
|  |       - name: Setup dotnet '2.2' | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: '2.2' | ||||||
|  |       - name: Verify dotnet | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/verify-dotnet.ps1 3.1 2.2 | ||||||
|  |  | ||||||
|  |   test-setup-latest-patch-version: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-22.04, windows-latest, macOS-latest] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear toolcache | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} | ||||||
|  |       - name: Setup dotnet 3.1.x | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: 3.1.x | ||||||
|  |       - name: Setup dotnet 2.2.x | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: 2.2.x | ||||||
|  |       - name: Verify dotnet | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/verify-dotnet.ps1 3.1 2.2 | ||||||
|  |  | ||||||
|  |   test-setup-with-wildcard: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-22.04, windows-latest, macOS-latest] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear toolcache | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} | ||||||
|  |       - name: Setup dotnet 3.1.* | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: 3.1.* | ||||||
|  |       - name: Setup dotnet 2.2.* | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: 2.2.* | ||||||
|  |       - name: Verify dotnet | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/verify-dotnet.ps1 3.1 2.2 | ||||||
|  |  | ||||||
|  |   test-setup-global-json-specified-and-version: | ||||||
|  |     runs-on: ${{ matrix.operating-system }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         operating-system: [ubuntu-22.04, windows-latest, macOS-latest] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear toolcache | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/clear-toolcache.ps1 ${{ runner.os }} | ||||||
|  |       - name: Write global.json | ||||||
|  |         shell: bash | ||||||
|  |         run: | | ||||||
|  |           mkdir subdirectory | ||||||
|  |           echo '{"sdk":{"version": "2.2","rollForward": "latestFeature"}}' > ./subdirectory/global.json | ||||||
|  |       - name: Setup dotnet | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           dotnet-version: 3.1 | ||||||
|  |           global-json-file: ./subdirectory/global.json | ||||||
|  |       - name: Verify dotnet | ||||||
|  |         shell: pwsh | ||||||
|  |         run: __tests__/verify-dotnet.ps1 2.2 3.1 | ||||||
|  |  | ||||||
|  |   test-proxy: | ||||||
|  |     runs-on: ubuntu-20.04 | ||||||
|  |     container: | ||||||
|  |       image: ubuntu:20.04 | ||||||
|  |       options: --dns 127.0.0.1 | ||||||
|  |     services: | ||||||
|  |       squid-proxy: | ||||||
|  |         image: ubuntu/squid:latest | ||||||
|  |         ports: | ||||||
|  |           - 3128:3128 | ||||||
|  |     env: | ||||||
|  |       https_proxy: http://squid-proxy:3128 | ||||||
|  |       http_proxy: http://squid-proxy:3128 | ||||||
|  |       DOTNET_SYSTEM_GLOBALIZATION_INVARIANT: true | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Clear tool cache | ||||||
|  |         run: rm -rf "/usr/share/dotnet" | ||||||
|  |       - name: Install curl | ||||||
|  |         run: | | ||||||
|  |           apt update | ||||||
|  |           apt -y install curl libssl1.1 libssl-dev | ||||||
|  |       - 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 | ||||||
|  |  | ||||||
|  |   test-bypass-proxy: | ||||||
|  |     runs-on: ubuntu-22.04 | ||||||
|  |     env: | ||||||
|  |       https_proxy: http://no-such-proxy:3128 | ||||||
|  |       no_proxy: github.com,download.visualstudio.microsoft.com,api.nuget.org,builds.dotnet.microsoft.com,ci.dot.net | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - 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 | ||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -3,8 +3,8 @@ global.json | |||||||
| lib/ | lib/ | ||||||
| node_modules/ | node_modules/ | ||||||
| __tests__/runner/* | __tests__/runner/* | ||||||
| __tests__/e2e-test-csproj/bin/ | __tests__/sample-csproj/bin/ | ||||||
| __tests__/e2e-test-csproj/obj/ | __tests__/sample-csproj/obj/ | ||||||
|  |  | ||||||
| # Rest of the file pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | # Rest of the file pulled from https://github.com/github/gitignore/blob/master/Node.gitignore | ||||||
| # Logs | # Logs | ||||||
|  | |||||||
| @ -2,4 +2,3 @@ | |||||||
| . "$(dirname -- "$0")/_/husky.sh" | . "$(dirname -- "$0")/_/husky.sh" | ||||||
|  |  | ||||||
| npm run format | npm run format | ||||||
| npm run lint:fix |  | ||||||
|  | |||||||
| @ -3,4 +3,3 @@ | |||||||
|  |  | ||||||
| # Tests are not run at push time since they can take 2-4 minutes to complete | # Tests are not run at push time since they can take 2-4 minutes to complete | ||||||
| npm run format-check | npm run format-check | ||||||
| npm run lint |  | ||||||
|  | |||||||
| @ -3,7 +3,6 @@ sources: | |||||||
|  |  | ||||||
| allowed: | allowed: | ||||||
|   - apache-2.0 |   - apache-2.0 | ||||||
|   - 0bsd |  | ||||||
|   - bsd-2-clause |   - bsd-2-clause | ||||||
|   - bsd-3-clause |   - bsd-3-clause | ||||||
|   - isc |   - isc | ||||||
| @ -13,4 +12,3 @@ allowed: | |||||||
|  |  | ||||||
| reviewed: | reviewed: | ||||||
|   npm: |   npm: | ||||||
|     - sax # ISC + MIT |  | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										20
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,20 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@actions/cache" |  | ||||||
| version: 3.2.1 |  | ||||||
| type: npm |  | ||||||
| summary: Actions cache lib |  | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/cache |  | ||||||
| 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: [] |  | ||||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: "@actions/core" | name: "@actions/core" | ||||||
| version: 1.10.0 | version: 1.6.0 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions core lib | summary: Actions core lib | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/core | homepage: https://github.com/actions/toolkit/tree/main/packages/core | ||||||
|  | |||||||
							
								
								
									
										30
									
								
								.licenses/npm/@actions/exec.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										30
									
								
								.licenses/npm/@actions/exec.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,20 +1,30 @@ | |||||||
| --- | --- | ||||||
| name: "@actions/exec" | name: "@actions/exec" | ||||||
| version: 1.1.1 | version: 1.0.4 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions exec lib | summary: Actions exec lib | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/exec | homepage: https://github.com/actions/toolkit/tree/master/packages/exec | ||||||
| license: mit | license: mit | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE.md | - sources: Auto-generated MIT license text | ||||||
|   text: |- |   text: | | ||||||
|     The MIT License (MIT) |     MIT License | ||||||
|  |  | ||||||
|     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: | ||||||
|  |  | ||||||
|     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 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, | ||||||
|     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. |     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: [] | notices: [] | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								.licenses/npm/@actions/glob-0.1.2.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										20
									
								
								.licenses/npm/@actions/glob-0.1.2.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,20 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@actions/glob" |  | ||||||
| version: 0.1.2 |  | ||||||
| type: npm |  | ||||||
| summary: Actions glob lib |  | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/glob |  | ||||||
| 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: [] |  | ||||||
							
								
								
									
										20
									
								
								.licenses/npm/@actions/glob-0.3.0.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										20
									
								
								.licenses/npm/@actions/glob-0.3.0.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,20 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@actions/glob" |  | ||||||
| version: 0.3.0 |  | ||||||
| type: npm |  | ||||||
| summary: Actions glob lib |  | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/glob |  | ||||||
| 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,9 +1,9 @@ | |||||||
| --- | --- | ||||||
| name: "@actions/http-client" | name: "@actions/http-client" | ||||||
| version: 2.0.1 | version: 1.0.11 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions Http Client | summary: Actions Http Client | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/http-client | homepage: https://github.com/actions/http-client#readme | ||||||
| license: mit | license: mit | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE | - sources: LICENSE | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@actions/http-client-1.0.8.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@actions/http-client-1.0.8.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | |||||||
|  | --- | ||||||
|  | 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: [] | ||||||
							
								
								
									
										30
									
								
								.licenses/npm/@actions/io.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										30
									
								
								.licenses/npm/@actions/io.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,20 +1,30 @@ | |||||||
| --- | --- | ||||||
| name: "@actions/io" | name: "@actions/io" | ||||||
| version: 1.1.2 | version: 1.0.2 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions io lib | summary: Actions io lib | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/io | homepage: https://github.com/actions/toolkit/tree/master/packages/io | ||||||
| license: mit | license: mit | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE.md | - sources: Auto-generated MIT license text | ||||||
|   text: |- |   text: | | ||||||
|     The MIT License (MIT) |     MIT License | ||||||
|  |  | ||||||
|     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: | ||||||
|  |  | ||||||
|     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 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, | ||||||
|     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. |     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: [] | notices: [] | ||||||
|  | |||||||
							
								
								
									
										32
									
								
								.licenses/npm/@azure/abort-controller.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@azure/abort-controller.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/abort-controller" |  | ||||||
| version: 1.1.0 |  | ||||||
| type: npm |  | ||||||
| summary: Microsoft Azure SDK for JavaScript - Aborter |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/core/abort-controller/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/@azure/core-auth.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/@azure/core-auth.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/core-auth" |  | ||||||
| version: 1.4.0 |  | ||||||
| type: npm |  | ||||||
| summary: Provides low-level interfaces and helper methods for authentication in Azure |  | ||||||
|   SDK |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/core/core-auth/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/@azure/core-http.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/@azure/core-http.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/core-http" |  | ||||||
| version: 3.0.1 |  | ||||||
| type: npm |  | ||||||
| summary: Isomorphic client Runtime for Typescript/node.js/browser javascript client |  | ||||||
|   libraries generated using AutoRest |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/core/core-http/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/@azure/core-lro.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/@azure/core-lro.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/core-lro" |  | ||||||
| version: 2.5.2 |  | ||||||
| type: npm |  | ||||||
| summary: Isomorphic client library for supporting long-running operations in node.js |  | ||||||
|   and browser. |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/core/core-lro/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@azure/core-paging.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@azure/core-paging.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/core-paging" |  | ||||||
| version: 1.5.0 |  | ||||||
| type: npm |  | ||||||
| summary: Core types for paging async iterable iterators |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/core/core-paging/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@azure/core-tracing.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@azure/core-tracing.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/core-tracing" |  | ||||||
| version: 1.0.0-preview.13 |  | ||||||
| type: npm |  | ||||||
| summary: Provides low-level interfaces and helper methods for tracing in Azure SDK |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/core/core-tracing/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@azure/core-util.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@azure/core-util.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/core-util" |  | ||||||
| version: 1.3.1 |  | ||||||
| type: npm |  | ||||||
| summary: Core library for shared utility methods |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/core/core-util/ |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@azure/logger.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@azure/logger.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/logger" |  | ||||||
| version: 1.0.4 |  | ||||||
| type: npm |  | ||||||
| summary: Microsoft Azure SDK for JavaScript - Logger |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/core/logger/README.md |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/@azure/ms-rest-js.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/@azure/ms-rest-js.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/ms-rest-js" |  | ||||||
| version: 2.6.6 |  | ||||||
| type: npm |  | ||||||
| summary: Isomorphic client Runtime for Typescript/node.js/browser javascript client |  | ||||||
|   libraries generated using AutoRest |  | ||||||
| homepage: https://github.com/Azure/ms-rest-js |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: |2 |  | ||||||
|         MIT License |  | ||||||
|  |  | ||||||
|         Copyright (c) Microsoft Corporation. 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 |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@azure/storage-blob.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@azure/storage-blob.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@azure/storage-blob" |  | ||||||
| version: 12.14.0 |  | ||||||
| type: npm |  | ||||||
| summary: Microsoft Azure Storage SDK for JavaScript - Blob |  | ||||||
| homepage: https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/storage/storage-blob/ |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2020 Microsoft |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										223
									
								
								.licenses/npm/@opentelemetry/api.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										223
									
								
								.licenses/npm/@opentelemetry/api.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,223 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@opentelemetry/api" |  | ||||||
| version: 1.4.1 |  | ||||||
| type: npm |  | ||||||
| summary: Public API for OpenTelemetry |  | ||||||
| homepage: https://github.com/open-telemetry/opentelemetry-js/tree/main/api |  | ||||||
| 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 [yyyy] [name of copyright owner] |  | ||||||
|  |  | ||||||
|        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 - See [LICENSE][license-url] for more information. |  | ||||||
|  |  | ||||||
|     [opentelemetry-js]: https://github.com/open-telemetry/opentelemetry-js |  | ||||||
|  |  | ||||||
|     [discussions-url]: https://github.com/open-telemetry/opentelemetry-js/discussions |  | ||||||
|     [license-url]: https://github.com/open-telemetry/opentelemetry-js/blob/main/api/LICENSE |  | ||||||
|     [license-image]: https://img.shields.io/badge/license-Apache_2.0-green.svg?style=flat |  | ||||||
|     [docs-tracing]: https://github.com/open-telemetry/opentelemetry-js/blob/main/doc/tracing.md |  | ||||||
|     [docs-sdk-registration]: https://github.com/open-telemetry/opentelemetry-js/blob/main/doc/sdk-registration.md |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@types/node-fetch.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@types/node-fetch.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@types/node-fetch" |  | ||||||
| version: 2.6.3 |  | ||||||
| type: npm |  | ||||||
| summary: TypeScript definitions for node-fetch |  | ||||||
| homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node-fetch |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: |2 |  | ||||||
|         MIT License |  | ||||||
|  |  | ||||||
|         Copyright (c) Microsoft Corporation. |  | ||||||
|  |  | ||||||
|         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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@types/node.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@types/node.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@types/node" |  | ||||||
| version: 16.11.25 |  | ||||||
| type: npm |  | ||||||
| summary: TypeScript definitions for Node.js |  | ||||||
| homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: |2 |  | ||||||
|         MIT License |  | ||||||
|  |  | ||||||
|         Copyright (c) Microsoft Corporation. |  | ||||||
|  |  | ||||||
|         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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@types/tunnel.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@types/tunnel.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: "@types/tunnel" |  | ||||||
| version: 0.0.3 |  | ||||||
| type: npm |  | ||||||
| summary: TypeScript definitions for tunnel |  | ||||||
| homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/tunnel |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: |2 |  | ||||||
|         MIT License |  | ||||||
|  |  | ||||||
|         Copyright (c) Microsoft Corporation. |  | ||||||
|  |  | ||||||
|         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: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/abort-controller.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/abort-controller.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: abort-controller |  | ||||||
| version: 3.0.0 |  | ||||||
| type: npm |  | ||||||
| summary: An implementation of WHATWG AbortController interface. |  | ||||||
| homepage: https://github.com/mysticatea/abort-controller#readme |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     MIT License |  | ||||||
|  |  | ||||||
|     Copyright (c) 2017 Toru Nagashima |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										34
									
								
								.licenses/npm/asynckit.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										34
									
								
								.licenses/npm/asynckit.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,34 +0,0 @@ | |||||||
| --- |  | ||||||
| name: asynckit |  | ||||||
| version: 0.4.0 |  | ||||||
| type: npm |  | ||||||
| summary: Minimal async jobs utility library, with streams support |  | ||||||
| homepage: https://github.com/alexindigo/asynckit#readme |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2016 Alex Indigo |  | ||||||
|  |  | ||||||
|     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: AsyncKit is licensed under the MIT license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										55
									
								
								.licenses/npm/balanced-match.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										55
									
								
								.licenses/npm/balanced-match.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,55 +0,0 @@ | |||||||
| --- |  | ||||||
| name: balanced-match |  | ||||||
| version: 1.0.2 |  | ||||||
| type: npm |  | ||||||
| summary: Match balanced character pairs, like "{" and "}" |  | ||||||
| homepage: https://github.com/juliangruber/balanced-match |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE.md |  | ||||||
|   text: | |  | ||||||
|     (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2013 Julian Gruber <julian@juliangruber.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) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2013 Julian Gruber <julian@juliangruber.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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										55
									
								
								.licenses/npm/brace-expansion.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										55
									
								
								.licenses/npm/brace-expansion.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,55 +0,0 @@ | |||||||
| --- |  | ||||||
| name: brace-expansion |  | ||||||
| version: 1.1.11 |  | ||||||
| type: npm |  | ||||||
| summary: Brace expansion as known from sh/bash |  | ||||||
| homepage: https://github.com/juliangruber/brace-expansion |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     MIT License |  | ||||||
|  |  | ||||||
|     Copyright (c) 2013 Julian Gruber <julian@juliangruber.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) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2013 Julian Gruber <julian@juliangruber.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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/combined-stream.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/combined-stream.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: combined-stream |  | ||||||
| version: 1.0.8 |  | ||||||
| type: npm |  | ||||||
| summary: A stream that emits multiple other streams one after another. |  | ||||||
| homepage: https://github.com/felixge/node-combined-stream |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: License |  | ||||||
|   text: | |  | ||||||
|     Copyright (c) 2011 Debuggable Limited <felix@debuggable.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: combined-stream is licensed under the MIT license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										31
									
								
								.licenses/npm/concat-map.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										31
									
								
								.licenses/npm/concat-map.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,31 +0,0 @@ | |||||||
| --- |  | ||||||
| name: concat-map |  | ||||||
| version: 0.0.1 |  | ||||||
| type: npm |  | ||||||
| summary: concatenative mapdashery |  | ||||||
| homepage:  |  | ||||||
| license: other |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   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.markdown |  | ||||||
|   text: MIT |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/delayed-stream.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/delayed-stream.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| --- |  | ||||||
| name: delayed-stream |  | ||||||
| version: 1.0.0 |  | ||||||
| type: npm |  | ||||||
| summary: Buffers events from a stream until you are ready to handle them. |  | ||||||
| homepage: https://github.com/felixge/node-delayed-stream |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: License |  | ||||||
|   text: | |  | ||||||
|     Copyright (c) 2011 Debuggable Limited <felix@debuggable.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: delayed-stream is licensed under the MIT license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/event-target-shim.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/event-target-shim.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: event-target-shim |  | ||||||
| version: 5.0.1 |  | ||||||
| type: npm |  | ||||||
| summary: An implementation of WHATWG EventTarget interface. |  | ||||||
| homepage: https://github.com/mysticatea/event-target-shim |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: |+ |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2015 Toru Nagashima |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										38
									
								
								.licenses/npm/events.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										38
									
								
								.licenses/npm/events.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,38 +0,0 @@ | |||||||
| --- |  | ||||||
| name: events |  | ||||||
| version: 3.3.0 |  | ||||||
| type: npm |  | ||||||
| summary: Node's event emitter for all engines. |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     MIT |  | ||||||
|  |  | ||||||
|     Copyright Joyent, Inc. and other Node 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) |  | ||||||
|  |  | ||||||
|     [node.js docs]: https://nodejs.org/dist/v11.13.0/docs/api/events.html |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										22
									
								
								.licenses/npm/fast-xml-parser.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										22
									
								
								.licenses/npm/fast-xml-parser.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,11 +1,27 @@ | |||||||
| --- | --- | ||||||
| name: fast-xml-parser | name: fast-xml-parser | ||||||
| version: 4.0.10 | version: 3.17.4 | ||||||
| type: npm | type: npm | ||||||
| summary: Validate XML, Parse XML to JS Object, or Build XML from JS Object without C/C++ based libraries and no callback. | 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 | homepage: https://github.com/NaturalIntelligence/fast-xml-parser#readme | ||||||
| license: mit | license: mit | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE | - 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\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." |   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: [] | notices: [] | ||||||
|  | |||||||
							
								
								
									
										33
									
								
								.licenses/npm/form-data-2.5.1.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/form-data-2.5.1.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: form-data |  | ||||||
| version: 2.5.1 |  | ||||||
| type: npm |  | ||||||
| summary: A library to create readable "multipart/form-data" streams. Can be used to |  | ||||||
|   submit forms and file uploads to other web applications. |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: License |  | ||||||
|   text: | |  | ||||||
|     Copyright (c) 2012 Felix Geisendörfer (felix@debuggable.com) and 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: Form-Data is released under the [MIT](License) license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/form-data-3.0.1.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/form-data-3.0.1.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: form-data |  | ||||||
| version: 3.0.1 |  | ||||||
| type: npm |  | ||||||
| summary: A library to create readable "multipart/form-data" streams. Can be used to |  | ||||||
|   submit forms and file uploads to other web applications. |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: License |  | ||||||
|   text: | |  | ||||||
|     Copyright (c) 2012 Felix Geisendörfer (felix@debuggable.com) and 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: Form-Data is released under the [MIT](License) license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/form-data-4.0.0.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/form-data-4.0.0.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: form-data |  | ||||||
| version: 4.0.0 |  | ||||||
| type: npm |  | ||||||
| summary: A library to create readable "multipart/form-data" streams. Can be used to |  | ||||||
|   submit forms and file uploads to other web applications. |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: License |  | ||||||
|   text: | |  | ||||||
|     Copyright (c) 2012 Felix Geisendörfer (felix@debuggable.com) and 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: Form-Data is released under the [MIT](License) license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										34
									
								
								.licenses/npm/ip-regex.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										34
									
								
								.licenses/npm/ip-regex.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,34 +0,0 @@ | |||||||
| --- |  | ||||||
| name: ip-regex |  | ||||||
| version: 2.1.0 |  | ||||||
| type: npm |  | ||||||
| summary: Regular expression for matching IP addresses (IPv4 & IPv6) |  | ||||||
| homepage:  |  | ||||||
| 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: [] |  | ||||||
							
								
								
									
										34
									
								
								.licenses/npm/mime-db.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										34
									
								
								.licenses/npm/mime-db.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,34 +0,0 @@ | |||||||
| --- |  | ||||||
| name: mime-db |  | ||||||
| version: 1.52.0 |  | ||||||
| type: npm |  | ||||||
| summary: Media Type Database |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     (The MIT License) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2014 Jonathan Ong <me@jongleberry.com> |  | ||||||
|     Copyright (c) 2015-2022 Douglas Christopher Wilson <doug@somethingdoug.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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										47
									
								
								.licenses/npm/mime-types.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										47
									
								
								.licenses/npm/mime-types.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,47 +0,0 @@ | |||||||
| --- |  | ||||||
| name: mime-types |  | ||||||
| version: 2.1.35 |  | ||||||
| type: npm |  | ||||||
| summary: The ultimate javascript content-type utility. |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     (The MIT License) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2014 Jonathan Ong <me@jongleberry.com> |  | ||||||
|     Copyright (c) 2015 Douglas Christopher Wilson <doug@somethingdoug.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](LICENSE) |  | ||||||
|  |  | ||||||
|     [ci-image]: https://badgen.net/github/checks/jshttp/mime-types/master?label=ci |  | ||||||
|     [ci-url]: https://github.com/jshttp/mime-types/actions/workflows/ci.yml |  | ||||||
|     [coveralls-image]: https://badgen.net/coveralls/c/github/jshttp/mime-types/master |  | ||||||
|     [coveralls-url]: https://coveralls.io/r/jshttp/mime-types?branch=master |  | ||||||
|     [node-version-image]: https://badgen.net/npm/node/mime-types |  | ||||||
|     [node-version-url]: https://nodejs.org/en/download |  | ||||||
|     [npm-downloads-image]: https://badgen.net/npm/dm/mime-types |  | ||||||
|     [npm-url]: https://npmjs.org/package/mime-types |  | ||||||
|     [npm-version-image]: https://badgen.net/npm/v/mime-types |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										26
									
								
								.licenses/npm/minimatch.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										26
									
								
								.licenses/npm/minimatch.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,26 +0,0 @@ | |||||||
| --- |  | ||||||
| name: minimatch |  | ||||||
| version: 3.1.2 |  | ||||||
| type: npm |  | ||||||
| summary: a glob matcher in javascript |  | ||||||
| homepage:  |  | ||||||
| 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: [] |  | ||||||
							
								
								
									
										33
									
								
								.licenses/npm/process.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										33
									
								
								.licenses/npm/process.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,33 +0,0 @@ | |||||||
| --- |  | ||||||
| name: process |  | ||||||
| version: 0.11.10 |  | ||||||
| type: npm |  | ||||||
| summary: process information for node.js and browsers |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     (The MIT License) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2013 Roman Shtylman <shtylman@gmail.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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										43
									
								
								.licenses/npm/psl.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										43
									
								
								.licenses/npm/psl.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,43 +0,0 @@ | |||||||
| --- |  | ||||||
| name: psl |  | ||||||
| version: 1.9.0 |  | ||||||
| type: npm |  | ||||||
| summary: Domain name parser based on the Public Suffix List |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2017 Lupo Montero lupomontero@gmail.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: |- |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2017 Lupo Montero <lupomontero@gmail.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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										34
									
								
								.licenses/npm/punycode.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										34
									
								
								.licenses/npm/punycode.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,34 +0,0 @@ | |||||||
| --- |  | ||||||
| name: punycode |  | ||||||
| version: 2.1.1 |  | ||||||
| type: npm |  | ||||||
| summary: A robust Punycode converter that fully complies to RFC 3492 and RFC 5891, |  | ||||||
|   and works on nearly all JavaScript platforms. |  | ||||||
| homepage: https://mths.be/punycode |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE-MIT.txt |  | ||||||
|   text: | |  | ||||||
|     Copyright Mathias Bynens <https://mathiasbynens.be/> |  | ||||||
|  |  | ||||||
|     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: Punycode.js is available under the [MIT](https://mths.be/mit) license. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										52
									
								
								.licenses/npm/sax.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										52
									
								
								.licenses/npm/sax.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,52 +0,0 @@ | |||||||
| --- |  | ||||||
| name: sax |  | ||||||
| version: 1.2.4 |  | ||||||
| type: npm |  | ||||||
| summary: An evented streaming XML parser in JavaScript |  | ||||||
| homepage:  |  | ||||||
| license: other |  | ||||||
| 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. |  | ||||||
|  |  | ||||||
|     ==== |  | ||||||
|  |  | ||||||
|     `String.fromCodePoint` by Mathias Bynens used according to terms of MIT |  | ||||||
|     License, as follows: |  | ||||||
|  |  | ||||||
|         Copyright Mathias Bynens <https://mathiasbynens.be/> |  | ||||||
|  |  | ||||||
|         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: [] |  | ||||||
							
								
								
									
										2
									
								
								.licenses/npm/signal-exit.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/signal-exit.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: signal-exit | name: signal-exit | ||||||
| version: 3.0.7 | version: 3.0.2 | ||||||
| type: npm | type: npm | ||||||
| summary: when you want to fire an event no matter how a process exits. | summary: when you want to fire an event no matter how a process exits. | ||||||
| homepage: https://github.com/tapjs/signal-exit | homepage: https://github.com/tapjs/signal-exit | ||||||
|  | |||||||
							
								
								
									
										11
									
								
								.licenses/npm/strnum.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										11
									
								
								.licenses/npm/strnum.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,11 +0,0 @@ | |||||||
| --- |  | ||||||
| name: strnum |  | ||||||
| version: 1.0.5 |  | ||||||
| type: npm |  | ||||||
| summary: Parse string into Number based on configuration |  | ||||||
| homepage: https://github.com/NaturalIntelligence/strnum |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: "MIT License\n\nCopyright (c) 2021 Natural Intelligence\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\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." |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										23
									
								
								.licenses/npm/tough-cookie.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										23
									
								
								.licenses/npm/tough-cookie.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,23 +0,0 @@ | |||||||
| --- |  | ||||||
| name: tough-cookie |  | ||||||
| version: 3.0.1 |  | ||||||
| type: npm |  | ||||||
| summary: RFC6265 Cookies and Cookie Jar for node.js |  | ||||||
| homepage: https://github.com/salesforce/tough-cookie |  | ||||||
| license: bsd-3-clause |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     Copyright (c) 2015, Salesforce.com, Inc. |  | ||||||
|     All rights reserved. |  | ||||||
|  |  | ||||||
|     Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: |  | ||||||
|  |  | ||||||
|     1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. |  | ||||||
|  |  | ||||||
|     2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. |  | ||||||
|  |  | ||||||
|     3. Neither the name of Salesforce.com nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. |  | ||||||
|  |  | ||||||
|     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										35
									
								
								.licenses/npm/tslib-1.14.1.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										35
									
								
								.licenses/npm/tslib-1.14.1.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,35 +0,0 @@ | |||||||
| --- |  | ||||||
| name: tslib |  | ||||||
| version: 1.14.1 |  | ||||||
| type: npm |  | ||||||
| summary: Runtime library for TypeScript helper functions |  | ||||||
| homepage: https://www.typescriptlang.org/ |  | ||||||
| license: 0bsd |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE.txt |  | ||||||
|   text: |- |  | ||||||
|     Copyright (c) Microsoft Corporation. |  | ||||||
|  |  | ||||||
|     Permission to use, copy, modify, and/or distribute this software for any |  | ||||||
|     purpose with or without fee is hereby granted. |  | ||||||
|  |  | ||||||
|     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: |  | ||||||
| - sources: CopyrightNotice.txt |  | ||||||
|   text: "/*! *****************************************************************************\r\nCopyright |  | ||||||
|     (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute |  | ||||||
|     this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE |  | ||||||
|     SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD |  | ||||||
|     TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. |  | ||||||
|     IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR |  | ||||||
|     CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, |  | ||||||
|     DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS |  | ||||||
|     ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS |  | ||||||
|     SOFTWARE.\r\n***************************************************************************** |  | ||||||
|     */" |  | ||||||
							
								
								
									
										23
									
								
								.licenses/npm/tslib-2.5.0.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										23
									
								
								.licenses/npm/tslib-2.5.0.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,23 +0,0 @@ | |||||||
| --- |  | ||||||
| name: tslib |  | ||||||
| version: 2.5.0 |  | ||||||
| type: npm |  | ||||||
| summary: Runtime library for TypeScript helper functions |  | ||||||
| homepage: https://www.typescriptlang.org/ |  | ||||||
| license: 0bsd |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE.txt |  | ||||||
|   text: |- |  | ||||||
|     Copyright (c) Microsoft Corporation. |  | ||||||
|  |  | ||||||
|     Permission to use, copy, modify, and/or distribute this software for any |  | ||||||
|     purpose with or without fee is hereby granted. |  | ||||||
|  |  | ||||||
|     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: [] |  | ||||||
							
								
								
									
										4
									
								
								.licenses/npm/universal-user-agent-4.0.0.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								.licenses/npm/universal-user-agent-4.0.0.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -3,8 +3,8 @@ name: universal-user-agent | |||||||
| version: 4.0.0 | version: 4.0.0 | ||||||
| type: npm | type: npm | ||||||
| summary: Get a user agent string in both browser and node | summary: Get a user agent string in both browser and node | ||||||
| homepage:  | homepage: https://github.com/gr2m/universal-user-agent#readme | ||||||
| license: isc | license: other | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE.md | - sources: LICENSE.md | ||||||
|   text: | |   text: | | ||||||
|  | |||||||
							
								
								
									
										39
									
								
								.licenses/npm/uuid-3.4.0.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										39
									
								
								.licenses/npm/uuid-3.4.0.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,39 +0,0 @@ | |||||||
| --- |  | ||||||
| name: uuid |  | ||||||
| version: 3.4.0 |  | ||||||
| type: npm |  | ||||||
| summary: RFC4122 (v1, v4, and v5) UUIDs |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE.md |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2010-2016 Robert Kieffer and other 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. |  | ||||||
| notices: |  | ||||||
| - sources: AUTHORS |  | ||||||
|   text: |- |  | ||||||
|     Robert Kieffer <robert@broofa.com> |  | ||||||
|     Christoph Tavan <dev@tavan.de> |  | ||||||
|     AJ ONeal <coolaj86@gmail.com> |  | ||||||
|     Vincent Voyer <vincent@zeroload.net> |  | ||||||
|     Roman Shtylman <shtylman@gmail.com> |  | ||||||
							
								
								
									
										20
									
								
								.licenses/npm/uuid-8.3.2.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										20
									
								
								.licenses/npm/uuid-8.3.2.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,20 +0,0 @@ | |||||||
| --- |  | ||||||
| name: uuid |  | ||||||
| version: 8.3.2 |  | ||||||
| type: npm |  | ||||||
| summary: RFC4122 (v1, v4, and v5) UUIDs |  | ||||||
| homepage:  |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE.md |  | ||||||
|   text: | |  | ||||||
|     The MIT License (MIT) |  | ||||||
|  |  | ||||||
|     Copyright (c) 2010-2020 Robert Kieffer and other 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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										30
									
								
								.licenses/npm/xml2js.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										30
									
								
								.licenses/npm/xml2js.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,30 +0,0 @@ | |||||||
| --- |  | ||||||
| name: xml2js |  | ||||||
| version: 0.5.0 |  | ||||||
| type: npm |  | ||||||
| summary: Simple XML to JavaScript object converter. |  | ||||||
| homepage: https://github.com/Leonidas-from-XIV/node-xml2js |  | ||||||
| license: mit |  | ||||||
| licenses: |  | ||||||
| - sources: LICENSE |  | ||||||
|   text: | |  | ||||||
|     Copyright 2010, 2011, 2012, 2013. 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. |  | ||||||
| notices: [] |  | ||||||
							
								
								
									
										38
									
								
								.licenses/npm/xmlbuilder.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										38
									
								
								.licenses/npm/xmlbuilder.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,32 +1,24 @@ | |||||||
| --- | --- | ||||||
| name: xmlbuilder | name: xmlbuilder | ||||||
| version: 11.0.1 | version: 13.0.2 | ||||||
| type: npm | type: npm | ||||||
| summary: An XML builder for node.js | summary: An XML builder for node.js | ||||||
| homepage: http://github.com/oozcitak/xmlbuilder-js | homepage: http://github.com/oozcitak/xmlbuilder-js | ||||||
| license: mit | license: mit | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE | - sources: LICENSE | ||||||
|   text: | |   text: "The MIT License (MIT)\r\n\r\nCopyright (c) 2013 Ozgur Ozcitak\r\n\r\nPermission | ||||||
|     The MIT License (MIT) |     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 | ||||||
|     Copyright (c) 2013 Ozgur Ozcitak |     without restriction, including without limitation the rights\r\nto use, copy, | ||||||
|  |     modify, merge, publish, distribute, sublicense, and/or sell\r\ncopies of the Software, | ||||||
|     Permission is hereby granted, free of charge, to any person obtaining a copy |     and to permit persons to whom the Software is\r\nfurnished to do so, subject to | ||||||
|     of this software and associated documentation files (the "Software"), to deal |     the following conditions:\r\n\r\nThe above copyright notice and this permission | ||||||
|     in the Software without restriction, including without limitation the rights |     notice shall be included in\r\nall copies or substantial portions of the Software.\r\n\r\nTHE | ||||||
|     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |     SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\nIMPLIED, | ||||||
|     copies of the Software, and to permit persons to whom the Software is |     INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\nFITNESS FOR | ||||||
|     furnished to do so, subject to the following conditions: |     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 | ||||||
|     The above copyright notice and this permission notice shall be included in |     IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\nOUT OF OR IN CONNECTION | ||||||
|     all copies or substantial portions of the Software. |     WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\nTHE SOFTWARE.\r\n" | ||||||
|  |  | ||||||
|     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: [] | notices: [] | ||||||
|  | |||||||
| @ -1,7 +0,0 @@ | |||||||
| # Ignore list |  | ||||||
| /* |  | ||||||
|  |  | ||||||
| # Do not ignore these folders: |  | ||||||
| !__tests__/ |  | ||||||
| !.github/ |  | ||||||
| !src/ |  | ||||||
| @ -1,11 +0,0 @@ | |||||||
| // This is a reusable configuration file copied from https://github.com/actions/reusable-workflows/tree/main/reusable-configurations. Please don't make changes to this file as it's the subject of an automatic update. |  | ||||||
| module.exports = { |  | ||||||
|   printWidth: 80, |  | ||||||
|   tabWidth: 2, |  | ||||||
|   useTabs: false, |  | ||||||
|   semi: true, |  | ||||||
|   singleQuote: true, |  | ||||||
|   trailingComma: 'none', |  | ||||||
|   bracketSpacing: false, |  | ||||||
|   arrowParens: 'avoid' |  | ||||||
| }; |  | ||||||
							
								
								
									
										11
									
								
								.prettierrc.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								.prettierrc.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | |||||||
|  | { | ||||||
|  |     "printWidth": 80, | ||||||
|  |     "tabWidth": 2, | ||||||
|  |     "useTabs": false, | ||||||
|  |     "semi": true, | ||||||
|  |     "singleQuote": true, | ||||||
|  |     "trailingComma": "none", | ||||||
|  |     "bracketSpacing": false, | ||||||
|  |     "arrowParens": "avoid", | ||||||
|  |     "parser": "typescript" | ||||||
|  |   } | ||||||
							
								
								
									
										250
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										250
									
								
								README.md
									
									
									
									
									
								
							| @ -1,7 +1,6 @@ | |||||||
| # setup-dotnet | # setup-dotnet | ||||||
|  |  | ||||||
| [](https://github.com/actions/setup-dotnet/actions/workflows/basic-validation.yml) | [](https://github.com/actions/setup-dotnet) | ||||||
| [](https://github.com/actions/setup-dotnet/actions/workflows/e2e-tests.yml) |  | ||||||
|  |  | ||||||
| This action sets up a [.NET CLI](https://github.com/dotnet/sdk) environment for use in actions by: | This action sets up a [.NET CLI](https://github.com/dotnet/sdk) environment for use in actions by: | ||||||
|  |  | ||||||
| @ -9,139 +8,62 @@ This action sets up a [.NET CLI](https://github.com/dotnet/sdk) environment for | |||||||
| - registering problem matchers for error output | - registering problem matchers for error output | ||||||
| - setting up authentication to private package sources like GitHub Packages | - setting up authentication to private package sources like GitHub Packages | ||||||
|  |  | ||||||
| > **Note**: GitHub hosted runners have some versions of the .NET SDK | Please Note: GitHub hosted runners have some versions of the .NET SDK | ||||||
| preinstalled. Installed versions are subject to change. Please refer to the | preinstalled. Installed versions are subject to change. Please refer to the | ||||||
| documentation: | documentation | ||||||
| [Software installed on github hosted runners](https://docs.github.com/en/actions/using-github-hosted-runners/about-github-hosted-runners#supported-software) | [software installed on github hosted runners](https://docs.github.com/en/actions/using-github-hosted-runners/about-github-hosted-runners#supported-software) | ||||||
| for .NET SDK versions that are currently available. | for .NET SDK versions that are currently available. | ||||||
|  |  | ||||||
| ## Usage | # Usage | ||||||
|  |  | ||||||
| See [action.yml](action.yml) | See [action.yml](action.yml) | ||||||
|  |  | ||||||
| **Basic**: | Basic: | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-dotnet@v3 | - uses: actions/setup-dotnet@v2 | ||||||
|   with: |   with: | ||||||
|     dotnet-version: '3.1.x' |     dotnet-version: '3.1.x' # SDK Version to use; x will use the latest version of the 3.1 channel | ||||||
| - run: dotnet build <my project> | - run: dotnet build <my project> | ||||||
| ``` | ``` | ||||||
| > **Warning**: Unless a concrete version is specified in the [`global.json`](https://learn.microsoft.com/en-us/dotnet/core/tools/global-json) file, **_the latest .NET version installed on the runner (including preinstalled versions) will be used [by default](https://learn.microsoft.com/en-us/dotnet/core/versions/selection#the-sdk-uses-the-latest-installed-version)_**. Please refer to the [documentation](https://docs.github.com/en/actions/using-github-hosted-runners/about-github-hosted-runners#supported-software) for the currently preinstalled .NET SDK versions. | Multiple versions: | ||||||
|  | > Note: In case multiple versions are installed, the latest .NET version will be used by default unless another version is specified in the `global.json` file. | ||||||
|  |  | ||||||
| **Multiple version installation**: |  | ||||||
| ```yml | ```yml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v3 | ||||||
| - name: Setup dotnet | - name: Setup dotnet | ||||||
|   uses: actions/setup-dotnet@v3 |   uses: actions/setup-dotnet@v2 | ||||||
|   with: |   with: | ||||||
|     dotnet-version: |  |     dotnet-version: |  | ||||||
|       3.1.x |       3.1.x | ||||||
|       5.0.x |       5.0.x | ||||||
| - run: dotnet build <my project> | - run: dotnet build <my project> | ||||||
| ``` | ``` | ||||||
| ## Supported version syntax | Preview version: | ||||||
|  |  | ||||||
| The `dotnet-version` input supports following syntax: |  | ||||||
|  |  | ||||||
| - **A.B.C** (e.g 6.0.400, 7.0.100-preview.7.22377.5) - installs exact version of .NET SDK |  | ||||||
| - **A.B** or **A.B.x** (e.g. 3.1, 3.1.x) - installs the latest patch version of .NET SDK on the channel `3.1`, including prerelease versions (preview, rc) |  | ||||||
| - **A** or **A.x** (e.g. 3, 3.x) - installs the latest minor version of the specified major tag, including prerelease versions (preview, rc) |  | ||||||
| - **A.B.Cxx** (e.g. 6.0.4xx) - available since `.NET 5.0` release. Installs the latest version of the specific SDK release, including prerelease versions (preview, rc).  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Using the `dotnet-quality` input |  | ||||||
| This input sets up the action to install the latest build of the specified quality in the channel. The possible values of `dotnet-quality` are: **daily**, **signed**, **validated**, **preview**, **ga**. |  | ||||||
|  |  | ||||||
| > **Note**: `dotnet-quality` input can be used only with .NET SDK version in 'A.B', 'A.B.x', 'A', 'A.x' and 'A.B.Cxx' formats where the major version is higher than 5. In other cases, `dotnet-quality` input will be ignored. |  | ||||||
|  |  | ||||||
| ```yml | ```yml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-dotnet@v3 | - uses: actions/setup-dotnet@v2 | ||||||
|   with: |   with: | ||||||
|     dotnet-version: '6.0.x' |     dotnet-version: '6.0.x' | ||||||
|     dotnet-quality: 'preview' |     include-prerelease: true | ||||||
| - run: dotnet build <my project> | - run: dotnet build <my project> | ||||||
| ``` | ``` | ||||||
|  | global.json in a subdirectory: | ||||||
| ## Using the `global-json-file` input |  | ||||||
| `setup-dotnet` action can read .NET SDK version from a `global.json` file. Input `global-json-file` is used for specifying the path to the `global.json`. If the file that was supplied to `global-json-file` input doesn't exist, the action will fail with error. |  | ||||||
|  |  | ||||||
| >**Note**: In case both `dotnet-version` and `global-json-file` inputs are used, versions from both inputs will be installed. |  | ||||||
|  |  | ||||||
| ```yml | ```yml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-dotnet@v3 | - uses: actions/setup-dotnet@v2 | ||||||
|   with: |   with: | ||||||
|     global-json-file: csharp/global.json |     global-json-file: csharp/global.json | ||||||
| - run: dotnet build <my project> | - run: dotnet build <my project> | ||||||
|   working-directory: csharp |   working-directory: csharp | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Caching NuGet Packages | Matrix Testing: | ||||||
| The action has a built-in functionality for caching and restoring dependencies. It uses [toolkit/cache](https://github.com/actions/toolkit/tree/main/packages/cache) under the hood for caching global packages data but requires less configuration settings. The `cache` input is optional, and caching is turned off by default. |  | ||||||
|  |  | ||||||
| The action searches for [NuGet Lock files](https://learn.microsoft.com/nuget/consume-packages/package-references-in-project-files#locking-dependencies) (`packages.lock.json`) in the repository root, calculates their hash and uses it as a part of the cache key. If lock file does not exist, this action throws error. Use `cache-dependency-path` for cases when multiple dependency files are used, or they are located in different subdirectories. |  | ||||||
|  |  | ||||||
| > **Warning**: Caching NuGet packages is available since .NET SDK 2.1.500 and 2.2.100 as the NuGet lock file [is available](https://learn.microsoft.com/nuget/consume-packages/package-references-in-project-files#locking-dependencies) only for NuGet 4.9 and above. |  | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| steps: |  | ||||||
| - uses: actions/checkout@v3 |  | ||||||
| - uses: actions/setup-dotnet@v3 |  | ||||||
|   with: |  | ||||||
|     dotnet-version: 6.x |  | ||||||
|     cache: true |  | ||||||
| - run: dotnet restore --locked-mode |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| > **Note**: This action will only restore `global-packages` folder, so you will probably get the [NU1403](https://learn.microsoft.com/nuget/reference/errors-and-warnings/nu1403) error when running `dotnet restore`. |  | ||||||
| > To avoid this, you can use [`DisableImplicitNuGetFallbackFolder`](https://github.com/dotnet/reproducible-builds/blob/abfe986832aa28597d3340b92469d1a702013d23/Documentation/Reproducible-MSBuild/Techniques/DisableImplicitNuGetFallbackFolder.md) option. |  | ||||||
|  |  | ||||||
| ```xml |  | ||||||
| <PropertyGroup> |  | ||||||
|   <DisableImplicitNuGetFallbackFolder>true</DisableImplicitNuGetFallbackFolder> |  | ||||||
| </PropertyGroup> |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Reduce caching size |  | ||||||
|  |  | ||||||
| > **Note**: Use [`NUGET_PACKAGES`](https://learn.microsoft.com/nuget/reference/cli-reference/cli-ref-environment-variables) environment variable if available. Some action runners already has huge libraries. (ex. Xamarin) |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| env: |  | ||||||
|   NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages |  | ||||||
| steps: |  | ||||||
| - uses: actions/checkout@v3 |  | ||||||
| - uses: actions/setup-dotnet@v3 |  | ||||||
|   with: |  | ||||||
|     dotnet-version: 6.x |  | ||||||
|     cache: true |  | ||||||
| - run: dotnet restore --locked-mode |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Caching NuGet packages in monorepos |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| env: |  | ||||||
|   NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages |  | ||||||
| steps: |  | ||||||
| - uses: actions/checkout@v3 |  | ||||||
| - uses: actions/setup-dotnet@v3 |  | ||||||
|   with: |  | ||||||
|     dotnet-version: 6.x |  | ||||||
|     cache: true |  | ||||||
|     cache-dependency-path: subdir/packages.lock.json |  | ||||||
| - run: dotnet restore --locked-mode |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Matrix Testing |  | ||||||
| Using `setup-dotnet` it's possible to use [matrix syntax](https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstrategymatrix) to install several versions of .NET SDK: |  | ||||||
| ```yml |  | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
| @ -152,44 +74,38 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
|       - name: Setup dotnet |       - name: Setup dotnet | ||||||
|         uses: actions/setup-dotnet@v3 |         uses: actions/setup-dotnet@v2 | ||||||
|         with: |         with: | ||||||
|           dotnet-version: ${{ matrix.dotnet }} |           dotnet-version: ${{ matrix.dotnet }} | ||||||
|       - name: Execute dotnet |       - run: dotnet build <my project> | ||||||
|         run: dotnet build <my project> |  | ||||||
| ``` | ``` | ||||||
| >**Note**: Unless a concrete version is specified in the [`global.json`](https://learn.microsoft.com/en-us/dotnet/core/tools/global-json) file, the latest .NET version installed on the runner (including preinstalled versions) will be used [by default](https://learn.microsoft.com/en-us/dotnet/core/versions/selection#the-sdk-uses-the-latest-installed-version). To control this behavior you may want to use temporary `global.json` files: |  | ||||||
|  |  | ||||||
| **Matrix testing with temporary global.json creation** | Side by Side Testing: | ||||||
| ```yml | ```yaml | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     strategy: |     name: Dotnet Side by Side testing sample | ||||||
|       matrix: |  | ||||||
|         dotnet: [ '2.1.x', '3.1.x', '5.0.x' ] |  | ||||||
|     name: Dotnet ${{ matrix.dotnet }} sample |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
|       - name: Setup dotnet |       - name: Setup dotnet | ||||||
|         uses: actions/setup-dotnet@v3 |         uses: actions/setup-dotnet@v2 | ||||||
|         id: stepid |  | ||||||
|         with: |         with: | ||||||
|           dotnet-version: ${{ matrix.dotnet }} |           dotnet-version: | | ||||||
|       - name: Create temporary global.json |             2.1.x | ||||||
|         run: echo '{"sdk":{"version": "${{ steps.stepid.outputs.dotnet-version }}"}}' > ./global.json |             3.1.x | ||||||
|       - name: Execute dotnet |       - run: dotnet build <my project> | ||||||
|         run: dotnet build <my project> |       - run: dotnet test <my project> | ||||||
| ``` | ``` | ||||||
| ## Setting up authentication for nuget feeds |  | ||||||
|  |  | ||||||
| ### Github Package Registry (GPR) | Authentication for nuget feeds: | ||||||
| ```yml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-dotnet@v3 | # Authenticates packages to push to GPR | ||||||
|  | - uses: actions/setup-dotnet@v2 | ||||||
|   with: |   with: | ||||||
|     dotnet-version: '3.1.x' |     dotnet-version: '3.1.x' # SDK Version to use. | ||||||
|     source-url: https://nuget.pkg.github.com/<owner>/index.json |     source-url: https://nuget.pkg.github.com/<owner>/index.json | ||||||
|   env: |   env: | ||||||
|     NUGET_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} |     NUGET_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} | ||||||
| @ -198,22 +114,19 @@ steps: | |||||||
|   run: dotnet pack --configuration Release <my project> |   run: dotnet pack --configuration Release <my project> | ||||||
| - name: Publish the package to GPR | - name: Publish the package to GPR | ||||||
|   run: dotnet nuget push <my project>/bin/Release/*.nupkg |   run: dotnet nuget push <my project>/bin/Release/*.nupkg | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Azure Artifacts | # Authenticates packages to push to Azure Artifacts | ||||||
| ```yml | - uses: actions/setup-dotnet@v2 | ||||||
| - uses: actions/setup-dotnet@v3 |  | ||||||
|   with: |   with: | ||||||
|     source-url: https://pkgs.dev.azure.com/<your-organization>/_packaging/<your-feed-name>/nuget/v3/index.json |     source-url: https://pkgs.dev.azure.com/<your-organization>/_packaging/<your-feed-name>/nuget/v3/index.json | ||||||
|   env: |   env: | ||||||
|     NUGET_AUTH_TOKEN: ${{secrets.AZURE_DEVOPS_PAT}} # Note, create a secret with this name in Settings |     NUGET_AUTH_TOKEN: ${{secrets.AZURE_DEVOPS_PAT}} # Note, create a secret with this name in Settings | ||||||
| - name: Publish the package to Azure Artifacts | - name: Publish the package to Azure Artifacts | ||||||
|   run: dotnet nuget push <my project>/bin/Release/*.nupkg |   run: dotnet nuget push <my project>/bin/Release/*.nupkg | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### nuget.org | # Authenticates packages to push to nuget.org. | ||||||
| ```yml | # It's only the way to push a package to nuget.org feed for macOS/Linux machines due to API key config store limitations. | ||||||
| - uses: actions/setup-dotnet@v3 | - uses: actions/setup-dotnet@v2 | ||||||
|   with: |   with: | ||||||
|     dotnet-version: 3.1.x |     dotnet-version: 3.1.x | ||||||
| - name: Publish the package to nuget.org | - name: Publish the package to nuget.org | ||||||
| @ -221,97 +134,32 @@ steps: | |||||||
|   env: |   env: | ||||||
|     NUGET_AUTH_TOKEN: ${{ secrets.NUGET_TOKEN }} |     NUGET_AUTH_TOKEN: ${{ secrets.NUGET_TOKEN }} | ||||||
| ``` | ``` | ||||||
| > **Note**: It's the only way to push a package to nuget.org feed for macOS/Linux machines due to API key config store limitations. |  | ||||||
|  |  | ||||||
| # Outputs and environment variables | ## Environment Variables to use with dotnet | ||||||
|  |  | ||||||
| ## Outputs |  | ||||||
|  |  | ||||||
| ### `dotnet-version` |  | ||||||
|  |  | ||||||
| Using the **dotnet-version** output it's possible to get the installed by the action .NET SDK version.  |  | ||||||
|  |  | ||||||
| **Single version installation** |  | ||||||
|  |  | ||||||
| In case of a single version installation, the `dotnet-version` output contains the version that is installed by the action. |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
|     - uses: actions/setup-dotnet@v3 |  | ||||||
|       id: stepid |  | ||||||
|       with: |  | ||||||
|         dotnet-version: 3.1.422 |  | ||||||
|     - run: echo '${{ steps.stepid.outputs.dotnet-version }}' # outputs 3.1.422 |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **Multiple version installation** |  | ||||||
|  |  | ||||||
| In case of a multiple version installation, the `dotnet-version` output contains the latest version that is installed by the action. |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
|     - uses: actions/setup-dotnet@v3 |  | ||||||
|       id: stepid |  | ||||||
|       with: |  | ||||||
|         dotnet-version: |  |  | ||||||
|           3.1.422 |  | ||||||
|           5.0.408 |  | ||||||
|     - run: echo '${{ steps.stepid.outputs.dotnet-version }}' # outputs 5.0.408 |  | ||||||
| ``` |  | ||||||
| **Installation from global.json** |  | ||||||
|  |  | ||||||
| When the `dotnet-version` input is used along with the `global-json-file` input, the `dotnet-version` output contains the version resolved from the `global.json`. |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
|     - uses: actions/setup-dotnet@v3 |  | ||||||
|       id: stepid |  | ||||||
|       with: |  | ||||||
|         dotnet-version: |  |  | ||||||
|           3.1.422 |  | ||||||
|           5.0.408 |  | ||||||
|         global-json-file: "./global.json" # contains version 2.2.207 |  | ||||||
|     - run: echo '${{ steps.stepid.outputs.dotnet-version }}' # outputs 2.2.207 |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### `cache-hit` |  | ||||||
| A boolean value to indicate an exact match was found for the cache key (follows [actions/cache](https://github.com/actions/cache#outputs)) |  | ||||||
|  |  | ||||||
| ## Environment variables |  | ||||||
|  |  | ||||||
| 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 | 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 | ||||||
|  |  | ||||||
| | **Env.variable**      | **Description** | **Default value** | | - 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_INSTALL_DIR      |Specifies a directory where .NET SDKs should be installed by the action.|*default value for each OS* | | - DOTNET_MULTILEVEL_LOOKUP - configures whether the global install location is used as a fall-back (default: true) | ||||||
| | DOTNET_NOLOGO      |Removes logo and telemetry message from first run of dotnet cli|*false*| |  | ||||||
| | DOTNET_CLI_TELEMETRY_OPTOUT   |Opt-out of telemetry being sent to Microsoft|*false*| |  | ||||||
| | DOTNET_MULTILEVEL_LOOKUP   |Configures whether the global install location is used as a fall-back|*true*| |  | ||||||
| | NUGET_PACKAGES |Configures a path to the [NuGet `global-packages` folder](https://learn.microsoft.com/nuget/consume-packages/managing-the-global-packages-and-cache-folders)|*default value for each OS* | |  | ||||||
|  |  | ||||||
| The default values of the `DOTNET_INSTALL_DIR` and `NUGET_PACKAGES` environment variables depend on the operation system which is used on a runner: | Example usage: | ||||||
| | **Operation system** | `DOTNET_INSTALL_DIR` | `NUGET_PACKAGES` | | ```yaml | ||||||
| | ----------- | ----------- | ----------- | |  | ||||||
| | **Windows** | `C:\Program Files\dotnet` | `%userprofile%\.nuget\packages` | |  | ||||||
| | **Ubuntu** | `/usr/share/dotnet` | `~/.nuget/packages` | |  | ||||||
| | **macOS** | `/Users/runner/.dotnet` | `~/.nuget/packages` | |  | ||||||
|  |  | ||||||
| **Example usage of environment variable**: |  | ||||||
| ```yml |  | ||||||
| build: | build: | ||||||
|   runs-on: ubuntu-latest |   runs-on: ubuntu-latest | ||||||
|   env: |   env: | ||||||
|     DOTNET_INSTALL_DIR: "path/to/directory" |     DOTNET_NOLOGO: true | ||||||
|     NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages |  | ||||||
|   steps: |   steps: | ||||||
|     - uses: actions/checkout@main |     - uses: actions/checkout@main | ||||||
|     - uses: actions/setup-dotnet@v3 |     - uses: actions/setup-dotnet@v2 | ||||||
|       with: |       with: | ||||||
|         dotnet-version: '3.1.x' |         dotnet-version: '3.1.x' # SDK Version to use. | ||||||
|         cache: true |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## License | # License | ||||||
|  |  | ||||||
| The scripts and documentation in this project are released under the [MIT License](LICENSE) | The scripts and documentation in this project are released under the [MIT License](LICENSE) | ||||||
|  |  | ||||||
| ## Contributions | # Contributions | ||||||
|  |  | ||||||
| Contributions are welcome!  See [Contributor's Guide](docs/contributors.md) | Contributions are welcome!  See [Contributor's Guide](docs/contributors.md) | ||||||
|  | |||||||
| @ -1,6 +1,6 @@ | |||||||
| // Jest Snapshot v1, https://goo.gl/fbAQLP | // 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`] = ` | exports[`authutil tests Existing config not in repo root, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||||
| "<?xml version=\\"1.0\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -15,7 +15,7 @@ exports[`authutil tests existing config not in repo root, sets up a partial NuGe | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ Azure Artifacts source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | 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\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -30,7 +30,7 @@ exports[`authutil tests existing config w/ Azure Artifacts source and NuGet.org, | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ GPR source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | 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\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -45,7 +45,7 @@ exports[`authutil tests existing config w/ GPR source and NuGet.org, sets up a p | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ no GPR sources, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | 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\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -63,7 +63,7 @@ exports[`authutil tests existing config w/ no GPR sources, sets up a full NuGet. | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ no sources, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | 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\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -81,7 +81,7 @@ exports[`authutil tests existing config w/ no sources, sets up a full NuGet.conf | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ only Azure Artifacts source, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | 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\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -96,7 +96,7 @@ exports[`authutil tests existing config w/ only Azure Artifacts source, sets up | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ only GPR source, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | exports[`authutil tests Existing config w/ only GPR source, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||||
| "<?xml version=\\"1.0\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -111,7 +111,7 @@ exports[`authutil tests existing config w/ only GPR source, sets up a partial Nu | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests existing config w/ two GPR sources, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | exports[`authutil tests Existing config w/ two GPR sources, sets up a partial NuGet.config user/PAT for GPR 1`] = ` | ||||||
| "<?xml version=\\"1.0\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -130,7 +130,7 @@ exports[`authutil tests existing config w/ two GPR sources, sets up a partial Nu | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests no existing config, sets up a full NuGet.config with URL and other owner/PAT for GPR 1`] = ` | 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\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -148,7 +148,7 @@ exports[`authutil tests no existing config, sets up a full NuGet.config with URL | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests no existing config, sets up a full NuGet.config with URL and token for other source 1`] = ` | exports[`authutil tests No existing config, sets up a full NuGet.config with URL and token for other source 1`] = ` | ||||||
| "<?xml version=\\"1.0\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
| @ -166,7 +166,7 @@ exports[`authutil tests no existing config, sets up a full NuGet.config with URL | |||||||
| </configuration>" | </configuration>" | ||||||
| `; | `; | ||||||
|  |  | ||||||
| exports[`authutil tests no existing config, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | exports[`authutil tests No existing config, sets up a full NuGet.config with URL and user/PAT for GPR 1`] = ` | ||||||
| "<?xml version=\\"1.0\\"?> | "<?xml version=\\"1.0\\"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <config> |   <config> | ||||||
|  | |||||||
| @ -1,28 +1,32 @@ | |||||||
| import * as io from '@actions/io'; | import io = require('@actions/io'); | ||||||
| import fs from 'fs'; | import fs = require('fs'); | ||||||
| import path from 'path'; | import path = require('path'); | ||||||
|  |  | ||||||
| const fakeSourcesDirForTesting = path.join( | const fakeSourcesDirForTesting = path.join( | ||||||
|   __dirname, |   __dirname, | ||||||
|   'runner', |   'runner', | ||||||
|   path.join(Math.random().toString(36).substring(7)), |   path.join( | ||||||
|  |     Math.random() | ||||||
|  |       .toString(36) | ||||||
|  |       .substring(7) | ||||||
|  |   ), | ||||||
|   's' |   's' | ||||||
| ); | ); | ||||||
|  |  | ||||||
| const invalidNuGetConfig = `<?xml version="1.0" encoding="utf-8"?>`; | const invalidNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?>`; | ||||||
|  |  | ||||||
| const emptyNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const emptyNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const nugetorgNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const nugetorgNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" /> |     <add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" /> | ||||||
|   </packageSources> |   </packageSources> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const gprnugetorgNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const gprnugetorgNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="GPR" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> |     <add key="GPR" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||||
| @ -30,14 +34,14 @@ const gprnugetorgNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | |||||||
|   </packageSources> |   </packageSources> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const gprNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const gprNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="GPR" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> |     <add key="GPR" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||||
|   </packageSources> |   </packageSources> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const twogprNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const twogprNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="GPR-GitHub" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> |     <add key="GPR-GitHub" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||||
| @ -45,21 +49,21 @@ const twogprNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | |||||||
|   </packageSources> |   </packageSources> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const spaceNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const spaceNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="GPR GitHub" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> |     <add key="GPR GitHub" value="https://nuget.pkg.github.com/OwnerName/index.json" protocolVersion="3" /> | ||||||
|   </packageSources> |   </packageSources> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const azureartifactsNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const azureartifactsNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="AzureArtifacts" value="https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json" protocolVersion="3" /> |     <add key="AzureArtifacts" value="https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json" protocolVersion="3" /> | ||||||
|   </packageSources> |   </packageSources> | ||||||
| </configuration>`; | </configuration>`; | ||||||
|  |  | ||||||
| const azureartifactsnugetorgNuGetConfig = `<?xml version="1.0" encoding="utf-8"?> | const azureartifactsnugetorgNuGetConfig: string = `<?xml version="1.0" encoding="utf-8"?> | ||||||
| <configuration> | <configuration> | ||||||
|   <packageSources> |   <packageSources> | ||||||
|     <add key="AzureArtifacts" value="https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json" protocolVersion="3" /> |     <add key="AzureArtifacts" value="https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json" protocolVersion="3" /> | ||||||
| @ -91,9 +95,9 @@ describe('authutil tests', () => { | |||||||
|     process.env['NUGET_AUTH_TOKEN'] = ''; |     process.env['NUGET_AUTH_TOKEN'] = ''; | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('no existing config, sets up a full NuGet.config with URL and user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', |       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -104,10 +108,10 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('no existing config, auth token environment variable not provided, throws', async () => { |   it('No existing config, auth token environment variable not provided, throws', async () => { | ||||||
|     let thrown = false; |     let thrown = false; | ||||||
|     try { |     try { | ||||||
|       auth.configAuthentication( |       await auth.configAuthentication( | ||||||
|         'https://nuget.pkg.github.com/OwnerName/index.json', |         'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|         '', |         '', | ||||||
|         fakeSourcesDirForTesting |         fakeSourcesDirForTesting | ||||||
| @ -118,10 +122,10 @@ describe('authutil tests', () => { | |||||||
|     expect(thrown).toBe(true); |     expect(thrown).toBe(true); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('no existing config, sets up a full NuGet.config with URL and other owner/PAT for GPR', async () => { |   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['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     process.env['INPUT_OWNER'] = 'otherorg'; |     process.env['INPUT_OWNER'] = 'otherorg'; | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/otherorg/index.json', |       'https://nuget.pkg.github.com/otherorg/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -132,7 +136,7 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config (invalid), tries to parse an invalid NuGet.config and throws', async () => { |   it('Existing config (invalid), tries to parse an invalid NuGet.config and throws', async () => { | ||||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
| @ -141,7 +145,7 @@ describe('authutil tests', () => { | |||||||
|     fs.writeFileSync(inputNuGetConfigPath, invalidNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, invalidNuGetConfig); | ||||||
|     let thrown = false; |     let thrown = false; | ||||||
|     try { |     try { | ||||||
|       auth.configAuthentication( |       await auth.configAuthentication( | ||||||
|         'https://nuget.pkg.github.com/OwnerName/index.json', |         'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|         '', |         '', | ||||||
|         fakeSourcesDirForTesting |         fakeSourcesDirForTesting | ||||||
| @ -152,14 +156,14 @@ describe('authutil tests', () => { | |||||||
|     expect(thrown).toBe(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 () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, emptyNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, emptyNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', |       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -170,14 +174,14 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ no GPR sources, sets up a full NuGet.config with URL and user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, nugetorgNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, nugetorgNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', |       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -188,14 +192,14 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ only GPR source, sets up a partial NuGet.config user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, gprNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, gprNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', |       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -206,14 +210,14 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ GPR source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, gprnugetorgNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, gprnugetorgNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', |       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -224,14 +228,14 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ two GPR sources, sets up a partial NuGet.config user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, twogprNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, twogprNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com', |       'https://nuget.pkg.github.com', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -242,7 +246,7 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ spaces in key, throws for now', async () => { |   it('Existing config w/ spaces in key, throws for now', async () => { | ||||||
|     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
| @ -251,7 +255,7 @@ describe('authutil tests', () => { | |||||||
|     fs.writeFileSync(inputNuGetConfigPath, spaceNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, spaceNuGetConfig); | ||||||
|     let thrown = false; |     let thrown = false; | ||||||
|     try { |     try { | ||||||
|       auth.configAuthentication( |       await auth.configAuthentication( | ||||||
|         'https://nuget.pkg.github.com/OwnerName/index.json', |         'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|         '', |         '', | ||||||
|         fakeSourcesDirForTesting |         fakeSourcesDirForTesting | ||||||
| @ -262,7 +266,7 @@ describe('authutil tests', () => { | |||||||
|     expect(thrown).toBe(true); |     expect(thrown).toBe(true); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config not in repo root, sets up a partial NuGet.config user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigDirectory: string = path.join( |     const inputNuGetConfigDirectory: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
| @ -274,7 +278,7 @@ describe('authutil tests', () => { | |||||||
|     ); |     ); | ||||||
|     fs.mkdirSync(inputNuGetConfigDirectory, {recursive: true}); |     fs.mkdirSync(inputNuGetConfigDirectory, {recursive: true}); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, gprNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, gprNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://nuget.pkg.github.com/OwnerName/index.json', |       'https://nuget.pkg.github.com/OwnerName/index.json', | ||||||
|       'subfolder/nuget.config', |       'subfolder/nuget.config', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -285,14 +289,14 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ only Azure Artifacts source, sets up a partial NuGet.config user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, azureartifactsNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, azureartifactsNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', |       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -303,14 +307,14 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('existing config w/ Azure Artifacts source and NuGet.org, sets up a partial NuGet.config user/PAT for GPR', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     const inputNuGetConfigPath: string = path.join( |     const inputNuGetConfigPath: string = path.join( | ||||||
|       fakeSourcesDirForTesting, |       fakeSourcesDirForTesting, | ||||||
|       'nuget.config' |       'nuget.config' | ||||||
|     ); |     ); | ||||||
|     fs.writeFileSync(inputNuGetConfigPath, azureartifactsnugetorgNuGetConfig); |     fs.writeFileSync(inputNuGetConfigPath, azureartifactsnugetorgNuGetConfig); | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', |       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
| @ -321,9 +325,9 @@ describe('authutil tests', () => { | |||||||
|     ).toMatchSnapshot(); |     ).toMatchSnapshot(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('no existing config, sets up a full NuGet.config with URL and token for other source', async () => { |   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'; |     process.env['NUGET_AUTH_TOKEN'] = 'TEST_FAKE_AUTH_TOKEN'; | ||||||
|     auth.configAuthentication( |     await auth.configAuthentication( | ||||||
|       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', |       'https://pkgs.dev.azure.com/amullans/_packaging/GitHubBuilds/nuget/v3/index.json', | ||||||
|       '', |       '', | ||||||
|       fakeSourcesDirForTesting |       fakeSourcesDirForTesting | ||||||
|  | |||||||
| @ -1,101 +0,0 @@ | |||||||
| import {readdir} from 'node:fs/promises'; |  | ||||||
| import * as cache from '@actions/cache'; |  | ||||||
| import * as core from '@actions/core'; |  | ||||||
| import * as glob from '@actions/glob'; |  | ||||||
| import {restoreCache} from '../src/cache-restore'; |  | ||||||
| import {getNuGetFolderPath} from '../src/cache-utils'; |  | ||||||
| import {lockFilePatterns} from '../src/constants'; |  | ||||||
|  |  | ||||||
| jest.mock('node:fs/promises'); |  | ||||||
| jest.mock('@actions/cache'); |  | ||||||
| jest.mock('@actions/core'); |  | ||||||
| jest.mock('@actions/glob'); |  | ||||||
| jest.mock('../src/cache-utils'); |  | ||||||
|  |  | ||||||
| describe('cache-restore tests', () => { |  | ||||||
|   describe.each(lockFilePatterns)('restoreCache("%s")', lockFilePattern => { |  | ||||||
|     /** Store original process.env.GITHUB_WORKSPACE */ |  | ||||||
|     let githubWorkspace: string | undefined; |  | ||||||
|     beforeAll(() => { |  | ||||||
|       githubWorkspace = process.env.GITHUB_WORKSPACE; |  | ||||||
|       jest.mocked(getNuGetFolderPath).mockResolvedValue({ |  | ||||||
|         'global-packages': 'global-packages', |  | ||||||
|         'http-cache': 'http-cache', |  | ||||||
|         temp: 'temp', |  | ||||||
|         'plugins-cache': 'plugins-cache' |  | ||||||
|       }); |  | ||||||
|     }); |  | ||||||
|     beforeEach(() => { |  | ||||||
|       process.env.GITHUB_WORKSPACE = './'; |  | ||||||
|       jest.mocked(glob.hashFiles).mockClear(); |  | ||||||
|       jest.mocked(core.saveState).mockClear(); |  | ||||||
|       jest.mocked(core.setOutput).mockClear(); |  | ||||||
|       jest.mocked(cache.restoreCache).mockClear(); |  | ||||||
|     }); |  | ||||||
|     afterEach(() => (process.env.GITHUB_WORKSPACE = githubWorkspace)); |  | ||||||
|  |  | ||||||
|     it('throws error when lock file is not found', async () => { |  | ||||||
|       jest.mocked(glob.hashFiles).mockResolvedValue(''); |  | ||||||
|  |  | ||||||
|       await expect(restoreCache(lockFilePattern)).rejects.toThrow(); |  | ||||||
|  |  | ||||||
|       expect(jest.mocked(core.saveState)).not.toHaveBeenCalled(); |  | ||||||
|       expect(jest.mocked(core.setOutput)).not.toHaveBeenCalled(); |  | ||||||
|       expect(jest.mocked(cache.restoreCache)).not.toHaveBeenCalled(); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('does not call core.saveState("CACHE_RESULT") when cache.restoreCache() returns falsy', async () => { |  | ||||||
|       jest.mocked(glob.hashFiles).mockResolvedValue('hash'); |  | ||||||
|       jest.mocked(cache.restoreCache).mockResolvedValue(undefined); |  | ||||||
|  |  | ||||||
|       await restoreCache(lockFilePattern); |  | ||||||
|  |  | ||||||
|       const expectedKey = `dotnet-cache-${process.env.RUNNER_OS}-hash`; |  | ||||||
|       expect(jest.mocked(core.saveState)).toHaveBeenCalledWith( |  | ||||||
|         'CACHE_KEY', |  | ||||||
|         expectedKey |  | ||||||
|       ); |  | ||||||
|       expect(jest.mocked(core.saveState)).not.toHaveBeenCalledWith( |  | ||||||
|         'CACHE_RESULT', |  | ||||||
|         expectedKey |  | ||||||
|       ); |  | ||||||
|       expect(jest.mocked(core.setOutput)).toHaveBeenCalledWith( |  | ||||||
|         'cache-hit', |  | ||||||
|         false |  | ||||||
|       ); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('calls core.saveState("CACHE_RESULT") when cache.restoreCache() returns key', async () => { |  | ||||||
|       const expectedKey = `dotnet-cache-${process.env.RUNNER_OS}-hash`; |  | ||||||
|       jest.mocked(glob.hashFiles).mockResolvedValue('hash'); |  | ||||||
|       jest.mocked(cache.restoreCache).mockResolvedValue(expectedKey); |  | ||||||
|  |  | ||||||
|       await restoreCache(lockFilePattern); |  | ||||||
|  |  | ||||||
|       expect(jest.mocked(core.saveState)).toHaveBeenCalledWith( |  | ||||||
|         'CACHE_KEY', |  | ||||||
|         expectedKey |  | ||||||
|       ); |  | ||||||
|       expect(jest.mocked(core.saveState)).toHaveBeenCalledWith( |  | ||||||
|         'CACHE_RESULT', |  | ||||||
|         expectedKey |  | ||||||
|       ); |  | ||||||
|       expect(jest.mocked(core.setOutput)).toHaveBeenCalledWith( |  | ||||||
|         'cache-hit', |  | ||||||
|         true |  | ||||||
|       ); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('calls glob.hashFiles("/packages.lock.json") if cacheDependencyPath is falsy', async () => { |  | ||||||
|       const expectedKey = `dotnet-cache-${process.env.RUNNER_OS}-hash`; |  | ||||||
|       jest.mocked(glob.hashFiles).mockResolvedValue('hash'); |  | ||||||
|       jest.mocked(cache.restoreCache).mockResolvedValue(expectedKey); |  | ||||||
|       jest.mocked(readdir).mockResolvedValue([lockFilePattern] as any); |  | ||||||
|  |  | ||||||
|       await restoreCache(''); |  | ||||||
|  |  | ||||||
|       expect(jest.mocked(glob.hashFiles)).not.toHaveBeenCalledWith(''); |  | ||||||
|       expect(jest.mocked(glob.hashFiles)).toHaveBeenCalledWith(lockFilePattern); |  | ||||||
|     }); |  | ||||||
|   }); |  | ||||||
| }); |  | ||||||
| @ -1,87 +0,0 @@ | |||||||
| import * as cache from '@actions/cache'; |  | ||||||
| import * as core from '@actions/core'; |  | ||||||
| import fs from 'node:fs'; |  | ||||||
| import {run} from '../src/cache-save'; |  | ||||||
| import {getNuGetFolderPath} from '../src/cache-utils'; |  | ||||||
|  |  | ||||||
| jest.mock('@actions/cache'); |  | ||||||
| jest.mock('@actions/core'); |  | ||||||
| jest.mock('node:fs'); |  | ||||||
| jest.mock('../src/cache-utils'); |  | ||||||
|  |  | ||||||
| describe('cache-save tests', () => { |  | ||||||
|   beforeAll(() => { |  | ||||||
|     jest.mocked(getNuGetFolderPath).mockResolvedValue({ |  | ||||||
|       'global-packages': 'global-packages', |  | ||||||
|       'http-cache': 'http-cache', |  | ||||||
|       temp: 'temp', |  | ||||||
|       'plugins-cache': 'plugins-cache' |  | ||||||
|     }); |  | ||||||
|   }); |  | ||||||
|   beforeEach(() => { |  | ||||||
|     jest.mocked(core.setFailed).mockClear(); |  | ||||||
|     jest.mocked(core.getState).mockClear(); |  | ||||||
|     jest.mocked(core.setOutput).mockClear(); |  | ||||||
|     jest.mocked(cache.saveCache).mockClear(); |  | ||||||
|     jest.mocked(fs.existsSync).mockClear(); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   it('does not save cache when inputs:cache === false', async () => { |  | ||||||
|     jest.mocked(core.getBooleanInput).mockReturnValue(false); |  | ||||||
|  |  | ||||||
|     await run(); |  | ||||||
|  |  | ||||||
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(core.getState)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(fs.existsSync)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled(); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   it('does not save cache when core.getState("CACHE_KEY") returns ""', async () => { |  | ||||||
|     jest.mocked(core.getBooleanInput).mockReturnValue(true); |  | ||||||
|     jest.mocked(core.getState).mockReturnValue(''); |  | ||||||
|  |  | ||||||
|     await run(); |  | ||||||
|  |  | ||||||
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2); |  | ||||||
|     expect(jest.mocked(fs.existsSync)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled(); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   it('throws Error when cachePath not exists', async () => { |  | ||||||
|     jest.mocked(core.getBooleanInput).mockReturnValue(true); |  | ||||||
|     jest.mocked(core.getState).mockReturnValue('cache-key'); |  | ||||||
|     jest.mocked(fs.existsSync).mockReturnValue(false); |  | ||||||
|  |  | ||||||
|     await run(); |  | ||||||
|  |  | ||||||
|     expect(jest.mocked(core.setFailed)).toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2); |  | ||||||
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled(); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   it('does not save cache when state.CACHE_KEY === state.CACHE_RESULT', async () => { |  | ||||||
|     jest.mocked(core.getBooleanInput).mockReturnValue(true); |  | ||||||
|     jest.mocked(core.getState).mockReturnValue('cache-key'); |  | ||||||
|     jest.mocked(fs.existsSync).mockReturnValue(true); |  | ||||||
|  |  | ||||||
|     await run(); |  | ||||||
|  |  | ||||||
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2); |  | ||||||
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled(); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   it('saves cache when state.CACHE_KEY !== state.CACHE_RESULT', async () => { |  | ||||||
|     jest.mocked(core.getBooleanInput).mockReturnValue(true); |  | ||||||
|     jest.mocked(core.getState).mockImplementation(s => s); |  | ||||||
|     jest.mocked(fs.existsSync).mockReturnValue(true); |  | ||||||
|  |  | ||||||
|     await run(); |  | ||||||
|  |  | ||||||
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled(); |  | ||||||
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2); |  | ||||||
|     expect(jest.mocked(cache.saveCache)).toHaveBeenCalled(); |  | ||||||
|   }); |  | ||||||
| }); |  | ||||||
| @ -1,122 +0,0 @@ | |||||||
| import * as cache from '@actions/cache'; |  | ||||||
| import * as exec from '@actions/exec'; |  | ||||||
|  |  | ||||||
| import {getNuGetFolderPath, isCacheFeatureAvailable} from '../src/cache-utils'; |  | ||||||
|  |  | ||||||
| jest.mock('@actions/cache'); |  | ||||||
| jest.mock('@actions/core'); |  | ||||||
| jest.mock('@actions/exec'); |  | ||||||
|  |  | ||||||
| describe('cache-utils tests', () => { |  | ||||||
|   describe('getNuGetFolderPath()', () => { |  | ||||||
|     it.each([ |  | ||||||
|       [ |  | ||||||
|         ` |  | ||||||
| http-cache: /home/codespace/.local/share/NuGet/v3-cache |  | ||||||
| global-packages: /var/nuget |  | ||||||
| temp: /tmp/NuGetScratch |  | ||||||
| plugins-cache: /home/codespace/.local/share/NuGet/plugins-cache |  | ||||||
| `, |  | ||||||
|         { |  | ||||||
|           'http-cache': '/home/codespace/.local/share/NuGet/v3-cache', |  | ||||||
|           'global-packages': '/var/nuget', |  | ||||||
|           temp: '/tmp/NuGetScratch', |  | ||||||
|           'plugins-cache': '/home/codespace/.local/share/NuGet/plugins-cache' |  | ||||||
|         } |  | ||||||
|       ], |  | ||||||
|       [ |  | ||||||
|         ` |  | ||||||
|   http-cache: /home/codespace/.local/share/NuGet/v3-cache |  | ||||||
|   global-packages: /var/nuget |  | ||||||
|   temp: /tmp/NuGetScratch |  | ||||||
|   plugins-cache: /home/codespace/.local/share/NuGet/plugins-cache |  | ||||||
| `, |  | ||||||
|         { |  | ||||||
|           'http-cache': '/home/codespace/.local/share/NuGet/v3-cache', |  | ||||||
|           'global-packages': '/var/nuget', |  | ||||||
|           temp: '/tmp/NuGetScratch', |  | ||||||
|           'plugins-cache': '/home/codespace/.local/share/NuGet/plugins-cache' |  | ||||||
|         } |  | ||||||
|       ], |  | ||||||
|       [ |  | ||||||
|         ` |  | ||||||
| http-cache: C:\\Users\\user\\AppData\\Local\\NuGet\\v3-cache |  | ||||||
| global-packages: C:\\Users\\user\\.nuget\\packages\\ |  | ||||||
| temp: C:\\Users\\user\\AppData\\Local\\Temp\\NuGetScratch |  | ||||||
| plugins-cache: C:\\Users\\user\\AppData\\Local\\NuGet\\plugins-cache |  | ||||||
|         `, |  | ||||||
|         { |  | ||||||
|           'http-cache': 'C:\\Users\\user\\AppData\\Local\\NuGet\\v3-cache', |  | ||||||
|           'global-packages': 'C:\\Users\\user\\.nuget\\packages\\', |  | ||||||
|           temp: 'C:\\Users\\user\\AppData\\Local\\Temp\\NuGetScratch', |  | ||||||
|           'plugins-cache': |  | ||||||
|             'C:\\Users\\user\\AppData\\Local\\NuGet\\plugins-cache' |  | ||||||
|         } |  | ||||||
|       ], |  | ||||||
|       [ |  | ||||||
|         ` |  | ||||||
|   http-cache: C:\\Users\\user\\AppData\\Local\\NuGet\\v3-cache |  | ||||||
|   global-packages: C:\\Users\\user\\.nuget\\packages\\ |  | ||||||
|   temp: C:\\Users\\user\\AppData\\Local\\Temp\\NuGetScratch |  | ||||||
|   plugins-cache: C:\\Users\\user\\AppData\\Local\\NuGet\\plugins-cache |  | ||||||
|         `, |  | ||||||
|         { |  | ||||||
|           'http-cache': 'C:\\Users\\user\\AppData\\Local\\NuGet\\v3-cache', |  | ||||||
|           'global-packages': 'C:\\Users\\user\\.nuget\\packages\\', |  | ||||||
|           temp: 'C:\\Users\\user\\AppData\\Local\\Temp\\NuGetScratch', |  | ||||||
|           'plugins-cache': |  | ||||||
|             'C:\\Users\\user\\AppData\\Local\\NuGet\\plugins-cache' |  | ||||||
|         } |  | ||||||
|       ] |  | ||||||
|     ])('(stdout: "%s") returns %p', async (stdout, expected) => { |  | ||||||
|       jest |  | ||||||
|         .mocked(exec.getExecOutput) |  | ||||||
|         .mockResolvedValue({stdout, stderr: '', exitCode: 0}); |  | ||||||
|       const pathes = await getNuGetFolderPath(); |  | ||||||
|       expect(pathes).toStrictEqual(expected); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it.each([ |  | ||||||
|       ` |  | ||||||
| error: An invalid local resource name was provided. Provide one of the following values: http-cache, temp, global-packages, all. |  | ||||||
| Usage: dotnet nuget locals [arguments] [options] |  | ||||||
| Arguments: |  | ||||||
|   Cache Location(s)  Specifies the cache location(s) to list or clear. |  | ||||||
| <all | http-cache | global-packages | temp> |  | ||||||
| Options: |  | ||||||
|   -h|--help               Show help information |  | ||||||
|   --force-english-output  Forces the application to run using an invariant, English-based culture. |  | ||||||
|   -c|--clear              Clear the selected local resources or cache location(s). |  | ||||||
|   -l|--list               List the selected local resources or cache location(s). |  | ||||||
|       `, |  | ||||||
|       'bash: dotnet: command not found', |  | ||||||
|       '' |  | ||||||
|     ])('(stderr: "%s", exitCode: 1) throws Error', async stderr => { |  | ||||||
|       jest |  | ||||||
|         .mocked(exec.getExecOutput) |  | ||||||
|         .mockResolvedValue({stdout: '', stderr, exitCode: 1}); |  | ||||||
|       await expect(getNuGetFolderPath()).rejects.toThrow(); |  | ||||||
|     }); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   describe.each(['', 'https://github.com/', 'https://example.com/'])( |  | ||||||
|     'isCacheFeatureAvailable()', |  | ||||||
|     url => { |  | ||||||
|       // Save & Restore env |  | ||||||
|       let serverUrlEnv: string | undefined; |  | ||||||
|       beforeAll(() => (serverUrlEnv = process.env['GITHUB_SERVER_URL'])); |  | ||||||
|       beforeEach(() => (process.env['GITHUB_SERVER_URL'] = url)); |  | ||||||
|       afterEach(() => (process.env['GITHUB_SERVER_URL'] = serverUrlEnv)); |  | ||||||
|  |  | ||||||
|       it('returns true when cache.isFeatureAvailable() === true', () => { |  | ||||||
|         jest.mocked(cache.isFeatureAvailable).mockReturnValue(true); |  | ||||||
|         expect(isCacheFeatureAvailable()).toBe(true); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it('returns false when cache.isFeatureAvailable() === false', () => { |  | ||||||
|         jest.mocked(cache.isFeatureAvailable).mockReturnValue(false); |  | ||||||
|         expect(isCacheFeatureAvailable()).toBe(false); |  | ||||||
|       }); |  | ||||||
|     } |  | ||||||
|   ); |  | ||||||
| }); |  | ||||||
| @ -1,45 +1,23 @@ | |||||||
| import cscFile from '../.github/csc.json'; | import fs = require('fs'); | ||||||
|  |  | ||||||
| describe('csc tests', () => { | describe('csc tests', () => { | ||||||
|   test('regular expression in csc.json is valid', async () => { |   it('Valid regular expression', async () => { | ||||||
|     const regexPattern = cscFile['problemMatcher'][0]['pattern'][0]['regexp']; |     var cscFile = require('../.github/csc.json'); | ||||||
|     const regexResultsMap = cscFile['problemMatcher'][0]['pattern'][0]; |     var regex = cscFile['problemMatcher'][0]['pattern'][0]['regexp']; | ||||||
|  |  | ||||||
|     const regex = new RegExp(regexPattern); |     console.log(regex); | ||||||
|  |     var re = new RegExp(regex); | ||||||
|  |  | ||||||
|     const stringsToMatch = [ |     // 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]', |       '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]" |       "S:\\Msbuild\\src\\Build\\Evaluation\\ExpressionShredder.cs(33,7): error CS1003: Syntax error, ',' expected [S:\\msbuild\\src\\Build\\Microsoft.Build.csproj > Properties:prop]" | ||||||
|     ]; |     ]; | ||||||
|     // Expected results are calculated according to the csc matcher located in csc.json file |  | ||||||
|     const expectedResults = [ |  | ||||||
|       { |  | ||||||
|         file: 'Program.cs', |  | ||||||
|         line: '10', |  | ||||||
|         severity: 'error', |  | ||||||
|         code: 'CS1002', |  | ||||||
|         message: '; expected', |  | ||||||
|         fromPath: |  | ||||||
|           '/Users/zacharyeisinger/Documents/repo/setup-dotnet/__tests__/sample-broken-csproj/sample.csproj' |  | ||||||
|       }, |  | ||||||
|       { |  | ||||||
|         file: 'S:\\Msbuild\\src\\Build\\Evaluation\\ExpressionShredder.cs', |  | ||||||
|         line: '33', |  | ||||||
|         severity: 'error', |  | ||||||
|         code: 'CS1003', |  | ||||||
|         message: "Syntax error, ',' expected", |  | ||||||
|         fromPath: |  | ||||||
|           'S:\\msbuild\\src\\Build\\Microsoft.Build.csproj > Properties:prop' |  | ||||||
|       } |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     stringsToMatch.map((string, index) => { |     stringsToMatch.forEach(string => { | ||||||
|       const matchedResultsArray = string.match(regex); |       var matchStr = string.match(re); | ||||||
|       for (const propName in expectedResults[index]) { |       console.log(matchStr); | ||||||
|         const propertyIndex = regexResultsMap[propName]; |       expect(matchStr).toEqual(expect.anything()); | ||||||
|         const expectedPropValue = expectedResults[index][propName]; |  | ||||||
|         const matchedPropValue = matchedResultsArray![propertyIndex]; |  | ||||||
|         expect(matchedPropValue).toEqual(expectedPropValue); |  | ||||||
|       } |  | ||||||
|     }); |     }); | ||||||
|   }, 10000); |   }, 10000); | ||||||
| }); | }); | ||||||
|  | |||||||
| @ -1,18 +0,0 @@ | |||||||
| using Microsoft.VisualStudio.TestTools.UnitTesting; |  | ||||||
| using System; |  | ||||||
|  |  | ||||||
| namespace test_csproj |  | ||||||
| { |  | ||||||
|     [TestClass] |  | ||||||
|     public class Test |  | ||||||
|     { |  | ||||||
|         [TestMethod] |  | ||||||
|         public void TestMethod() |  | ||||||
|         {    |  | ||||||
|             Console.WriteLine("TestMethod"); |  | ||||||
|             int calculatedResult = 1000 / 25; |  | ||||||
|             int expectedResult = 40; |  | ||||||
|             Assert.AreEqual(calculatedResult, expectedResult); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,16 +0,0 @@ | |||||||
| <Project Sdk="Microsoft.NET.Sdk"> |  | ||||||
|  |  | ||||||
|   <PropertyGroup> |  | ||||||
|     <TargetFramework>$(TEST_TARGET_FRAMEWORK)</TargetFramework> |  | ||||||
|     <IsPackable>false</IsPackable> |  | ||||||
|     <DisableImplicitNuGetFallbackFolder>true</DisableImplicitNuGetFallbackFolder> |  | ||||||
|   </PropertyGroup> |  | ||||||
|  |  | ||||||
|   <ItemGroup> |  | ||||||
|     <!-- These packages will be downloaded over the network for testing proxy settings --> |  | ||||||
|     <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0-preview-20170810-02" /> |  | ||||||
|     <PackageReference Include="MSTest.TestAdapter" Version="1.1.18" /> |  | ||||||
|     <PackageReference Include="MSTest.TestFramework" Version="1.1.18" /> |  | ||||||
|   </ItemGroup> |  | ||||||
|  |  | ||||||
| </Project> |  | ||||||
| @ -1,65 +0,0 @@ | |||||||
| import path from 'path'; |  | ||||||
| import fs from 'fs'; |  | ||||||
| import * as hc from '@actions/http-client'; |  | ||||||
|  |  | ||||||
| const HTTP_CLIENT_OPTIONS = {allowRetries: true, maxRetries: 10} as const; |  | ||||||
| const TEST_TIMEOUT = 30000; |  | ||||||
|  |  | ||||||
| describe('Dotnet installation scripts tests', () => { |  | ||||||
|   it( |  | ||||||
|     'Uses an up to date bash download script', |  | ||||||
|     async () => { |  | ||||||
|       const httpCallbackClient = new hc.HttpClient( |  | ||||||
|         'setup-dotnet-test', |  | ||||||
|         [], |  | ||||||
|         HTTP_CLIENT_OPTIONS |  | ||||||
|       ); |  | ||||||
|       const response: hc.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( |  | ||||||
|           path.join(__dirname, '..', 'externals', 'install-dotnet.sh') |  | ||||||
|         ) |  | ||||||
|         .toString(); |  | ||||||
|       expect(normalizeFileContents(currentContents)).toBe( |  | ||||||
|         normalizeFileContents(upToDateContents) |  | ||||||
|       ); |  | ||||||
|     }, |  | ||||||
|     TEST_TIMEOUT |  | ||||||
|   ); |  | ||||||
|  |  | ||||||
|   it( |  | ||||||
|     'Uses an up to date powershell download script', |  | ||||||
|     async () => { |  | ||||||
|       const httpCallbackClient = new hc.HttpClient( |  | ||||||
|         'setup-dotnet-test', |  | ||||||
|         [], |  | ||||||
|         HTTP_CLIENT_OPTIONS |  | ||||||
|       ); |  | ||||||
|       const response: hc.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( |  | ||||||
|           path.join(__dirname, '..', 'externals', 'install-dotnet.ps1') |  | ||||||
|         ) |  | ||||||
|         .toString(); |  | ||||||
|       expect(normalizeFileContents(currentContents)).toBe( |  | ||||||
|         normalizeFileContents(upToDateContents) |  | ||||||
|       ); |  | ||||||
|     }, |  | ||||||
|     TEST_TIMEOUT |  | ||||||
|   ); |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| function normalizeFileContents(contents: string): string { |  | ||||||
|   return contents |  | ||||||
|     .trim() |  | ||||||
|     .replace(new RegExp('\r\n', 'g'), '\n') |  | ||||||
|     .replace(new RegExp('\r', 'g'), '\n'); |  | ||||||
| } |  | ||||||
| @ -1,457 +1,151 @@ | |||||||
| import each from 'jest-each'; | import io = require('@actions/io'); | ||||||
| import semver from 'semver'; | import fs = require('fs'); | ||||||
| import fs from 'fs'; | import os = require('os'); | ||||||
| import fspromises from 'fs/promises'; | import path = require('path'); | ||||||
| import * as exec from '@actions/exec'; | import hc = require('@actions/http-client'); | ||||||
| import * as core from '@actions/core'; |  | ||||||
| import * as io from '@actions/io'; | 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 installer from '../src/installer'; | import * as installer from '../src/installer'; | ||||||
|  |  | ||||||
| import {IS_WINDOWS} from '../src/utils'; | const IS_WINDOWS = process.platform === 'win32'; | ||||||
| import {QualityOptions} from '../src/setup-dotnet'; |  | ||||||
|  |  | ||||||
| describe('installer tests', () => { | describe('installer tests', () => { | ||||||
|   const env = process.env; |   beforeAll(async () => { | ||||||
|  |     process.env.RUNNER_TOOL_CACHE = toolDir; | ||||||
|   beforeEach(() => { |     process.env.DOTNET_INSTALL_DIR = toolDir; | ||||||
|     jest.resetModules(); |     process.env.RUNNER_TEMP = tempDir; | ||||||
|     process.env = {...env}; |     process.env.DOTNET_ROOT = ''; | ||||||
|  |     await io.rmRF(toolDir); | ||||||
|  |     await io.rmRF(tempDir); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   describe('DotnetCoreInstaller tests', () => { |   afterAll(async () => { | ||||||
|     const getExecOutputSpy = jest.spyOn(exec, 'getExecOutput'); |     try { | ||||||
|     const warningSpy = jest.spyOn(core, 'warning'); |       await io.rmRF(toolDir); | ||||||
|     const whichSpy = jest.spyOn(io, 'which'); |       await io.rmRF(tempDir); | ||||||
|     const maxSatisfyingSpy = jest.spyOn(semver, 'maxSatisfying'); |     } catch { | ||||||
|     const chmodSyncSpy = jest.spyOn(fs, 'chmodSync'); |       console.log('Failed to remove test directories'); | ||||||
|     const readdirSpy = jest.spyOn(fspromises, 'readdir'); |  | ||||||
|  |  | ||||||
|     describe('installDotnet() tests', () => { |  | ||||||
|       beforeAll(() => { |  | ||||||
|         whichSpy.mockImplementation(() => Promise.resolve('PathToShell')); |  | ||||||
|         chmodSyncSpy.mockImplementation(() => {}); |  | ||||||
|         readdirSpy.mockImplementation(() => Promise.resolve([])); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       afterAll(() => { |  | ||||||
|         jest.resetAllMocks(); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it('should throw the error in case of non-zero exit code of the installation script. The error message should contain logs.', async () => { |  | ||||||
|         const inputVersion = '3.1.100'; |  | ||||||
|         const inputQuality = '' as QualityOptions; |  | ||||||
|         const errorMessage = 'fictitious error message!'; |  | ||||||
|  |  | ||||||
|         getExecOutputSpy.mockImplementation(() => { |  | ||||||
|           return Promise.resolve({ |  | ||||||
|             exitCode: 1, |  | ||||||
|             stdout: '', |  | ||||||
|             stderr: errorMessage |  | ||||||
|           }); |  | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|           inputVersion, |  | ||||||
|           inputQuality |  | ||||||
|         ); |  | ||||||
|         await expect(dotnetInstaller.installDotnet()).rejects.toThrow( |  | ||||||
|           `Failed to install dotnet, exit code: 1. ${errorMessage}` |  | ||||||
|         ); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it('should return version of .NET SDK after installation complete', async () => { |  | ||||||
|         const inputVersion = '3.1.100'; |  | ||||||
|         const inputQuality = '' as QualityOptions; |  | ||||||
|         const stdout = `Fictitious dotnet version ${inputVersion} is installed`; |  | ||||||
|         getExecOutputSpy.mockImplementation(() => { |  | ||||||
|           return Promise.resolve({ |  | ||||||
|             exitCode: 0, |  | ||||||
|             stdout: `${stdout}`, |  | ||||||
|             stderr: '' |  | ||||||
|           }); |  | ||||||
|         }); |  | ||||||
|         maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|         const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|           inputVersion, |  | ||||||
|           inputQuality |  | ||||||
|         ); |  | ||||||
|         const installedVersion = await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|         expect(installedVersion).toBe(inputVersion); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it(`should supply 'version' argument to the installation script if supplied version is in A.B.C syntax`, async () => { |  | ||||||
|         const inputVersion = '6.0.300'; |  | ||||||
|         const inputQuality = '' as QualityOptions; |  | ||||||
|         const stdout = `Fictitious dotnet version ${inputVersion} is installed`; |  | ||||||
|  |  | ||||||
|         getExecOutputSpy.mockImplementation(() => { |  | ||||||
|           return Promise.resolve({ |  | ||||||
|             exitCode: 0, |  | ||||||
|             stdout: `${stdout}`, |  | ||||||
|             stderr: '' |  | ||||||
|           }); |  | ||||||
|         }); |  | ||||||
|         maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|         const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|           inputVersion, |  | ||||||
|           inputQuality |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|         const scriptArguments = ( |  | ||||||
|           getExecOutputSpy.mock.calls[0][1] as string[] |  | ||||||
|         ).join(' '); |  | ||||||
|         const expectedArgument = IS_WINDOWS |  | ||||||
|           ? `-Version ${inputVersion}` |  | ||||||
|           : `--version ${inputVersion}`; |  | ||||||
|  |  | ||||||
|         expect(scriptArguments).toContain(expectedArgument); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it(`should warn if the 'quality' input is set and the supplied version is in A.B.C syntax`, async () => { |  | ||||||
|         const inputVersion = '6.0.300'; |  | ||||||
|         const inputQuality = 'ga' as QualityOptions; |  | ||||||
|         const stdout = `Fictitious dotnet version ${inputVersion} is installed`; |  | ||||||
|         getExecOutputSpy.mockImplementation(() => { |  | ||||||
|           return Promise.resolve({ |  | ||||||
|             exitCode: 0, |  | ||||||
|             stdout: `${stdout}`, |  | ||||||
|             stderr: '' |  | ||||||
|           }); |  | ||||||
|         }); |  | ||||||
|         maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|         const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|           inputVersion, |  | ||||||
|           inputQuality |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|         expect(warningSpy).toHaveBeenCalledWith( |  | ||||||
|           `The 'dotnet-quality' input can be used only with .NET SDK version in A.B, A.B.x, A, A.x and A.B.Cxx formats where the major tag is higher than 5. You specified: ${inputVersion}. 'dotnet-quality' input is ignored.` |  | ||||||
|         ); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it(`should warn if the 'quality' input is set and version isn't in A.B.C syntax but major tag is lower then 6`, async () => { |  | ||||||
|         const inputVersion = '3.1'; |  | ||||||
|         const inputQuality = 'ga' as QualityOptions; |  | ||||||
|         const stdout = `Fictitious dotnet version 3.1.100 is installed`; |  | ||||||
|  |  | ||||||
|         getExecOutputSpy.mockImplementation(() => { |  | ||||||
|           return Promise.resolve({ |  | ||||||
|             exitCode: 0, |  | ||||||
|             stdout: `${stdout}`, |  | ||||||
|             stderr: '' |  | ||||||
|           }); |  | ||||||
|         }); |  | ||||||
|         maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|         const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|           inputVersion, |  | ||||||
|           inputQuality |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|         expect(warningSpy).toHaveBeenCalledWith( |  | ||||||
|           `The 'dotnet-quality' input can be used only with .NET SDK version in A.B, A.B.x, A, A.x and A.B.Cxx formats where the major tag is higher than 5. You specified: ${inputVersion}. 'dotnet-quality' input is ignored.` |  | ||||||
|         ); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       each(['6', '6.0', '6.0.x', '6.0.*', '6.0.X']).test( |  | ||||||
|         `should supply 'quality' argument to the installation script if quality input is set and version (%s) is not in A.B.C syntax`, |  | ||||||
|         async inputVersion => { |  | ||||||
|           const inputQuality = 'ga' as QualityOptions; |  | ||||||
|           const exitCode = 0; |  | ||||||
|           const stdout = `Fictitious dotnet version 6.0.0 is installed`; |  | ||||||
|           getExecOutputSpy.mockImplementation(() => { |  | ||||||
|             return Promise.resolve({ |  | ||||||
|               exitCode: exitCode, |  | ||||||
|               stdout: `${stdout}`, |  | ||||||
|               stderr: '' |  | ||||||
|             }); |  | ||||||
|           }); |  | ||||||
|           maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|           const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|             inputVersion, |  | ||||||
|             inputQuality |  | ||||||
|           ); |  | ||||||
|  |  | ||||||
|           await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|           const scriptArguments = ( |  | ||||||
|             getExecOutputSpy.mock.calls[0][1] as string[] |  | ||||||
|           ).join(' '); |  | ||||||
|           const expectedArgument = IS_WINDOWS |  | ||||||
|             ? `-Quality ${inputQuality}` |  | ||||||
|             : `--quality ${inputQuality}`; |  | ||||||
|  |  | ||||||
|           expect(scriptArguments).toContain(expectedArgument); |  | ||||||
|     } |     } | ||||||
|       ); |   }, 30000); | ||||||
|  |  | ||||||
|       each(['6', '6.0', '6.0.x', '6.0.*', '6.0.X']).test( |   it('Aquires multiple versions of dotnet', async () => { | ||||||
|         `should supply 'channel' argument to the installation script if version (%s) isn't in A.B.C syntax`, |     const versions = ['2.2.207', '3.1.120']; | ||||||
|         async inputVersion => { |  | ||||||
|           const inputQuality = '' as QualityOptions; |  | ||||||
|           const exitCode = 0; |  | ||||||
|           const stdout = `Fictitious dotnet version 6.0.0 is installed`; |  | ||||||
|           getExecOutputSpy.mockImplementation(() => { |  | ||||||
|             return Promise.resolve({ |  | ||||||
|               exitCode: exitCode, |  | ||||||
|               stdout: `${stdout}`, |  | ||||||
|               stderr: '' |  | ||||||
|             }); |  | ||||||
|           }); |  | ||||||
|           maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|           const dotnetInstaller = new installer.DotnetCoreInstaller( |     for (const version of versions) { | ||||||
|             inputVersion, |       await getDotnet(version); | ||||||
|             inputQuality |  | ||||||
|           ); |  | ||||||
|  |  | ||||||
|           await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|           const scriptArguments = ( |  | ||||||
|             getExecOutputSpy.mock.calls[0][1] as string[] |  | ||||||
|           ).join(' '); |  | ||||||
|           const expectedArgument = IS_WINDOWS |  | ||||||
|             ? `-Channel 6.0` |  | ||||||
|             : `--channel 6.0`; |  | ||||||
|  |  | ||||||
|           expect(scriptArguments).toContain(expectedArgument); |  | ||||||
|     } |     } | ||||||
|       ); |     expect(fs.existsSync(path.join(toolDir, 'sdk', '2.2.207'))).toBe(true); | ||||||
|  |     expect(fs.existsSync(path.join(toolDir, 'sdk', '3.1.120'))).toBe(true); | ||||||
|  |  | ||||||
|     if (IS_WINDOWS) { |     if (IS_WINDOWS) { | ||||||
|         it(`should supply '-ProxyAddress' argument to the installation script if env.variable 'https_proxy' is set`, async () => { |       expect(fs.existsSync(path.join(toolDir, 'dotnet.exe'))).toBe(true); | ||||||
|           process.env['https_proxy'] = 'https://proxy.com'; |  | ||||||
|           const inputVersion = '6.0.100'; |  | ||||||
|           const inputQuality = '' as QualityOptions; |  | ||||||
|           const stdout = `Fictitious dotnet version ${inputVersion} is installed`; |  | ||||||
|  |  | ||||||
|           getExecOutputSpy.mockImplementation(() => { |  | ||||||
|             return Promise.resolve({ |  | ||||||
|               exitCode: 0, |  | ||||||
|               stdout: `${stdout}`, |  | ||||||
|               stderr: '' |  | ||||||
|             }); |  | ||||||
|           }); |  | ||||||
|           maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|           const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|             inputVersion, |  | ||||||
|             inputQuality |  | ||||||
|           ); |  | ||||||
|  |  | ||||||
|           await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|           const scriptArguments = ( |  | ||||||
|             getExecOutputSpy.mock.calls[0][1] as string[] |  | ||||||
|           ).join(' '); |  | ||||||
|  |  | ||||||
|           expect(scriptArguments).toContain( |  | ||||||
|             `-ProxyAddress ${process.env['https_proxy']}` |  | ||||||
|           ); |  | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         it(`should supply '-ProxyBypassList' argument to the installation script if env.variable 'no_proxy' is set`, async () => { |  | ||||||
|           process.env['no_proxy'] = 'first.url,second.url'; |  | ||||||
|           const inputVersion = '6.0.100'; |  | ||||||
|           const inputQuality = '' as QualityOptions; |  | ||||||
|           const stdout = `Fictitious dotnet version 6.0.0 is installed`; |  | ||||||
|  |  | ||||||
|           getExecOutputSpy.mockImplementation(() => { |  | ||||||
|             return Promise.resolve({ |  | ||||||
|               exitCode: 0, |  | ||||||
|               stdout: `${stdout}`, |  | ||||||
|               stderr: '' |  | ||||||
|             }); |  | ||||||
|           }); |  | ||||||
|           maxSatisfyingSpy.mockImplementation(() => inputVersion); |  | ||||||
|  |  | ||||||
|           const dotnetInstaller = new installer.DotnetCoreInstaller( |  | ||||||
|             inputVersion, |  | ||||||
|             inputQuality |  | ||||||
|           ); |  | ||||||
|  |  | ||||||
|           await dotnetInstaller.installDotnet(); |  | ||||||
|  |  | ||||||
|           const scriptArguments = ( |  | ||||||
|             getExecOutputSpy.mock.calls[0][1] as string[] |  | ||||||
|           ).join(' '); |  | ||||||
|  |  | ||||||
|           expect(scriptArguments).toContain( |  | ||||||
|             `-ProxyBypassList ${process.env['no_proxy']}` |  | ||||||
|           ); |  | ||||||
|         }); |  | ||||||
|       } |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     describe('addToPath() tests', () => { |  | ||||||
|       it(`should export DOTNET_ROOT env.var with value from DOTNET_INSTALL_DIR env.var`, async () => { |  | ||||||
|         process.env['DOTNET_INSTALL_DIR'] = 'fictitious/dotnet/install/dir'; |  | ||||||
|         installer.DotnetCoreInstaller.addToPath(); |  | ||||||
|         const dotnet_root = process.env['DOTNET_ROOT']; |  | ||||||
|         expect(dotnet_root).toBe(process.env['DOTNET_INSTALL_DIR']); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       it(`should export value from DOTNET_INSTALL_DIR env.var to the PATH`, async () => { |  | ||||||
|         process.env['DOTNET_INSTALL_DIR'] = 'fictitious/dotnet/install/dir'; |  | ||||||
|         installer.DotnetCoreInstaller.addToPath(); |  | ||||||
|         const path = process.env['PATH']; |  | ||||||
|         expect(path).toContain(process.env['DOTNET_INSTALL_DIR']); |  | ||||||
|       }); |  | ||||||
|     }); |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   describe('DotnetVersionResolver tests', () => { |  | ||||||
|     describe('createDotNetVersion() tests', () => { |  | ||||||
|       each([ |  | ||||||
|         '3.1', |  | ||||||
|         '3.x', |  | ||||||
|         '3.1.x', |  | ||||||
|         '3.1.*', |  | ||||||
|         '3.1.X', |  | ||||||
|         '3.1.2', |  | ||||||
|         '3.1.0-preview1', |  | ||||||
|         '6.0.2xx' |  | ||||||
|       ]).test( |  | ||||||
|         'if valid version is supplied (%s), it should return version object with some value', |  | ||||||
|         async version => { |  | ||||||
|           const dotnetVersionResolver = new installer.DotnetVersionResolver( |  | ||||||
|             version |  | ||||||
|           ); |  | ||||||
|           const versionObject = |  | ||||||
|             await dotnetVersionResolver.createDotNetVersion(); |  | ||||||
|  |  | ||||||
|           expect(!!versionObject.value).toBe(true); |  | ||||||
|         } |  | ||||||
|       ); |  | ||||||
|  |  | ||||||
|       each([ |  | ||||||
|         '.', |  | ||||||
|         '..', |  | ||||||
|         ' . ', |  | ||||||
|         '. ', |  | ||||||
|         ' .', |  | ||||||
|         ' . . ', |  | ||||||
|         ' .. ', |  | ||||||
|         ' .  ', |  | ||||||
|         '-1.-1', |  | ||||||
|         '-1', |  | ||||||
|         '-1.-1.-1', |  | ||||||
|         '..3', |  | ||||||
|         '1..3', |  | ||||||
|         '1..', |  | ||||||
|         '.2.3', |  | ||||||
|         '.2.x', |  | ||||||
|         '*.', |  | ||||||
|         '1.2.', |  | ||||||
|         '1.2.-abc', |  | ||||||
|         'a.b', |  | ||||||
|         'a.b.c', |  | ||||||
|         'a.b.c-preview', |  | ||||||
|         ' 0 . 1 . 2 ', |  | ||||||
|         'invalid' |  | ||||||
|       ]).test( |  | ||||||
|         'if invalid version is supplied (%s), it should throw', |  | ||||||
|         async version => { |  | ||||||
|           const dotnetVersionResolver = new installer.DotnetVersionResolver( |  | ||||||
|             version |  | ||||||
|           ); |  | ||||||
|  |  | ||||||
|           await expect( |  | ||||||
|             async () => await dotnetVersionResolver.createDotNetVersion() |  | ||||||
|           ).rejects.toThrow(); |  | ||||||
|         } |  | ||||||
|       ); |  | ||||||
|  |  | ||||||
|       each(['3', '3.1', '3.1.x', '3.1.*', '3.1.X', '6.0.2xx']).test( |  | ||||||
|         "if version that can be resolved to 'channel' option is supplied (%s), it should set type to 'channel' in version object", |  | ||||||
|         async version => { |  | ||||||
|           const dotnetVersionResolver = new installer.DotnetVersionResolver( |  | ||||||
|             version |  | ||||||
|           ); |  | ||||||
|           const versionObject = |  | ||||||
|             await dotnetVersionResolver.createDotNetVersion(); |  | ||||||
|  |  | ||||||
|           expect(versionObject.type.toLowerCase().includes('channel')).toBe( |  | ||||||
|             true |  | ||||||
|           ); |  | ||||||
|         } |  | ||||||
|       ); |  | ||||||
|  |  | ||||||
|       each(['6.0', '6.0.x', '6.0.*', '6.0.X', '6.0.2xx']).test( |  | ||||||
|         "if version that can be resolved to 'channel' option is supplied and its major tag is >= 6 (%s), it should set type to 'channel' and qualityFlag to 'true' in version object", |  | ||||||
|         async version => { |  | ||||||
|           const dotnetVersionResolver = new installer.DotnetVersionResolver( |  | ||||||
|             version |  | ||||||
|           ); |  | ||||||
|           const versionObject = |  | ||||||
|             await dotnetVersionResolver.createDotNetVersion(); |  | ||||||
|  |  | ||||||
|           expect(versionObject.type.toLowerCase().includes('channel')).toBe( |  | ||||||
|             true |  | ||||||
|           ); |  | ||||||
|           expect(versionObject.qualityFlag).toBe(true); |  | ||||||
|         } |  | ||||||
|       ); |  | ||||||
|  |  | ||||||
|       each(['3.1.2', '3.1.0-preview1']).test( |  | ||||||
|         "if version that can be resolved to 'version' option is supplied (%s), it should set quality flag to 'false' and type to 'version' in version object", |  | ||||||
|         async version => { |  | ||||||
|           const dotnetVersionResolver = new installer.DotnetVersionResolver( |  | ||||||
|             version |  | ||||||
|           ); |  | ||||||
|           const versionObject = |  | ||||||
|             await dotnetVersionResolver.createDotNetVersion(); |  | ||||||
|  |  | ||||||
|           expect(versionObject.type.toLowerCase().includes('version')).toBe( |  | ||||||
|             true |  | ||||||
|           ); |  | ||||||
|           expect(versionObject.qualityFlag).toBe(false); |  | ||||||
|         } |  | ||||||
|       ); |  | ||||||
|  |  | ||||||
|       each(['3.1.2', '3.1']).test( |  | ||||||
|         'it should create proper line arguments for powershell/bash installation scripts', |  | ||||||
|         async version => { |  | ||||||
|           const dotnetVersionResolver = new installer.DotnetVersionResolver( |  | ||||||
|             version |  | ||||||
|           ); |  | ||||||
|           const versionObject = |  | ||||||
|             await dotnetVersionResolver.createDotNetVersion(); |  | ||||||
|           const windowsRegEx = new RegExp(/^-(Version|Channel)/); |  | ||||||
|           const nonWindowsRegEx = new RegExp(/^--(version|channel)/); |  | ||||||
|  |  | ||||||
|           if (IS_WINDOWS) { |  | ||||||
|             expect(windowsRegEx.test(versionObject.type)).toBe(true); |  | ||||||
|             expect(nonWindowsRegEx.test(versionObject.type)).toBe(false); |  | ||||||
|     } else { |     } else { | ||||||
|             expect(nonWindowsRegEx.test(versionObject.type)).toBe(true); |       expect(fs.existsSync(path.join(toolDir, 'dotnet'))).toBe(true); | ||||||
|             expect(windowsRegEx.test(versionObject.type)).toBe(false); |  | ||||||
|     } |     } | ||||||
|         } |  | ||||||
|       ); |  | ||||||
|  |  | ||||||
|       it(`should throw if dotnet-version is supplied in A.B.Cxx syntax with major tag lower that 5`, async () => { |     expect(process.env.DOTNET_ROOT).toBeDefined; | ||||||
|         const version = '3.0.1xx'; |     expect(process.env.PATH).toBeDefined; | ||||||
|         const dotnetVersionResolver = new installer.DotnetVersionResolver( |     expect(process.env.DOTNET_ROOT).toBe(toolDir); | ||||||
|           version |     expect(process.env.PATH?.startsWith(toolDir)).toBe(true); | ||||||
|  |   }, 600000); | ||||||
|  |  | ||||||
|  |   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); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     expect(process.env.DOTNET_ROOT).toBeDefined; | ||||||
|  |     expect(process.env.PATH).toBeDefined; | ||||||
|  |     expect(process.env.DOTNET_ROOT).toBe(toolDir); | ||||||
|  |     expect(process.env.PATH?.startsWith(toolDir)).toBe(true); | ||||||
|  |   }, 600000); //This needs some time to download on "slower" internet connections | ||||||
|  |  | ||||||
|  |   it('Acquires generic version of dotnet if no matching version is installed', async () => { | ||||||
|  |     await getDotnet('3.1'); | ||||||
|  |     var directory = fs | ||||||
|  |       .readdirSync(path.join(toolDir, 'sdk')) | ||||||
|  |       .filter(fn => fn.startsWith('3.1.')); | ||||||
|  |     expect(directory.length > 0).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); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     expect(process.env.DOTNET_ROOT).toBeDefined; | ||||||
|  |     expect(process.env.PATH).toBeDefined; | ||||||
|  |     expect(process.env.DOTNET_ROOT).toBe(toolDir); | ||||||
|  |     expect(process.env.PATH?.startsWith(toolDir)).toBe(true); | ||||||
|  |   }, 600000); //This needs some time to download on "slower" internet connections | ||||||
|  |  | ||||||
|  |   it('Throws if no location contains correct dotnet version', async () => { | ||||||
|  |     let thrown = false; | ||||||
|  |     try { | ||||||
|  |       await getDotnet('1000.0.0'); | ||||||
|  |     } catch { | ||||||
|  |       thrown = true; | ||||||
|  |     } | ||||||
|  |     expect(thrown).toBe(true); | ||||||
|  |   }, 30000); | ||||||
|  |  | ||||||
|  |   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( | ||||||
|  |       'https://dot.net/v1/dotnet-install.sh' | ||||||
|     ); |     ); | ||||||
|         await expect( |     expect(response.message.statusCode).toBe(200); | ||||||
|           async () => await dotnetVersionResolver.createDotNetVersion() |     const upToDateContents: string = await response.readBody(); | ||||||
|         ).rejects.toThrow( |     const currentContents: string = fs | ||||||
|           `'dotnet-version' was supplied in invalid format: ${version}! The A.B.Cxx syntax is available since the .NET 5.0 release.` |       .readFileSync( | ||||||
|  |         path.join(__dirname, '..', 'externals', 'install-dotnet.sh') | ||||||
|  |       ) | ||||||
|  |       .toString(); | ||||||
|  |     expect(normalizeFileContents(currentContents)).toBe( | ||||||
|  |       normalizeFileContents(upToDateContents) | ||||||
|     ); |     ); | ||||||
|  |   }, 30000); | ||||||
|  |  | ||||||
|  |   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( | ||||||
|  |       'https://dot.net/v1/dotnet-install.ps1' | ||||||
|  |     ); | ||||||
|  |     expect(response.message.statusCode).toBe(200); | ||||||
|  |     const upToDateContents: string = await response.readBody(); | ||||||
|  |     const currentContents: string = fs | ||||||
|  |       .readFileSync( | ||||||
|  |         path.join(__dirname, '..', 'externals', 'install-dotnet.ps1') | ||||||
|  |       ) | ||||||
|  |       .toString(); | ||||||
|  |     expect(normalizeFileContents(currentContents)).toBe( | ||||||
|  |       normalizeFileContents(upToDateContents) | ||||||
|  |     ); | ||||||
|  |   }, 30000); | ||||||
| }); | }); | ||||||
|   }); |  | ||||||
| }); | function normalizeFileContents(contents: string): string { | ||||||
|  |   return contents | ||||||
|  |     .trim() | ||||||
|  |     .replace(new RegExp('\r\n', 'g'), '\n') | ||||||
|  |     .replace(new RegExp('\r', 'g'), '\n'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function getDotnet(version: string): Promise<void> { | ||||||
|  |   const dotnetInstaller = new installer.DotnetCoreInstaller(version); | ||||||
|  |   await dotnetInstaller.installDotnet(); | ||||||
|  |   installer.DotnetCoreInstaller.addToPath(); | ||||||
|  | } | ||||||
|  | |||||||
							
								
								
									
										15
									
								
								__tests__/sample-csproj/Program.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								__tests__/sample-csproj/Program.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | |||||||
|  | using Microsoft.VisualStudio.TestTools.UnitTesting; | ||||||
|  | using System; | ||||||
|  |  | ||||||
|  | namespace sample_csproj | ||||||
|  | { | ||||||
|  |     [TestClass] | ||||||
|  |     public class Program | ||||||
|  |     { | ||||||
|  |         [TestMethod] | ||||||
|  |         public void TestMethod1() | ||||||
|  |         { | ||||||
|  |             Console.WriteLine("Hello, World!"); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										18
									
								
								__tests__/sample-csproj/sample.csproj
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								__tests__/sample-csproj/sample.csproj
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | |||||||
|  | <Project Sdk="Microsoft.NET.Sdk"> | ||||||
|  |  | ||||||
|  |   <PropertyGroup> | ||||||
|  |     <TargetFrameworks>netcoreapp3.1;netcoreapp3.0;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,230 +1,71 @@ | |||||||
| import * as core from '@actions/core'; | import io = require('@actions/io'); | ||||||
| import fs from 'fs'; | import fs = require('fs'); | ||||||
| import semver from 'semver'; | import os = require('os'); | ||||||
| import * as auth from '../src/authutil'; | 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'; | import * as setup from '../src/setup-dotnet'; | ||||||
| import {DotnetCoreInstaller} from '../src/installer'; | import * as dotnetInstaller from '../src/installer'; | ||||||
| import * as cacheUtils from '../src/cache-utils'; |  | ||||||
| import * as cacheRestore from '../src/cache-restore'; | const IS_WINDOWS = process.platform === 'win32'; | ||||||
|  |  | ||||||
| describe('setup-dotnet tests', () => { | describe('setup-dotnet tests', () => { | ||||||
|   const inputs = {} as any; |   beforeAll(async () => { | ||||||
|  |     process.env.RUNNER_TOOL_CACHE = toolDir; | ||||||
|  |     process.env.DOTNET_INSTALL_DIR = toolDir; | ||||||
|  |     process.env.RUNNER_TEMP = tempDir; | ||||||
|  |     process.env['INPUT_INCLUDE-PRERELEASE'] = 'false'; | ||||||
|  |     await io.rmRF(toolDir); | ||||||
|  |     await io.rmRF(tempDir); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|   const getInputSpy = jest.spyOn(core, 'getInput'); |   afterEach(async () => { | ||||||
|   const getMultilineInputSpy = jest.spyOn(core, 'getMultilineInput'); |     try { | ||||||
|   const getBooleanInputSpy = jest.spyOn(core, 'getBooleanInput'); |       await io.rmRF(path.join(process.cwd(), 'global.json')); | ||||||
|   const setFailedSpy = jest.spyOn(core, 'setFailed'); |       await io.rmRF(toolDir); | ||||||
|   const warningSpy = jest.spyOn(core, 'warning'); |       await io.rmRF(tempDir); | ||||||
|   const debugSpy = jest.spyOn(core, 'debug'); |     } catch { | ||||||
|   const infoSpy = jest.spyOn(core, 'info'); |       console.log('Failed to remove test directories'); | ||||||
|   const setOutputSpy = jest.spyOn(core, 'setOutput'); |     } | ||||||
|  |   }, 30000); | ||||||
|  |  | ||||||
|   const existsSyncSpy = jest.spyOn(fs, 'existsSync'); |   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(); | ||||||
|  |  | ||||||
|   const maxSatisfyingSpy = jest.spyOn(semver, 'maxSatisfying'); |     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); | ||||||
|  |  | ||||||
|   const installDotnetSpy = jest.spyOn( |   it('Acquires version of dotnet from global.json with rollForward option, install the latest patch', async () => { | ||||||
|     DotnetCoreInstaller.prototype, |     const globalJsonPath = path.join(process.cwd(), 'global.json'); | ||||||
|     'installDotnet' |     const jsonContents = `{${os.EOL}"sdk": {${os.EOL}"version":"3.1.201",${os.EOL}"rollForward":"latestFeature"${os.EOL}}${os.EOL}}`; | ||||||
|  |     if (!fs.existsSync(globalJsonPath)) { | ||||||
|  |       fs.writeFileSync(globalJsonPath, jsonContents); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     const version = '3.1'; | ||||||
|  |     const installer = new dotnetInstaller.DotnetCoreInstaller(version); | ||||||
|  |     const patchVersion = await installer.resolveVersion( | ||||||
|  |       new dotnetInstaller.DotNetVersionInfo(version) | ||||||
|     ); |     ); | ||||||
|   const addToPathSpy = jest.spyOn(DotnetCoreInstaller, 'addToPath'); |  | ||||||
|   const isCacheFeatureAvailableSpy = jest.spyOn( |  | ||||||
|     cacheUtils, |  | ||||||
|     'isCacheFeatureAvailable' |  | ||||||
|   ); |  | ||||||
|   const restoreCacheSpy = jest.spyOn(cacheRestore, 'restoreCache'); |  | ||||||
|   const configAuthenticationSpy = jest.spyOn(auth, 'configAuthentication'); |  | ||||||
|  |  | ||||||
|   describe('run() tests', () => { |  | ||||||
|     beforeEach(() => { |  | ||||||
|       getMultilineInputSpy.mockImplementation(input => inputs[input as string]); |  | ||||||
|       getInputSpy.mockImplementation(input => inputs[input as string]); |  | ||||||
|       getBooleanInputSpy.mockImplementation(input => inputs[input as string]); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     afterEach(() => { |  | ||||||
|       jest.clearAllMocks(); |  | ||||||
|       jest.resetAllMocks(); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('should fail the action if global-json-file input is present, but the file does not exist in the file system', async () => { |  | ||||||
|       inputs['global-json-file'] = 'fictitious.json'; |  | ||||||
|       inputs['dotnet-version'] = []; |  | ||||||
|  |  | ||||||
|       const expectedErrorMessage = `The specified global.json file '${inputs['global-json-file']}' does not exist`; |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(setFailedSpy).toHaveBeenCalledWith(expectedErrorMessage); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     test(`if 'dotnet-version' and 'global-json-file' inputs aren't present, should log into debug output, try to find global.json in the repo root, fail and log message into info output`, async () => { |  | ||||||
|       inputs['global-json-file'] = ''; |  | ||||||
|       inputs['dotnet-version'] = []; |  | ||||||
|  |  | ||||||
|       maxSatisfyingSpy.mockImplementation(() => null); |  | ||||||
|       setOutputSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       const expectedDebugMessage = |  | ||||||
|         'No version found, trying to find version from global.json'; |  | ||||||
|       const expectedInfoMessage = `The global.json wasn't found in the root directory. No .NET version will be installed.`; |  | ||||||
|  |  | ||||||
|     await setup.run(); |     await setup.run(); | ||||||
|  |  | ||||||
|       expect(debugSpy).toHaveBeenCalledWith(expectedDebugMessage); |     expect(fs.existsSync(path.join(toolDir, 'sdk', patchVersion))).toBe(true); | ||||||
|       expect(existsSyncSpy).toHaveBeenCalled(); |     if (IS_WINDOWS) { | ||||||
|       expect(infoSpy).toHaveBeenCalledWith(expectedInfoMessage); |       expect(fs.existsSync(path.join(toolDir, 'dotnet.exe'))).toBe(true); | ||||||
|     }); |     } else { | ||||||
|  |       expect(fs.existsSync(path.join(toolDir, 'dotnet'))).toBe(true); | ||||||
|     it('should fail the action if quality is supplied but its value is not supported', async () => { |     } | ||||||
|       inputs['global-json-file'] = ''; |   }, 400000); | ||||||
|       inputs['dotnet-version'] = ['6.0']; |  | ||||||
|       inputs['dotnet-quality'] = 'fictitiousQuality'; |  | ||||||
|  |  | ||||||
|       const expectedErrorMessage = `Value '${inputs['dotnet-quality']}' is not supported for the 'dotnet-quality' option. Supported values are: daily, signed, validated, preview, ga.`; |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(setFailedSpy).toHaveBeenCalledWith(expectedErrorMessage); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('should call installDotnet() multiple times if dotnet-version multiline input is provided', async () => { |  | ||||||
|       inputs['global-json-file'] = ''; |  | ||||||
|       inputs['dotnet-version'] = ['6.0', '7.0']; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => Promise.resolve('')); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(installDotnetSpy).toHaveBeenCalledTimes(2); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('should call addToPath() after installation complete', async () => { |  | ||||||
|       inputs['global-json-file'] = ''; |  | ||||||
|       inputs['dotnet-version'] = ['6.0', '7.0']; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => Promise.resolve('')); |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(addToPathSpy).toHaveBeenCalledTimes(1); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('should call auth.configAuthentication() if source-url input is provided', async () => { |  | ||||||
|       inputs['global-json-file'] = ''; |  | ||||||
|       inputs['dotnet-version'] = []; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|       inputs['source-url'] = 'fictitious.source.url'; |  | ||||||
|  |  | ||||||
|       configAuthenticationSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(configAuthenticationSpy).toHaveBeenCalledWith( |  | ||||||
|         inputs['source-url'], |  | ||||||
|         undefined |  | ||||||
|       ); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('should call auth.configAuthentication() with proper parameters if source-url and config-file inputs are provided', async () => { |  | ||||||
|       inputs['global-json-file'] = ''; |  | ||||||
|       inputs['dotnet-version'] = []; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|       inputs['source-url'] = 'fictitious.source.url'; |  | ||||||
|       inputs['config-file'] = 'fictitious.path'; |  | ||||||
|  |  | ||||||
|       configAuthenticationSpy.mockImplementation(() => {}); |  | ||||||
|       setOutputSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(configAuthenticationSpy).toHaveBeenCalledWith( |  | ||||||
|         inputs['source-url'], |  | ||||||
|         inputs['config-file'] |  | ||||||
|       ); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it('should call setOutput() after installation complete successfully', async () => { |  | ||||||
|       inputs['dotnet-version'] = ['6.0.300']; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => |  | ||||||
|         Promise.resolve(`${inputs['dotnet-version']}`) |  | ||||||
|       ); |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(setOutputSpy).toHaveBeenCalledTimes(1); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it(`shouldn't call setOutput() if parsing dotnet-installer logs failed`, async () => { |  | ||||||
|       inputs['dotnet-version'] = ['6.0.300']; |  | ||||||
|       const warningMessage = `Failed to output the installed version of .NET. The 'dotnet-version' output will not be set.`; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => Promise.resolve(null)); |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(warningSpy).toHaveBeenCalledWith(warningMessage); |  | ||||||
|       expect(setOutputSpy).not.toHaveBeenCalled(); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it(`shouldn't call setOutput() if actions didn't install .NET`, async () => { |  | ||||||
|       inputs['dotnet-version'] = []; |  | ||||||
|       const warningMessage = `The 'dotnet-version' output will not be set.`; |  | ||||||
|  |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|  |  | ||||||
|       expect(infoSpy).toHaveBeenCalledWith(warningMessage); |  | ||||||
|       expect(setOutputSpy).not.toHaveBeenCalled(); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it(`should get 'cache-dependency-path' and call restoreCache() if input cache is set to true and cache feature is available`, async () => { |  | ||||||
|       inputs['dotnet-version'] = ['6.0.300']; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|       inputs['cache'] = true; |  | ||||||
|       inputs['cache-dependency-path'] = 'fictitious.package.lock.json'; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => Promise.resolve('')); |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       isCacheFeatureAvailableSpy.mockImplementation(() => true); |  | ||||||
|       restoreCacheSpy.mockImplementation(() => Promise.resolve()); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(isCacheFeatureAvailableSpy).toHaveBeenCalledTimes(1); |  | ||||||
|       expect(restoreCacheSpy).toHaveBeenCalledWith( |  | ||||||
|         inputs['cache-dependency-path'] |  | ||||||
|       ); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it(`shouldn't call restoreCache() if input cache isn't set to true`, async () => { |  | ||||||
|       inputs['dotnet-version'] = ['6.0.300']; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|       inputs['cache'] = false; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => Promise.resolve('')); |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       isCacheFeatureAvailableSpy.mockImplementation(() => true); |  | ||||||
|       restoreCacheSpy.mockImplementation(() => Promise.resolve()); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(restoreCacheSpy).not.toHaveBeenCalled(); |  | ||||||
|     }); |  | ||||||
|  |  | ||||||
|     it(`shouldn't call restoreCache() if cache feature isn't available`, async () => { |  | ||||||
|       inputs['dotnet-version'] = ['6.0.300']; |  | ||||||
|       inputs['dotnet-quality'] = ''; |  | ||||||
|       inputs['cache'] = true; |  | ||||||
|  |  | ||||||
|       installDotnetSpy.mockImplementation(() => Promise.resolve('')); |  | ||||||
|       addToPathSpy.mockImplementation(() => {}); |  | ||||||
|  |  | ||||||
|       isCacheFeatureAvailableSpy.mockImplementation(() => false); |  | ||||||
|       restoreCacheSpy.mockImplementation(() => Promise.resolve()); |  | ||||||
|  |  | ||||||
|       await setup.run(); |  | ||||||
|       expect(restoreCacheSpy).not.toHaveBeenCalled(); |  | ||||||
|     }); |  | ||||||
|   }); |  | ||||||
| }); | }); | ||||||
|  | |||||||
| @ -1,117 +1,73 @@ | |||||||
| <# | if (!$args[0]) | ||||||
|   .DESCRIPTION | { | ||||||
|   Verifies that installed on the machine .NET SDK versions match the input patterns. |   throw "Must supply dotnet version argument" | ||||||
|   Optionally checks that the nuget.config file is generated correctly. |  | ||||||
|  |  | ||||||
|   .PARAMETER Patterns |  | ||||||
|   Specifies the regular expression patterns that should be matched with the installed |  | ||||||
|   on the machine .NET SDK versions. The number of patterns should be equal to the number |  | ||||||
|   of installed .NET versions.  |  | ||||||
|  |  | ||||||
|   .PARAMETER CheckNugetConfig |  | ||||||
|   Switches the check for the existence of the nuget.config file. |  | ||||||
|  |  | ||||||
|   .EXAMPLE |  | ||||||
|   PS> .\verify-dotnet.ps1 -Paterns "^3.1.200$", "^6.0" -CheckNugetConfig |  | ||||||
| #> |  | ||||||
|  |  | ||||||
| param( |  | ||||||
|   [ValidateNotNullOrEmpty()] |  | ||||||
|   [Parameter(Mandatory=$true)] |  | ||||||
|   [string[]]$Patterns, |  | ||||||
|   [switch]$CheckNugetConfig |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| $PatternsList = [System.Collections.ArrayList]($Patterns) |  | ||||||
|  |  | ||||||
| if ($CheckNugetConfig.IsPresent -and !(Test-Path "../nuget.config")) { |  | ||||||
|   throw "The nuget.config file is not generated correctly." |  | ||||||
| } | } | ||||||
|  |  | ||||||
| Write-Host "These patterns were supplied to the script: $($PatternsList -join ', ')." |  | ||||||
| $dotnet = Get-Command dotnet | Select-Object -First 1 | ForEach-Object { $_.Path } | $dotnet = Get-Command dotnet | Select-Object -First 1 | ForEach-Object { $_.Path } | ||||||
| Write-Host "Found: '$dotnet'" | Write-Host "Found '$dotnet'" | ||||||
|  |  | ||||||
|  | if($args.count -eq 1) | ||||||
|  | { | ||||||
|  |   $version = & $dotnet --version | Out-String | ForEach-Object { $_.Trim() } | ||||||
|  |   Write-Host "Version $version" | ||||||
|  |   if (-not ($version.StartsWith($args[0].ToString()))) | ||||||
|  |   { | ||||||
|  |     Write-Host "PATH='$env:PATH'" | ||||||
|  |     throw "Unexpected version" | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | if ($args[1]) | ||||||
|  | { | ||||||
|   # SDKs are listed on multiple lines with the path afterwards in square brackets |   # SDKs are listed on multiple lines with the path afterwards in square brackets | ||||||
| $Versions = & $dotnet --list-sdks | ForEach-Object { $_.SubString(0, $_.IndexOf('[')).Trim() } |   $versions = & $dotnet --list-sdks | ForEach-Object { $_.SubString(0, $_.IndexOf('[')).Trim() } | ||||||
| Write-Host "Found installed versions: $($Versions -join ', ')." |   Write-Host "Installed versions: $versions" | ||||||
| $InstalledVersionCount = $Versions.Count |   $InstalledVersionCount = 0 | ||||||
|  |   foreach($arg in $args){ | ||||||
| foreach($version in $Versions) |     foreach ($version in $versions) | ||||||
|     { |     { | ||||||
|   foreach($pattern in $PatternsList)  |       if ($version.StartsWith($arg.ToString()))  | ||||||
|       { |       { | ||||||
|     if ($version -match $pattern) |         $InstalledVersionCount++ | ||||||
|     {  |  | ||||||
|       $PatternsList.Remove($pattern) |  | ||||||
|       $InstalledVersionCount-- |  | ||||||
|       break |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|    } |    } | ||||||
|  |   if ( $InstalledVersionCount -ne $args.Count) | ||||||
| if ( $InstalledVersionCount -ne 0) |  | ||||||
|   { |   { | ||||||
|   throw "An unexpected version of Dotnet is found on the machine, please check the correctness of the -Patterns input." |     Write-Host "PATH='$env:PATH'" | ||||||
|  |     throw "Unexpected version" | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| $workingDir = Get-Location | Write-Host "Building sample csproj" | ||||||
| $testProjectDir = "./__tests__/e2e-test-csproj" | & $dotnet build __tests__/sample-csproj/ --no-cache | ||||||
| Write-Host "Changing directory to the $testProjectDir" |  | ||||||
| Set-Location $testProjectDir |  | ||||||
|  |  | ||||||
| $targetFrameworkVersionMap = @{ |  | ||||||
|   "1.0" = "netcoreapp1.0"; |  | ||||||
|   "1.1" = "netcoreapp1.1"; |  | ||||||
|   "2.0" = "netcoreapp2.0"; |  | ||||||
|   "2.1" = "netcoreapp2.1"; |  | ||||||
|   "2.2" = "netcoreapp2.2"; |  | ||||||
|   "3.0" = "netcoreapp3.0"; |  | ||||||
|   "3.1" = "netcoreapp3.1"; |  | ||||||
|   "5.0" = "net5.0"; |  | ||||||
|   "6.0" = "net6.0"; |  | ||||||
|   "7.0" = "net7.0"; |  | ||||||
|   "8.0" = "net8.0"; |  | ||||||
|  } |  | ||||||
|  |  | ||||||
| foreach ($version in $Versions) |  | ||||||
| { |  | ||||||
|   # Creating temporary global.json file inside e2e-test-csproj dir and setting exact version of .NET inside allows to override default behavior of .NET and run build and tests on that exact version.  |  | ||||||
|   Write-Host "Creating temporary global.json file for $version .NET version." |  | ||||||
|   & $dotnet new globaljson --sdk-version $version --force | Out-Null |  | ||||||
|   if (!(Test-Path "./global.json")) |  | ||||||
|   { |  | ||||||
|     throw "An error occured while creating the global.json file. Exit code: $LASTEXITCODE" |  | ||||||
|   } |  | ||||||
|   Write-Host "The global.json file for the version $version is created. Currently used .NET version is: $(& $dotnet --version)." |  | ||||||
|  |  | ||||||
|   # Environment variable TEST_TARGET_FRAMEWORK is used inside the test.csproj file to target required framework version |  | ||||||
|   $version -match "^(?<key>\d+\.\d+)" | Out-Null |  | ||||||
|   if (!($targetFrameworkVersionMap.ContainsKey($Matches.key))) |  | ||||||
|   { |  | ||||||
|     throw "The map with the framework targets doesn't contain a target name for the version $version." |  | ||||||
|   } |  | ||||||
|   Write-Host "Setting the TEST_TARGET_FRAMEWORK environment variable to $($targetFrameworkVersionMap[$Matches.key])" |  | ||||||
|   [Environment]::SetEnvironmentVariable('TEST_TARGET_FRAMEWORK', $($targetFrameworkVersionMap[$Matches.key])) |  | ||||||
|  |  | ||||||
|   Write-Host "Building test C# project with $version .NET version." |  | ||||||
|   & $dotnet build --no-cache |  | ||||||
| if ($LASTEXITCODE -ne 0) | if ($LASTEXITCODE -ne 0) | ||||||
| { | { | ||||||
|     throw "Building process is not successful, exit code: $LASTEXITCODE" |   throw "Unexpected exit code $LASTEXITCODE" | ||||||
| } | } | ||||||
|  |  | ||||||
|   Write-Host "Testing compiled C# project with $version .NET version." | Write-Host "Testing compiled app" | ||||||
|   & $dotnet test --no-build | $sample_output = "$(dotnet test __tests__/sample-csproj/ --no-build)" | ||||||
|   if ($LASTEXITCODE -ne 0) | 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]) | ||||||
| { | { | ||||||
|     throw "Testing process is not successful, exit code: $LASTEXITCODE" |   if ($sample_output -notlike "*Test Run Successful.*Test Run Successful.*") | ||||||
|  |   { | ||||||
|  |     throw "Unexpected output" | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | if ($args[2]) | ||||||
|  | { | ||||||
|  |   if ($sample_output -notlike "*Test Run Successful.*Test Run Successful.*Test Run Successful.*") | ||||||
|  |   { | ||||||
|  |     throw "Unexpected output" | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | else | ||||||
|  | { | ||||||
|  |   if ($sample_output -notlike "*Test Run Successful.*") | ||||||
|  |   { | ||||||
|  |     throw "Unexpected output" | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   Write-Host "Tests are completed successfully!" |  | ||||||
|  |  | ||||||
|   Write-Host "Removing temporary global.json file." |  | ||||||
|   Remove-Item ./global.json |  | ||||||
| } | } | ||||||
|  |  | ||||||
| Set-Location $workingDir |  | ||||||
|  | |||||||
							
								
								
									
										44
									
								
								__tests__/verify-dotnet.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										44
									
								
								__tests__/verify-dotnet.sh
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,44 @@ | |||||||
|  | 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 | ||||||
							
								
								
									
										17
									
								
								__tests__/verify-no-unstaged-changes.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										17
									
								
								__tests__/verify-no-unstaged-changes.sh
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,17 @@ | |||||||
|  | #!/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 | ||||||
							
								
								
									
										91
									
								
								__tests__/versionutil.test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								__tests__/versionutil.test.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,91 @@ | |||||||
|  | import each from 'jest-each'; | ||||||
|  | import * as installer from '../src/installer'; | ||||||
|  |  | ||||||
|  | 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.x', '3.x'], | ||||||
|  |     ['3.*', '3.*'], | ||||||
|  |     ['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', | ||||||
|  |     '*.*.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(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   each([ | ||||||
|  |     ['3.1.x', '3.1.'], | ||||||
|  |     ['3.1.*', '3.1.'], | ||||||
|  |     ['3.1', '3.1.'], | ||||||
|  |     ['5.0.0-preview.6', '5.0.0-preview.6'], | ||||||
|  |     ['3.1.201', '3.1.201'] | ||||||
|  |   ]).test( | ||||||
|  |     "Resolving version '%s' as '%s'", | ||||||
|  |     async (input, expectedVersion) => { | ||||||
|  |       const dotnetInstaller = new installer.DotnetCoreInstaller(input); | ||||||
|  |       let versInfo = await dotnetInstaller.resolveVersion( | ||||||
|  |         new installer.DotNetVersionInfo(input) | ||||||
|  |       ); | ||||||
|  |       console.log(versInfo); | ||||||
|  |  | ||||||
|  |       expect(versInfo.startsWith(expectedVersion)); | ||||||
|  |     }, | ||||||
|  |     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); | ||||||
|  | }); | ||||||
							
								
								
									
										24
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								action.yml
									
									
									
									
									
								
							| @ -6,9 +6,7 @@ branding: | |||||||
|   color: green |   color: green | ||||||
| inputs: | inputs: | ||||||
|   dotnet-version: |   dotnet-version: | ||||||
|     description: 'Optional SDK version(s) to use. If not provided, will install global.json version when available. Examples: 2.2.104, 3.1, 3.1.x, 3.x, 6.0.2xx' |     description: 'Optional SDK version(s) to use. If not provided, will install global.json version when available. Examples: 2.2.104, 3.1, 3.1.x' | ||||||
|   dotnet-quality: |  | ||||||
|     description: 'Optional quality of the build. The possible values are: daily, signed, validated, preview, ga.' |  | ||||||
|   global-json-file: |   global-json-file: | ||||||
|     description: 'Optional global.json location, if your global.json isn''t located in the root of the repo.' |     description: 'Optional global.json location, if your global.json isn''t located in the root of the repo.' | ||||||
|   source-url: |   source-url: | ||||||
| @ -17,20 +15,10 @@ inputs: | |||||||
|     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' |     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: |   config-file: | ||||||
|     description: 'Optional NuGet.config location, if your NuGet.config isn''t located in the root of the repo.' |     description: 'Optional NuGet.config location, if your NuGet.config isn''t located in the root of the repo.' | ||||||
|   cache: |   include-prerelease: | ||||||
|     description: 'Optional input to enable caching of the NuGet global-packages folder' |     description: 'Whether prerelease versions should be matched with non-exact versions (for example 5.0.0-preview.6 being matched by 5, 5.0, 5.x or 5.0.x). Defaults to false if not provided.' | ||||||
|     required: false |     required: False | ||||||
|     default: false |     default: 'false' | ||||||
|   cache-dependency-path: |  | ||||||
|     description: 'Used to specify the path to a dependency file: packages.lock.json. Supports wildcards or a list of file names for caching multiple dependencies.' |  | ||||||
|     required: false |  | ||||||
| outputs: |  | ||||||
|   cache-hit: |  | ||||||
|     description: 'A boolean value to indicate if a cache was hit.' |  | ||||||
|   dotnet-version: |  | ||||||
|     description: 'Contains the installed by action .NET SDK version for reuse.' |  | ||||||
| runs: | runs: | ||||||
|   using: 'node16' |   using: 'node16' | ||||||
|   main: 'dist/setup/index.js' |   main: 'dist/index.js' | ||||||
|   post: 'dist/cache-save/index.js' |  | ||||||
|   post-if: success() |  | ||||||
|  | |||||||
							
								
								
									
										58942
									
								
								dist/cache-save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58942
									
								
								dist/cache-save/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										25521
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										25521
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										71848
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										71848
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -61,13 +61,12 @@ Pull requests are the easiest way to contribute changes to git repos at GitHub. | |||||||
|  |  | ||||||
| - To implement new features or fix bugs, you need to make changes to the `.ts` files, which are located in the `src` folder | - To implement new features or fix bugs, you need to make changes to the `.ts` files, which are located in the `src` folder | ||||||
| - To comply with the code style, **you need to run the `format` script** | - To comply with the code style, **you need to run the `format` script** | ||||||
| - To lint the code, **you need to run the `lint:fix` script** |  | ||||||
| - To transpile source code to `javascript` we use [NCC](https://github.com/vercel/ncc). **It is very important to run the `build` script after making changes**, otherwise your changes will not get into the final `javascript` build | - To transpile source code to `javascript` we use [NCC](https://github.com/vercel/ncc). **It is very important to run the `build` script after making changes**, otherwise your changes will not get into the final `javascript` build | ||||||
|  |  | ||||||
| **Learn more about how to implement tests:** | **Learn more about how to implement tests:** | ||||||
|  |  | ||||||
| Adding or changing tests is an integral part of making a change to the code.  | Adding or changing tests is an integral part of making a change to the code.  | ||||||
| Unit tests are in the `__tests__` folder, and end-to-end tests are in the `workflows` folder, particularly in the [e2e-tests.yml](https://github.com/actions/setup-dotnet/blob/main/.github/workflows/e2e-tests.yml). | Unit tests are in the `__tests__` folder, and end-to-end tests are in the `workflows` folder, particularly in the [workflow.yml](https://github.com/actions/setup-dotnet/blob/main/.github/workflows/workflow.yml). | ||||||
|  |  | ||||||
| - The contributor can add various types of tests (like unit tests or end-to-end tests), which, in his opinion, will be necessary and sufficient for testing new or changed functionality | - The contributor can add various types of tests (like unit tests or end-to-end tests), which, in his opinion, will be necessary and sufficient for testing new or changed functionality | ||||||
| - Tests should cover a successful execution, as well as some edge cases and possible errors | - Tests should cover a successful execution, as well as some edge cases and possible errors | ||||||
|  | |||||||
							
								
								
									
										563
									
								
								externals/install-dotnet.ps1
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										563
									
								
								externals/install-dotnet.ps1
									
									
									
									
										vendored
									
									
								
							| @ -72,14 +72,12 @@ | |||||||
| .PARAMETER Verbose | .PARAMETER Verbose | ||||||
|     Displays diagnostics information. |     Displays diagnostics information. | ||||||
| .PARAMETER AzureFeed | .PARAMETER AzureFeed | ||||||
|     Default: https://dotnetcli.azureedge.net/dotnet |     Default: https://builds.dotnet.microsoft.com/dotnet | ||||||
|     For internal use only. |     For internal use only. | ||||||
|     Allows using a different storage to download SDK archives from. |     Allows using a different storage to download SDK archives from. | ||||||
|     This parameter is only used if $NoCdn is false. |  | ||||||
| .PARAMETER UncachedFeed | .PARAMETER UncachedFeed | ||||||
|     For internal use only. |     For internal use only. | ||||||
|     Allows using a different storage to download SDK archives from. |     Allows using a different storage to download SDK archives from. | ||||||
|     This parameter is only used if $NoCdn is true. |  | ||||||
| .PARAMETER ProxyAddress | .PARAMETER ProxyAddress | ||||||
|     If set, the installer will use the proxy when making web requests |     If set, the installer will use the proxy when making web requests | ||||||
| .PARAMETER ProxyUseDefaultCredentials | .PARAMETER ProxyUseDefaultCredentials | ||||||
| @ -90,14 +88,22 @@ | |||||||
| .PARAMETER SkipNonVersionedFiles | .PARAMETER SkipNonVersionedFiles | ||||||
|     Default: false |     Default: false | ||||||
|     Skips installing non-versioned files if they already exist, such as dotnet.exe. |     Skips installing non-versioned files if they already exist, such as dotnet.exe. | ||||||
| .PARAMETER NoCdn |  | ||||||
|     Disable downloading from the Azure CDN, and use the uncached feed directly. |  | ||||||
| .PARAMETER JSonFile | .PARAMETER JSonFile | ||||||
|     Determines the SDK version from a user specified global.json file |     Determines the SDK version from a user specified global.json file | ||||||
|     Note: global.json must have a value for 'SDK:Version' |     Note: global.json must have a value for 'SDK:Version' | ||||||
| .PARAMETER DownloadTimeout | .PARAMETER DownloadTimeout | ||||||
|     Determines timeout duration in seconds for dowloading of the SDK file |     Determines timeout duration in seconds for dowloading of the SDK file | ||||||
|     Default: 1200 seconds (20 minutes) |     Default: 1200 seconds (20 minutes) | ||||||
|  | .PARAMETER KeepZip | ||||||
|  |     If set, downloaded file is kept | ||||||
|  | .PARAMETER ZipPath | ||||||
|  |     Use that path to store installer, generated by default | ||||||
|  | .EXAMPLE | ||||||
|  |     dotnet-install.ps1 -Version 7.0.401 | ||||||
|  |     Installs the .NET SDK version 7.0.401 | ||||||
|  | .EXAMPLE | ||||||
|  |     dotnet-install.ps1 -Channel 8.0 -Quality GA | ||||||
|  |     Installs the latest GA (general availability) version of the .NET 8.0 SDK | ||||||
| #> | #> | ||||||
| [cmdletbinding()] | [cmdletbinding()] | ||||||
| param( | param( | ||||||
| @ -120,8 +126,10 @@ param( | |||||||
|     [switch]$ProxyUseDefaultCredentials, |     [switch]$ProxyUseDefaultCredentials, | ||||||
|     [string[]]$ProxyBypassList = @(), |     [string[]]$ProxyBypassList = @(), | ||||||
|     [switch]$SkipNonVersionedFiles, |     [switch]$SkipNonVersionedFiles, | ||||||
|    [switch]$NoCdn, |     [int]$DownloadTimeout = 1200, | ||||||
|    [int]$DownloadTimeout=1200 |     [switch]$KeepZip, | ||||||
|  |     [string]$ZipPath = [System.IO.Path]::combine([System.IO.Path]::GetTempPath(), [System.IO.Path]::GetRandomFileName()), | ||||||
|  |     [switch]$Help | ||||||
| ) | ) | ||||||
|  |  | ||||||
| Set-StrictMode -Version Latest | Set-StrictMode -Version Latest | ||||||
| @ -173,7 +181,24 @@ function Say-Verbose($str) { | |||||||
| function Measure-Action($name, $block) { | function Measure-Action($name, $block) { | ||||||
|     $time = Measure-Command $block |     $time = Measure-Command $block | ||||||
|     $totalSeconds = $time.TotalSeconds |     $totalSeconds = $time.TotalSeconds | ||||||
|     Say-Verbose "⏱ Action '$name' took $totalSeconds seconds" |     Say-Verbose "Action '$name' took $totalSeconds seconds" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function Get-Remote-File-Size($zipUri) { | ||||||
|  |     try { | ||||||
|  |         $response = Invoke-WebRequest -Uri $zipUri -Method Head | ||||||
|  |         $fileSize = $response.Headers["Content-Length"] | ||||||
|  |         if ((![string]::IsNullOrEmpty($fileSize))) { | ||||||
|  |             Say "Remote file $zipUri size is $fileSize bytes." | ||||||
|  |          | ||||||
|  |             return $fileSize | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     catch { | ||||||
|  |         Say-Verbose "Content-Length header was not extracted for $zipUri." | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $null | ||||||
| } | } | ||||||
|  |  | ||||||
| function Say-Invocation($Invocation) { | function Say-Invocation($Invocation) { | ||||||
| @ -219,8 +244,7 @@ function Get-Machine-Architecture() { | |||||||
|  |  | ||||||
|     try {         |     try {         | ||||||
|         if ( ((Get-CimInstance -ClassName CIM_OperatingSystem).OSArchitecture) -like "ARM*") { |         if ( ((Get-CimInstance -ClassName CIM_OperatingSystem).OSArchitecture) -like "ARM*") { | ||||||
|             if( [Environment]::Is64BitOperatingSystem ) |             if ( [Environment]::Is64BitOperatingSystem ) { | ||||||
|             { |  | ||||||
|                 return "arm64" |                 return "arm64" | ||||||
|             }   |             }   | ||||||
|             return "arm" |             return "arm" | ||||||
| @ -249,13 +273,13 @@ function Get-CLIArchitecture-From-Architecture([string]$Architecture) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function ValidateFeedCredential([string] $FeedCredential) | function ValidateFeedCredential([string] $FeedCredential) { | ||||||
| { |  | ||||||
|     if ($Internal -and [string]::IsNullOrWhitespace($FeedCredential)) { |     if ($Internal -and [string]::IsNullOrWhitespace($FeedCredential)) { | ||||||
|         $message = "Provide credentials via -FeedCredential parameter." |         $message = "Provide credentials via -FeedCredential parameter." | ||||||
|         if ($DryRun) { |         if ($DryRun) { | ||||||
|             Say-Warning "$message" |             Say-Warning "$message" | ||||||
|         } else { |         } | ||||||
|  |         else { | ||||||
|             throw "$message" |             throw "$message" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -347,8 +371,7 @@ function Load-Assembly([string] $Assembly) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function GetHTTPResponse([Uri] $Uri, [bool]$HeaderOnly, [bool]$DisableRedirect, [bool]$DisableFeedCredential) | function GetHTTPResponse([Uri] $Uri, [bool]$HeaderOnly, [bool]$DisableRedirect, [bool]$DisableFeedCredential) { | ||||||
| { |  | ||||||
|     $cts = New-Object System.Threading.CancellationTokenSource |     $cts = New-Object System.Threading.CancellationTokenSource | ||||||
|  |  | ||||||
|     $downloadScript = { |     $downloadScript = { | ||||||
| @ -366,12 +389,14 @@ function GetHTTPResponse([Uri] $Uri, [bool]$HeaderOnly, [bool]$DisableRedirect, | |||||||
|                     if ($DefaultProxy -and (-not $DefaultProxy.IsBypassed($Uri))) { |                     if ($DefaultProxy -and (-not $DefaultProxy.IsBypassed($Uri))) { | ||||||
|                         if ($null -ne $DefaultProxy.GetProxy($Uri)) { |                         if ($null -ne $DefaultProxy.GetProxy($Uri)) { | ||||||
|                             $ProxyAddress = $DefaultProxy.GetProxy($Uri).OriginalString |                             $ProxyAddress = $DefaultProxy.GetProxy($Uri).OriginalString | ||||||
|                         } else { |                         } | ||||||
|  |                         else { | ||||||
|                             $ProxyAddress = $null |                             $ProxyAddress = $null | ||||||
|                         } |                         } | ||||||
|                         $ProxyUseDefaultCredentials = $true |                         $ProxyUseDefaultCredentials = $true | ||||||
|                     } |                     } | ||||||
|                 } catch { |                 } | ||||||
|  |                 catch { | ||||||
|                     # Eat the exception and move forward as the above code is an attempt |                     # Eat the exception and move forward as the above code is an attempt | ||||||
|                     #    at resolving the DefaultProxy that may not have been a problem. |                     #    at resolving the DefaultProxy that may not have been a problem. | ||||||
|                     $ProxyAddress = $null |                     $ProxyAddress = $null | ||||||
| @ -387,8 +412,7 @@ function GetHTTPResponse([Uri] $Uri, [bool]$HeaderOnly, [bool]$DisableRedirect, | |||||||
|                     BypassList            = $ProxyBypassList; |                     BypassList            = $ProxyBypassList; | ||||||
|                 } |                 } | ||||||
|             }        |             }        | ||||||
|             if ($DisableRedirect) |             if ($DisableRedirect) { | ||||||
|             { |  | ||||||
|                 $HttpClientHandler.AllowAutoRedirect = $false |                 $HttpClientHandler.AllowAutoRedirect = $false | ||||||
|             } |             } | ||||||
|             $HttpClient = New-Object System.Net.Http.HttpClient -ArgumentList $HttpClientHandler |             $HttpClient = New-Object System.Net.Http.HttpClient -ArgumentList $HttpClientHandler | ||||||
| @ -422,8 +446,7 @@ function GetHTTPResponse([Uri] $Uri, [bool]$HeaderOnly, [bool]$DisableRedirect, | |||||||
|                     $DownloadException.Data["StatusCode"] = [int] $Response.StatusCode |                     $DownloadException.Data["StatusCode"] = [int] $Response.StatusCode | ||||||
|                     $DownloadException.Data["ErrorMessage"] = "Unable to download $Uri. Returned HTTP status code: " + $DownloadException.Data["StatusCode"] |                     $DownloadException.Data["ErrorMessage"] = "Unable to download $Uri. Returned HTTP status code: " + $DownloadException.Data["StatusCode"] | ||||||
|  |  | ||||||
|                     if (404 -eq [int] $Response.StatusCode) |                     if (404 -eq [int] $Response.StatusCode) { | ||||||
|                     { |  | ||||||
|                         $cts.Cancel() |                         $cts.Cancel() | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @ -462,10 +485,8 @@ function GetHTTPResponse([Uri] $Uri, [bool]$HeaderOnly, [bool]$DisableRedirect, | |||||||
|     try { |     try { | ||||||
|         return Invoke-With-Retry $downloadScript $cts.Token |         return Invoke-With-Retry $downloadScript $cts.Token | ||||||
|     } |     } | ||||||
|     finally |     finally { | ||||||
|     { |         if ($null -ne $cts) { | ||||||
|         if ($null -ne $cts) |  | ||||||
|         { |  | ||||||
|             $cts.Dispose() |             $cts.Dispose() | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -583,11 +604,9 @@ function Get-Download-Link([string]$AzureFeed, [string]$SpecificVersion, [string | |||||||
|     elseif ($Runtime -eq "windowsdesktop") { |     elseif ($Runtime -eq "windowsdesktop") { | ||||||
|         # The windows desktop runtime is part of the core runtime layout prior to 5.0 |         # The windows desktop runtime is part of the core runtime layout prior to 5.0 | ||||||
|         $PayloadURL = "$AzureFeed/Runtime/$SpecificVersion/windowsdesktop-runtime-$SpecificProductVersion-win-$CLIArchitecture.zip" |         $PayloadURL = "$AzureFeed/Runtime/$SpecificVersion/windowsdesktop-runtime-$SpecificProductVersion-win-$CLIArchitecture.zip" | ||||||
|         if ($SpecificVersion -match '^(\d+)\.(.*)$') |         if ($SpecificVersion -match '^(\d+)\.(.*)$') { | ||||||
|         { |  | ||||||
|             $majorVersion = [int]$Matches[1] |             $majorVersion = [int]$Matches[1] | ||||||
|             if ($majorVersion -ge 5) |             if ($majorVersion -ge 5) { | ||||||
|             { |  | ||||||
|                 $PayloadURL = "$AzureFeed/WindowsDesktop/$SpecificVersion/windowsdesktop-runtime-$SpecificProductVersion-win-$CLIArchitecture.zip" |                 $PayloadURL = "$AzureFeed/WindowsDesktop/$SpecificVersion/windowsdesktop-runtime-$SpecificProductVersion-win-$CLIArchitecture.zip" | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @ -637,8 +656,7 @@ function Get-Product-Version([string]$AzureFeed, [string]$SpecificVersion, [stri | |||||||
|  |  | ||||||
|             if ($productVersionResponse.StatusCode -eq 200) { |             if ($productVersionResponse.StatusCode -eq 200) { | ||||||
|                 $productVersion = $productVersionResponse.Content.ReadAsStringAsync().Result.Trim() |                 $productVersion = $productVersionResponse.Content.ReadAsStringAsync().Result.Trim() | ||||||
|                 if ($productVersion -ne $SpecificVersion) |                 if ($productVersion -ne $SpecificVersion) { | ||||||
|                 { |  | ||||||
|                     Say "Using alternate version $productVersion found in $ProductVersionTxtURL" |                     Say "Using alternate version $productVersion found in $ProductVersionTxtURL" | ||||||
|                 } |                 } | ||||||
|                 return $productVersion |                 return $productVersion | ||||||
| @ -653,8 +671,7 @@ function Get-Product-Version([string]$AzureFeed, [string]$SpecificVersion, [stri | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     # Getting the version number with productVersion.txt has failed. Try parsing the download link for a version number. |     # Getting the version number with productVersion.txt has failed. Try parsing the download link for a version number. | ||||||
|     if ([string]::IsNullOrEmpty($PackageDownloadLink)) |     if ([string]::IsNullOrEmpty($PackageDownloadLink)) { | ||||||
|     { |  | ||||||
|         Say-Verbose "Using the default value '$SpecificVersion' as the product version." |         Say-Verbose "Using the default value '$SpecificVersion' as the product version." | ||||||
|         return $SpecificVersion |         return $SpecificVersion | ||||||
|     } |     } | ||||||
| @ -714,16 +731,14 @@ function Get-Product-Version-Url([string]$AzureFeed, [string]$SpecificVersion, [ | |||||||
|     return $ProductVersionTxtURL |     return $ProductVersionTxtURL | ||||||
| } | } | ||||||
|  |  | ||||||
| function Get-ProductVersionFromDownloadLink([string]$PackageDownloadLink, [string]$SpecificVersion) | function Get-ProductVersionFromDownloadLink([string]$PackageDownloadLink, [string]$SpecificVersion) { | ||||||
| { |  | ||||||
|     Say-Invocation $MyInvocation |     Say-Invocation $MyInvocation | ||||||
|  |  | ||||||
|     #product specific version follows the product name |     #product specific version follows the product name | ||||||
|     #for filename 'dotnet-sdk-3.1.404-win-x64.zip': the product version is 3.1.400 |     #for filename 'dotnet-sdk-3.1.404-win-x64.zip': the product version is 3.1.400 | ||||||
|     $filename = $PackageDownloadLink.Substring($PackageDownloadLink.LastIndexOf("/") + 1) |     $filename = $PackageDownloadLink.Substring($PackageDownloadLink.LastIndexOf("/") + 1) | ||||||
|     $filenameParts = $filename.Split('-') |     $filenameParts = $filename.Split('-') | ||||||
|     if ($filenameParts.Length -gt 2) |     if ($filenameParts.Length -gt 2) { | ||||||
|     { |  | ||||||
|         $productVersion = $filenameParts[2] |         $productVersion = $filenameParts[2] | ||||||
|         Say-Verbose "Extracted product version '$productVersion' from download link '$PackageDownloadLink'." |         Say-Verbose "Extracted product version '$productVersion' from download link '$PackageDownloadLink'." | ||||||
|     } |     } | ||||||
| @ -741,6 +756,9 @@ function Get-User-Share-Path() { | |||||||
|     if (!$InstallRoot) { |     if (!$InstallRoot) { | ||||||
|         $InstallRoot = "$env:LocalAppData\Microsoft\dotnet" |         $InstallRoot = "$env:LocalAppData\Microsoft\dotnet" | ||||||
|     } |     } | ||||||
|  |     elseif ($InstallRoot -like "$env:ProgramFiles\dotnet\?*") { | ||||||
|  |         Say-Warning "The install root specified by the environment variable DOTNET_INSTALL_DIR points to the sub folder of $env:ProgramFiles\dotnet which is the default dotnet install root using .NET SDK installer. It is better to keep aligned with .NET SDK installer." | ||||||
|  |     } | ||||||
|     return $InstallRoot |     return $InstallRoot | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -753,6 +771,19 @@ function Resolve-Installation-Path([string]$InstallDir) { | |||||||
|     return $InstallDir |     return $InstallDir | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function Test-User-Write-Access([string]$InstallDir) { | ||||||
|  |     try { | ||||||
|  |         $tempFileName = [guid]::NewGuid().ToString() | ||||||
|  |         $tempFilePath = Join-Path -Path $InstallDir -ChildPath $tempFileName | ||||||
|  |         New-Item -Path $tempFilePath -ItemType File -Force | ||||||
|  |         Remove-Item $tempFilePath -Force | ||||||
|  |         return $true | ||||||
|  |     } | ||||||
|  |     catch { | ||||||
|  |         return $false | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| function Is-Dotnet-Package-Installed([string]$InstallRoot, [string]$RelativePathToPackage, [string]$SpecificVersion) { | function Is-Dotnet-Package-Installed([string]$InstallRoot, [string]$RelativePathToPackage, [string]$SpecificVersion) { | ||||||
|     Say-Invocation $MyInvocation |     Say-Invocation $MyInvocation | ||||||
|  |  | ||||||
| @ -836,8 +867,7 @@ function Extract-Dotnet-Package([string]$ZipPath, [string]$OutPath) { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     catch |     catch { | ||||||
|     { |  | ||||||
|         Say-Error "Failed to extract package. Exception: $_" |         Say-Error "Failed to extract package. Exception: $_" | ||||||
|         throw; |         throw; | ||||||
|     } |     } | ||||||
| @ -869,6 +899,8 @@ function DownloadFile($Source, [string]$OutPath) { | |||||||
|         $File = [System.IO.File]::Create($OutPath) |         $File = [System.IO.File]::Create($OutPath) | ||||||
|         $Stream.CopyTo($File) |         $Stream.CopyTo($File) | ||||||
|         $File.Close() |         $File.Close() | ||||||
|  |  | ||||||
|  |         ValidateRemoteLocalFileSizes -LocalFileOutPath $OutPath -SourceUri $Source | ||||||
|     } |     } | ||||||
|     finally { |     finally { | ||||||
|         if ($null -ne $Stream) { |         if ($null -ne $Stream) { | ||||||
| @ -877,19 +909,40 @@ function DownloadFile($Source, [string]$OutPath) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function ValidateRemoteLocalFileSizes([string]$LocalFileOutPath, $SourceUri) { | ||||||
|  |     try { | ||||||
|  |         $remoteFileSize = Get-Remote-File-Size -zipUri $SourceUri | ||||||
|  |         $fileSize = [long](Get-Item $LocalFileOutPath).Length | ||||||
|  |         Say "Downloaded file $SourceUri size is $fileSize bytes." | ||||||
|  |      | ||||||
|  |         if ((![string]::IsNullOrEmpty($remoteFileSize)) -and !([string]::IsNullOrEmpty($fileSize)) ) { | ||||||
|  |             if ($remoteFileSize -ne $fileSize) { | ||||||
|  |                 Say "The remote and local file sizes are not equal. Remote file size is $remoteFileSize bytes and local size is $fileSize bytes. The local package may be corrupted." | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 Say "The remote and local file sizes are equal." | ||||||
|  |             }    | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             Say "Either downloaded or local package size can not be measured. One of them may be corrupted." | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     catch { | ||||||
|  |         Say "Either downloaded or local package size can not be measured. One of them may be corrupted." | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| function SafeRemoveFile($Path) { | function SafeRemoveFile($Path) { | ||||||
|     try { |     try { | ||||||
|         if (Test-Path $Path) { |         if (Test-Path $Path) { | ||||||
|             Remove-Item $Path |             Remove-Item $Path | ||||||
|             Say-Verbose "The temporary file `"$Path`" was removed." |             Say-Verbose "The temporary file `"$Path`" was removed." | ||||||
|         } |         } | ||||||
|         else |         else { | ||||||
|         { |  | ||||||
|             Say-Verbose "The temporary file `"$Path`" does not exist, therefore is not removed." |             Say-Verbose "The temporary file `"$Path`" does not exist, therefore is not removed." | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     catch |     catch { | ||||||
|     { |  | ||||||
|         Say-Warning "Failed to remove the temporary file: `"$Path`", remove it manually." |         Say-Warning "Failed to remove the temporary file: `"$Path`", remove it manually." | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -901,7 +954,8 @@ function Prepend-Sdk-InstallRoot-To-Path([string]$InstallRoot) { | |||||||
|         if (-Not $env:path.Contains($SuffixedBinPath)) { |         if (-Not $env:path.Contains($SuffixedBinPath)) { | ||||||
|             Say "Adding to current process PATH: `"$BinPath`". Note: This change will not be visible if PowerShell was run as a child process." |             Say "Adding to current process PATH: `"$BinPath`". Note: This change will not be visible if PowerShell was run as a child process." | ||||||
|             $env:path = $SuffixedBinPath + $env:path |             $env:path = $SuffixedBinPath + $env:path | ||||||
|         } else { |         } | ||||||
|  |         else { | ||||||
|             Say-Verbose "Current process PATH already contains `"$BinPath`"" |             Say-Verbose "Current process PATH already contains `"$BinPath`"" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -910,8 +964,7 @@ function Prepend-Sdk-InstallRoot-To-Path([string]$InstallRoot) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function PrintDryRunOutput($Invocation, $DownloadLinks) | function PrintDryRunOutput($Invocation, $DownloadLinks) { | ||||||
| { |  | ||||||
|     Say "Payload URLs:" |     Say "Payload URLs:" | ||||||
|      |      | ||||||
|     for ($linkIndex = 0; $linkIndex -lt $DownloadLinks.count; $linkIndex++) { |     for ($linkIndex = 0; $linkIndex -lt $DownloadLinks.count; $linkIndex++) { | ||||||
| @ -934,12 +987,37 @@ function PrintDryRunOutput($Invocation, $DownloadLinks) | |||||||
|         $RepeatableCommand += " -FeedCredential `"<feedCredential>`"" |         $RepeatableCommand += " -FeedCredential `"<feedCredential>`"" | ||||||
|     } |     } | ||||||
|     Say "Repeatable invocation: $RepeatableCommand" |     Say "Repeatable invocation: $RepeatableCommand" | ||||||
|     if ($SpecificVersion -ne $EffectiveVersion) |     if ($SpecificVersion -ne $EffectiveVersion) { | ||||||
|     { |  | ||||||
|         Say "NOTE: Due to finding a version manifest with this runtime, it would actually install with version '$EffectiveVersion'" |         Say "NOTE: Due to finding a version manifest with this runtime, it would actually install with version '$EffectiveVersion'" | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | # grab the 'stem' of the redirect and check it against all of our configured feeds,  | ||||||
|  | # if it matches, we can be sure that the redirect is valid and we should use it for | ||||||
|  | # subsequent processing | ||||||
|  | function Sanitize-RedirectUrl([string]$url) { | ||||||
|  |     $urlSegments = ([System.Uri]$url).Segments; | ||||||
|  |     $urlStem = $urlSegments[2..($urlSegments.Length - 1)] -join ""; | ||||||
|  |     Write-Verbose "Checking configured feeds for the asset at $urlStem" | ||||||
|  |     foreach ($prospectiveFeed in $feeds) { | ||||||
|  |         $trialUrl = "$prospectiveFeed/$urlStem"; | ||||||
|  |         Write-Verbose "Checking $trialUrl" | ||||||
|  |         try { | ||||||
|  |             $trialResponse = Invoke-WebRequest -Uri $trialUrl -Method HEAD | ||||||
|  |             if ($trialResponse.StatusCode -eq 200) { | ||||||
|  |                 Write-Verbose "Found a match at $trialUrl" | ||||||
|  |                 return $trialUrl; | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 Write-Verbose "No match at $trialUrl" | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         catch { | ||||||
|  |             Write-Verbose "Failed to check $trialUrl" | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| function Get-AkaMSDownloadLink([string]$Channel, [string]$Quality, [bool]$Internal, [string]$Product, [string]$Architecture) { | function Get-AkaMSDownloadLink([string]$Channel, [string]$Quality, [bool]$Internal, [string]$Product, [string]$Architecture) { | ||||||
|     Say-Invocation $MyInvocation  |     Say-Invocation $MyInvocation  | ||||||
|  |  | ||||||
| @ -963,8 +1041,7 @@ function Get-AkaMSDownloadLink([string]$Channel, [string]$Quality, [bool]$Intern | |||||||
|     Say-Verbose  "Constructed aka.ms link: '$akaMsLink'." |     Say-Verbose  "Constructed aka.ms link: '$akaMsLink'." | ||||||
|     $akaMsDownloadLink = $null |     $akaMsDownloadLink = $null | ||||||
|  |  | ||||||
|     for ($maxRedirections = 9; $maxRedirections -ge 0; $maxRedirections--) |     for ($maxRedirections = 9; $maxRedirections -ge 0; $maxRedirections--) { | ||||||
|     { |  | ||||||
|         #get HTTP response |         #get HTTP response | ||||||
|         #do not pass credentials as a part of the $akaMsLink and do not apply credentials in the GetHTTPResponse function |         #do not pass credentials as a part of the $akaMsLink and do not apply credentials in the GetHTTPResponse function | ||||||
|         #otherwise the redirect link would have credentials as well |         #otherwise the redirect link would have credentials as well | ||||||
| @ -978,8 +1055,7 @@ function Get-AkaMSDownloadLink([string]$Channel, [string]$Quality, [bool]$Intern | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         #if HTTP code is 301 (Moved Permanently), the redirect link exists |         #if HTTP code is 301 (Moved Permanently), the redirect link exists | ||||||
|         if  ($Response.StatusCode -eq 301) |         if ($Response.StatusCode -eq 301) { | ||||||
|         { |  | ||||||
|             try { |             try { | ||||||
|                 $akaMsDownloadLink = $Response.Headers.GetValues("Location")[0] |                 $akaMsDownloadLink = $Response.Headers.GetValues("Location")[0] | ||||||
|  |  | ||||||
| @ -998,9 +1074,13 @@ function Get-AkaMSDownloadLink([string]$Channel, [string]$Quality, [bool]$Intern | |||||||
|                 return $null |                 return $null | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         elseif ((($Response.StatusCode -lt 300) -or ($Response.StatusCode -ge 400)) -and (-not [string]::IsNullOrEmpty($akaMsDownloadLink))) |         elseif ((($Response.StatusCode -lt 300) -or ($Response.StatusCode -ge 400)) -and (-not [string]::IsNullOrEmpty($akaMsDownloadLink))) { | ||||||
|         { |  | ||||||
|             # Redirections have ended. |             # Redirections have ended. | ||||||
|  |             $actualRedirectUrl = Sanitize-RedirectUrl $akaMsDownloadLink | ||||||
|  |             if ($null -ne $actualRedirectUrl) { | ||||||
|  |                 $akaMsDownloadLink = $actualRedirectUrl | ||||||
|  |             } | ||||||
|  |  | ||||||
|             return $akaMsDownloadLink |             return $akaMsDownloadLink | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @ -1049,27 +1129,21 @@ function Get-AkaMsLink-And-Version([string] $NormalizedChannel, [string] $Normal | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function Get-Feeds-To-Use() | function Get-Feeds-To-Use() { | ||||||
| { |  | ||||||
|     $feeds = @( |     $feeds = @( | ||||||
|     "https://dotnetcli.azureedge.net/dotnet", |         "https://builds.dotnet.microsoft.com/dotnet" | ||||||
|     "https://dotnetbuilds.azureedge.net/public" |         "https://ci.dot.net/public" | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|     if (-not [string]::IsNullOrEmpty($AzureFeed)) { |     if (-not [string]::IsNullOrEmpty($AzureFeed)) { | ||||||
|         $feeds = @($AzureFeed) |         $feeds = @($AzureFeed) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if ($NoCdn) { |  | ||||||
|         $feeds = @( |  | ||||||
|         "https://dotnetcli.blob.core.windows.net/dotnet", |  | ||||||
|         "https://dotnetbuilds.blob.core.windows.net/public" |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|     if (-not [string]::IsNullOrEmpty($UncachedFeed)) { |     if (-not [string]::IsNullOrEmpty($UncachedFeed)) { | ||||||
|             $feeds = @($UncachedFeed) |             $feeds = @($UncachedFeed) | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|  |     Write-Verbose "Initialized feeds: $feeds" | ||||||
|  |  | ||||||
|     return $feeds |     return $feeds | ||||||
| } | } | ||||||
| @ -1100,6 +1174,13 @@ function Resolve-AssetName-And-RelativePath([string] $Runtime) { | |||||||
| } | } | ||||||
|  |  | ||||||
| function Prepare-Install-Directory { | function Prepare-Install-Directory { | ||||||
|  |     $diskSpaceWarning = "Failed to check the disk space. Installation will continue, but it may fail if you do not have enough disk space."; | ||||||
|  |  | ||||||
|  |     if ($PSVersionTable.PSVersion.Major -lt 7) { | ||||||
|  |         Say-Verbose $diskSpaceWarning | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |  | ||||||
|     New-Item -ItemType Directory -Force -Path $InstallRoot | Out-Null |     New-Item -ItemType Directory -Force -Path $InstallRoot | Out-Null | ||||||
|  |  | ||||||
|     $installDrive = $((Get-Item $InstallRoot -Force).PSDrive.Name); |     $installDrive = $((Get-Item $InstallRoot -Force).PSDrive.Name); | ||||||
| @ -1108,14 +1189,20 @@ function Prepare-Install-Directory { | |||||||
|         $diskInfo = Get-PSDrive -Name $installDrive |         $diskInfo = Get-PSDrive -Name $installDrive | ||||||
|     } |     } | ||||||
|     catch { |     catch { | ||||||
|         Say-Warning "Failed to check the disk space. Installation will continue, but it may fail if you do not have enough disk space." |         Say-Warning $diskSpaceWarning | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     # The check is relevant for PS version >= 7, the result can be irrelevant for older versions. See https://github.com/PowerShell/PowerShell/issues/12442. | ||||||
|     if ( ($null -ne $diskInfo) -and ($diskInfo.Free / 1MB -le 100)) { |     if ( ($null -ne $diskInfo) -and ($diskInfo.Free / 1MB -le 100)) { | ||||||
|         throw "There is not enough disk space on drive ${installDrive}:" |         throw "There is not enough disk space on drive ${installDrive}:" | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | if ($Help) { | ||||||
|  |     Get-Help $PSCommandPath -Examples | ||||||
|  |     exit | ||||||
|  | } | ||||||
|  |  | ||||||
| Say-Verbose "Note that the intended use of this script is for Continuous Integration (CI) scenarios, where:" | Say-Verbose "Note that the intended use of this script is for Continuous Integration (CI) scenarios, where:" | ||||||
| Say-Verbose "- The SDK needs to be installed without user interaction and without admin rights." | Say-Verbose "- The SDK needs to be installed without user interaction and without admin rights." | ||||||
| Say-Verbose "- The SDK installation doesn't need to persist across multiple CI runs." | Say-Verbose "- The SDK installation doesn't need to persist across multiple CI runs." | ||||||
| @ -1139,6 +1226,10 @@ Measure-Action "Product discovery" { | |||||||
| } | } | ||||||
|  |  | ||||||
| $InstallRoot = Resolve-Installation-Path $InstallDir | $InstallRoot = Resolve-Installation-Path $InstallDir | ||||||
|  | if (-not (Test-User-Write-Access $InstallRoot)) { | ||||||
|  |     Say-Error "The current user doesn't have write access to the installation root '$InstallRoot' to install .NET. Please try specifying a different installation directory using the -InstallDir parameter, or ensure the selected directory has the appropriate permissions." | ||||||
|  |     throw | ||||||
|  | } | ||||||
| Say-Verbose "InstallRoot: $InstallRoot" | Say-Verbose "InstallRoot: $InstallRoot" | ||||||
| $ScriptName = $MyInvocation.MyCommand.Name | $ScriptName = $MyInvocation.MyCommand.Name | ||||||
| ($assetName, $dotnetPackageRelativePath) = Resolve-AssetName-And-RelativePath -Runtime $Runtime | ($assetName, $dotnetPackageRelativePath) = Resolve-AssetName-And-RelativePath -Runtime $Runtime | ||||||
| @ -1160,8 +1251,7 @@ if ([string]::IsNullOrEmpty($JSonFile) -and ($Version -eq "latest")) { | |||||||
|          |          | ||||||
|         if (-Not $DryRun) { |         if (-Not $DryRun) { | ||||||
|             Say-Verbose "Checking if the version $EffectiveVersion is already installed" |             Say-Verbose "Checking if the version $EffectiveVersion is already installed" | ||||||
|             if (Is-Dotnet-Package-Installed -InstallRoot $InstallRoot -RelativePathToPackage $dotnetPackageRelativePath -SpecificVersion $EffectiveVersion) |             if (Is-Dotnet-Package-Installed -InstallRoot $InstallRoot -RelativePathToPackage $dotnetPackageRelativePath -SpecificVersion $EffectiveVersion) { | ||||||
|             { |  | ||||||
|                 Say "$assetName with version '$EffectiveVersion' is already installed." |                 Say "$assetName with version '$EffectiveVersion' is already installed." | ||||||
|                 Prepend-Sdk-InstallRoot-To-Path -InstallRoot $InstallRoot |                 Prepend-Sdk-InstallRoot-To-Path -InstallRoot $InstallRoot | ||||||
|                 return |                 return | ||||||
| @ -1172,8 +1262,7 @@ if ([string]::IsNullOrEmpty($JSonFile) -and ($Version -eq "latest")) { | |||||||
|  |  | ||||||
| # Primary and legacy links cannot be used if a quality was specified. | # Primary and legacy links cannot be used if a quality was specified. | ||||||
| # If we already have an aka.ms link, no need to search the blob feeds. | # If we already have an aka.ms link, no need to search the blob feeds. | ||||||
| if ([string]::IsNullOrEmpty($NormalizedQuality) -and 0 -eq $DownloadLinks.count) | if ([string]::IsNullOrEmpty($NormalizedQuality) -and 0 -eq $DownloadLinks.count) { | ||||||
| { |  | ||||||
|     foreach ($feed in $feeds) { |     foreach ($feed in $feeds) { | ||||||
|         try { |         try { | ||||||
|             $SpecificVersion = Get-Specific-Version-From-Version -AzureFeed $feed -Channel $Channel -Version $Version -JSonFile $JSonFile |             $SpecificVersion = Get-Specific-Version-From-Version -AzureFeed $feed -Channel $Channel -Version $Version -JSonFile $JSonFile | ||||||
| @ -1190,16 +1279,14 @@ if ([string]::IsNullOrEmpty($NormalizedQuality) -and 0 -eq $DownloadLinks.count) | |||||||
|      |      | ||||||
|             if (-Not $DryRun) { |             if (-Not $DryRun) { | ||||||
|                 Say-Verbose "Checking if the version $EffectiveVersion is already installed" |                 Say-Verbose "Checking if the version $EffectiveVersion is already installed" | ||||||
|                 if (Is-Dotnet-Package-Installed -InstallRoot $InstallRoot -RelativePathToPackage $dotnetPackageRelativePath -SpecificVersion $EffectiveVersion) |                 if (Is-Dotnet-Package-Installed -InstallRoot $InstallRoot -RelativePathToPackage $dotnetPackageRelativePath -SpecificVersion $EffectiveVersion) { | ||||||
|                 { |  | ||||||
|                     Say "$assetName with version '$EffectiveVersion' is already installed." |                     Say "$assetName with version '$EffectiveVersion' is already installed." | ||||||
|                     Prepend-Sdk-InstallRoot-To-Path -InstallRoot $InstallRoot |                     Prepend-Sdk-InstallRoot-To-Path -InstallRoot $InstallRoot | ||||||
|                     return |                     return | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         catch |         catch { | ||||||
|         { |  | ||||||
|             Say-Verbose "Failed to acquire download links from feed $feed. Exception: $_" |             Say-Verbose "Failed to acquire download links from feed $feed. Exception: $_" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -1216,15 +1303,13 @@ if ($DryRun) { | |||||||
|  |  | ||||||
| Measure-Action "Installation directory preparation" { Prepare-Install-Directory } | Measure-Action "Installation directory preparation" { Prepare-Install-Directory } | ||||||
|  |  | ||||||
| $ZipPath = [System.IO.Path]::combine([System.IO.Path]::GetTempPath(), [System.IO.Path]::GetRandomFileName()) |  | ||||||
| Say-Verbose "Zip path: $ZipPath" | Say-Verbose "Zip path: $ZipPath" | ||||||
|  |  | ||||||
| $DownloadSucceeded = $false | $DownloadSucceeded = $false | ||||||
| $DownloadedLink = $null | $DownloadedLink = $null | ||||||
| $ErrorMessages = @() | $ErrorMessages = @() | ||||||
|  |  | ||||||
| foreach ($link in $DownloadLinks) | foreach ($link in $DownloadLinks) { | ||||||
| { |  | ||||||
|     Say-Verbose "Downloading `"$($link.type)`" link $($link.downloadLink)" |     Say-Verbose "Downloading `"$($link.type)`" link $($link.downloadLink)" | ||||||
|  |  | ||||||
|     try { |     try { | ||||||
| @ -1244,7 +1329,8 @@ foreach ($link in $DownloadLinks) | |||||||
|      |      | ||||||
|         if ($PSItem.Exception.Data.Contains("ErrorMessage")) { |         if ($PSItem.Exception.Data.Contains("ErrorMessage")) { | ||||||
|             $ErrorMessage = $PSItem.Exception.Data["ErrorMessage"] |             $ErrorMessage = $PSItem.Exception.Data["ErrorMessage"] | ||||||
|         } else { |         } | ||||||
|  |         else { | ||||||
|             $ErrorMessage = $PSItem.Exception.Message |             $ErrorMessage = $PSItem.Exception.Message | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @ -1289,51 +1375,54 @@ if (!$isAssetInstalled) { | |||||||
|     throw "`"$assetName`" with version = $($DownloadedLink.effectiveVersion) failed to install with an unknown error." |     throw "`"$assetName`" with version = $($DownloadedLink.effectiveVersion) failed to install with an unknown error." | ||||||
| } | } | ||||||
|  |  | ||||||
|  | if (-not $KeepZip) { | ||||||
|     SafeRemoveFile -Path $ZipPath |     SafeRemoveFile -Path $ZipPath | ||||||
|  | } | ||||||
|  |  | ||||||
| Measure-Action "Setting up shell environment" { Prepend-Sdk-InstallRoot-To-Path -InstallRoot $InstallRoot } | Measure-Action "Setting up shell environment" { Prepend-Sdk-InstallRoot-To-Path -InstallRoot $InstallRoot } | ||||||
|  |  | ||||||
| Say "Note that the script does not resolve dependencies during installation." | Say "Note that the script does not ensure your Windows version is supported during the installation." | ||||||
| Say "To check the list of dependencies, go to https://learn.microsoft.com/dotnet/core/install/windows#dependencies" | Say "To check the list of supported versions, go to https://learn.microsoft.com/dotnet/core/install/windows#supported-versions" | ||||||
| Say "Installed version is $($DownloadedLink.effectiveVersion)" | Say "Installed version is $($DownloadedLink.effectiveVersion)" | ||||||
| Say "Installation finished" | Say "Installation finished" | ||||||
|  |  | ||||||
| # SIG # Begin signature block | # SIG # Begin signature block | ||||||
| # MIInvwYJKoZIhvcNAQcCoIInsDCCJ6wCAQExDzANBglghkgBZQMEAgEFADB5Bgor | # MIIoRgYJKoZIhvcNAQcCoIIoNzCCKDMCAQExDzANBglghkgBZQMEAgEFADB5Bgor | ||||||
| # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG | # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG | ||||||
| # KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCBhfTi3SRn7+vyy | # KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCAA6hOL3sfG/4jH | ||||||
| # uCXKPjhiawegWZ493EcaOEycbgkZcKCCDXYwggX0MIID3KADAgECAhMzAAACy7d1 | # iO4VqZoOTVqC+yp2rOhb1M2cc+ic7KCCDXYwggX0MIID3KADAgECAhMzAAAEBGx0 | ||||||
| # OfsCcUI2AAAAAALLMA0GCSqGSIb3DQEBCwUAMH4xCzAJBgNVBAYTAlVTMRMwEQYD | # Bv9XKydyAAAAAAQEMA0GCSqGSIb3DQEBCwUAMH4xCzAJBgNVBAYTAlVTMRMwEQYD | ||||||
| # VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy | # VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy | ||||||
| # b3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNpZ25p | # b3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNpZ25p | ||||||
| # bmcgUENBIDIwMTEwHhcNMjIwNTEyMjA0NTU5WhcNMjMwNTExMjA0NTU5WjB0MQsw | # bmcgUENBIDIwMTEwHhcNMjQwOTEyMjAxMTE0WhcNMjUwOTExMjAxMTE0WjB0MQsw | ||||||
| # CQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9u | # CQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9u | ||||||
| # ZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMR4wHAYDVQQDExVNaWNy | # ZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMR4wHAYDVQQDExVNaWNy | ||||||
| # b3NvZnQgQ29ycG9yYXRpb24wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB | # b3NvZnQgQ29ycG9yYXRpb24wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB | ||||||
| # AQC3sN0WcdGpGXPZIb5iNfFB0xZ8rnJvYnxD6Uf2BHXglpbTEfoe+mO//oLWkRxA | # AQC0KDfaY50MDqsEGdlIzDHBd6CqIMRQWW9Af1LHDDTuFjfDsvna0nEuDSYJmNyz | ||||||
| # wppditsSVOD0oglKbtnh9Wp2DARLcxbGaW4YanOWSB1LyLRpHnnQ5POlh2U5trg4 | # NB10jpbg0lhvkT1AzfX2TLITSXwS8D+mBzGCWMM/wTpciWBV/pbjSazbzoKvRrNo | ||||||
| # 3gQjvlNZlQB3lL+zrPtbNvMA7E0Wkmo+Z6YFnsf7aek+KGzaGboAeFO4uKZjQXY5 | # DV/u9omOM2Eawyo5JJJdNkM2d8qzkQ0bRuRd4HarmGunSouyb9NY7egWN5E5lUc3 | ||||||
| # RmMzE70Bwaz7hvA05jDURdRKH0i/1yK96TDuP7JyRFLOvA3UXNWz00R9w7ppMDcN | # a2AROzAdHdYpObpCOdeAY2P5XqtJkk79aROpzw16wCjdSn8qMzCBzR7rvH2WVkvF | ||||||
| # lXtrmbPigv3xE9FfpfmJRtiOZQKd73K72Wujmj6/Su3+DBTpOq7NgdntW2lJfX3X | # HLIxZQET1yhPb6lRmpgBQNnzidHV2Ocxjc8wNiIDzgbDkmlx54QPfw7RwQi8p1fy | ||||||
| # a6oe4F9Pk9xRhkwHsk7Ju9E/AgMBAAGjggFzMIIBbzAfBgNVHSUEGDAWBgorBgEE | # 4byhBrTjv568x8NGv3gwb0RbAgMBAAGjggFzMIIBbzAfBgNVHSUEGDAWBgorBgEE | ||||||
| # AYI3TAgBBggrBgEFBQcDAzAdBgNVHQ4EFgQUrg/nt/gj+BBLd1jZWYhok7v5/w4w | # AYI3TAgBBggrBgEFBQcDAzAdBgNVHQ4EFgQU8huhNbETDU+ZWllL4DNMPCijEU4w | ||||||
| # RQYDVR0RBD4wPKQ6MDgxHjAcBgNVBAsTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEW | # RQYDVR0RBD4wPKQ6MDgxHjAcBgNVBAsTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEW | ||||||
| # MBQGA1UEBRMNMjMwMDEyKzQ3MDUyODAfBgNVHSMEGDAWgBRIbmTlUAXTgqoXNzci | # MBQGA1UEBRMNMjMwMDEyKzUwMjkyMzAfBgNVHSMEGDAWgBRIbmTlUAXTgqoXNzci | ||||||
| # tW2oynUClTBUBgNVHR8ETTBLMEmgR6BFhkNodHRwOi8vd3d3Lm1pY3Jvc29mdC5j | # tW2oynUClTBUBgNVHR8ETTBLMEmgR6BFhkNodHRwOi8vd3d3Lm1pY3Jvc29mdC5j | ||||||
| # b20vcGtpb3BzL2NybC9NaWNDb2RTaWdQQ0EyMDExXzIwMTEtMDctMDguY3JsMGEG | # b20vcGtpb3BzL2NybC9NaWNDb2RTaWdQQ0EyMDExXzIwMTEtMDctMDguY3JsMGEG | ||||||
| # CCsGAQUFBwEBBFUwUzBRBggrBgEFBQcwAoZFaHR0cDovL3d3dy5taWNyb3NvZnQu | # CCsGAQUFBwEBBFUwUzBRBggrBgEFBQcwAoZFaHR0cDovL3d3dy5taWNyb3NvZnQu | ||||||
| # Y29tL3BraW9wcy9jZXJ0cy9NaWNDb2RTaWdQQ0EyMDExXzIwMTEtMDctMDguY3J0 | # Y29tL3BraW9wcy9jZXJ0cy9NaWNDb2RTaWdQQ0EyMDExXzIwMTEtMDctMDguY3J0 | ||||||
| # MAwGA1UdEwEB/wQCMAAwDQYJKoZIhvcNAQELBQADggIBAJL5t6pVjIRlQ8j4dAFJ | # MAwGA1UdEwEB/wQCMAAwDQYJKoZIhvcNAQELBQADggIBAIjmD9IpQVvfB1QehvpC | ||||||
| # ZnMke3rRHeQDOPFxswM47HRvgQa2E1jea2aYiMk1WmdqWnYw1bal4IzRlSVf4czf | # Ge7QeTQkKQ7j3bmDMjwSqFL4ri6ae9IFTdpywn5smmtSIyKYDn3/nHtaEn0X1NBj | ||||||
| # zx2vjOIOiaGllW2ByHkfKApngOzJmAQ8F15xSHPRvNMmvpC3PFLvKMf3y5SyPJxh | # L5oP0BjAy1sqxD+uy35B+V8wv5GrxhMDJP8l2QjLtH/UglSTIhLqyt8bUAqVfyfp | ||||||
| # 922TTq0q5epJv1SgZDWlUlHL/Ex1nX8kzBRhHvc6D6F5la+oAO4A3o/ZC05OOgm4 | # h4COMRvwwjTvChtCnUXXACuCXYHWalOoc0OU2oGN+mPJIJJxaNQc1sjBsMbGIWv3 | ||||||
| # EJxZP9MqUi5iid2dw4Jg/HvtDpCcLj1GLIhCDaebKegajCJlMhhxnDXrGFLJfX8j | # cmgSHkCEmrMv7yaidpePt6V+yPMik+eXw3IfZ5eNOiNgL1rZzgSJfTnvUqiaEQ0X | ||||||
| # 7k7LUvrZDsQniJZ3D66K+3SZTLhvwK7dMGVFuUUJUfDifrlCTjKG9mxsPDllfyck | # dG1HbkDv9fv6CTq6m4Ty3IzLiwGSXYxRIXTxT4TYs5VxHy2uFjFXWVSL0J2ARTYL | ||||||
| # 4zGnRZv8Jw9RgE1zAghnU14L0vVUNOzi/4bE7wIsiRyIcCcVoXRneBA3n/frLXvd | # E4Oyl1wXDF1PX4bxg1yDMfKPHcE1Ijic5lx1KdK1SkaEJdto4hd++05J9Bf9TAmi | ||||||
| # jDsbb2lpGu78+s1zbO5N0bhHWq4j5WMutrspBxEhqG2PSBjC5Ypi+jhtfu3+x76N | # u6EK6C9Oe5vRadroJCK26uCUI4zIjL/qG7mswW+qT0CW0gnR9JHkXCWNbo8ccMk1 | ||||||
| # mBvsyKuxx9+Hm/ALnlzKxr4KyMR3/z4IRMzA1QyppNk65Ui+jB14g+w4vole33M1 | # sJatmRoSAifbgzaYbUz8+lv+IXy5GFuAmLnNbGjacB3IMGpa+lbFgih57/fIhamq | ||||||
| # pVqVckrmSebUkmjnCshCiH12IFgHZF7gRwE4YZrJ7QjxZeoZqHaKsQLRMp653beB | # 5VhxgaEmn/UjWyr+cPiAFWuTVIpfsOjbEAww75wURNM1Imp9NJKye1O24EspEHmb | ||||||
| # fHfeva9zJPhBSdVcCW7x9q0c2HVPLJHX9YCUU714I+qtLpDGrdbZxD9mikPqL/To | # DmqCUcq7NqkOKIG4PVm3hDDED/WQpzJDkvu4FrIbvyTGVU01vKsg4UfcdiZ0fQ+/ | ||||||
| # /1lDZ0ch8FtePhME7houuoPcMIIHejCCBWKgAwIBAgIKYQ6Q0gAAAAAAAzANBgkq | # V0hf8yrtq9CkB8iIuk5bBxuPMIIHejCCBWKgAwIBAgIKYQ6Q0gAAAAAAAzANBgkq | ||||||
| # hkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24x | # hkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24x | ||||||
| # EDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlv | # EDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlv | ||||||
| # bjEyMDAGA1UEAxMpTWljcm9zb2Z0IFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5 | # bjEyMDAGA1UEAxMpTWljcm9zb2Z0IFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5 | ||||||
| @ -1373,142 +1462,144 @@ Say "Installation finished" | |||||||
| # XJbYANahRr1Z85elCUtIEJmAH9AAKcWxm6U/RXceNcbSoqKfenoi+kiVH6v7RyOA | # XJbYANahRr1Z85elCUtIEJmAH9AAKcWxm6U/RXceNcbSoqKfenoi+kiVH6v7RyOA | ||||||
| # 9Z74v2u3S5fi63V4GuzqN5l5GEv/1rMjaHXmr/r8i+sLgOppO6/8MO0ETI7f33Vt | # 9Z74v2u3S5fi63V4GuzqN5l5GEv/1rMjaHXmr/r8i+sLgOppO6/8MO0ETI7f33Vt | ||||||
| # Y5E90Z1WTk+/gFcioXgRMiF670EKsT/7qMykXcGhiJtXcVZOSEXAQsmbdlsKgEhr | # Y5E90Z1WTk+/gFcioXgRMiF670EKsT/7qMykXcGhiJtXcVZOSEXAQsmbdlsKgEhr | ||||||
| # /Xmfwb1tbWrJUnMTDXpQzTGCGZ8wghmbAgEBMIGVMH4xCzAJBgNVBAYTAlVTMRMw | # /Xmfwb1tbWrJUnMTDXpQzTGCGiYwghoiAgEBMIGVMH4xCzAJBgNVBAYTAlVTMRMw | ||||||
| # EQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVN | # EQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVN | ||||||
| # aWNyb3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNp | # aWNyb3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNp | ||||||
| # Z25pbmcgUENBIDIwMTECEzMAAALLt3U5+wJxQjYAAAAAAsswDQYJYIZIAWUDBAIB | # Z25pbmcgUENBIDIwMTECEzMAAAQEbHQG/1crJ3IAAAAABAQwDQYJYIZIAWUDBAIB | ||||||
| # BQCgga4wGQYJKoZIhvcNAQkDMQwGCisGAQQBgjcCAQQwHAYKKwYBBAGCNwIBCzEO | # BQCgga4wGQYJKoZIhvcNAQkDMQwGCisGAQQBgjcCAQQwHAYKKwYBBAGCNwIBCzEO | ||||||
| # MAwGCisGAQQBgjcCARUwLwYJKoZIhvcNAQkEMSIEIFmuaTXYQ37AFvsEol24fdW+ | # MAwGCisGAQQBgjcCARUwLwYJKoZIhvcNAQkEMSIEIL7Zm9jjqasUipeS7XNbT5Gz | ||||||
| # nRqHcc1fr+VQVdqhXc/vMEIGCisGAQQBgjcCAQwxNDAyoBSAEgBNAGkAYwByAG8A | # uhEwSf09z2Ab+694mR/3MEIGCisGAQQBgjcCAQwxNDAyoBSAEgBNAGkAYwByAG8A | ||||||
| # cwBvAGYAdKEagBhodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20wDQYJKoZIhvcNAQEB | # cwBvAGYAdKEagBhodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20wDQYJKoZIhvcNAQEB | ||||||
| # BQAEggEAjY5XW5Ly7TJ1OTbeIR98xU+2dmtw7L71ws+ICnQCGhj2xJDUK+5yrTfO | # BQAEggEAfTNcpMwgkFxkb0hBch2MCvTb1mGCFv8rZWTkR/aRZTyzuAIEb2GfL4qB | ||||||
| # 8C98l/P4ynFi33Dl8z2YElqUCuqEXbiCzz06lIL4NuibC5DV/X80ZmICR/NYd2v1 | # rPycLC2+q4gaksj1Cv+mRTEq+ysl0aWbXgPiRNiijlnuWKRPZ4nlcGkeXu5zxJ1W | ||||||
| # ww7IH+7dpsHAowBBindCYpVwQ3Ea3kDWgsjPAinAysFFushSOnNWFvrF6vi2smrs | # uUOCIe03s6eJCUZseRZkNHB1/CqIlk/YB5yqB38cfq6ct+lWKoSCbSwRVh3Du6am | ||||||
| # smbrAAhEhSfLd1Pxxdw73hQ0YjM/D3F3opaybMQ0blpHhOaqtbiyYzvk0doIzBEc | # jxnQRa4njduu1xywcKZYp9NGGeAgRDpMNbvFKF4Qf3krbTAn3vIVDBay6oeiHo2I | ||||||
| # trSH4NDIc3yLNj5VbjSczpexE+hyQNY4xCtwco4bVtXhONUihv08AIKR8+sIaI7A | # x1RLrRC/CEYZ7oJ8tyc3SUE2/Jd00M4EKax+z3xTIkOmyMBZjEe1el92WVcUWukT | ||||||
| # mM/SWrrwGYSSSxydKqDei7biKG4jDqGCFykwghclBgorBgEEAYI3AwMBMYIXFTCC | # ACoQjF5jPyXnfYGH7rjevjpI5u2T66GCF7AwghesBgorBgEEAYI3AwMBMYIXnDCC | ||||||
| # FxEGCSqGSIb3DQEHAqCCFwIwghb+AgEDMQ8wDQYJYIZIAWUDBAIBBQAwggFZBgsq | # F5gGCSqGSIb3DQEHAqCCF4kwgheFAgEDMQ8wDQYJYIZIAWUDBAIBBQAwggFaBgsq | ||||||
| # hkiG9w0BCRABBKCCAUgEggFEMIIBQAIBAQYKKwYBBAGEWQoDATAxMA0GCWCGSAFl | # hkiG9w0BCRABBKCCAUkEggFFMIIBQQIBAQYKKwYBBAGEWQoDATAxMA0GCWCGSAFl | ||||||
| # AwQCAQUABCB6Hzt2gUb/WZK8fvVnOocriE4rYr6mscZi3gZnBCpiigIGZBr2iMZU | # AwQCAQUABCBjHcYL0Rw5C6IE3Lyb3B0i9qsTzN6j8bzChm+bMp97RgIGZ2Ld17Jt | ||||||
| # GBMyMDIzMDMzMTE1MjEwNi41MTZaMASAAgH0oIHYpIHVMIHSMQswCQYDVQQGEwJV | # GBMyMDI1MDExMjAwNDMxNy4yNTZaMASAAgH0oIHZpIHWMIHTMQswCQYDVQQGEwJV | ||||||
| # UzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UE | # UzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UE | ||||||
| # ChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQLEyRNaWNyb3NvZnQgSXJl | # ChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQLEyRNaWNyb3NvZnQgSXJl | ||||||
| # bGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJjAkBgNVBAsTHVRoYWxlcyBUU1MgRVNO | # bGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJzAlBgNVBAsTHm5TaGllbGQgVFNTIEVT | ||||||
| # OjA4NDItNEJFNi1DMjlBMSUwIwYDVQQDExxNaWNyb3NvZnQgVGltZS1TdGFtcCBT | # Tjo0MzFBLTA1RTAtRDk0NzElMCMGA1UEAxMcTWljcm9zb2Z0IFRpbWUtU3RhbXAg | ||||||
| # ZXJ2aWNloIIReDCCBycwggUPoAMCAQICEzMAAAGybkADf26plJIAAQAAAbIwDQYJ | # U2VydmljZaCCEf4wggcoMIIFEKADAgECAhMzAAAB+vs7RNN3M8bTAAEAAAH6MA0G | ||||||
| # KoZIhvcNAQELBQAwfDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24x | # CSqGSIb3DQEBCwUAMHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9u | ||||||
| # EDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlv | # MRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRp | ||||||
| # bjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUtU3RhbXAgUENBIDIwMTAwHhcNMjIw | # b24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwMB4XDTI0 | ||||||
| # OTIwMjAyMjAxWhcNMjMxMjE0MjAyMjAxWjCB0jELMAkGA1UEBhMCVVMxEzARBgNV | # MDcyNTE4MzExMVoXDTI1MTAyMjE4MzExMVowgdMxCzAJBgNVBAYTAlVTMRMwEQYD | ||||||
| # BAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jv | # VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy | ||||||
| # c29mdCBDb3Jwb3JhdGlvbjEtMCsGA1UECxMkTWljcm9zb2Z0IElyZWxhbmQgT3Bl | # b3NvZnQgQ29ycG9yYXRpb24xLTArBgNVBAsTJE1pY3Jvc29mdCBJcmVsYW5kIE9w | ||||||
| # cmF0aW9ucyBMaW1pdGVkMSYwJAYDVQQLEx1UaGFsZXMgVFNTIEVTTjowODQyLTRC | # ZXJhdGlvbnMgTGltaXRlZDEnMCUGA1UECxMeblNoaWVsZCBUU1MgRVNOOjQzMUEt | ||||||
| # RTYtQzI5QTElMCMGA1UEAxMcTWljcm9zb2Z0IFRpbWUtU3RhbXAgU2VydmljZTCC | # MDVFMC1EOTQ3MSUwIwYDVQQDExxNaWNyb3NvZnQgVGltZS1TdGFtcCBTZXJ2aWNl | ||||||
| # AiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMqiZTIde/lQ4rC+Bml5f/Wu | # MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAyhZVBM3PZcBfEpAf7fII | ||||||
| # q/xKTxrfbG23HofmQ+qZAN4GyO73PF3y9OAfpt7Qf2jcldWOGUB+HzBuwllYyP3f | # hygwYVVP64USeZbSlRR3pvJebva0LQCDW45yOrtpwIpGyDGX+EbCbHhS5Td4J0Yl | ||||||
| # x4MY8zvuAuB37FvoytnNC2DKnVrVlHOVcGUL9CnmhDNMA2/nskjIf2IoiG9J0qLY | # c83ztLEbbQD7M6kqR0Xj+n82cGse/QnMH0WRZLnwggJdenpQ6UciM4nMYZvdQjyb | ||||||
| # r8duvHdQJ9Li2Pq9guySb9mvUL60ogslCO9gkh6FiEDwMrwUr8Wja6jFpUTny8tg | # A4qejOe9Y073JlXv3VIbdkQH2JGyT8oB/LsvPL/kAnJ45oQIp7Sx57RPQ/0O6qay | ||||||
| # 0N0cnCN2w4fKkp5qZcbUYFYicLSb/6A7pHCtX6xnjqwhmJoib3vkKJyVxbuFLRhV | # J2SJrwcjA8auMdAnZKOixFlzoooh7SyycI7BENHTpkVKrRV5YelRvWNTg1pH4EC2 | ||||||
| # XxH95b0LHeNhifn3jvo2j+/4QV10jEpXVW+iC9BsTtR69xvTjU51ZgP7BR4YDEWq | # KO2bxsBN23btMeTvZFieGIr+D8mf1lQQs0Ht/tMOVdah14t7Yk+xl5P4Tw3xfAGg | ||||||
| # 7JsylSOv5B5THTDXRf184URzFhTyb8OZQKY7mqMh7c8J8w1sEM4XDUF2UZNy829N | # Hsvsa6ugrxwmKTTX1kqXH5XCdw3TVeKCax6JV+ygM5i1NroJKwBCW11Pwi0z/ki9 | ||||||
| # VCzG2tfdEXZaHxF8RmxpQYBxyhZwY1rotuIS+gfN2eq+hkAT3ipGn8/KmDwDtzAb | # 0ZeO6XfEE9mCnJm76Qcxi3tnW/Y/3ZumKQ6X/iVIJo7Lk0Z/pATRwAINqwdvzpdt | ||||||
| # nfuXjApgeZqwgcYJ8pDJ+y/xU6ouzJz1Bve5TTihkiA7wQsQe6R60Zk9dPdNzw0M | # X2hOJib4GR8is2bpKks04GurfweWPn9z6jY7GBC+js8pSwGewrffwgAbNKm82ZDF | ||||||
| # K5niRzuQZAt4GI96FhjhlUWcUZOCkv/JXM/OGu/rgSplYwdmPLzzfDtXyuy/GCU5 | # vqBGQQVJwIHSXpjkS+G39eyYOG2rcILBIDlzUzMFFJbNh5tDv3GeJ3EKvC4vNSAx | ||||||
| # I4l08g6iifXypMgoYkkceOAAz4vx1x0BOnZWfI3fSwqNUvoN7ncTT+MB4Vpvf1QB | # tGfaG/mQhK43YjevsB72LouU78rxtNhuMXSzaHq5fFiG3zcsYHaa4+w+YmMrhTEz | ||||||
| # ppjBAQUuvui6eCG0MCVNAgMBAAGjggFJMIIBRTAdBgNVHQ4EFgQUmfIngFzZEZlP | # D4SAish35BjoXP1P1Ct4Va0CAwEAAaOCAUkwggFFMB0GA1UdDgQWBBRjjHKbL5WV | ||||||
| # kjDOVluBSDDaanEwHwYDVR0jBBgwFoAUn6cVXQBeYl2D9OXSZacbUzUZ6XIwXwYD | # 6kd06KocQHphK9U/vzAfBgNVHSMEGDAWgBSfpxVdAF5iXYP05dJlpxtTNRnpcjBf | ||||||
| # VR0fBFgwVjBUoFKgUIZOaHR0cDovL3d3dy5taWNyb3NvZnQuY29tL3BraW9wcy9j | # BgNVHR8EWDBWMFSgUqBQhk5odHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3Bz | ||||||
| # cmwvTWljcm9zb2Z0JTIwVGltZS1TdGFtcCUyMFBDQSUyMDIwMTAoMSkuY3JsMGwG | # L2NybC9NaWNyb3NvZnQlMjBUaW1lLVN0YW1wJTIwUENBJTIwMjAxMCgxKS5jcmww | ||||||
| # CCsGAQUFBwEBBGAwXjBcBggrBgEFBQcwAoZQaHR0cDovL3d3dy5taWNyb3NvZnQu | # bAYIKwYBBQUHAQEEYDBeMFwGCCsGAQUFBzAChlBodHRwOi8vd3d3Lm1pY3Jvc29m | ||||||
| # Y29tL3BraW9wcy9jZXJ0cy9NaWNyb3NvZnQlMjBUaW1lLVN0YW1wJTIwUENBJTIw | # dC5jb20vcGtpb3BzL2NlcnRzL01pY3Jvc29mdCUyMFRpbWUtU3RhbXAlMjBQQ0El | ||||||
| # MjAxMCgxKS5jcnQwDAYDVR0TAQH/BAIwADAWBgNVHSUBAf8EDDAKBggrBgEFBQcD | # MjAyMDEwKDEpLmNydDAMBgNVHRMBAf8EAjAAMBYGA1UdJQEB/wQMMAoGCCsGAQUF | ||||||
| # CDAOBgNVHQ8BAf8EBAMCB4AwDQYJKoZIhvcNAQELBQADggIBANxHtu3FzIabaDbW | # BwMIMA4GA1UdDwEB/wQEAwIHgDANBgkqhkiG9w0BAQsFAAOCAgEAuFbCorFrvodG | ||||||
| # qswdKBlAhKXRCN+5CSMiv2TYa4i2QuWIm+99piwAhDhADfbqor1zyLi95Y6GQnvI | # +ZNJH3Y+Nz5QpUytQVObOyYFrgcGrxq6MUa4yLmxN4xWdL1kygaW5BOZ3xBlPY7V | ||||||
| # WUgdeC7oL1ZtZye92zYK+EIfwYZmhS+CH4infAzUvscHZF3wlrJUfPUIDGVP0lCY | # puf5b5eaXP7qRq61xeOrX3f64kGiSWoRi9EJawJWCzJfUQRThDL4zxI2pYc1wnPp | ||||||
| # Vse9mguvG0dqkY4ayQPEHOvJubgZZaOdg/N8dInd6fGeOc+0DoGzB+LieObJ2Q0A | # 7Q695bHqwZ02eaOBudh/IfEkGe0Ofj6IS3oyZsJP1yatcm4kBqIH6db1+weM4q46 | ||||||
| # tEt3XN3iX8Cp6+dZTX8xwE/LvhRwPpb/+nKshO7TVuvenwdTwqB/LT6CNPaElwFe | # NhAfAf070zF6F+IpUHyhtMbQg5+QHfOuyBzrt67CiMJSKcJ3nMVyfNlnv6yvttYz | ||||||
| # KxKrqRTPMbHeg+i+KnBLfwmhEXsMg2s1QX7JIxfvT96md0eiMjiMEO22LbOzmLMN | # LK3wS+0QwJUibLYJMI6FGcSuRxKlq6RjOhK9L3QOjh0VCM11rHM11ZmN0euJbbBC | ||||||
| # d3LINowAnRBAJtX+3/e390B9sMGMHp+a1V+hgs62AopBl0p/00li30DN5wEQ5If3 | # VfQEufOLNkG88MFCUNE10SSbM/Og/CbTko0M5wbVvQJ6CqLKjtHSoeoAGPeeX24f | ||||||
| # 5Zk7b/T6pEx6rJUDYCti7zCbikjKTanBnOc99zGMlej5X+fC/k5ExUCrOs3/VzGR | # 5cPYyTcKlbM6LoUdO2P5JSdI5s1JF/On6LiUT50adpRstZajbYEeX/N7RvSbkn0d | ||||||
| # CZt5LvVQSdWqq/QMzTEmim4sbzASK9imEkjNtZZyvC1CsUcD1voFktld4mKMjE+u | # jD3BvT2Of3Wf9gIeaQIHbv1J2O/P5QOPQiVo8+0AKm6M0TKOduihhKxAt/6Yyk17 | ||||||
| # DEV3IddD+DrRk94nVzNPSuZXewfVOnXHSeqG7xM3V7fl2aL4v1OhL2+JwO1Tx3B0 | # Fv3RIdjT6wiL2qRIEsgOJp3fILw4mQRPu3spRfakSoQe5N0e4HWFf8WW2ZL0+c83 | ||||||
| # irO1O9qbNdJk355bntd1RSVKgM22KFBHnoL7Js7pRhBiaKmVTQGoOb+j1Qa7q+ci | # Qzh3VtEPI6Y2e2BO/eWhTYbIbHpqYDfAtAYtaYIde87ZymXG3MO2wUjhL9HvSQzj | ||||||
| # xGo48Vh9k35BDsJS/DLoXFSPDl4mMIIHcTCCBVmgAwIBAgITMwAAABXF52ueAptJ | # oquq+OoUmvfBUcB2e5L6QCHO6qTO7WowggdxMIIFWaADAgECAhMzAAAAFcXna54C | ||||||
| # mQAAAAAAFTANBgkqhkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgT | # m0mZAAAAAAAVMA0GCSqGSIb3DQEBCwUAMIGIMQswCQYDVQQGEwJVUzETMBEGA1UE | ||||||
|  | # CBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9z | ||||||
|  | # b2Z0IENvcnBvcmF0aW9uMTIwMAYDVQQDEylNaWNyb3NvZnQgUm9vdCBDZXJ0aWZp | ||||||
|  | # Y2F0ZSBBdXRob3JpdHkgMjAxMDAeFw0yMTA5MzAxODIyMjVaFw0zMDA5MzAxODMy | ||||||
|  | # MjVaMHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQH | ||||||
|  | # EwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xJjAkBgNV | ||||||
|  | # BAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwMIICIjANBgkqhkiG9w0B | ||||||
|  | # AQEFAAOCAg8AMIICCgKCAgEA5OGmTOe0ciELeaLL1yR5vQ7VgtP97pwHB9KpbE51 | ||||||
|  | # yMo1V/YBf2xK4OK9uT4XYDP/XE/HZveVU3Fa4n5KWv64NmeFRiMMtY0Tz3cywBAY | ||||||
|  | # 6GB9alKDRLemjkZrBxTzxXb1hlDcwUTIcVxRMTegCjhuje3XD9gmU3w5YQJ6xKr9 | ||||||
|  | # cmmvHaus9ja+NSZk2pg7uhp7M62AW36MEBydUv626GIl3GoPz130/o5Tz9bshVZN | ||||||
|  | # 7928jaTjkY+yOSxRnOlwaQ3KNi1wjjHINSi947SHJMPgyY9+tVSP3PoFVZhtaDua | ||||||
|  | # Rr3tpK56KTesy+uDRedGbsoy1cCGMFxPLOJiss254o2I5JasAUq7vnGpF1tnYN74 | ||||||
|  | # kpEeHT39IM9zfUGaRnXNxF803RKJ1v2lIH1+/NmeRd+2ci/bfV+AutuqfjbsNkz2 | ||||||
|  | # K26oElHovwUDo9Fzpk03dJQcNIIP8BDyt0cY7afomXw/TNuvXsLz1dhzPUNOwTM5 | ||||||
|  | # TI4CvEJoLhDqhFFG4tG9ahhaYQFzymeiXtcodgLiMxhy16cg8ML6EgrXY28MyTZk | ||||||
|  | # i1ugpoMhXV8wdJGUlNi5UPkLiWHzNgY1GIRH29wb0f2y1BzFa/ZcUlFdEtsluq9Q | ||||||
|  | # BXpsxREdcu+N+VLEhReTwDwV2xo3xwgVGD94q0W29R6HXtqPnhZyacaue7e3Pmri | ||||||
|  | # Lq0CAwEAAaOCAd0wggHZMBIGCSsGAQQBgjcVAQQFAgMBAAEwIwYJKwYBBAGCNxUC | ||||||
|  | # BBYEFCqnUv5kxJq+gpE8RjUpzxD/LwTuMB0GA1UdDgQWBBSfpxVdAF5iXYP05dJl | ||||||
|  | # pxtTNRnpcjBcBgNVHSAEVTBTMFEGDCsGAQQBgjdMg30BATBBMD8GCCsGAQUFBwIB | ||||||
|  | # FjNodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3BzL0RvY3MvUmVwb3NpdG9y | ||||||
|  | # eS5odG0wEwYDVR0lBAwwCgYIKwYBBQUHAwgwGQYJKwYBBAGCNxQCBAweCgBTAHUA | ||||||
|  | # YgBDAEEwCwYDVR0PBAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAU | ||||||
|  | # 1fZWy4/oolxiaNE9lJBb186aGMQwVgYDVR0fBE8wTTBLoEmgR4ZFaHR0cDovL2Ny | ||||||
|  | # bC5taWNyb3NvZnQuY29tL3BraS9jcmwvcHJvZHVjdHMvTWljUm9vQ2VyQXV0XzIw | ||||||
|  | # MTAtMDYtMjMuY3JsMFoGCCsGAQUFBwEBBE4wTDBKBggrBgEFBQcwAoY+aHR0cDov | ||||||
|  | # L3d3dy5taWNyb3NvZnQuY29tL3BraS9jZXJ0cy9NaWNSb29DZXJBdXRfMjAxMC0w | ||||||
|  | # Ni0yMy5jcnQwDQYJKoZIhvcNAQELBQADggIBAJ1VffwqreEsH2cBMSRb4Z5yS/yp | ||||||
|  | # b+pcFLY+TkdkeLEGk5c9MTO1OdfCcTY/2mRsfNB1OW27DzHkwo/7bNGhlBgi7ulm | ||||||
|  | # ZzpTTd2YurYeeNg2LpypglYAA7AFvonoaeC6Ce5732pvvinLbtg/SHUB2RjebYIM | ||||||
|  | # 9W0jVOR4U3UkV7ndn/OOPcbzaN9l9qRWqveVtihVJ9AkvUCgvxm2EhIRXT0n4ECW | ||||||
|  | # OKz3+SmJw7wXsFSFQrP8DJ6LGYnn8AtqgcKBGUIZUnWKNsIdw2FzLixre24/LAl4 | ||||||
|  | # FOmRsqlb30mjdAy87JGA0j3mSj5mO0+7hvoyGtmW9I/2kQH2zsZ0/fZMcm8Qq3Uw | ||||||
|  | # xTSwethQ/gpY3UA8x1RtnWN0SCyxTkctwRQEcb9k+SS+c23Kjgm9swFXSVRk2XPX | ||||||
|  | # fx5bRAGOWhmRaw2fpCjcZxkoJLo4S5pu+yFUa2pFEUep8beuyOiJXk+d0tBMdrVX | ||||||
|  | # VAmxaQFEfnyhYWxz/gq77EFmPWn9y8FBSX5+k77L+DvktxW/tM4+pTFRhLy/AsGC | ||||||
|  | # onsXHRWJjXD+57XQKBqJC4822rpM+Zv/Cuk0+CQ1ZyvgDbjmjJnW4SLq8CdCPSWU | ||||||
|  | # 5nR0W2rRnj7tfqAxM328y+l7vzhwRNGQ8cirOoo6CGJ/2XBjU02N7oJtpQUQwXEG | ||||||
|  | # ahC0HVUzWLOhcGbyoYIDWTCCAkECAQEwggEBoYHZpIHWMIHTMQswCQYDVQQGEwJV | ||||||
|  | # UzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UE | ||||||
|  | # ChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMS0wKwYDVQQLEyRNaWNyb3NvZnQgSXJl | ||||||
|  | # bGFuZCBPcGVyYXRpb25zIExpbWl0ZWQxJzAlBgNVBAsTHm5TaGllbGQgVFNTIEVT | ||||||
|  | # Tjo0MzFBLTA1RTAtRDk0NzElMCMGA1UEAxMcTWljcm9zb2Z0IFRpbWUtU3RhbXAg | ||||||
|  | # U2VydmljZaIjCgEBMAcGBSsOAwIaAxUA94Z+bUJn+nKwBvII6sg0Ny7aPDaggYMw | ||||||
|  | # gYCkfjB8MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UE | ||||||
|  | # BxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSYwJAYD | ||||||
|  | # VQQDEx1NaWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAxMDANBgkqhkiG9w0BAQsF | ||||||
|  | # AAIFAOss/ykwIhgPMjAyNTAxMTExNDMxMDVaGA8yMDI1MDExMjE0MzEwNVowdzA9 | ||||||
|  | # BgorBgEEAYRZCgQBMS8wLTAKAgUA6yz/KQIBADAKAgEAAgIpggIB/zAHAgEAAgIT | ||||||
|  | # XjAKAgUA6y5QqQIBADA2BgorBgEEAYRZCgQCMSgwJjAMBgorBgEEAYRZCgMCoAow | ||||||
|  | # CAIBAAIDB6EgoQowCAIBAAIDAYagMA0GCSqGSIb3DQEBCwUAA4IBAQCHE6DSGdY4 | ||||||
|  | # KF25iAsxQP9F9Lz6ye/vrWGv+j0aSzSbjHVM3kMcEmX9278XgAKgAYII/f16uDtE | ||||||
|  | # 7VlEwnKGXujGF249I864U50QFt9hIxqCeuvrshDq8a4Q4KVmuDTosYjS114IJeBK | ||||||
|  | # LMOBRgLQCIC+wmvdP4EeYH1tnMIEASFvptE+XBro44/A5pmx5UiDJRL1AG4+aO3x | ||||||
|  | # 13psQu7H3thmbGy7Sf0Azjx0PZ+1QUVI7jWNk9DWjGd18G4SQD8Uxeh0v73/dQx1 | ||||||
|  | # XsFhsyvnrw6uUrxkoAdurif9kyKS+ppo4j9ZkPXzzuc95s1bPcPAyjXCu07Tlunj | ||||||
|  | # sXttGVEPQIeXMYIEDTCCBAkCAQEwgZMwfDELMAkGA1UEBhMCVVMxEzARBgNVBAgT | ||||||
| # Cldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29m | # Cldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29m | ||||||
| # dCBDb3Jwb3JhdGlvbjEyMDAGA1UEAxMpTWljcm9zb2Z0IFJvb3QgQ2VydGlmaWNh | # dCBDb3Jwb3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUtU3RhbXAgUENB | ||||||
| # dGUgQXV0aG9yaXR5IDIwMTAwHhcNMjEwOTMwMTgyMjI1WhcNMzAwOTMwMTgzMjI1 | # IDIwMTACEzMAAAH6+ztE03czxtMAAQAAAfowDQYJYIZIAWUDBAIBBQCgggFKMBoG | ||||||
| # WjB8MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMH | # CSqGSIb3DQEJAzENBgsqhkiG9w0BCRABBDAvBgkqhkiG9w0BCQQxIgQgxenDb/df | ||||||
| # UmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSYwJAYDVQQD | # q8XJS+q7Oxyca1ryDMmDRA0I3mtr+xYHGZQwgfoGCyqGSIb3DQEJEAIvMYHqMIHn | ||||||
| # Ex1NaWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAxMDCCAiIwDQYJKoZIhvcNAQEB | # MIHkMIG9BCB98n8tya8+B2jjU/dpJRIwHwHHpco5ogNStYocbkOeVjCBmDCBgKR+ | ||||||
| # BQADggIPADCCAgoCggIBAOThpkzntHIhC3miy9ckeb0O1YLT/e6cBwfSqWxOdcjK | # MHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdS | ||||||
| # NVf2AX9sSuDivbk+F2Az/1xPx2b3lVNxWuJ+Slr+uDZnhUYjDLWNE893MsAQGOhg | # ZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xJjAkBgNVBAMT | ||||||
| # fWpSg0S3po5GawcU88V29YZQ3MFEyHFcUTE3oAo4bo3t1w/YJlN8OWECesSq/XJp | # HU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwAhMzAAAB+vs7RNN3M8bTAAEA | ||||||
| # rx2rrPY2vjUmZNqYO7oaezOtgFt+jBAcnVL+tuhiJdxqD89d9P6OU8/W7IVWTe/d | # AAH6MCIEIC8gtQ6HRW7jzwlpg15qoYopXwF01KaO1EM5tYzqJwx/MA0GCSqGSIb3 | ||||||
| # vI2k45GPsjksUZzpcGkNyjYtcI4xyDUoveO0hyTD4MmPfrVUj9z6BVWYbWg7mka9 | # DQEBCwUABIICAIsSn8x3zVS870Zf4pa+jfZjdOq++5dHpeLg46sujQ3w+xj3RyhB | ||||||
| # 7aSueik3rMvrg0XnRm7KMtXAhjBcTyziYrLNueKNiOSWrAFKu75xqRdbZ2De+JKR | # nRa3kjWyU9nNF6hrt0Q+ILOxUt3jCd3hbB1ZuspwbXdoRtRLfuLPvGiSmINdgFR4 | ||||||
| # Hh09/SDPc31BmkZ1zcRfNN0Sidb9pSB9fvzZnkXftnIv231fgLrbqn427DZM9itu | # LD/jXLrq9USAHYXHzhuYhaVLIpn7M87TbFuGFVaByjmohZRcPCE8y8b7/RIlGm7B | ||||||
| # qBJR6L8FA6PRc6ZNN3SUHDSCD/AQ8rdHGO2n6Jl8P0zbr17C89XYcz1DTsEzOUyO | # wgx0thZA4lHWFyj8j7CwjmueOJSSZ9an4P9VHFKJ63kYub4J1VxbeApGAeeS32SD | ||||||
| # ArxCaC4Q6oRRRuLRvWoYWmEBc8pnol7XKHYC4jMYctenIPDC+hIK12NvDMk2ZItb | # oI3zDdC+iI+IetR9BUHGcR3Vg7j7c0T+NcrIoPPNb4Ff90Ue24h5RDJMQWrM56ak | ||||||
| # oKaDIV1fMHSRlJTYuVD5C4lh8zYGNRiER9vcG9H9stQcxWv2XFJRXRLbJbqvUAV6 | # VEWgVlzhf8CeyeO7/ButBUZu8VLkH0DQraK9UKptZFKOXMELoi/oZL6IJftHp5vU | ||||||
| # bMURHXLvjflSxIUXk8A8FdsaN8cIFRg/eKtFtvUeh17aj54WcmnGrnu3tz5q4i6t | # +sPpF3NuuXw8Z5eL9jZ7A1y+H7nMhdXP2pojHDN213VZqeoUoOZlbFl6spDF1hFP | ||||||
| # AgMBAAGjggHdMIIB2TASBgkrBgEEAYI3FQEEBQIDAQABMCMGCSsGAQQBgjcVAgQW | # 44Fu7TPGEwUNS213Pwln2SJ8SayeVUxsreo4pTvhDl/xZ+B7WNuLL7hatWFGrcf3 | ||||||
| # BBQqp1L+ZMSavoKRPEY1Kc8Q/y8E7jAdBgNVHQ4EFgQUn6cVXQBeYl2D9OXSZacb | # w/HiVCoTfsY49SaN6zAK6akS3KI6KZHfzjaxDw+4LHo8gL68Ik1HZe4W1jaLYaED | ||||||
| # UzUZ6XIwXAYDVR0gBFUwUzBRBgwrBgEEAYI3TIN9AQEwQTA/BggrBgEFBQcCARYz | # LWvKIinaH2vwU0J4a+oX+64eSh0tI9Ef3aM6jn9LgqubY36TzptUTWcsM3vv3YGB | ||||||
| # aHR0cDovL3d3dy5taWNyb3NvZnQuY29tL3BraW9wcy9Eb2NzL1JlcG9zaXRvcnku | # Dnf7LPxSt4/s5bUgAHvkWTjESdtIbt6Pxqz4BRha+ckPYBj968t3mSh6 | ||||||
| # aHRtMBMGA1UdJQQMMAoGCCsGAQUFBwMIMBkGCSsGAQQBgjcUAgQMHgoAUwB1AGIA |  | ||||||
| # QwBBMAsGA1UdDwQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNX2 |  | ||||||
| # VsuP6KJcYmjRPZSQW9fOmhjEMFYGA1UdHwRPME0wS6BJoEeGRWh0dHA6Ly9jcmwu |  | ||||||
| # bWljcm9zb2Z0LmNvbS9wa2kvY3JsL3Byb2R1Y3RzL01pY1Jvb0NlckF1dF8yMDEw |  | ||||||
| # LTA2LTIzLmNybDBaBggrBgEFBQcBAQROMEwwSgYIKwYBBQUHMAKGPmh0dHA6Ly93 |  | ||||||
| # d3cubWljcm9zb2Z0LmNvbS9wa2kvY2VydHMvTWljUm9vQ2VyQXV0XzIwMTAtMDYt |  | ||||||
| # MjMuY3J0MA0GCSqGSIb3DQEBCwUAA4ICAQCdVX38Kq3hLB9nATEkW+Geckv8qW/q |  | ||||||
| # XBS2Pk5HZHixBpOXPTEztTnXwnE2P9pkbHzQdTltuw8x5MKP+2zRoZQYIu7pZmc6 |  | ||||||
| # U03dmLq2HnjYNi6cqYJWAAOwBb6J6Gngugnue99qb74py27YP0h1AdkY3m2CDPVt |  | ||||||
| # I1TkeFN1JFe53Z/zjj3G82jfZfakVqr3lbYoVSfQJL1AoL8ZthISEV09J+BAljis |  | ||||||
| # 9/kpicO8F7BUhUKz/AyeixmJ5/ALaoHCgRlCGVJ1ijbCHcNhcy4sa3tuPywJeBTp |  | ||||||
| # kbKpW99Jo3QMvOyRgNI95ko+ZjtPu4b6MhrZlvSP9pEB9s7GdP32THJvEKt1MMU0 |  | ||||||
| # sHrYUP4KWN1APMdUbZ1jdEgssU5HLcEUBHG/ZPkkvnNtyo4JvbMBV0lUZNlz138e |  | ||||||
| # W0QBjloZkWsNn6Qo3GcZKCS6OEuabvshVGtqRRFHqfG3rsjoiV5PndLQTHa1V1QJ |  | ||||||
| # sWkBRH58oWFsc/4Ku+xBZj1p/cvBQUl+fpO+y/g75LcVv7TOPqUxUYS8vwLBgqJ7 |  | ||||||
| # Fx0ViY1w/ue10CgaiQuPNtq6TPmb/wrpNPgkNWcr4A245oyZ1uEi6vAnQj0llOZ0 |  | ||||||
| # dFtq0Z4+7X6gMTN9vMvpe784cETRkPHIqzqKOghif9lwY1NNje6CbaUFEMFxBmoQ |  | ||||||
| # tB1VM1izoXBm8qGCAtQwggI9AgEBMIIBAKGB2KSB1TCB0jELMAkGA1UEBhMCVVMx |  | ||||||
| # EzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoT |  | ||||||
| # FU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEtMCsGA1UECxMkTWljcm9zb2Z0IElyZWxh |  | ||||||
| # bmQgT3BlcmF0aW9ucyBMaW1pdGVkMSYwJAYDVQQLEx1UaGFsZXMgVFNTIEVTTjow |  | ||||||
| # ODQyLTRCRTYtQzI5QTElMCMGA1UEAxMcTWljcm9zb2Z0IFRpbWUtU3RhbXAgU2Vy |  | ||||||
| # dmljZaIjCgEBMAcGBSsOAwIaAxUAjhJ+EeySRfn2KCNsjn9cF9AUSTqggYMwgYCk |  | ||||||
| # fjB8MQswCQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMH |  | ||||||
| # UmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSYwJAYDVQQD |  | ||||||
| # Ex1NaWNyb3NvZnQgVGltZS1TdGFtcCBQQ0EgMjAxMDANBgkqhkiG9w0BAQUFAAIF |  | ||||||
| # AOfRUdUwIhgPMjAyMzAzMzEyMDM0MjlaGA8yMDIzMDQwMTIwMzQyOVowdDA6Bgor |  | ||||||
| # BgEEAYRZCgQBMSwwKjAKAgUA59FR1QIBADAHAgEAAgIKJDAHAgEAAgIRLzAKAgUA |  | ||||||
| # 59KjVQIBADA2BgorBgEEAYRZCgQCMSgwJjAMBgorBgEEAYRZCgMCoAowCAIBAAID |  | ||||||
| # B6EgoQowCAIBAAIDAYagMA0GCSqGSIb3DQEBBQUAA4GBAJlOESCa/uRR1x6GunE8 |  | ||||||
| # K/WgHWTpSE31EITDOfTMvDcF4ptngCS5aOc4gfzmhNNehWfP6EOrgoSQzJYZ4YCh |  | ||||||
| # fYbHNMk56f18sq8t7y2hgR7KixcEo/4HVzeSdaOclHNc4Gn7kCGpMvpT3Xz9Lzc7 |  | ||||||
| # UKWDZ0zkNKnbS8TZLNueVQwfMYIEDTCCBAkCAQEwgZMwfDELMAkGA1UEBhMCVVMx |  | ||||||
| # EzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoT |  | ||||||
| # FU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUt |  | ||||||
| # U3RhbXAgUENBIDIwMTACEzMAAAGybkADf26plJIAAQAAAbIwDQYJYIZIAWUDBAIB |  | ||||||
| # BQCgggFKMBoGCSqGSIb3DQEJAzENBgsqhkiG9w0BCRABBDAvBgkqhkiG9w0BCQQx |  | ||||||
| # IgQgXhJRuHCXk3arJvifIY3DBe9Ce9EmlP1y6U4XkgL31DkwgfoGCyqGSIb3DQEJ |  | ||||||
| # EAIvMYHqMIHnMIHkMIG9BCBTeM485+E+t4PEVieUoFKX7PVyLo/nzu+htJPCG04+ |  | ||||||
| # NTCBmDCBgKR+MHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAw |  | ||||||
| # DgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24x |  | ||||||
| # JjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwAhMzAAABsm5A |  | ||||||
| # A39uqZSSAAEAAAGyMCIEIGGWlnNnYHrB5HguWG0/nJd/WvSrCogze+QCpenu3IM5 |  | ||||||
| # MA0GCSqGSIb3DQEBCwUABIICADVOLTuNxeEnBOfZpb7Nv4uf91W/Ho5i99zenDSJ |  | ||||||
| # x5QHVs+bKXmgc3a7/SSsliAT3zygHc7cH4zARbCZePLTivByKmeG08Ka35eyR+FK |  | ||||||
| # awSNrI/X+eVIC6nw/egCwviBC1NAG8jHGkuScbHeiiGajvS6lp3ORML7UexMuE4w |  | ||||||
| # 9SEumoghljCLZMwCSvw+3WxhQoBEZroR8u+PID2RdD0vi85FjKPWcZZijVLqHeFi |  | ||||||
| # TnuFqwRCLTV0MV+dDCbjwXneIqV+AVlnqb9iDMr3ZhISlRcy9XJNpY5vQBj/wqUW |  | ||||||
| # vefrmpdz0LNkdtXYThPkyl3mha2KsoQi5SA9zSjlAjFgY3ppmXvi3Frbfqk+iL+f |  | ||||||
| # l/Qc4+B71jG4t28lTWKteJiHqo+6AUXK2rlAl0d74yvhO6N8lMMtXhdJc8JABYn1 |  | ||||||
| # v2/KKZn5RvPFF8QP7Ac1saIe1+gUFNcsYOLaMm/xl8E6kefWwZnm5Rhm606g1AC/ |  | ||||||
| # N5Wo08aAs0ymTPH91dEbmOURXLbA3vCyG7kbfgnhCs/j7oQHWaFDzEYuXDIA4ICT |  | ||||||
| # dxPUTltbq3OWdp0PAS8JSEKPQFaOoQEnPa4adrXWxMvOmel8IGqJiQ+BPOaLQG64 |  | ||||||
| # Qu2tMkH/5szb1fsEnCe8SJmy5ESF+kmpnLBtJ17Y9o+9nJHF5ddFmvzy+LUaIqDN |  | ||||||
| # cOfH |  | ||||||
| # SIG # End signature block | # SIG # End signature block | ||||||
							
								
								
									
										288
									
								
								externals/install-dotnet.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										288
									
								
								externals/install-dotnet.sh
									
									
									
									
										vendored
									
									
								
							| @ -298,11 +298,20 @@ get_machine_architecture() { | |||||||
|     if command -v uname > /dev/null; then |     if command -v uname > /dev/null; then | ||||||
|         CPUName=$(uname -m) |         CPUName=$(uname -m) | ||||||
|         case $CPUName in |         case $CPUName in | ||||||
|  |         armv1*|armv2*|armv3*|armv4*|armv5*|armv6*) | ||||||
|  |             echo "armv6-or-below" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|         armv*l) |         armv*l) | ||||||
|             echo "arm" |             echo "arm" | ||||||
|             return 0 |             return 0 | ||||||
|             ;; |             ;; | ||||||
|         aarch64|arm64) |         aarch64|arm64) | ||||||
|  |             if [ "$(getconf LONG_BIT)" -lt 64 ]; then | ||||||
|  |                 # This is 32-bit OS running on 64-bit CPU (for example Raspberry Pi OS) | ||||||
|  |                 echo "arm" | ||||||
|  |                 return 0 | ||||||
|  |             fi | ||||||
|             echo "arm64" |             echo "arm64" | ||||||
|             return 0 |             return 0 | ||||||
|             ;; |             ;; | ||||||
| @ -310,6 +319,22 @@ get_machine_architecture() { | |||||||
|             echo "s390x" |             echo "s390x" | ||||||
|             return 0 |             return 0 | ||||||
|             ;; |             ;; | ||||||
|  |         ppc64le) | ||||||
|  |             echo "ppc64le" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|  |         loongarch64) | ||||||
|  |             echo "loongarch64" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|  |         riscv64) | ||||||
|  |             echo "riscv64" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|  |         powerpc|ppc) | ||||||
|  |             echo "ppc" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|         esac |         esac | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @ -326,7 +351,13 @@ get_normalized_architecture_from_architecture() { | |||||||
|     local architecture="$(to_lowercase "$1")" |     local architecture="$(to_lowercase "$1")" | ||||||
|  |  | ||||||
|     if [[ $architecture == \<auto\> ]]; then |     if [[ $architecture == \<auto\> ]]; then | ||||||
|         echo "$(get_machine_architecture)" |         machine_architecture="$(get_machine_architecture)" | ||||||
|  |         if [[ "$machine_architecture" == "armv6-or-below" ]]; then | ||||||
|  |             say_err "Architecture \`$machine_architecture\` not supported. If you think this is a bug, report it at https://github.com/dotnet/install-scripts/issues" | ||||||
|  |             return 1 | ||||||
|  |         fi | ||||||
|  |  | ||||||
|  |         echo $machine_architecture | ||||||
|         return 0 |         return 0 | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @ -347,6 +378,14 @@ get_normalized_architecture_from_architecture() { | |||||||
|             echo "s390x" |             echo "s390x" | ||||||
|             return 0 |             return 0 | ||||||
|             ;; |             ;; | ||||||
|  |         ppc64le) | ||||||
|  |             echo "ppc64le" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|  |         loongarch64) | ||||||
|  |             echo "loongarch64" | ||||||
|  |             return 0 | ||||||
|  |             ;; | ||||||
|     esac |     esac | ||||||
|  |  | ||||||
|     say_err "Architecture \`$architecture\` not supported. If you think this is a bug, report it at https://github.com/dotnet/install-scripts/issues" |     say_err "Architecture \`$architecture\` not supported. If you think this is a bug, report it at https://github.com/dotnet/install-scripts/issues" | ||||||
| @ -384,11 +423,17 @@ get_normalized_architecture_for_specific_sdk_version() { | |||||||
| # args: | # args: | ||||||
| # version or channel - $1 | # version or channel - $1 | ||||||
| is_arm64_supported() { | is_arm64_supported() { | ||||||
|     #any channel or version that starts with the specified versions |     # Extract the major version by splitting on the dot | ||||||
|     case "$1" in |     major_version="${1%%.*}" | ||||||
|         ( "1"* | "2"* | "3"*  | "4"* | "5"*)  |  | ||||||
|  |     # Check if the major version is a valid number and less than 6 | ||||||
|  |     case "$major_version" in | ||||||
|  |         [0-9]*)   | ||||||
|  |             if [ "$major_version" -lt 6 ]; then | ||||||
|                 echo false |                 echo false | ||||||
|                 return 0 |                 return 0 | ||||||
|  |             fi | ||||||
|  |             ;; | ||||||
|     esac |     esac | ||||||
|  |  | ||||||
|     echo true |     echo true | ||||||
| @ -407,8 +452,13 @@ get_normalized_os() { | |||||||
|                 echo "$osname" |                 echo "$osname" | ||||||
|                 return 0 |                 return 0 | ||||||
|                 ;; |                 ;; | ||||||
|  |             macos) | ||||||
|  |                 osname='osx' | ||||||
|  |                 echo "$osname" | ||||||
|  |                 return 0 | ||||||
|  |                 ;; | ||||||
|             *) |             *) | ||||||
|                 say_err "'$user_defined_os' is not a supported value for --os option, supported values are: osx, linux, linux-musl, freebsd, rhel.6. If you think this is a bug, report it at https://github.com/dotnet/install-scripts/issues." |                 say_err "'$user_defined_os' is not a supported value for --os option, supported values are: osx, macos, linux, linux-musl, freebsd, rhel.6. If you think this is a bug, report it at https://github.com/dotnet/install-scripts/issues." | ||||||
|                 return 1 |                 return 1 | ||||||
|                 ;; |                 ;; | ||||||
|         esac |         esac | ||||||
| @ -538,6 +588,40 @@ is_dotnet_package_installed() { | |||||||
|     fi |     fi | ||||||
| } | } | ||||||
|  |  | ||||||
|  | # args: | ||||||
|  | # downloaded file - $1 | ||||||
|  | # remote_file_size - $2 | ||||||
|  | validate_remote_local_file_sizes()  | ||||||
|  | { | ||||||
|  |     eval $invocation | ||||||
|  |  | ||||||
|  |     local downloaded_file="$1" | ||||||
|  |     local remote_file_size="$2" | ||||||
|  |     local file_size='' | ||||||
|  |  | ||||||
|  |     if [[ "$OSTYPE" == "linux-gnu"* ]]; then | ||||||
|  |         file_size="$(stat -c '%s' "$downloaded_file")" | ||||||
|  |     elif [[ "$OSTYPE" == "darwin"* ]]; then | ||||||
|  |         # hardcode in order to avoid conflicts with GNU stat | ||||||
|  |         file_size="$(/usr/bin/stat -f '%z' "$downloaded_file")" | ||||||
|  |     fi   | ||||||
|  |      | ||||||
|  |     if [ -n "$file_size" ]; then | ||||||
|  |         say "Downloaded file size is $file_size bytes." | ||||||
|  |  | ||||||
|  |         if [ -n "$remote_file_size" ] && [ -n "$file_size" ]; then | ||||||
|  |             if [ "$remote_file_size" -ne "$file_size" ]; then | ||||||
|  |                 say "The remote and local file sizes are not equal. The remote file size is $remote_file_size bytes and the local size is $file_size bytes. The local package may be corrupted." | ||||||
|  |             else | ||||||
|  |                 say "The remote and local file sizes are equal." | ||||||
|  |             fi | ||||||
|  |         fi | ||||||
|  |          | ||||||
|  |     else | ||||||
|  |         say "Either downloaded or local package size can not be measured. One of them may be corrupted."       | ||||||
|  |     fi  | ||||||
|  | } | ||||||
|  |  | ||||||
| # args: | # args: | ||||||
| # azure_feed - $1 | # azure_feed - $1 | ||||||
| # channel - $2 | # channel - $2 | ||||||
| @ -872,6 +956,37 @@ get_absolute_path() { | |||||||
|     return 0 |     return 0 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | # args: | ||||||
|  | # override - $1 (boolean, true or false) | ||||||
|  | get_cp_options() { | ||||||
|  |     eval $invocation | ||||||
|  |  | ||||||
|  |     local override="$1" | ||||||
|  |     local override_switch="" | ||||||
|  |  | ||||||
|  |     if [ "$override" = false ]; then | ||||||
|  |         override_switch="-n" | ||||||
|  |  | ||||||
|  |         # create temporary files to check if 'cp -u' is supported | ||||||
|  |         tmp_dir="$(mktemp -d)" | ||||||
|  |         tmp_file="$tmp_dir/testfile" | ||||||
|  |         tmp_file2="$tmp_dir/testfile2" | ||||||
|  |  | ||||||
|  |         touch "$tmp_file" | ||||||
|  |  | ||||||
|  |         # use -u instead of -n if it's available | ||||||
|  |         if cp -u "$tmp_file" "$tmp_file2" 2>/dev/null; then | ||||||
|  |             override_switch="-u" | ||||||
|  |         fi | ||||||
|  |  | ||||||
|  |         # clean up | ||||||
|  |         rm -f "$tmp_file" "$tmp_file2" | ||||||
|  |         rm -rf "$tmp_dir" | ||||||
|  |     fi | ||||||
|  |  | ||||||
|  |     echo "$override_switch" | ||||||
|  | } | ||||||
|  |  | ||||||
| # args: | # args: | ||||||
| # input_files - stdin | # input_files - stdin | ||||||
| # root_path - $1 | # root_path - $1 | ||||||
| @ -883,15 +998,7 @@ copy_files_or_dirs_from_list() { | |||||||
|     local root_path="$(remove_trailing_slash "$1")" |     local root_path="$(remove_trailing_slash "$1")" | ||||||
|     local out_path="$(remove_trailing_slash "$2")" |     local out_path="$(remove_trailing_slash "$2")" | ||||||
|     local override="$3" |     local override="$3" | ||||||
|     local osname="$(get_current_os_name)" |     local override_switch="$(get_cp_options "$override")" | ||||||
|     local override_switch=$( |  | ||||||
|         if [ "$override" = false ]; then |  | ||||||
|             if [ "$osname" = "linux-musl" ]; then |  | ||||||
|                 printf -- "-u"; |  | ||||||
|             else |  | ||||||
|                 printf -- "-n"; |  | ||||||
|             fi |  | ||||||
|         fi) |  | ||||||
|  |  | ||||||
|     cat | uniq | while read -r file_path; do |     cat | uniq | while read -r file_path; do | ||||||
|         local path="$(remove_beginning_slash "${file_path#$root_path}")" |         local path="$(remove_beginning_slash "${file_path#$root_path}")" | ||||||
| @ -906,14 +1013,39 @@ copy_files_or_dirs_from_list() { | |||||||
|     done |     done | ||||||
| } | } | ||||||
|  |  | ||||||
|  | # args: | ||||||
|  | # zip_uri - $1 | ||||||
|  | get_remote_file_size() { | ||||||
|  |     local zip_uri="$1" | ||||||
|  |  | ||||||
|  |     if machine_has "curl"; then | ||||||
|  |         file_size=$(curl -sI  "$zip_uri" | grep -i content-length | awk '{ num = $2 + 0; print num }') | ||||||
|  |     elif machine_has "wget"; then | ||||||
|  |         file_size=$(wget --spider --server-response -O /dev/null "$zip_uri" 2>&1 | grep -i 'Content-Length:' | awk '{ num = $2 + 0; print num }') | ||||||
|  |     else | ||||||
|  |         say "Neither curl nor wget is available on this system." | ||||||
|  |         return | ||||||
|  |     fi | ||||||
|  |  | ||||||
|  |     if [ -n "$file_size" ]; then | ||||||
|  |         say "Remote file $zip_uri size is $file_size bytes." | ||||||
|  |         echo "$file_size" | ||||||
|  |     else | ||||||
|  |         say_verbose "Content-Length header was not extracted for $zip_uri." | ||||||
|  |         echo "" | ||||||
|  |     fi | ||||||
|  | } | ||||||
|  |  | ||||||
| # args: | # args: | ||||||
| # zip_path - $1 | # zip_path - $1 | ||||||
| # out_path - $2 | # out_path - $2 | ||||||
|  | # remote_file_size - $3 | ||||||
| extract_dotnet_package() { | extract_dotnet_package() { | ||||||
|     eval $invocation |     eval $invocation | ||||||
|  |  | ||||||
|     local zip_path="$1" |     local zip_path="$1" | ||||||
|     local out_path="$2" |     local out_path="$2" | ||||||
|  |     local remote_file_size="$3" | ||||||
|  |  | ||||||
|     local temp_out_path="$(mktemp -d "$temporary_file_template")" |     local temp_out_path="$(mktemp -d "$temporary_file_template")" | ||||||
|  |  | ||||||
| @ -924,8 +1056,12 @@ extract_dotnet_package() { | |||||||
|     find "$temp_out_path" -type f | grep -Eo "$folders_with_version_regex" | sort | copy_files_or_dirs_from_list "$temp_out_path" "$out_path" false |     find "$temp_out_path" -type f | grep -Eo "$folders_with_version_regex" | sort | copy_files_or_dirs_from_list "$temp_out_path" "$out_path" false | ||||||
|     find "$temp_out_path" -type f | grep -Ev "$folders_with_version_regex" | copy_files_or_dirs_from_list "$temp_out_path" "$out_path" "$override_non_versioned_files" |     find "$temp_out_path" -type f | grep -Ev "$folders_with_version_regex" | copy_files_or_dirs_from_list "$temp_out_path" "$out_path" "$override_non_versioned_files" | ||||||
|      |      | ||||||
|  |     validate_remote_local_file_sizes "$zip_path" "$remote_file_size" | ||||||
|  |      | ||||||
|     rm -rf "$temp_out_path" |     rm -rf "$temp_out_path" | ||||||
|     rm -f "$zip_path" && say_verbose "Temporary zip file $zip_path was removed" |     if [ -z ${keep_zip+x} ]; then | ||||||
|  |         rm -f "$zip_path" && say_verbose "Temporary archive file $zip_path was removed" | ||||||
|  |     fi | ||||||
|  |  | ||||||
|     if [ "$failed" = true ]; then |     if [ "$failed" = true ]; then | ||||||
|         say_err "Extraction failed" |         say_err "Extraction failed" | ||||||
| @ -1136,6 +1272,61 @@ downloadwget() { | |||||||
|     return 0 |     return 0 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | extract_stem() { | ||||||
|  |     local url="$1" | ||||||
|  |     # extract the protocol | ||||||
|  |     proto="$(echo $1 | grep :// | sed -e's,^\(.*://\).*,\1,g')" | ||||||
|  |     # remove the protocol | ||||||
|  |     url="${1/$proto/}" | ||||||
|  |     # extract the path (if any) - since we know all of our feeds have a first path segment, we can skip the first one. otherwise we'd use -f2- to get the full path | ||||||
|  |     full_path="$(echo $url | grep / | cut -d/ -f2-)" | ||||||
|  |     path="$(echo $full_path | cut -d/ -f2-)" | ||||||
|  |     echo $path | ||||||
|  | } | ||||||
|  |  | ||||||
|  | check_url_exists() { | ||||||
|  |     eval $invocation | ||||||
|  |     local url="$1" | ||||||
|  |  | ||||||
|  |     local code="" | ||||||
|  |     if machine_has "curl" | ||||||
|  |     then | ||||||
|  |         code=$(curl --head -o /dev/null -w "%{http_code}" -s --fail "$url"); | ||||||
|  |     elif machine_has "wget" | ||||||
|  |     then | ||||||
|  |         # get the http response, grab the status code | ||||||
|  |         server_response=$(wget -qO- --method=HEAD --server-response "$url" 2>&1) | ||||||
|  |         code=$(echo "$server_response" | grep "HTTP/" | awk '{print $2}') | ||||||
|  |     fi | ||||||
|  |     if [ $code = "200" ]; then | ||||||
|  |         return 0 | ||||||
|  |     else | ||||||
|  |         return 1 | ||||||
|  |     fi | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sanitize_redirect_url() { | ||||||
|  |     eval $invocation | ||||||
|  |  | ||||||
|  |     local url_stem | ||||||
|  |     url_stem=$(extract_stem "$1") | ||||||
|  |     say_verbose "Checking configured feeds for the asset at ${yellow:-}$url_stem${normal:-}" | ||||||
|  |  | ||||||
|  |     for feed in "${feeds[@]}" | ||||||
|  |     do | ||||||
|  |         local trial_url="$feed/$url_stem" | ||||||
|  |         say_verbose "Checking ${yellow:-}$trial_url${normal:-}" | ||||||
|  |         if check_url_exists "$trial_url"; then | ||||||
|  |             say_verbose "Found a match at ${yellow:-}$trial_url${normal:-}" | ||||||
|  |             echo "$trial_url" | ||||||
|  |             return 0 | ||||||
|  |         else | ||||||
|  |             say_verbose "No match at ${yellow:-}$trial_url${normal:-}" | ||||||
|  |         fi | ||||||
|  |     done | ||||||
|  |     return 1 | ||||||
|  | } | ||||||
|  |  | ||||||
| get_download_link_from_aka_ms() { | get_download_link_from_aka_ms() { | ||||||
|     eval $invocation |     eval $invocation | ||||||
|  |  | ||||||
| @ -1172,6 +1363,12 @@ get_download_link_from_aka_ms() { | |||||||
|     http_codes=$( echo "$response" | awk '$1 ~ /^HTTP/ {print $2}' ) |     http_codes=$( echo "$response" | awk '$1 ~ /^HTTP/ {print $2}' ) | ||||||
|     # They all need to be 301, otherwise some links are broken (except for the last, which is not a redirect but 200 or 404). |     # They all need to be 301, otherwise some links are broken (except for the last, which is not a redirect but 200 or 404). | ||||||
|     broken_redirects=$( echo "$http_codes" | sed '$d' | grep -v '301' ) |     broken_redirects=$( echo "$http_codes" | sed '$d' | grep -v '301' ) | ||||||
|  |     # The response may end without final code 2xx/4xx/5xx somehow, e.g. network restrictions on www.bing.com causes redirecting to bing.com fails with connection refused. | ||||||
|  |     # In this case it should not exclude the last. | ||||||
|  |     last_http_code=$(  echo "$http_codes" | tail -n 1 ) | ||||||
|  |     if ! [[ $last_http_code =~ ^(2|4|5)[0-9][0-9]$ ]]; then | ||||||
|  |         broken_redirects=$( echo "$http_codes" | grep -v '301' ) | ||||||
|  |     fi | ||||||
|  |  | ||||||
|     # All HTTP codes are 301 (Moved Permanently), the redirect link exists. |     # All HTTP codes are 301 (Moved Permanently), the redirect link exists. | ||||||
|     if [[ -z "$broken_redirects" ]]; then |     if [[ -z "$broken_redirects" ]]; then | ||||||
| @ -1182,6 +1379,11 @@ get_download_link_from_aka_ms() { | |||||||
|             return 1 |             return 1 | ||||||
|         fi |         fi | ||||||
|  |  | ||||||
|  |         sanitized_redirect_url=$(sanitize_redirect_url "$aka_ms_download_link") | ||||||
|  |         if [[ -n "$sanitized_redirect_url" ]]; then | ||||||
|  |             aka_ms_download_link="$sanitized_redirect_url" | ||||||
|  |         fi | ||||||
|  |  | ||||||
|         say_verbose "The redirect location retrieved: '$aka_ms_download_link'." |         say_verbose "The redirect location retrieved: '$aka_ms_download_link'." | ||||||
|         return 0 |         return 0 | ||||||
|     else |     else | ||||||
| @ -1193,24 +1395,17 @@ get_download_link_from_aka_ms() { | |||||||
| get_feeds_to_use() | get_feeds_to_use() | ||||||
| { | { | ||||||
|     feeds=( |     feeds=( | ||||||
|     "https://dotnetcli.azureedge.net/dotnet" |     "https://builds.dotnet.microsoft.com/dotnet" | ||||||
|     "https://dotnetbuilds.azureedge.net/public" |     "https://ci.dot.net/public" | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|     if [[ -n "$azure_feed" ]]; then |     if [[ -n "$azure_feed" ]]; then | ||||||
|         feeds=("$azure_feed") |         feeds=("$azure_feed") | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if [[ "$no_cdn" == "true" ]]; then |  | ||||||
|         feeds=( |  | ||||||
|         "https://dotnetcli.blob.core.windows.net/dotnet" |  | ||||||
|         "https://dotnetbuilds.blob.core.windows.net/public" |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|     if [[ -n "$uncached_feed" ]]; then |     if [[ -n "$uncached_feed" ]]; then | ||||||
|         feeds=("$uncached_feed") |         feeds=("$uncached_feed") | ||||||
|     fi |     fi | ||||||
|     fi |  | ||||||
| } | } | ||||||
|  |  | ||||||
| # THIS FUNCTION MAY EXIT (if the determined version is already installed). | # THIS FUNCTION MAY EXIT (if the determined version is already installed). | ||||||
| @ -1341,7 +1536,7 @@ generate_regular_links() { | |||||||
|         link_types+=("legacy") |         link_types+=("legacy") | ||||||
|     else |     else | ||||||
|         legacy_download_link="" |         legacy_download_link="" | ||||||
|         say_verbose "Cound not construct a legacy_download_link; omitting..." |         say_verbose "Could not construct a legacy_download_link; omitting..." | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     #  Check if the SDK version is already installed. |     #  Check if the SDK version is already installed. | ||||||
| @ -1419,10 +1614,11 @@ install_dotnet() { | |||||||
|     eval $invocation |     eval $invocation | ||||||
|     local download_failed=false |     local download_failed=false | ||||||
|     local download_completed=false |     local download_completed=false | ||||||
|  |     local remote_file_size=0 | ||||||
|  |  | ||||||
|     mkdir -p "$install_root" |     mkdir -p "$install_root" | ||||||
|     zip_path="$(mktemp "$temporary_file_template")" |     zip_path="${zip_path:-$(mktemp "$temporary_file_template")}" | ||||||
|     say_verbose "Zip path: $zip_path" |     say_verbose "Archive path: $zip_path" | ||||||
|  |  | ||||||
|     for link_index in "${!download_links[@]}" |     for link_index in "${!download_links[@]}" | ||||||
|     do |     do | ||||||
| @ -1443,10 +1639,10 @@ install_dotnet() { | |||||||
|                 say "The resource at $link_type link '$download_link' is not available." |                 say "The resource at $link_type link '$download_link' is not available." | ||||||
|                 ;; |                 ;; | ||||||
|             *) |             *) | ||||||
|                 say "Failed to download $link_type link '$download_link': $download_error_msg" |                 say "Failed to download $link_type link '$download_link': $http_code $download_error_msg" | ||||||
|                 ;; |                 ;; | ||||||
|             esac |             esac | ||||||
|             rm -f "$zip_path" 2>&1 && say_verbose "Temporary zip file $zip_path was removed" |             rm -f "$zip_path" 2>&1 && say_verbose "Temporary archive file $zip_path was removed" | ||||||
|         else |         else | ||||||
|             download_completed=true |             download_completed=true | ||||||
|             break |             break | ||||||
| @ -1459,8 +1655,10 @@ install_dotnet() { | |||||||
|         return 1 |         return 1 | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     say "Extracting zip from $download_link" |     remote_file_size="$(get_remote_file_size "$download_link")" | ||||||
|     extract_dotnet_package "$zip_path" "$install_root" || return 1 |  | ||||||
|  |     say "Extracting archive from $download_link" | ||||||
|  |     extract_dotnet_package "$zip_path" "$install_root" "$remote_file_size" || return 1 | ||||||
|  |  | ||||||
|     #  Check if the SDK version is installed; if not, fail the installation. |     #  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 the version contains "RTM" or "servicing"; check if a 'release-type' SDK version is installed. | ||||||
| @ -1502,7 +1700,6 @@ install_dir="<auto>" | |||||||
| architecture="<auto>" | architecture="<auto>" | ||||||
| dry_run=false | dry_run=false | ||||||
| no_path=false | no_path=false | ||||||
| no_cdn=false |  | ||||||
| azure_feed="" | azure_feed="" | ||||||
| uncached_feed="" | uncached_feed="" | ||||||
| feed_credential="" | feed_credential="" | ||||||
| @ -1575,10 +1772,6 @@ do | |||||||
|             verbose=true |             verbose=true | ||||||
|             non_dynamic_parameters+=" $name" |             non_dynamic_parameters+=" $name" | ||||||
|             ;; |             ;; | ||||||
|         --no-cdn|-[Nn]o[Cc]dn) |  | ||||||
|             no_cdn=true |  | ||||||
|             non_dynamic_parameters+=" $name" |  | ||||||
|             ;; |  | ||||||
|         --azure-feed|-[Aa]zure[Ff]eed) |         --azure-feed|-[Aa]zure[Ff]eed) | ||||||
|             shift |             shift | ||||||
|             azure_feed="$1" |             azure_feed="$1" | ||||||
| @ -1610,10 +1803,22 @@ do | |||||||
|             override_non_versioned_files=false |             override_non_versioned_files=false | ||||||
|             non_dynamic_parameters+=" $name" |             non_dynamic_parameters+=" $name" | ||||||
|             ;; |             ;; | ||||||
|  |         --keep-zip|-[Kk]eep[Zz]ip) | ||||||
|  |             keep_zip=true | ||||||
|  |             non_dynamic_parameters+=" $name" | ||||||
|  |             ;; | ||||||
|  |         --zip-path|-[Zz]ip[Pp]ath) | ||||||
|  |             shift | ||||||
|  |             zip_path="$1" | ||||||
|  |             ;; | ||||||
|         -?|--?|-h|--help|-[Hh]elp) |         -?|--?|-h|--help|-[Hh]elp) | ||||||
|             script_name="$(basename "$0")" |             script_name="dotnet-install.sh" | ||||||
|             echo ".NET Tools Installer" |             echo ".NET Tools Installer" | ||||||
|             echo "Usage: $script_name [-c|--channel <CHANNEL>] [-v|--version <VERSION>] [-p|--prefix <DESTINATION>]" |             echo "Usage:" | ||||||
|  |             echo "       # Install a .NET SDK of a given Quality from a given Channel" | ||||||
|  |             echo "       $script_name [-c|--channel <CHANNEL>] [-q|--quality <QUALITY>]" | ||||||
|  |             echo "       # Install a .NET SDK of a specific public version" | ||||||
|  |             echo "       $script_name [-v|--version <VERSION>]" | ||||||
|             echo "       $script_name -h|-?|--help" |             echo "       $script_name -h|-?|--help" | ||||||
|             echo "" |             echo "" | ||||||
|             echo "$script_name is a simple command line interface for obtaining dotnet cli." |             echo "$script_name is a simple command line interface for obtaining dotnet cli." | ||||||
| @ -1655,7 +1860,7 @@ do | |||||||
|             echo "      -InstallDir" |             echo "      -InstallDir" | ||||||
|             echo "  --architecture <ARCHITECTURE>      Architecture of dotnet binaries to be installed, Defaults to \`$architecture\`." |             echo "  --architecture <ARCHITECTURE>      Architecture of dotnet binaries to be installed, Defaults to \`$architecture\`." | ||||||
|             echo "      --arch,-Architecture,-Arch" |             echo "      --arch,-Architecture,-Arch" | ||||||
|             echo "          Possible values: x64, arm, arm64 and s390x" |             echo "          Possible values: x64, arm, arm64, s390x, ppc64le and loongarch64" | ||||||
|             echo "  --os <system>                    Specifies operating system to be used when selecting the installer." |             echo "  --os <system>                    Specifies operating system to be used when selecting the installer." | ||||||
|             echo "          Overrides the OS determination approach used by the script. Supported values: osx, linux, linux-musl, freebsd, rhel.6." |             echo "          Overrides the OS determination approach used by the script. Supported values: osx, linux, linux-musl, freebsd, rhel.6." | ||||||
|             echo "          In case any other value is provided, the platform will be determined by the script based on machine configuration." |             echo "          In case any other value is provided, the platform will be determined by the script based on machine configuration." | ||||||
| @ -1671,15 +1876,14 @@ do | |||||||
|             echo "  --verbose,-Verbose                 Display diagnostics information." |             echo "  --verbose,-Verbose                 Display diagnostics information." | ||||||
|             echo "  --azure-feed,-AzureFeed            For internal use only." |             echo "  --azure-feed,-AzureFeed            For internal use only." | ||||||
|             echo "                                     Allows using a different storage to download SDK archives from." |             echo "                                     Allows using a different storage to download SDK archives from." | ||||||
|             echo "                                     This parameter is only used if --no-cdn is false." |  | ||||||
|             echo "  --uncached-feed,-UncachedFeed      For internal use only." |             echo "  --uncached-feed,-UncachedFeed      For internal use only." | ||||||
|             echo "                                     Allows using a different storage to download SDK archives from." |             echo "                                     Allows using a different storage to download SDK archives from." | ||||||
|             echo "                                     This parameter is only used if --no-cdn is true." |  | ||||||
|             echo "  --skip-non-versioned-files         Skips non-versioned files if they already exist, such as the dotnet executable." |             echo "  --skip-non-versioned-files         Skips non-versioned files if they already exist, such as the dotnet executable." | ||||||
|             echo "      -SkipNonVersionedFiles" |             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 "  --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 "                                     Note: global.json must have a value for 'SDK:Version'" | ||||||
|  |             echo "  --keep-zip,-KeepZip                If set, downloaded file is kept." | ||||||
|  |             echo "  --zip-path, -ZipPath               If set, downloaded file is stored at the specified path." | ||||||
|             echo "  -?,--?,-h,--help,-Help             Shows this help message" |             echo "  -?,--?,-h,--help,-Help             Shows this help message" | ||||||
|             echo "" |             echo "" | ||||||
|             echo "Install Location:" |             echo "Install Location:" | ||||||
|  | |||||||
							
								
								
									
										5848
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										5848
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	