You've already forked setup-dotnet
							
							
				mirror of
				https://github.com/actions/setup-dotnet.git
				synced 2025-10-25 12:45:09 +07:00 
			
		
		
		
	Compare commits
	
		
			32 Commits
		
	
	
		
			v2.1.0
			...
			remove-fal
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8bcd8d8b49 | |||
| 0b32034241 | |||
| aab9aab748 | |||
| a351d9ea84 | |||
| 857c316a9d | |||
| bba8299c35 | |||
| fd4e15fa44 | |||
| 95e7de77d1 | |||
| 52c3199a78 | |||
| 2d9def7067 | |||
| df51eabf53 | |||
| e4b2fcaa19 | |||
| d45c10e6f7 | |||
| 4d1b6c2c63 | |||
| 4cb4764ae2 | |||
| d33e605efe | |||
| f7747565a1 | |||
| 2f75d1de25 | |||
| e6a9a96293 | |||
| 025aba53b2 | |||
| 37b00c4fc5 | |||
| c2dac7f367 | |||
| c5267f5e54 | |||
| ba5e53c61d | |||
| 043fb8900f | |||
| cb04ff8cb3 | |||
| bac4044d91 | |||
| d26ead4cf0 | |||
| e81cd4d454 | |||
| ee11c4faa4 | |||
| 8bf1fb6084 | |||
| fb09b12527 | 
							
								
								
									
										4
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							| @ -30,7 +30,7 @@ jobs: | |||||||
|           cache: npm |           cache: npm | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: npm ci |         run: npm ci --ignore-scripts | ||||||
|  |  | ||||||
|       - name: Rebuild the dist/ directory |       - name: Rebuild the dist/ directory | ||||||
|         run: npm run build |         run: npm run build | ||||||
| @ -45,7 +45,7 @@ jobs: | |||||||
|         id: diff |         id: diff | ||||||
|  |  | ||||||
|       # If index.js was different than expected, upload the expected version as an artifact |       # If index.js was different than expected, upload the expected version as an artifact | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v4 | ||||||
|         if: ${{ failure() && steps.diff.conclusion == 'failure' }} |         if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||||
|         with: |         with: | ||||||
|           name: dist |           name: dist | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							| @ -15,7 +15,7 @@ jobs: | |||||||
|     name: Check licenses |     name: Check licenses | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
|       - run: npm ci |       - run: npm ci --ignore-scripts | ||||||
|       - name: Install licensed |       - name: Install licensed | ||||||
|         run: | |         run: | | ||||||
|           cd $RUNNER_TEMP |           cd $RUNNER_TEMP | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/test-dotnet.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/test-dotnet.yml
									
									
									
									
										vendored
									
									
								
							| @ -17,7 +17,7 @@ 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'] |         dotnet-version: ['2.1', '2.2', '3.0', '3.1', '5.0'] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|  | |||||||
							
								
								
									
										26
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @ -26,7 +26,7 @@ jobs: | |||||||
|       with: |       with: | ||||||
|         node-version: 16.x |         node-version: 16.x | ||||||
|         cache: npm |         cache: npm | ||||||
|     - run: npm ci |     - run: npm ci --ignore-scripts | ||||||
|     - run: npm run build |     - run: npm run build | ||||||
|     - run: npm run format-check |     - run: npm run format-check | ||||||
|     - run: npm test |     - run: npm test | ||||||
| @ -39,7 +39,7 @@ 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] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -62,7 +62,7 @@ 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-13] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -95,7 +95,7 @@ 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] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -120,7 +120,7 @@ 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] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -144,7 +144,7 @@ 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] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -168,7 +168,7 @@ 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] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -190,18 +190,20 @@ jobs: | |||||||
|         run: __tests__/verify-dotnet.ps1 2.2 3.1 |         run: __tests__/verify-dotnet.ps1 2.2 3.1 | ||||||
|  |  | ||||||
|   test-proxy: |   test-proxy: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-20.04 | ||||||
|     container: |     container: | ||||||
|       image: mcr.microsoft.com/dotnet/core/runtime-deps:3.0-bionic |       image: ubuntu:20.04 | ||||||
|       options: --dns 127.0.0.1 |       options: --dns 127.0.0.1 | ||||||
|     services: |     services: | ||||||
|       squid-proxy: |       squid-proxy: | ||||||
|         image: datadog/squid:latest |         image: ubuntu/squid:latest | ||||||
|         ports: |         ports: | ||||||
|           - 3128:3128 |           - 3128:3128 | ||||||
|     env: |     env: | ||||||
|       https_proxy: http://squid-proxy:3128 |       https_proxy: http://squid-proxy:3128 | ||||||
|       http_proxy: http://squid-proxy:3128 |       http_proxy: http://squid-proxy:3128 | ||||||
|  |       DOTNET_SYSTEM_GLOBALIZATION_INVARIANT: true | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -210,7 +212,7 @@ jobs: | |||||||
|       - name: Install curl |       - name: Install curl | ||||||
|         run: | |         run: | | ||||||
|           apt update |           apt update | ||||||
|           apt -y install curl |           apt -y install curl libssl1.1 libssl-dev | ||||||
|       - name: Setup dotnet 3.1.201 |       - name: Setup dotnet 3.1.201 | ||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
| @ -222,7 +224,7 @@ jobs: | |||||||
|         run: __tests__/verify-dotnet.sh 3.1.201 |         run: __tests__/verify-dotnet.sh 3.1.201 | ||||||
|  |  | ||||||
|   test-bypass-proxy: |   test-bypass-proxy: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-22.04 | ||||||
|     env: |     env: | ||||||
|       https_proxy: http://no-such-proxy:3128 |       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 |       no_proxy: github.com,dotnetcli.blob.core.windows.net,download.visualstudio.microsoft.com,api.nuget.org,dotnetcli.azureedge.net | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								.husky/pre-commit
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										4
									
								
								.husky/pre-commit
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  | . "$(dirname -- "$0")/_/husky.sh" | ||||||
|  |  | ||||||
|  | npm run format | ||||||
							
								
								
									
										5
									
								
								.husky/pre-push
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										5
									
								
								.husky/pre-push
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  | . "$(dirname -- "$0")/_/husky.sh" | ||||||
|  |  | ||||||
|  | # Tests are not run at push time since they can take 2-4 minutes to complete | ||||||
|  | npm run format-check | ||||||
| @ -5,11 +5,7 @@ import path = require('path'); | |||||||
| const fakeSourcesDirForTesting = path.join( | const fakeSourcesDirForTesting = path.join( | ||||||
|   __dirname, |   __dirname, | ||||||
|   'runner', |   'runner', | ||||||
|   path.join( |   path.join(Math.random().toString(36).substring(7)), | ||||||
|     Math.random() |  | ||||||
|       .toString(36) |  | ||||||
|       .substring(7) |  | ||||||
|   ), |  | ||||||
|   's' |   's' | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ describe('setup-dotnet tests', () => { | |||||||
|     process.env.RUNNER_TOOL_CACHE = toolDir; |     process.env.RUNNER_TOOL_CACHE = toolDir; | ||||||
|     process.env.DOTNET_INSTALL_DIR = toolDir; |     process.env.DOTNET_INSTALL_DIR = toolDir; | ||||||
|     process.env.RUNNER_TEMP = tempDir; |     process.env.RUNNER_TEMP = tempDir; | ||||||
|  |     process.env['INPUT_INCLUDE-PRERELEASE'] = 'false'; | ||||||
|     await io.rmRF(toolDir); |     await io.rmRF(toolDir); | ||||||
|     await io.rmRF(tempDir); |     await io.rmRF(tempDir); | ||||||
|   }); |   }); | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ inputs: | |||||||
|   include-prerelease: |   include-prerelease: | ||||||
|     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.' |     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' | ||||||
| runs: | runs: | ||||||
|   using: 'node16' |   using: 'node16' | ||||||
|   main: 'dist/index.js' |   main: 'dist/index.js' | ||||||
|  | |||||||
							
								
								
									
										15
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							| @ -275,7 +275,7 @@ class DotnetCoreInstaller { | |||||||
|                     command += ` -ProxyBypassList ${process.env['no_proxy']}`; |                     command += ` -ProxyBypassList ${process.env['no_proxy']}`; | ||||||
|                 } |                 } | ||||||
|                 // process.env must be explicitly passed in for DOTNET_INSTALL_DIR to be used
 |                 // process.env must be explicitly passed in for DOTNET_INSTALL_DIR to be used
 | ||||||
|                 const powershellPath = yield io.which('powershell', true); |                 const powershellPath = (yield io.which('pwsh', false)) || (yield io.which('powershell', true)); | ||||||
|                 var options = { |                 var options = { | ||||||
|                     listeners: { |                     listeners: { | ||||||
|                         stdout: (data) => { |                         stdout: (data) => { | ||||||
| @ -379,7 +379,13 @@ class DotnetCoreInstaller { | |||||||
|     } |     } | ||||||
|     getReleasesJsonUrl(httpClient, versionParts) { |     getReleasesJsonUrl(httpClient, versionParts) { | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             const response = yield httpClient.getJson(DotNetCoreIndexUrl); |             let response; | ||||||
|  |             try { | ||||||
|  |                 response = yield httpClient.getJson(DotNetCoreIndexUrl); | ||||||
|  |             } | ||||||
|  |             catch (error) { | ||||||
|  |                 response = yield httpClient.getJson(DotnetCoreIndexFallbackUrl); | ||||||
|  |             } | ||||||
|             const result = response.result || {}; |             const result = response.result || {}; | ||||||
|             let releasesInfo = result['releases-index']; |             let releasesInfo = result['releases-index']; | ||||||
|             releasesInfo = releasesInfo.filter((info) => { |             releasesInfo = releasesInfo.filter((info) => { | ||||||
| @ -403,7 +409,7 @@ class DotnetCoreInstaller { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| exports.DotnetCoreInstaller = DotnetCoreInstaller; | exports.DotnetCoreInstaller = DotnetCoreInstaller; | ||||||
| const DotNetCoreIndexUrl = 'https://dotnetcli.blob.core.windows.net/dotnet/release-metadata/releases-index.json'; | const DotNetCoreIndexUrl = 'https://builds.dotnet.microsoft.com/dotnet/release-metadata/releases-index.json'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| @ -478,8 +484,7 @@ function run() { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (versions.length) { |             if (versions.length) { | ||||||
|                 const includePrerelease = (core.getInput('include-prerelease') || 'false').toLowerCase() === |                 const includePrerelease = core.getBooleanInput('include-prerelease'); | ||||||
|                     'true'; |  | ||||||
|                 let dotnetInstaller; |                 let dotnetInstaller; | ||||||
|                 for (const version of new Set(versions)) { |                 for (const version of new Set(versions)) { | ||||||
|                     dotnetInstaller = new installer.DotnetCoreInstaller(version, includePrerelease); |                     dotnetInstaller = new installer.DotnetCoreInstaller(version, includePrerelease); | ||||||
|  | |||||||
							
								
								
									
										57
									
								
								docs/adrs/v3-setup-dotnet.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								docs/adrs/v3-setup-dotnet.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,57 @@ | |||||||
|  | # v3 setup-dotnet | ||||||
|  |  | ||||||
|  | Date: 2022-08-25   | ||||||
|  | Status: Accepted | ||||||
|  |  | ||||||
|  | # Context | ||||||
|  | - GitHub-hosted Ubuntu and Windows runners have .NET versions pre-installed in system directories | ||||||
|  |   - Ubuntu:`/usr/share/dotnet` | ||||||
|  |   - Windows:`C:\Program Files\dotnet` | ||||||
|  | - V1 version of Action installs .NET to the user's directory | ||||||
|  |   - Ubuntu:`/home/runner/.dotnet` | ||||||
|  |   - Windows: `C:\Users\runneradmin\AppData\Local\Microsoft\dotnet` | ||||||
|  | - It means that action always downloads and installs .NET version even if it is pre-installed. Also after using the action all pre-installed .NET versions are unavailable because `DOTNET_ROOT` is overridden to the user's directory. | ||||||
|  | The behavior is different for macOS runners because the pre-installation directory matches the one that is used by action. It means action can use pre-installed versions if they exist, which speeds up the customer's workflow. | ||||||
|  |  | ||||||
|  | - The different behavior of the setup task on Ubuntu, Windows and macOS runners is unclear and confusing for customers. | ||||||
|  |  | ||||||
|  | - .NET supports installing and using multiple versions of .NET SDK and .NET runtime side-by-side. .NET CLI will use the latest installed .NET SDK and .NET runtime versions if there is no global.json file containing a different version. This behavior is defined by .NET design (https://docs.microsoft.com/en-us/dotnet/core/versions/selection). | ||||||
|  |  | ||||||
|  | - The action contains logic to handle inputs with wildcards, for example `5.0.x`, `5.0.*`, `5.x` or `5.*`. This logic uses metadata from `https://dotnetcli.blob.core.windows.net/dotnet/release-metadata/releases-index.json` to retrieve the list of available releases and get the latest release version for the specified major and/or minor version from the input. After that, installer script (`dotnet-install.ps1` for Windows or `dotnet-install.sh` for Linux and macOS) installs the required SDK using exact version as a parameter. | ||||||
|  |  | ||||||
|  | # Proposal | ||||||
|  |  | ||||||
|  | - Change .NET installation path for Windows and Ubuntu images to match the location of pre-installed versions by using `-InstallDir` (Windows) and `--install-dir` (Ubuntu) properties for installer scripts: | ||||||
|  | https://docs.microsoft.com/en-us/dotnet/core/tools/dotnet-install-script | ||||||
|  |  | ||||||
|  | - Simplify and in some cases fully get rid of logic for resolving wildcard versions and start relying on [official installer scripts provided by .NET Core team](https://github.com/dotnet/install-scripts).   | ||||||
|  | The execution `dotnet-install.ps1 -Channel 5.0` installs the latest patch version for 5.0 SDK. If SDK is in the prerelease phase, the latest prerelease version (preview or rc) will be installed. | ||||||
|  |  | ||||||
|  | Inputs with wildcards in the patch tag (`5.0.x` or `5.0.*`) can be handled by passing major and minor versions to the installer script directly as a `channel` parameter. This parameter supports two-part version in `X.Y` format as input value ([see installer scripts documentation](https://docs.microsoft.com/en-us/dotnet/core/tools/dotnet-install-script)). | ||||||
|  |  | ||||||
|  | Inputs with wildcards in the minor tag (`3.x` or `3.*`) can be handled like that: | ||||||
|  | 1. The request is sent to MS dist and the `releases.json` file is got | ||||||
|  | 2. The action gets the latest possible channel version out of retrieved `releases.json` that satisfies input major tag (e.g. for `3.x` nowadays it's `3.1`)  | ||||||
|  | 3. Retrieved channel version is passed to installer script directly as `channel` parameter. | ||||||
|  |  | ||||||
|  | > **Note:** Using the `channel` parameter of the MS .NET installer scripts will allow us to use the `quality` parameter as well. This functionality is also asked for by our customers. | ||||||
|  |  | ||||||
|  | # Breaking changes | ||||||
|  | - The presence of pre-installed .NET versions that are higher than the version that the users specify in the setup task can be breaking for some customers, who expect only one installed .NET version on the runner after using the setup task. If a user doesn't have .NET version specified in project file, the `dotnet` will use the latest installed version instead of provided in the setup task.   | ||||||
|  | > **Note:** It is the biggest deal in this ADR. | ||||||
|  |  | ||||||
|  | Previously, when a user would specify a .NET version, this exact version was used by the `dotnet` command by default (because it was installed in a separate folder and there were no other.NET versions in that folder)   | ||||||
|  | In the proposal, the specified version will be installed on the machine but the latest version will be used by the `dotnet` command by default (because specified version will be installed alongside with pre-installed .NET versions).   | ||||||
|  | Based on [official .NET documentation](https://docs.microsoft.com/en-us/dotnet/core/versions/selection), it is expected behavior and how it works on user's local machine with multiple installed .NET versions but some customer's workflows could be broken because they already rely on current behavior. | ||||||
|  |  | ||||||
|  | To avoid breaking customers, we will need to release a new major task version (v3). | ||||||
|  |  | ||||||
|  | # v3-preview | ||||||
|  | There will be a v3-preview branch that will be created for development and testing. Any changes will first be merged into the v3-preview branch. After a period of testing & verification, the v3-preview branch will be merged into the main branch and a v3 tag will be created. Any GitHub public documentation and starter workflows that mention setup-dotnet will then be updated to use v3 instead of v2: | ||||||
|  | - [README.md](https://github.com/actions/setup-dotnet/blob/main/README.md) | ||||||
|  | - [action.yml](https://github.com/actions/setup-dotnet/blob/main/action.yml) | ||||||
|  | - [GitHub docs](https://docs.github.com/en/actions/guides/building-and-testing-net#using-a-specific-net-version) | ||||||
|  | - Starter-workflow yamls: [#1](https://github.com/actions/starter-workflows/blob/main/ci/dotnet.yml#L17), [#2](https://github.com/actions/starter-workflows/blob/main/ci/dotnet-desktop.yml#L72) | ||||||
|  |  | ||||||
|  | # Consequences | ||||||
|  | - Customers will be able to use pre-installed .NET versions with setup-dotnet action on Windows and Ubuntu | ||||||
| @ -1,40 +1,113 @@ | |||||||
| # Contributors | # Contributors | ||||||
|  |  | ||||||
| Thank you for contributing! This action is targetted around setting up the dotnet cli and related sdks for GitHub actions. As part of that we use proxy settings (for self-hosted runners) and set-up nuget authentication for private feeds. | Thank you for contributing! | ||||||
|  |  | ||||||
| If you would like to contribute there are a few things to consider: | We have prepared a short guide so that the process of making your contribution is as simple and clear as possible. Please check it out before you contribute! | ||||||
|  |  | ||||||
| ## Commands to use | ## How can I contribute... | ||||||
|  |  | ||||||
| - npm run build - Compiles the action into a single js file at dist/index.js (Please check in the changes made by this command) | * [Contribute Documentation:green_book:](#contribute-documentation) | ||||||
| - npm run test - Runs all tests under __tests__ |  | ||||||
| - npm run format - Runs formatting required to pass the lint test (Please check in the changes made by this command) |  | ||||||
| - npm run update-installers - Updates the install-dotnet scripts in externals (Please check in the changes made by this command) |  | ||||||
|  |  | ||||||
| ## To check in or not to check in | * [Contribute Code :computer:](#contribute-code) | ||||||
|  |  | ||||||
| - Do check in source (src) | * [Provide Support on Issues:pencil:](#provide-support-on-issues) | ||||||
| - Do check in index file (dist) |  | ||||||
| - Do check in updates to install-dotnet scripts (externals) |  | ||||||
| - Do not check in build output (lib) |  | ||||||
| - Do not check in runtime (node_modules) |  | ||||||
|  |  | ||||||
| ## Writing tests | * [Review Pull Requests:mag:](#review-pull-requests) | ||||||
|  |  | ||||||
| With any contribution please take time to consider how this can be tested to maintain high quality. Current tests can be found in the folder __tests__ for examples. | ## Contribute documentation | ||||||
|  |  | ||||||
| ## Creating new version | Documentation is a super important, critical part of this project. Docs are how we keep track of what we're doing, how, and why. It's how we stay on the same page about our policies and how we tell others everything they need to be able to use this project or contribute to it.  | ||||||
|  |  | ||||||
| Details on versioning can be found here: https://github.com/actions/toolkit/blob/main/docs/action-versioning.md | Documentation contributions of any size are welcome! Feel free to contribute even if you're just rewording a sentence to be more clear, or fixing a spelling mistake! | ||||||
| Create a new release using the UI. Version format should be `vX.Y.Z`. Creating a new major version requires reaction from users and should be done only with breaking changes. |  | ||||||
| Once the new release is created, the vX tag needs to be updated as well. |  | ||||||
| ``` |  | ||||||
| git tag -fa vX -m "Update vX tag" |  | ||||||
| git push origin vX --force |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| For example, if you're publishing v2: | **How to contribute:** | ||||||
| ``` |  | ||||||
| git tag -fa v2 -m "Update v2 tag" | Pull requests are the easiest way to contribute changes to git repos at GitHub. They are the preferred contribution method, as they offer a convenient way of commenting and amending the proposed changes. | ||||||
| git push origin v2 --force |  | ||||||
| ``` | - Please check that no one else has already created a pull request with these or similar changes | ||||||
|  | - Use a "feature branch" for your changes. That separates the changes in the pull request from your other changes and makes it easy to edit/amend commits in the pull request  | ||||||
|  | - Make sure your changes are formatted properly and consistently with the rest of the documentation | ||||||
|  | - Re-read what you wrote, and run a spellchecker on it to make sure you didn't miss anything | ||||||
|  | - If your pull request is connected to an open issue, please, leave a link to this issue in the `Related issue:` section | ||||||
|  | - If you later need to add new commits to the pull request, you can simply commit the changes to the local branch and then push them. The pull request gets automatically updated | ||||||
|  |  | ||||||
|  | **Once you've filed the pull request:** | ||||||
|  |  | ||||||
|  | - Maintainers will review your pull request | ||||||
|  | - If a maintainer requests changes, first of all, try to think about this request critically and only after that implement and request another review | ||||||
|  | - If your PR gets accepted, it will soon be merged into the main branch. But your contribution will take effect only after the release of a new version of the action and updating the major tag | ||||||
|  | > Sometimes maintainers reject pull requests and that's ok! Usually, along with rejection, we supply the reason for it. Nonetheless, we still really appreciate you taking the time to do it, and we don't take that lightly :heart: | ||||||
|  |  | ||||||
|  | ## Contribute code | ||||||
|  |  | ||||||
|  | We like code commits a lot! They're super handy, and they keep the project going and doing the work it needs to do to be useful to others. | ||||||
|  |  | ||||||
|  | Code contributions of just about any size are acceptable! | ||||||
|  |  | ||||||
|  | The main difference between code contributions and documentation contributions is that contributing code requires the inclusion of relevant tests for the code being added or changed. Contributions without accompanying tests will be held off until a test is added unless the maintainers consider the specific tests to be either impossible or way too much of a burden for such a contribution. | ||||||
|  |  | ||||||
|  | **How to contribute:** | ||||||
|  |  | ||||||
|  | Pull requests are the easiest way to contribute changes to git repos at GitHub. They are the preferred contribution method, as they offer a convenient way of commenting and amending the proposed changes. | ||||||
|  |  | ||||||
|  | - Please check that no one else has already created a pull request with these or similar changes | ||||||
|  | - Use a "feature branch" for your changes. That separates the changes in the pull request from your other changes and makes it easy to edit/amend commits in the pull request | ||||||
|  | -  Format, build and test changes | ||||||
|  | - Make sure your changes are well formatted and that all tests are passing | ||||||
|  | - If your pull request is connected to an open issue, please, leave a link to this issue in the `Related issue:` section | ||||||
|  | - If you later need to add new commits to the pull request, you can simply commit the changes to the local branch and then push them. The pull request gets automatically updated | ||||||
|  |  | ||||||
|  | **Learn more about how to work with the repository:** | ||||||
|  |  | ||||||
|  | - 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 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:** | ||||||
|  |  | ||||||
|  | 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 [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 | ||||||
|  | - Tests should cover a successful execution, as well as some edge cases and possible errors | ||||||
|  | - As already mentioned, pull requests without tests will be considered more carefully by maintainers. If you are sure that in this situation the tests are not needed or cannot be implemented with a commensurate effort - please add this clarification message to your pull request | ||||||
|  |  | ||||||
|  | **Once you've filed the pull request:** | ||||||
|  |  | ||||||
|  | - CI will start automatically with some checks. Wait until the end of the execution and make sure that all checks passed successfully. If some checks fail, you can open them one by one, try to find the reason for failing and make changes to your code to resolve the problem | ||||||
|  | > Sometimes you may need to update the installers you can do this with the `npm run update-installers` command | ||||||
|  | - Maintainers will review your pull request | ||||||
|  | - If a maintainer requests changes, first of all, try to think about his request critically and only after that implement and request another review | ||||||
|  | - If your PR gets accepted, it will soon be merged into the main branch. But your contribution will take effect only after the release of a new version of the action and updating the major tag | ||||||
|  | > Sometimes maintainers reject pull requests and that's ok! Usually, along with rejection, we supply the reason for it. Nonetheless, we still really appreciate you taking the time to do it, and we don't take that lightly :heart: | ||||||
|  |  | ||||||
|  | ## Provide support on issues | ||||||
|  |  | ||||||
|  | Helping out other users with their questions is an awesome way of contributing to any community. It's not uncommon for most of the issues on open source projects to be support-related questions by users trying to understand something they ran into or find their way around a known bug. | ||||||
|  |  | ||||||
|  | **To help other folks out with their questions:** | ||||||
|  |  | ||||||
|  | - Go to the [issue tracker](https://github.com/actions/setup-dotnet/issues) | ||||||
|  | - Read through the list until you find something that you're familiar enough with to answer to | ||||||
|  | - Respond to the issue with whatever details are needed to clarify the question, or get more details about what's going on | ||||||
|  | - Once the discussion wraps up and things are clarified, ask the original issue filer (or a maintainer) to close it for you | ||||||
|  |   | ||||||
|  | *Some notes on picking up support issues:* | ||||||
|  |  | ||||||
|  | - Avoid responding to issues you don't know you can answer accurately | ||||||
|  | - Try to refer to past issues with accepted answers as much as possible. Link to them from your replies | ||||||
|  | - Be kind and patient with users. Often, folks who have run into confusing things might be upset or impatient. This is natural. If you feel uncomfortable in conversation with them, it's better to stay away or withdraw from the issue. | ||||||
|  |  | ||||||
|  |  > If some user is violating our code of conduct [standards](https://github.com/actions/setup-dotnet/blob/main/CODE_OF_CONDUCT.md#our-standards), refer to the [Enforcement](https://github.com/actions/setup-dotnet/blob/main/CODE_OF_CONDUCT.md#enforcement) section of the Code of Conduct to resolve the conflict | ||||||
|  |   | ||||||
|  | ## Review pull requests | ||||||
|  |   | ||||||
|  | Another great way to contribute is to review pull request. Please, be extra kind: people who submit code/doc contributions are putting themselves in a pretty vulnerable position, and have put time and care into what they've done (even if that's not obvious to you!) Please, always respond with respect, and be understanding, but don't feel like you need to sacrifice your standards for their sake, either. | ||||||
|  |   | ||||||
|  | **How to review:** | ||||||
|  |  | ||||||
|  | - Go to the [pull requests](https://github.com/actions/setup-dotnet/pulls) | ||||||
|  | - Make sure you're familiar with the code or documentation is updated, unless it's a minor change (spellchecking, minor formatting, etc.) | ||||||
|  | - Review changes using the GitHub functionality. You can ask a clarifying question, point out an error or suggest an alternative.  | ||||||
|  | > Note: You may ask for minor changes - "nitpicks", but consider whether they are real blockers to merging or not | ||||||
|  | - Submit your review, which may include comments, an approval, or a changes request | ||||||
							
								
								
									
										815
									
								
								externals/install-dotnet.ps1
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										815
									
								
								externals/install-dotnet.ps1
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										391
									
								
								externals/install-dotnet.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										391
									
								
								externals/install-dotnet.sh
									
									
									
									
										vendored
									
									
								
							| @ -298,14 +298,43 @@ 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 | ||||||
|             ;; |             ;; | ||||||
|  |         s390x) | ||||||
|  |             echo "s390x" | ||||||
|  |             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 | ||||||
|  |  | ||||||
| @ -322,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 | ||||||
|  |  | ||||||
| @ -339,12 +374,72 @@ get_normalized_architecture_from_architecture() { | |||||||
|             echo "arm64" |             echo "arm64" | ||||||
|             return 0 |             return 0 | ||||||
|             ;; |             ;; | ||||||
|  |         s390x) | ||||||
|  |             echo "s390x" | ||||||
|  |             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" | ||||||
|     return 1 |     return 1 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | # args: | ||||||
|  | # version - $1 | ||||||
|  | # channel - $2 | ||||||
|  | # architecture - $3 | ||||||
|  | get_normalized_architecture_for_specific_sdk_version() { | ||||||
|  |     eval $invocation | ||||||
|  |  | ||||||
|  |     local is_version_support_arm64="$(is_arm64_supported "$1")" | ||||||
|  |     local is_channel_support_arm64="$(is_arm64_supported "$2")" | ||||||
|  |     local architecture="$3"; | ||||||
|  |     local osname="$(get_current_os_name)" | ||||||
|  |  | ||||||
|  |     if [ "$osname" == "osx" ] && [ "$architecture" == "arm64" ] && { [ "$is_version_support_arm64" = false ] || [ "$is_channel_support_arm64" = false ]; }; then | ||||||
|  |         #check if rosetta is installed | ||||||
|  |         if [ "$(/usr/bin/pgrep oahd >/dev/null 2>&1;echo $?)" -eq 0 ]; then  | ||||||
|  |             say_verbose "Changing user architecture from '$architecture' to 'x64' because .NET SDKs prior to version 6.0 do not support arm64."  | ||||||
|  |             echo "x64" | ||||||
|  |             return 0; | ||||||
|  |         else | ||||||
|  |             say_err "Architecture \`$architecture\` is not supported for .NET SDK version \`$version\`. Please install Rosetta to allow emulation of the \`$architecture\` .NET SDK on this platform" | ||||||
|  |             return 1 | ||||||
|  |         fi | ||||||
|  |     fi | ||||||
|  |  | ||||||
|  |     echo "$architecture" | ||||||
|  |     return 0 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # args: | ||||||
|  | # version or channel - $1 | ||||||
|  | is_arm64_supported() { | ||||||
|  |     # Extract the major version by splitting on the dot | ||||||
|  |     major_version="${1%%.*}" | ||||||
|  |  | ||||||
|  |     # 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 | ||||||
|  |                 return 0 | ||||||
|  |             fi | ||||||
|  |             ;; | ||||||
|  |     esac | ||||||
|  |  | ||||||
|  |     echo true | ||||||
|  |     return 0 | ||||||
|  | } | ||||||
|  |  | ||||||
| # args: | # args: | ||||||
| # user_defined_os - $1 | # user_defined_os - $1 | ||||||
| get_normalized_os() { | get_normalized_os() { | ||||||
| @ -357,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 | ||||||
| @ -401,6 +501,10 @@ get_normalized_channel() { | |||||||
|  |  | ||||||
|     local channel="$(to_lowercase "$1")" |     local channel="$(to_lowercase "$1")" | ||||||
|  |  | ||||||
|  |     if [[ $channel == current ]]; then | ||||||
|  |         say_warning 'Value "Current" is deprecated for -Channel option. Use "STS" instead.' | ||||||
|  |     fi | ||||||
|  |  | ||||||
|     if [[ $channel == release/* ]]; then |     if [[ $channel == release/* ]]; then | ||||||
|         say_warning 'Using branch name with -Channel option is no longer supported with newer releases. Use -Quality option with a channel in X.Y format instead.'; |         say_warning 'Using branch name with -Channel option is no longer supported with newer releases. Use -Quality option with a channel in X.Y format instead.'; | ||||||
|     fi |     fi | ||||||
| @ -411,6 +515,14 @@ get_normalized_channel() { | |||||||
|                 echo "LTS" |                 echo "LTS" | ||||||
|                 return 0 |                 return 0 | ||||||
|                 ;; |                 ;; | ||||||
|  |             sts) | ||||||
|  |                 echo "STS" | ||||||
|  |                 return 0 | ||||||
|  |                 ;; | ||||||
|  |             current) | ||||||
|  |                 echo "STS" | ||||||
|  |                 return 0 | ||||||
|  |                 ;; | ||||||
|             *) |             *) | ||||||
|                 echo "$channel" |                 echo "$channel" | ||||||
|                 return 0 |                 return 0 | ||||||
| @ -476,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 | ||||||
| @ -515,7 +661,7 @@ parse_globaljson_file_for_version() { | |||||||
|         return 1 |         return 1 | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     sdk_section=$(cat $json_file | awk '/"sdk"/,/}/') |     sdk_section=$(cat $json_file | tr -d "\r" | awk '/"sdk"/,/}/') | ||||||
|     if [ -z "$sdk_section" ]; then |     if [ -z "$sdk_section" ]; then | ||||||
|         say_err "Unable to parse the SDK node in \`$json_file\`" |         say_err "Unable to parse the SDK node in \`$json_file\`" | ||||||
|         return 1 |         return 1 | ||||||
| @ -810,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 | ||||||
| @ -821,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}")" | ||||||
| @ -844,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")" | ||||||
|  |  | ||||||
| @ -862,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" | ||||||
| @ -980,8 +1178,6 @@ download() { | |||||||
|         sleep $((attempts*10)) |         sleep $((attempts*10)) | ||||||
|     done |     done | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     if [ "$failed" = true ]; then |     if [ "$failed" = true ]; then | ||||||
|         say_verbose "Download failed: $remote_path" |         say_verbose "Download failed: $remote_path" | ||||||
|         return 1 |         return 1 | ||||||
| @ -1000,20 +1196,28 @@ downloadcurl() { | |||||||
|     # Avoid passing URI with credentials to functions: note, most of them echoing parameters of invocation in verbose output. |     # Avoid passing URI with credentials to functions: note, most of them echoing parameters of invocation in verbose output. | ||||||
|     local remote_path_with_credential="${remote_path}${feed_credential}" |     local remote_path_with_credential="${remote_path}${feed_credential}" | ||||||
|     local curl_options="--retry 20 --retry-delay 2 --connect-timeout 15 -sSL -f --create-dirs " |     local curl_options="--retry 20 --retry-delay 2 --connect-timeout 15 -sSL -f --create-dirs " | ||||||
|     local failed=false |     local curl_exit_code=0; | ||||||
|     if [ -z "$out_path" ]; then |     if [ -z "$out_path" ]; then | ||||||
|         curl $curl_options "$remote_path_with_credential" 2>&1 || failed=true |         curl $curl_options "$remote_path_with_credential" 2>&1 | ||||||
|  |         curl_exit_code=$? | ||||||
|     else |     else | ||||||
|         curl $curl_options -o "$out_path" "$remote_path_with_credential" 2>&1 || failed=true |         curl $curl_options -o "$out_path" "$remote_path_with_credential" 2>&1 | ||||||
|  |         curl_exit_code=$? | ||||||
|     fi |     fi | ||||||
|     if [ "$failed" = true ]; then |      | ||||||
|  |     if [ $curl_exit_code -gt 0 ]; then | ||||||
|  |         download_error_msg="Unable to download $remote_path." | ||||||
|  |         # Check for curl timeout codes | ||||||
|  |         if [[ $curl_exit_code == 7 || $curl_exit_code == 28 ]]; then | ||||||
|  |             download_error_msg+=" Failed to reach the server: connection timeout." | ||||||
|  |         else | ||||||
|             local disable_feed_credential=false |             local disable_feed_credential=false | ||||||
|             local response=$(get_http_header_curl $remote_path $disable_feed_credential) |             local response=$(get_http_header_curl $remote_path $disable_feed_credential) | ||||||
|             http_code=$( echo "$response" | awk '/^HTTP/{print $2}' | tail -1 ) |             http_code=$( echo "$response" | awk '/^HTTP/{print $2}' | tail -1 ) | ||||||
|         download_error_msg="Unable to download $remote_path." |             if  [[ ! -z $http_code && $http_code != 2* ]]; then | ||||||
|         if  [[ $http_code != 2* ]]; then |  | ||||||
|                 download_error_msg+=" Returned HTTP status code: $http_code." |                 download_error_msg+=" Returned HTTP status code: $http_code." | ||||||
|             fi |             fi | ||||||
|  |         fi | ||||||
|         say_verbose "$download_error_msg" |         say_verbose "$download_error_msg" | ||||||
|         return 1 |         return 1 | ||||||
|     fi |     fi | ||||||
| @ -1055,8 +1259,11 @@ downloadwget() { | |||||||
|         local response=$(get_http_header_wget $remote_path $disable_feed_credential) |         local response=$(get_http_header_wget $remote_path $disable_feed_credential) | ||||||
|         http_code=$( echo "$response" | awk '/^  HTTP/{print $2}' | tail -1 ) |         http_code=$( echo "$response" | awk '/^  HTTP/{print $2}' | tail -1 ) | ||||||
|         download_error_msg="Unable to download $remote_path." |         download_error_msg="Unable to download $remote_path." | ||||||
|         if  [[ $http_code != 2* ]]; then |         if  [[ ! -z $http_code && $http_code != 2* ]]; then | ||||||
|             download_error_msg+=" Returned HTTP status code: $http_code." |             download_error_msg+=" Returned HTTP status code: $http_code." | ||||||
|  |         # wget exit code 4 stands for network-issue | ||||||
|  |         elif [[ $wget_result == 4 ]]; then | ||||||
|  |             download_error_msg+=" Failed to reach the server: connection timeout." | ||||||
|         fi |         fi | ||||||
|         say_verbose "$download_error_msg" |         say_verbose "$download_error_msg" | ||||||
|         return 1 |         return 1 | ||||||
| @ -1065,13 +1272,69 @@ 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 | ||||||
|  |  | ||||||
|     #quality is not supported for LTS or current channel |     #quality is not supported for LTS or STS channel | ||||||
|     if [[ ! -z "$normalized_quality"  && ("$normalized_channel" == "LTS" || "$normalized_channel" == "current") ]]; then |     #STS maps to current | ||||||
|  |     if [[ ! -z "$normalized_quality"  && ("$normalized_channel" == "LTS" || "$normalized_channel" == "STS") ]]; then | ||||||
|         normalized_quality="" |         normalized_quality="" | ||||||
|         say_warning "Specifying quality for current or LTS channel is not supported, the quality will be ignored." |         say_warning "Specifying quality for STS or LTS channel is not supported, the quality will be ignored." | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     say_verbose "Retrieving primary payload URL from aka.ms for channel: '$normalized_channel', quality: '$normalized_quality', product: '$normalized_product', os: '$normalized_os', architecture: '$normalized_architecture'."  |     say_verbose "Retrieving primary payload URL from aka.ms for channel: '$normalized_channel', quality: '$normalized_quality', product: '$normalized_product', os: '$normalized_os', architecture: '$normalized_architecture'."  | ||||||
| @ -1100,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 | ||||||
| @ -1110,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 | ||||||
| @ -1121,7 +1395,9 @@ get_download_link_from_aka_ms() { | |||||||
| get_feeds_to_use() | get_feeds_to_use() | ||||||
| { | { | ||||||
|     feeds=( |     feeds=( | ||||||
|  |     "https://builds.dotnet.microsoft.com/dotnet" | ||||||
|     "https://dotnetcli.azureedge.net/dotnet" |     "https://dotnetcli.azureedge.net/dotnet" | ||||||
|  |     "https://ci.dot.net/public" | ||||||
|     "https://dotnetbuilds.azureedge.net/public" |     "https://dotnetbuilds.azureedge.net/public" | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
| @ -1179,6 +1455,11 @@ generate_akams_links() { | |||||||
|     local valid_aka_ms_link=true; |     local valid_aka_ms_link=true; | ||||||
|  |  | ||||||
|     normalized_version="$(to_lowercase "$version")" |     normalized_version="$(to_lowercase "$version")" | ||||||
|  |     if [[ "$normalized_version" != "latest" ]] && [ -n "$normalized_quality" ]; then | ||||||
|  |         say_err "Quality and Version options are not allowed to be specified simultaneously. See https://learn.microsoft.com/dotnet/core/tools/dotnet-install-script#options for details." | ||||||
|  |         return 1 | ||||||
|  |     fi | ||||||
|  |  | ||||||
|     if [[ -n "$json_file" || "$normalized_version" != "latest" ]]; then |     if [[ -n "$json_file" || "$normalized_version" != "latest" ]]; then | ||||||
|         # aka.ms links are not needed when exact version is specified via command or json file |         # aka.ms links are not needed when exact version is specified via command or json file | ||||||
|         return |         return | ||||||
| @ -1322,6 +1603,8 @@ calculate_vars() { | |||||||
|     install_root="$(resolve_installation_path "$install_dir")" |     install_root="$(resolve_installation_path "$install_dir")" | ||||||
|     say_verbose "InstallRoot: '$install_root'." |     say_verbose "InstallRoot: '$install_root'." | ||||||
|  |  | ||||||
|  |     normalized_architecture="$(get_normalized_architecture_for_specific_sdk_version "$version" "$normalized_channel" "$normalized_architecture")" | ||||||
|  |  | ||||||
|     if [[ "$runtime" == "dotnet" ]]; then |     if [[ "$runtime" == "dotnet" ]]; then | ||||||
|         asset_relative_path="shared/Microsoft.NETCore.App" |         asset_relative_path="shared/Microsoft.NETCore.App" | ||||||
|         asset_name=".NET Core Runtime" |         asset_name=".NET Core Runtime" | ||||||
| @ -1340,10 +1623,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 | ||||||
| @ -1367,7 +1651,7 @@ install_dotnet() { | |||||||
|                 say "Failed to download $link_type link '$download_link': $download_error_msg" |                 say "Failed to download $link_type link '$download_link': $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 | ||||||
| @ -1380,8 +1664,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. | ||||||
| @ -1392,6 +1678,7 @@ install_dotnet() { | |||||||
|         unset IFS; |         unset IFS; | ||||||
|         say_verbose "Checking installation: version = $release_version" |         say_verbose "Checking installation: version = $release_version" | ||||||
|         if is_dotnet_package_installed "$install_root" "$asset_relative_path" "$release_version"; then |         if is_dotnet_package_installed "$install_root" "$asset_relative_path" "$release_version"; then | ||||||
|  |             say "Installed version is $effective_version" | ||||||
|             return 0 |             return 0 | ||||||
|         fi |         fi | ||||||
|     fi |     fi | ||||||
| @ -1399,6 +1686,7 @@ install_dotnet() { | |||||||
|     #  Check if the standard SDK version is installed. |     #  Check if the standard SDK version is installed. | ||||||
|     say_verbose "Checking installation: version = $effective_version" |     say_verbose "Checking installation: version = $effective_version" | ||||||
|     if is_dotnet_package_installed "$install_root" "$asset_relative_path" "$effective_version"; then |     if is_dotnet_package_installed "$install_root" "$asset_relative_path" "$effective_version"; then | ||||||
|  |         say "Installed version is $effective_version" | ||||||
|         return 0 |         return 0 | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @ -1529,36 +1817,53 @@ 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." | ||||||
|  |             echo "    Note that the intended use of this script is for Continuous Integration (CI) scenarios, where:" | ||||||
|  |             echo "    - The SDK needs to be installed without user interaction and without admin rights." | ||||||
|  |             echo "    - The SDK installation doesn't need to persist across multiple CI runs." | ||||||
|  |             echo "    To set up a development environment or to run apps, use installers rather than this script. Visit https://dotnet.microsoft.com/download to get the installer." | ||||||
|             echo "" |             echo "" | ||||||
|             echo "Options:" |             echo "Options:" | ||||||
|             echo "  -c,--channel <CHANNEL>         Download from the channel specified, Defaults to \`$channel\`." |             echo "  -c,--channel <CHANNEL>         Download from the channel specified, Defaults to \`$channel\`." | ||||||
|             echo "      -Channel" |             echo "      -Channel" | ||||||
|             echo "          Possible values:" |             echo "          Possible values:" | ||||||
|             echo "          - Current - most current release" |             echo "          - STS - the most recent Standard Term Support release" | ||||||
|             echo "          - LTS - most current supported release" |             echo "          - LTS - the most recent Long Term Support release" | ||||||
|             echo "          - 2-part version in a format A.B - represents a specific release" |             echo "          - 2-part version in a format A.B - represents a specific release" | ||||||
|             echo "              examples: 2.0; 1.0" |             echo "              examples: 2.0; 1.0" | ||||||
|             echo "          - 3-part version in a format A.B.Cxx - represents a specific SDK release" |             echo "          - 3-part version in a format A.B.Cxx - represents a specific SDK release" | ||||||
|             echo "              examples: 5.0.1xx, 5.0.2xx." |             echo "              examples: 5.0.1xx, 5.0.2xx." | ||||||
|             echo "              Supported since 5.0 release" |             echo "              Supported since 5.0 release" | ||||||
|  |             echo "          Warning: Value 'Current' is deprecated for the Channel parameter. Use 'STS' instead." | ||||||
|             echo "          Note: The version parameter overrides the channel parameter when any version other than 'latest' is used." |             echo "          Note: The version parameter overrides the channel parameter when any version other than 'latest' is used." | ||||||
|             echo "  -v,--version <VERSION>         Use specific VERSION, Defaults to \`$version\`." |             echo "  -v,--version <VERSION>         Use specific VERSION, Defaults to \`$version\`." | ||||||
|             echo "      -Version" |             echo "      -Version" | ||||||
|             echo "          Possible values:" |             echo "          Possible values:" | ||||||
|             echo "          - latest - most latest build on specific channel" |             echo "          - latest - the latest build on specific channel" | ||||||
|             echo "          - 3-part version in a format A.B.C - represents specific version of build" |             echo "          - 3-part version in a format A.B.C - represents specific version of build" | ||||||
|             echo "              examples: 2.0.0-preview2-006120; 1.1.0" |             echo "              examples: 2.0.0-preview2-006120; 1.1.0" | ||||||
|             echo "  -q,--quality <quality>         Download the latest build of specified quality in the channel." |             echo "  -q,--quality <quality>         Download the latest build of specified quality in the channel." | ||||||
|             echo "      -Quality" |             echo "      -Quality" | ||||||
|             echo "          The possible values are: daily, signed, validated, preview, GA." |             echo "          The possible values are: daily, signed, validated, preview, GA." | ||||||
|             echo "          Works only in combination with channel. Not applicable for current and LTS channels and will be ignored if those channels are used."  |             echo "          Works only in combination with channel. Not applicable for STS and LTS channels and will be ignored if those channels are used."  | ||||||
|             echo "          For SDK use channel in A.B.Cxx format. Using quality for SDK together with channel in A.B format is not supported."  |             echo "          For SDK use channel in A.B.Cxx format. Using quality for SDK together with channel in A.B format is not supported."  | ||||||
|             echo "          Supported since 5.0 release."  |             echo "          Supported since 5.0 release."  | ||||||
|             echo "          Note: The version parameter overrides the channel parameter when any version other than 'latest' is used, and therefore overrides the quality." |             echo "          Note: The version parameter overrides the channel parameter when any version other than 'latest' is used, and therefore overrides the quality." | ||||||
| @ -1569,7 +1874,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, and arm64" |             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." | ||||||
| @ -1594,6 +1899,8 @@ do | |||||||
|             echo "  --no-cdn,-NoCdn                    Disable downloading from the Azure CDN, and use the uncached feed directly." |             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:" | ||||||
| @ -1612,10 +1919,10 @@ do | |||||||
|     shift |     shift | ||||||
| done | done | ||||||
|  |  | ||||||
| say "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 "- 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 "- 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." | ||||||
| say "To set up a development environment or to run apps, use installers rather than this script. Visit https://dotnet.microsoft.com/download to get the installer.\n" | say_verbose "To set up a development environment or to run apps, use installers rather than this script. Visit https://dotnet.microsoft.com/download to get the installer.\n" | ||||||
|  |  | ||||||
| if [ "$internal" = true ] && [ -z "$(echo $feed_credential)" ]; then | if [ "$internal" = true ] && [ -z "$(echo $feed_credential)" ]; then | ||||||
|     message="Provide credentials via --feed-credential parameter." |     message="Provide credentials via --feed-credential parameter." | ||||||
| @ -1648,5 +1955,5 @@ else | |||||||
| fi | fi | ||||||
|  |  | ||||||
| say "Note that the script does not resolve dependencies during installation." | say "Note that the script does not resolve dependencies during installation." | ||||||
| say "To check the list of dependencies, go to https://docs.microsoft.com/dotnet/core/install, select your operating system and check the \"Dependencies\" section." | say "To check the list of dependencies, go to https://learn.microsoft.com/dotnet/core/install, select your operating system and check the \"Dependencies\" section." | ||||||
| say "Installation finished successfully." | say "Installation finished successfully." | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										20
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -1,12 +1,12 @@ | |||||||
| { | { | ||||||
|   "name": "setup-dotnet", |   "name": "setup-dotnet", | ||||||
|   "version": "1.0.0", |   "version": "2.1.0", | ||||||
|   "lockfileVersion": 2, |   "lockfileVersion": 2, | ||||||
|   "requires": true, |   "requires": true, | ||||||
|   "packages": { |   "packages": { | ||||||
|     "": { |     "": { | ||||||
|       "name": "setup-dotnet", |       "name": "setup-dotnet", | ||||||
|       "version": "1.0.0", |       "version": "2.1.0", | ||||||
|       "license": "MIT", |       "license": "MIT", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@actions/core": "^1.6.0", |         "@actions/core": "^1.6.0", | ||||||
| @ -23,7 +23,7 @@ | |||||||
|         "@types/node": "^16.11.25", |         "@types/node": "^16.11.25", | ||||||
|         "@types/semver": "^6.2.2", |         "@types/semver": "^6.2.2", | ||||||
|         "@vercel/ncc": "^0.33.4", |         "@vercel/ncc": "^0.33.4", | ||||||
|         "husky": "^7.0.2", |         "husky": "^8.0.1", | ||||||
|         "jest": "^27.2.5", |         "jest": "^27.2.5", | ||||||
|         "jest-circus": "^27.2.5", |         "jest-circus": "^27.2.5", | ||||||
|         "prettier": "^1.19.1", |         "prettier": "^1.19.1", | ||||||
| @ -2305,15 +2305,15 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/husky": { |     "node_modules/husky": { | ||||||
|       "version": "7.0.2", |       "version": "8.0.1", | ||||||
|       "resolved": "https://registry.npmjs.org/husky/-/husky-7.0.2.tgz", |       "resolved": "https://registry.npmjs.org/husky/-/husky-8.0.1.tgz", | ||||||
|       "integrity": "sha512-8yKEWNX4z2YsofXAMT7KvA1g8p+GxtB1ffV8XtpAEGuXNAbCV5wdNKH+qTpw8SM9fh4aMPDR+yQuKfgnreyZlg==", |       "integrity": "sha512-xs7/chUH/CKdOCs7Zy0Aev9e/dKOMZf3K1Az1nar3tzlv0jfqnYtu235bstsWTmXOR0EfINrPa97yy4Lz6RiKw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "husky": "lib/bin.js" |         "husky": "lib/bin.js" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=12" |         "node": ">=14" | ||||||
|       }, |       }, | ||||||
|       "funding": { |       "funding": { | ||||||
|         "url": "https://github.com/sponsors/typicode" |         "url": "https://github.com/sponsors/typicode" | ||||||
| @ -6645,9 +6645,9 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "husky": { |     "husky": { | ||||||
|       "version": "7.0.2", |       "version": "8.0.1", | ||||||
|       "resolved": "https://registry.npmjs.org/husky/-/husky-7.0.2.tgz", |       "resolved": "https://registry.npmjs.org/husky/-/husky-8.0.1.tgz", | ||||||
|       "integrity": "sha512-8yKEWNX4z2YsofXAMT7KvA1g8p+GxtB1ffV8XtpAEGuXNAbCV5wdNKH+qTpw8SM9fh4aMPDR+yQuKfgnreyZlg==", |       "integrity": "sha512-xs7/chUH/CKdOCs7Zy0Aev9e/dKOMZf3K1Az1nar3tzlv0jfqnYtu235bstsWTmXOR0EfINrPa97yy4Lz6RiKw==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "iconv-lite": { |     "iconv-lite": { | ||||||
|  | |||||||
							
								
								
									
										12
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								package.json
									
									
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "setup-dotnet", |   "name": "setup-dotnet", | ||||||
|   "version": "1.0.0", |   "version": "2.1.0", | ||||||
|   "private": true, |   "private": true, | ||||||
|   "description": "setup dotnet action", |   "description": "setup dotnet action", | ||||||
|   "main": "lib/setup-dotnet.js", |   "main": "lib/setup-dotnet.js", | ||||||
| @ -8,16 +8,10 @@ | |||||||
|     "build": "tsc && ncc build", |     "build": "tsc && ncc build", | ||||||
|     "format": "prettier --write **/*.ts", |     "format": "prettier --write **/*.ts", | ||||||
|     "format-check": "prettier --check **/*.ts", |     "format-check": "prettier --check **/*.ts", | ||||||
|  |     "prepare": "husky install", | ||||||
|     "test": "jest", |     "test": "jest", | ||||||
|     "update-installers": "nwget https://dot.net/v1/dotnet-install.ps1 -O externals/install-dotnet.ps1 && nwget https://dot.net/v1/dotnet-install.sh -O externals/install-dotnet.sh" |     "update-installers": "nwget https://dot.net/v1/dotnet-install.ps1 -O externals/install-dotnet.ps1 && nwget https://dot.net/v1/dotnet-install.sh -O externals/install-dotnet.sh" | ||||||
|   }, |   }, | ||||||
|   "husky": { |  | ||||||
|     "hooks": { |  | ||||||
|       "//": "Tests are not run at push time since they can take 2-4 minutes to complete", |  | ||||||
|       "pre-commit": "npm run format", |  | ||||||
|       "pre-push": "npm run format-check" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "repository": { |   "repository": { | ||||||
|     "type": "git", |     "type": "git", | ||||||
|     "url": "git+https://github.com/actions/setup-dotnet.git" |     "url": "git+https://github.com/actions/setup-dotnet.git" | ||||||
| @ -44,7 +38,7 @@ | |||||||
|     "@types/node": "^16.11.25", |     "@types/node": "^16.11.25", | ||||||
|     "@types/semver": "^6.2.2", |     "@types/semver": "^6.2.2", | ||||||
|     "@vercel/ncc": "^0.33.4", |     "@vercel/ncc": "^0.33.4", | ||||||
|     "husky": "^7.0.2", |     "husky": "^8.0.1", | ||||||
|     "jest": "^27.2.5", |     "jest": "^27.2.5", | ||||||
|     "jest-circus": "^27.2.5", |     "jest-circus": "^27.2.5", | ||||||
|     "prettier": "^1.19.1", |     "prettier": "^1.19.1", | ||||||
|  | |||||||
| @ -116,7 +116,8 @@ export class DotnetCoreInstaller { | |||||||
|       } |       } | ||||||
|  |  | ||||||
|       // process.env must be explicitly passed in for DOTNET_INSTALL_DIR to be used |       // process.env must be explicitly passed in for DOTNET_INSTALL_DIR to be used | ||||||
|       const powershellPath = await io.which('powershell', true); |       const powershellPath = | ||||||
|  |         (await io.which('pwsh', false)) || (await io.which('powershell', true)); | ||||||
|  |  | ||||||
|       var options: ExecOptions = { |       var options: ExecOptions = { | ||||||
|         listeners: { |         listeners: { | ||||||
| @ -262,6 +263,7 @@ export class DotnetCoreInstaller { | |||||||
|     versionParts: string[] |     versionParts: string[] | ||||||
|   ): Promise<string> { |   ): Promise<string> { | ||||||
|     const response = await httpClient.getJson<any>(DotNetCoreIndexUrl); |     const response = await httpClient.getJson<any>(DotNetCoreIndexUrl); | ||||||
|  |  | ||||||
|     const result = response.result || {}; |     const result = response.result || {}; | ||||||
|     let releasesInfo: any[] = result['releases-index']; |     let releasesInfo: any[] = result['releases-index']; | ||||||
|  |  | ||||||
| @ -300,4 +302,4 @@ export class DotnetCoreInstaller { | |||||||
| } | } | ||||||
|  |  | ||||||
| const DotNetCoreIndexUrl: string = | const DotNetCoreIndexUrl: string = | ||||||
|   'https://dotnetcli.blob.core.windows.net/dotnet/release-metadata/releases-index.json'; |   'https://builds.dotnet.microsoft.com/dotnet/release-metadata/releases-index.json'; | ||||||
|  | |||||||
| @ -39,8 +39,7 @@ export async function run() { | |||||||
|  |  | ||||||
|     if (versions.length) { |     if (versions.length) { | ||||||
|       const includePrerelease: boolean = |       const includePrerelease: boolean = | ||||||
|         (core.getInput('include-prerelease') || 'false').toLowerCase() === |         core.getBooleanInput('include-prerelease'); | ||||||
|         'true'; |  | ||||||
|       let dotnetInstaller!: installer.DotnetCoreInstaller; |       let dotnetInstaller!: installer.DotnetCoreInstaller; | ||||||
|       for (const version of new Set<string>(versions)) { |       for (const version of new Set<string>(versions)) { | ||||||
|         dotnetInstaller = new installer.DotnetCoreInstaller( |         dotnetInstaller = new installer.DotnetCoreInstaller( | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	