Compare commits
	
		
			9 Commits
		
	
	
		
			v4.2.0
			...
			dependabot
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					1b0793cc05 | ||
| 
						 | 
					cbb722410c | ||
| 
						 | 
					3b9b8c884f | ||
| 
						 | 
					11bd71901b | ||
| 
						 | 
					e3d2460bbb | ||
| 
						 | 
					163217dfcd | ||
| 
						 | 
					eef61447b9 | ||
| 
						 | 
					6b42224f41 | ||
| 
						 | 
					de5a000abf | 
							
								
								
									
										20
									
								
								.github/workflows/publish-immutable-actions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/publish-immutable-actions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,20 @@
 | 
				
			|||||||
 | 
					name: 'Publish Immutable Action Version'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					on:
 | 
				
			||||||
 | 
					  release:
 | 
				
			||||||
 | 
					    types: [published]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					jobs:
 | 
				
			||||||
 | 
					  publish:
 | 
				
			||||||
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
 | 
					    permissions:
 | 
				
			||||||
 | 
					      contents: read
 | 
				
			||||||
 | 
					      id-token: write
 | 
				
			||||||
 | 
					      packages: write
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    steps:
 | 
				
			||||||
 | 
					      - name: Checking out
 | 
				
			||||||
 | 
					        uses: actions/checkout@v4
 | 
				
			||||||
 | 
					      - name: Publish
 | 
				
			||||||
 | 
					        id: publish
 | 
				
			||||||
 | 
					        uses: actions/publish-immutable-action@v0.0.4
 | 
				
			||||||
							
								
								
									
										2
									
								
								.github/workflows/update-test-ubuntu-git.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/update-test-ubuntu-git.yml
									
									
									
									
										vendored
									
									
								
							@@ -48,7 +48,7 @@ jobs:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      # Use `docker/build-push-action` to build (and optionally publish) the image. 
 | 
					      # Use `docker/build-push-action` to build (and optionally publish) the image. 
 | 
				
			||||||
      - name: Build Docker Image (with optional Push)
 | 
					      - name: Build Docker Image (with optional Push)
 | 
				
			||||||
        uses: docker/build-push-action@v6.5.0
 | 
					        uses: docker/build-push-action@v6.10.0
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          context: .
 | 
					          context: .
 | 
				
			||||||
          file: images/test-ubuntu-git.Dockerfile
 | 
					          file: images/test-ubuntu-git.Dockerfile
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,5 +1,12 @@
 | 
				
			|||||||
# Changelog
 | 
					# Changelog
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.2
 | 
				
			||||||
 | 
					* `url-helper.ts` now leverages well-known environment variables by @jww3 in https://github.com/actions/checkout/pull/1941
 | 
				
			||||||
 | 
					* Expand unit test coverage for `isGhes` by @jww3 in https://github.com/actions/checkout/pull/1946
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## v4.2.1
 | 
				
			||||||
 | 
					* Check out other refs/* by commit if provided, fall back to ref by @orhantoy in https://github.com/actions/checkout/pull/1924
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v4.2.0
 | 
					## v4.2.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Add Ref and Commit outputs by @lucacome in https://github.com/actions/checkout/pull/1180
 | 
					* Add Ref and Commit outputs by @lucacome in https://github.com/actions/checkout/pull/1180
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										30
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								README.md
									
									
									
									
									
								
							@@ -143,6 +143,7 @@ Please refer to the [release page](https://github.com/actions/checkout/releases/
 | 
				
			|||||||
- [Checkout pull request HEAD commit instead of merge commit](#Checkout-pull-request-HEAD-commit-instead-of-merge-commit)
 | 
					- [Checkout pull request HEAD commit instead of merge commit](#Checkout-pull-request-HEAD-commit-instead-of-merge-commit)
 | 
				
			||||||
- [Checkout pull request on closed event](#Checkout-pull-request-on-closed-event)
 | 
					- [Checkout pull request on closed event](#Checkout-pull-request-on-closed-event)
 | 
				
			||||||
- [Push a commit using the built-in token](#Push-a-commit-using-the-built-in-token)
 | 
					- [Push a commit using the built-in token](#Push-a-commit-using-the-built-in-token)
 | 
				
			||||||
 | 
					- [Push a commit to a PR using the built-in token](#Push-a-commit-to-a-PR-using-the-built-in-token)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Fetch only the root files
 | 
					## Fetch only the root files
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -211,7 +212,7 @@ Please refer to the [release page](https://github.com/actions/checkout/releases/
 | 
				
			|||||||
    repository: my-org/my-tools
 | 
					    repository: my-org/my-tools
 | 
				
			||||||
    path: my-tools
 | 
					    path: my-tools
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
> - If your secondary repository is private you will need to add the option noted in [Checkout multiple repos (private)](#Checkout-multiple-repos-private)
 | 
					> - If your secondary repository is private or internal you will need to add the option noted in [Checkout multiple repos (private)](#Checkout-multiple-repos-private)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Checkout multiple repos (nested)
 | 
					## Checkout multiple repos (nested)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -225,7 +226,7 @@ Please refer to the [release page](https://github.com/actions/checkout/releases/
 | 
				
			|||||||
    repository: my-org/my-tools
 | 
					    repository: my-org/my-tools
 | 
				
			||||||
    path: my-tools
 | 
					    path: my-tools
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
> - If your secondary repository is private you will need to add the option noted in [Checkout multiple repos (private)](#Checkout-multiple-repos-private)
 | 
					> - If your secondary repository is private or internal you will need to add the option noted in [Checkout multiple repos (private)](#Checkout-multiple-repos-private)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Checkout multiple repos (private)
 | 
					## Checkout multiple repos (private)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -288,6 +289,31 @@ jobs:
 | 
				
			|||||||
```
 | 
					```
 | 
				
			||||||
*NOTE:* The user email is `{user.id}+{user.login}@users.noreply.github.com`. See users API: https://api.github.com/users/github-actions%5Bbot%5D
 | 
					*NOTE:* The user email is `{user.id}+{user.login}@users.noreply.github.com`. See users API: https://api.github.com/users/github-actions%5Bbot%5D
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Push a commit to a PR using the built-in token
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					In a pull request trigger, `ref` is required as GitHub Actions checks out in detached HEAD mode, meaning it doesn’t check out your branch by default.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```yaml
 | 
				
			||||||
 | 
					on: pull_request
 | 
				
			||||||
 | 
					jobs:
 | 
				
			||||||
 | 
					  build:
 | 
				
			||||||
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
 | 
					    steps:
 | 
				
			||||||
 | 
					      - uses: actions/checkout@v4
 | 
				
			||||||
 | 
					        with:
 | 
				
			||||||
 | 
					          ref: ${{ github.head_ref }}
 | 
				
			||||||
 | 
					      - run: |
 | 
				
			||||||
 | 
					          date > generated.txt
 | 
				
			||||||
 | 
					          # Note: the following account information will not work on GHES
 | 
				
			||||||
 | 
					          git config user.name "github-actions[bot]"
 | 
				
			||||||
 | 
					          git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
 | 
				
			||||||
 | 
					          git add .
 | 
				
			||||||
 | 
					          git commit -m "generated"
 | 
				
			||||||
 | 
					          git push
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					*NOTE:* The user email is `{user.id}+{user.login}@users.noreply.github.com`. See users API: https://api.github.com/users/github-actions%5Bbot%5D
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# License
 | 
					# License
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The scripts and documentation in this project are released under the [MIT License](LICENSE)
 | 
					The scripts and documentation in this project are released under the [MIT License](LICENSE)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -77,6 +77,16 @@ describe('ref-helper tests', () => {
 | 
				
			|||||||
    expect(checkoutInfo.startPoint).toBeFalsy()
 | 
					    expect(checkoutInfo.startPoint).toBeFalsy()
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('getCheckoutInfo refs/ without commit', async () => {
 | 
				
			||||||
 | 
					    const checkoutInfo = await refHelper.getCheckoutInfo(
 | 
				
			||||||
 | 
					      git,
 | 
				
			||||||
 | 
					      'refs/non-standard-ref',
 | 
				
			||||||
 | 
					      ''
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(checkoutInfo.ref).toBe('refs/non-standard-ref')
 | 
				
			||||||
 | 
					    expect(checkoutInfo.startPoint).toBeFalsy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  it('getCheckoutInfo unqualified branch only', async () => {
 | 
					  it('getCheckoutInfo unqualified branch only', async () => {
 | 
				
			||||||
    git.branchExists = jest.fn(async (remote: boolean, pattern: string) => {
 | 
					    git.branchExists = jest.fn(async (remote: boolean, pattern: string) => {
 | 
				
			||||||
      return true
 | 
					      return true
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										92
									
								
								__test__/url-helper.test.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								__test__/url-helper.test.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,92 @@
 | 
				
			|||||||
 | 
					import * as urlHelper from '../src/url-helper'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					describe('getServerUrl tests', () => {
 | 
				
			||||||
 | 
					  it('basics', async () => {
 | 
				
			||||||
 | 
					    // Note that URL::toString will append a trailing / when passed just a domain name ...
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl().toString()).toBe('https://github.com/')
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl(' ').toString()).toBe('https://github.com/')
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl('   ').toString()).toBe('https://github.com/')
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl('http://contoso.com').toString()).toBe(
 | 
				
			||||||
 | 
					      'http://contoso.com/'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl('https://contoso.com').toString()).toBe(
 | 
				
			||||||
 | 
					      'https://contoso.com/'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl('https://contoso.com/').toString()).toBe(
 | 
				
			||||||
 | 
					      'https://contoso.com/'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // ... but can't make that same assumption when passed an URL that includes some deeper path.
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerUrl('https://contoso.com/a/b').toString()).toBe(
 | 
				
			||||||
 | 
					      'https://contoso.com/a/b'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					describe('isGhes tests', () => {
 | 
				
			||||||
 | 
					  const pristineEnv = process.env
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  beforeEach(() => {
 | 
				
			||||||
 | 
					    jest.resetModules()
 | 
				
			||||||
 | 
					    process.env = {...pristineEnv}
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  afterAll(() => {
 | 
				
			||||||
 | 
					    process.env = pristineEnv
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('basics', async () => {
 | 
				
			||||||
 | 
					    delete process.env['GITHUB_SERVER_URL']
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes()).toBeFalsy()
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes('https://github.com')).toBeFalsy()
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes('https://contoso.ghe.com')).toBeFalsy()
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes('https://test.github.localhost')).toBeFalsy()
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes('https://src.onpremise.fabrikam.com')).toBeTruthy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('returns false when the GITHUB_SERVER_URL environment variable is not defined', async () => {
 | 
				
			||||||
 | 
					    delete process.env['GITHUB_SERVER_URL']
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes()).toBeFalsy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('returns false when the GITHUB_SERVER_URL environment variable is set to github.com', async () => {
 | 
				
			||||||
 | 
					    process.env['GITHUB_SERVER_URL'] = 'https://github.com'
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes()).toBeFalsy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('returns false when the GITHUB_SERVER_URL environment variable is set to a GitHub Enterprise Cloud-style URL', async () => {
 | 
				
			||||||
 | 
					    process.env['GITHUB_SERVER_URL'] = 'https://contoso.ghe.com'
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes()).toBeFalsy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('returns false when the GITHUB_SERVER_URL environment variable has a .localhost suffix', async () => {
 | 
				
			||||||
 | 
					    process.env['GITHUB_SERVER_URL'] = 'https://mock-github.localhost'
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes()).toBeFalsy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('returns true when the GITHUB_SERVER_URL environment variable is set to some other URL', async () => {
 | 
				
			||||||
 | 
					    process.env['GITHUB_SERVER_URL'] = 'https://src.onpremise.fabrikam.com'
 | 
				
			||||||
 | 
					    expect(urlHelper.isGhes()).toBeTruthy()
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					describe('getServerApiUrl tests', () => {
 | 
				
			||||||
 | 
					  it('basics', async () => {
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerApiUrl()).toBe('https://api.github.com')
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerApiUrl('https://github.com')).toBe(
 | 
				
			||||||
 | 
					      'https://api.github.com'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerApiUrl('https://GitHub.com')).toBe(
 | 
				
			||||||
 | 
					      'https://api.github.com'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerApiUrl('https://contoso.ghe.com')).toBe(
 | 
				
			||||||
 | 
					      'https://api.contoso.ghe.com'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(urlHelper.getServerApiUrl('https://fabrikam.GHE.COM')).toBe(
 | 
				
			||||||
 | 
					      'https://api.fabrikam.ghe.com'
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    expect(
 | 
				
			||||||
 | 
					      urlHelper.getServerApiUrl('https://src.onpremise.fabrikam.com')
 | 
				
			||||||
 | 
					    ).toBe('https://src.onpremise.fabrikam.com/api/v3')
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
							
								
								
									
										54
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										54
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							@@ -2005,8 +2005,8 @@ function getCheckoutInfo(git, ref, commit) {
 | 
				
			|||||||
            result.ref = ref;
 | 
					            result.ref = ref;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        // refs/
 | 
					        // refs/
 | 
				
			||||||
        else if (upperRef.startsWith('REFS/') && commit) {
 | 
					        else if (upperRef.startsWith('REFS/')) {
 | 
				
			||||||
            result.ref = commit;
 | 
					            result.ref = commit ? commit : ref;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        // Unqualified ref, check for a matching branch or tag
 | 
					        // Unqualified ref, check for a matching branch or tag
 | 
				
			||||||
        else {
 | 
					        else {
 | 
				
			||||||
@@ -2454,22 +2454,50 @@ function getFetchUrl(settings) {
 | 
				
			|||||||
    return `${serviceUrl.origin}/${encodedOwner}/${encodedName}`;
 | 
					    return `${serviceUrl.origin}/${encodedOwner}/${encodedName}`;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
function getServerUrl(url) {
 | 
					function getServerUrl(url) {
 | 
				
			||||||
    let urlValue = url && url.trim().length > 0
 | 
					    let resolvedUrl = process.env['GITHUB_SERVER_URL'] || 'https://github.com';
 | 
				
			||||||
        ? url
 | 
					    if (hasContent(url, WhitespaceMode.Trim)) {
 | 
				
			||||||
        : process.env['GITHUB_SERVER_URL'] || 'https://github.com';
 | 
					        resolvedUrl = url;
 | 
				
			||||||
    return new url_1.URL(urlValue);
 | 
					    }
 | 
				
			||||||
 | 
					    return new url_1.URL(resolvedUrl);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
function getServerApiUrl(url) {
 | 
					function getServerApiUrl(url) {
 | 
				
			||||||
    let apiUrl = 'https://api.github.com';
 | 
					    if (hasContent(url, WhitespaceMode.Trim)) {
 | 
				
			||||||
    if (isGhes(url)) {
 | 
					        let serverUrl = getServerUrl(url);
 | 
				
			||||||
        const serverUrl = getServerUrl(url);
 | 
					        if (isGhes(url)) {
 | 
				
			||||||
        apiUrl = new url_1.URL(`${serverUrl.origin}/api/v3`).toString();
 | 
					            serverUrl.pathname = 'api/v3';
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        else {
 | 
				
			||||||
 | 
					            serverUrl.hostname = 'api.' + serverUrl.hostname;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return pruneSuffix(serverUrl.toString(), '/');
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return apiUrl;
 | 
					    return process.env['GITHUB_API_URL'] || 'https://api.github.com';
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
function isGhes(url) {
 | 
					function isGhes(url) {
 | 
				
			||||||
    const ghUrl = getServerUrl(url);
 | 
					    const ghUrl = new url_1.URL(url || process.env['GITHUB_SERVER_URL'] || 'https://github.com');
 | 
				
			||||||
    return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM';
 | 
					    const hostname = ghUrl.hostname.trimEnd().toUpperCase();
 | 
				
			||||||
 | 
					    const isGitHubHost = hostname === 'GITHUB.COM';
 | 
				
			||||||
 | 
					    const isGitHubEnterpriseCloudHost = hostname.endsWith('.GHE.COM');
 | 
				
			||||||
 | 
					    const isLocalHost = hostname.endsWith('.LOCALHOST');
 | 
				
			||||||
 | 
					    return !isGitHubHost && !isGitHubEnterpriseCloudHost && !isLocalHost;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					function pruneSuffix(text, suffix) {
 | 
				
			||||||
 | 
					    if (hasContent(suffix, WhitespaceMode.Preserve) && (text === null || text === void 0 ? void 0 : text.endsWith(suffix))) {
 | 
				
			||||||
 | 
					        return text.substring(0, text.length - suffix.length);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return text;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					var WhitespaceMode;
 | 
				
			||||||
 | 
					(function (WhitespaceMode) {
 | 
				
			||||||
 | 
					    WhitespaceMode[WhitespaceMode["Trim"] = 0] = "Trim";
 | 
				
			||||||
 | 
					    WhitespaceMode[WhitespaceMode["Preserve"] = 1] = "Preserve";
 | 
				
			||||||
 | 
					})(WhitespaceMode || (WhitespaceMode = {}));
 | 
				
			||||||
 | 
					function hasContent(text, whitespaceMode) {
 | 
				
			||||||
 | 
					    let refinedText = text !== null && text !== void 0 ? text : '';
 | 
				
			||||||
 | 
					    if (whitespaceMode == WhitespaceMode.Trim) {
 | 
				
			||||||
 | 
					        refinedText = refinedText.trim();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return refinedText.length > 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -1,12 +1,12 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "name": "checkout",
 | 
					  "name": "checkout",
 | 
				
			||||||
  "version": "4.2.0",
 | 
					  "version": "4.2.2",
 | 
				
			||||||
  "lockfileVersion": 3,
 | 
					  "lockfileVersion": 3,
 | 
				
			||||||
  "requires": true,
 | 
					  "requires": true,
 | 
				
			||||||
  "packages": {
 | 
					  "packages": {
 | 
				
			||||||
    "": {
 | 
					    "": {
 | 
				
			||||||
      "name": "checkout",
 | 
					      "name": "checkout",
 | 
				
			||||||
      "version": "4.2.0",
 | 
					      "version": "4.2.2",
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@actions/core": "^1.10.1",
 | 
					        "@actions/core": "^1.10.1",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "name": "checkout",
 | 
					  "name": "checkout",
 | 
				
			||||||
  "version": "4.2.0",
 | 
					  "version": "4.2.2",
 | 
				
			||||||
  "description": "checkout action",
 | 
					  "description": "checkout action",
 | 
				
			||||||
  "main": "lib/main.js",
 | 
					  "main": "lib/main.js",
 | 
				
			||||||
  "scripts": {
 | 
					  "scripts": {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -46,8 +46,8 @@ export async function getCheckoutInfo(
 | 
				
			|||||||
    result.ref = ref
 | 
					    result.ref = ref
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  // refs/
 | 
					  // refs/
 | 
				
			||||||
  else if (upperRef.startsWith('REFS/') && commit) {
 | 
					  else if (upperRef.startsWith('REFS/')) {
 | 
				
			||||||
    result.ref = commit
 | 
					    result.ref = commit ? commit : ref
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  // Unqualified ref, check for a matching branch or tag
 | 
					  // Unqualified ref, check for a matching branch or tag
 | 
				
			||||||
  else {
 | 
					  else {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -21,26 +21,61 @@ export function getFetchUrl(settings: IGitSourceSettings): string {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function getServerUrl(url?: string): URL {
 | 
					export function getServerUrl(url?: string): URL {
 | 
				
			||||||
  let urlValue =
 | 
					  let resolvedUrl = process.env['GITHUB_SERVER_URL'] || 'https://github.com'
 | 
				
			||||||
    url && url.trim().length > 0
 | 
					  if (hasContent(url, WhitespaceMode.Trim)) {
 | 
				
			||||||
      ? url
 | 
					    resolvedUrl = url!
 | 
				
			||||||
      : process.env['GITHUB_SERVER_URL'] || 'https://github.com'
 | 
					  }
 | 
				
			||||||
  return new URL(urlValue)
 | 
					
 | 
				
			||||||
 | 
					  return new URL(resolvedUrl)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function getServerApiUrl(url?: string): string {
 | 
					export function getServerApiUrl(url?: string): string {
 | 
				
			||||||
  let apiUrl = 'https://api.github.com'
 | 
					  if (hasContent(url, WhitespaceMode.Trim)) {
 | 
				
			||||||
 | 
					    let serverUrl = getServerUrl(url)
 | 
				
			||||||
 | 
					    if (isGhes(url)) {
 | 
				
			||||||
 | 
					      serverUrl.pathname = 'api/v3'
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      serverUrl.hostname = 'api.' + serverUrl.hostname
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (isGhes(url)) {
 | 
					    return pruneSuffix(serverUrl.toString(), '/')
 | 
				
			||||||
    const serverUrl = getServerUrl(url)
 | 
					 | 
				
			||||||
    apiUrl = new URL(`${serverUrl.origin}/api/v3`).toString()
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return apiUrl
 | 
					  return process.env['GITHUB_API_URL'] || 'https://api.github.com'
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function isGhes(url?: string): boolean {
 | 
					export function isGhes(url?: string): boolean {
 | 
				
			||||||
  const ghUrl = getServerUrl(url)
 | 
					  const ghUrl = new URL(
 | 
				
			||||||
 | 
					    url || process.env['GITHUB_SERVER_URL'] || 'https://github.com'
 | 
				
			||||||
 | 
					  )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'
 | 
					  const hostname = ghUrl.hostname.trimEnd().toUpperCase()
 | 
				
			||||||
 | 
					  const isGitHubHost = hostname === 'GITHUB.COM'
 | 
				
			||||||
 | 
					  const isGitHubEnterpriseCloudHost = hostname.endsWith('.GHE.COM')
 | 
				
			||||||
 | 
					  const isLocalHost = hostname.endsWith('.LOCALHOST')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return !isGitHubHost && !isGitHubEnterpriseCloudHost && !isLocalHost
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function pruneSuffix(text: string, suffix: string) {
 | 
				
			||||||
 | 
					  if (hasContent(suffix, WhitespaceMode.Preserve) && text?.endsWith(suffix)) {
 | 
				
			||||||
 | 
					    return text.substring(0, text.length - suffix.length)
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return text
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					enum WhitespaceMode {
 | 
				
			||||||
 | 
					  Trim,
 | 
				
			||||||
 | 
					  Preserve
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function hasContent(
 | 
				
			||||||
 | 
					  text: string | undefined,
 | 
				
			||||||
 | 
					  whitespaceMode: WhitespaceMode
 | 
				
			||||||
 | 
					): boolean {
 | 
				
			||||||
 | 
					  let refinedText = text ?? ''
 | 
				
			||||||
 | 
					  if (whitespaceMode == WhitespaceMode.Trim) {
 | 
				
			||||||
 | 
					    refinedText = refinedText.trim()
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return refinedText.length > 0
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user