mirror of
				https://github.com/actions/checkout.git
				synced 2025-11-04 15:58:09 +08:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					f25a3a9f25 | 
							
								
								
									
										6
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							@@ -22,12 +22,12 @@ jobs:
 | 
				
			|||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Set Node.js 16.x
 | 
					      - name: Set Node.js 12.x
 | 
				
			||||||
        uses: actions/setup-node@v1
 | 
					        uses: actions/setup-node@v1
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          node-version: 16.x
 | 
					          node-version: 12.x
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Install dependencies
 | 
					      - name: Install dependencies
 | 
				
			||||||
        run: npm ci
 | 
					        run: npm ci
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							@@ -39,7 +39,7 @@ jobs:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
    - name: Checkout repository
 | 
					    - name: Checkout repository
 | 
				
			||||||
      uses: actions/checkout@v3
 | 
					      uses: actions/checkout@v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Initialize CodeQL
 | 
					    - name: Initialize CodeQL
 | 
				
			||||||
      uses: github/codeql-action/init@v1
 | 
					      uses: github/codeql-action/init@v1
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							@@ -9,6 +9,6 @@ jobs:
 | 
				
			|||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    name: Check licenses
 | 
					    name: Check licenses
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v2
 | 
				
			||||||
      - run: npm ci
 | 
					      - run: npm ci
 | 
				
			||||||
      - run: npm run licensed-check
 | 
					      - run: npm run licensed-check
 | 
				
			||||||
							
								
								
									
										48
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										48
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							@@ -13,8 +13,8 @@ jobs:
 | 
				
			|||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      - uses: actions/setup-node@v1
 | 
					      - uses: actions/setup-node@v1
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          node-version: 16.x
 | 
					          node-version: 12.x
 | 
				
			||||||
      - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v2
 | 
				
			||||||
      - run: npm ci
 | 
					      - run: npm ci
 | 
				
			||||||
      - run: npm run build
 | 
					      - run: npm run build
 | 
				
			||||||
      - run: npm run format-check
 | 
					      - run: npm run format-check
 | 
				
			||||||
@@ -32,7 +32,7 @@ jobs:
 | 
				
			|||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      # Clone this repo
 | 
					      # Clone this repo
 | 
				
			||||||
      - name: Checkout
 | 
					      - name: Checkout
 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					        uses: actions/checkout@v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Basic checkout
 | 
					      # Basic checkout
 | 
				
			||||||
      - name: Checkout basic
 | 
					      - name: Checkout basic
 | 
				
			||||||
@@ -150,7 +150,7 @@ jobs:
 | 
				
			|||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      # Clone this repo
 | 
					      # Clone this repo
 | 
				
			||||||
      - name: Checkout
 | 
					      - name: Checkout
 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					        uses: actions/checkout@v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Basic checkout using git
 | 
					      # Basic checkout using git
 | 
				
			||||||
      - name: Checkout basic
 | 
					      - name: Checkout basic
 | 
				
			||||||
@@ -182,7 +182,7 @@ jobs:
 | 
				
			|||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      # Clone this repo
 | 
					      # Clone this repo
 | 
				
			||||||
      - name: Checkout
 | 
					      - name: Checkout
 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					        uses: actions/checkout@v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Basic checkout using git
 | 
					      # Basic checkout using git
 | 
				
			||||||
      - name: Checkout basic
 | 
					      - name: Checkout basic
 | 
				
			||||||
@@ -205,41 +205,3 @@ jobs:
 | 
				
			|||||||
          path: basic
 | 
					          path: basic
 | 
				
			||||||
      - name: Verify basic
 | 
					      - name: Verify basic
 | 
				
			||||||
        run: __test__/verify-basic.sh --archive
 | 
					        run: __test__/verify-basic.sh --archive
 | 
				
			||||||
    
 | 
					 | 
				
			||||||
  test-git-container:
 | 
					 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					 | 
				
			||||||
    container: bitnami/git:latest
 | 
					 | 
				
			||||||
    steps:
 | 
					 | 
				
			||||||
      # Clone this repo
 | 
					 | 
				
			||||||
      - name: Checkout
 | 
					 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					 | 
				
			||||||
        with:
 | 
					 | 
				
			||||||
          path: v3
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      # Basic checkout using git
 | 
					 | 
				
			||||||
      - name: Checkout basic
 | 
					 | 
				
			||||||
        uses: ./v3
 | 
					 | 
				
			||||||
        with:
 | 
					 | 
				
			||||||
          ref: test-data/v2/basic
 | 
					 | 
				
			||||||
      - name: Verify basic
 | 
					 | 
				
			||||||
        run: |
 | 
					 | 
				
			||||||
          if [ ! -f "./basic-file.txt" ]; then
 | 
					 | 
				
			||||||
              echo "Expected basic file does not exist"
 | 
					 | 
				
			||||||
              exit 1
 | 
					 | 
				
			||||||
          fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
          # Verify .git folder
 | 
					 | 
				
			||||||
          if [ ! -d "./.git" ]; then
 | 
					 | 
				
			||||||
            echo "Expected ./.git folder to exist"
 | 
					 | 
				
			||||||
            exit 1
 | 
					 | 
				
			||||||
          fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
          # Verify auth token
 | 
					 | 
				
			||||||
          git config --global --add safe.directory "*"
 | 
					 | 
				
			||||||
          git fetch --no-tags --depth=1 origin +refs/heads/main:refs/remotes/origin/main
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      # needed to make checkout post cleanup succeed
 | 
					 | 
				
			||||||
      - name: Fix Checkout v3
 | 
					 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					 | 
				
			||||||
        with:
 | 
					 | 
				
			||||||
          path: v3
 | 
					 | 
				
			||||||
							
								
								
									
										2
									
								
								.licenses/npm/node-fetch.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/node-fetch.dep.yml
									
									
									
										generated
									
									
									
								
							@@ -1,6 +1,6 @@
 | 
				
			|||||||
---
 | 
					---
 | 
				
			||||||
name: node-fetch
 | 
					name: node-fetch
 | 
				
			||||||
version: 2.6.7
 | 
					version: 2.6.5
 | 
				
			||||||
type: npm
 | 
					type: npm
 | 
				
			||||||
summary: A light-weight module that brings window.fetch to node.js
 | 
					summary: A light-weight module that brings window.fetch to node.js
 | 
				
			||||||
homepage: https://github.com/bitinn/node-fetch
 | 
					homepage: https://github.com/bitinn/node-fetch
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										13
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -1,20 +1,13 @@
 | 
				
			|||||||
# Changelog
 | 
					# Changelog
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v3.0.2
 | 
					## v2.4.1
 | 
				
			||||||
- [Add input `set-safe-directory`](https://github.com/actions/checkout/pull/770)
 | 
					- [Set the safe directory option on git to prevent git commands failing when running in containers](https://github.com/actions/checkout/pull/762)
 | 
				
			||||||
 | 
					 | 
				
			||||||
## v3.0.1
 | 
					 | 
				
			||||||
- [Fixed an issue where checkout failed to run in container jobs due to the new git setting `safe.directory`](https://github.com/actions/checkout/pull/762)
 | 
					 | 
				
			||||||
- [Bumped various npm package versions](https://github.com/actions/checkout/pull/744)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
## v3.0.0
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
- [Update to node 16](https://github.com/actions/checkout/pull/689)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v2.3.1
 | 
					## v2.3.1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- [Fix default branch resolution for .wiki and when using SSH](https://github.com/actions/checkout/pull/284)
 | 
					- [Fix default branch resolution for .wiki and when using SSH](https://github.com/actions/checkout/pull/284)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## v2.3.0
 | 
					## v2.3.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- [Fallback to the default branch](https://github.com/actions/checkout/pull/278)
 | 
					- [Fallback to the default branch](https://github.com/actions/checkout/pull/278)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										50
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										50
									
								
								README.md
									
									
									
									
									
								
							@@ -2,7 +2,7 @@
 | 
				
			|||||||
  <a href="https://github.com/actions/checkout"><img alt="GitHub Actions status" src="https://github.com/actions/checkout/workflows/test-local/badge.svg"></a>
 | 
					  <a href="https://github.com/actions/checkout"><img alt="GitHub Actions status" src="https://github.com/actions/checkout/workflows/test-local/badge.svg"></a>
 | 
				
			||||||
</p>
 | 
					</p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Checkout V3
 | 
					# Checkout V2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
This action checks-out your repository under `$GITHUB_WORKSPACE`, so your workflow can access it.
 | 
					This action checks-out your repository under `$GITHUB_WORKSPACE`, so your workflow can access it.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -14,14 +14,27 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# What's new
 | 
					# What's new
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- Updated to the node16 runtime by default
 | 
					- Improved performance
 | 
				
			||||||
  - This requires a minimum [Actions Runner](https://github.com/actions/runner/releases/tag/v2.285.0) version of v2.285.0 to run, which is by default available in GHES 3.4 or later.
 | 
					  - Fetches only a single commit by default
 | 
				
			||||||
 | 
					- Script authenticated git commands
 | 
				
			||||||
 | 
					  - Auth token persisted in the local git config
 | 
				
			||||||
 | 
					- Supports SSH
 | 
				
			||||||
 | 
					- Creates a local branch
 | 
				
			||||||
 | 
					  - No longer detached HEAD when checking out a branch
 | 
				
			||||||
 | 
					- Improved layout
 | 
				
			||||||
 | 
					  - The input `path` is always relative to $GITHUB_WORKSPACE
 | 
				
			||||||
 | 
					  - Aligns better with container actions, where $GITHUB_WORKSPACE gets mapped in
 | 
				
			||||||
 | 
					- Fallback to REST API download
 | 
				
			||||||
 | 
					  - When Git 2.18 or higher is not in the PATH, the REST API will be used to download the files
 | 
				
			||||||
 | 
					  - When using a job container, the container's PATH is used
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Refer [here](https://github.com/actions/checkout/blob/v1/README.md) for previous versions.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Usage
 | 
					# Usage
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<!-- start usage -->
 | 
					<!-- start usage -->
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- uses: actions/checkout@v3
 | 
					- uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    # Repository name with owner. For example, actions/checkout
 | 
					    # Repository name with owner. For example, actions/checkout
 | 
				
			||||||
    # Default: ${{ github.repository }}
 | 
					    # Default: ${{ github.repository }}
 | 
				
			||||||
@@ -92,11 +105,6 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
    #
 | 
					    #
 | 
				
			||||||
    # Default: false
 | 
					    # Default: false
 | 
				
			||||||
    submodules: ''
 | 
					    submodules: ''
 | 
				
			||||||
 | 
					 | 
				
			||||||
    # Add repository path as safe.directory for Git global config by running `git
 | 
					 | 
				
			||||||
    # config --global --add safe.directory <path>`
 | 
					 | 
				
			||||||
    # Default: true
 | 
					 | 
				
			||||||
    set-safe-directory: ''
 | 
					 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
<!-- end usage -->
 | 
					<!-- end usage -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -115,7 +123,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
## Fetch all history for all tags and branches
 | 
					## Fetch all history for all tags and branches
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- uses: actions/checkout@v3
 | 
					- uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    fetch-depth: 0
 | 
					    fetch-depth: 0
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
@@ -123,7 +131,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
## Checkout a different branch
 | 
					## Checkout a different branch
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- uses: actions/checkout@v3
 | 
					- uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    ref: my-branch
 | 
					    ref: my-branch
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
@@ -131,7 +139,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
## Checkout HEAD^
 | 
					## Checkout HEAD^
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- uses: actions/checkout@v3
 | 
					- uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    fetch-depth: 2
 | 
					    fetch-depth: 2
 | 
				
			||||||
- run: git checkout HEAD^
 | 
					- run: git checkout HEAD^
 | 
				
			||||||
@@ -141,12 +149,12 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- name: Checkout
 | 
					- name: Checkout
 | 
				
			||||||
  uses: actions/checkout@v3
 | 
					  uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    path: main
 | 
					    path: main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- name: Checkout tools repo
 | 
					- name: Checkout tools repo
 | 
				
			||||||
  uses: actions/checkout@v3
 | 
					  uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    repository: my-org/my-tools
 | 
					    repository: my-org/my-tools
 | 
				
			||||||
    path: my-tools
 | 
					    path: my-tools
 | 
				
			||||||
@@ -156,10 +164,10 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- name: Checkout
 | 
					- name: Checkout
 | 
				
			||||||
  uses: actions/checkout@v3
 | 
					  uses: actions/checkout@v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- name: Checkout tools repo
 | 
					- name: Checkout tools repo
 | 
				
			||||||
  uses: actions/checkout@v3
 | 
					  uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    repository: my-org/my-tools
 | 
					    repository: my-org/my-tools
 | 
				
			||||||
    path: my-tools
 | 
					    path: my-tools
 | 
				
			||||||
@@ -169,12 +177,12 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- name: Checkout
 | 
					- name: Checkout
 | 
				
			||||||
  uses: actions/checkout@v3
 | 
					  uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    path: main
 | 
					    path: main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- name: Checkout private tools
 | 
					- name: Checkout private tools
 | 
				
			||||||
  uses: actions/checkout@v3
 | 
					  uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    repository: my-org/my-private-tools
 | 
					    repository: my-org/my-private-tools
 | 
				
			||||||
    token: ${{ secrets.GH_PAT }} # `GH_PAT` is a secret that contains your PAT
 | 
					    token: ${{ secrets.GH_PAT }} # `GH_PAT` is a secret that contains your PAT
 | 
				
			||||||
@@ -187,7 +195,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl
 | 
				
			|||||||
## Checkout pull request HEAD commit instead of merge commit
 | 
					## Checkout pull request HEAD commit instead of merge commit
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- uses: actions/checkout@v3
 | 
					- uses: actions/checkout@v2
 | 
				
			||||||
  with:
 | 
					  with:
 | 
				
			||||||
    ref: ${{ github.event.pull_request.head.sha }}
 | 
					    ref: ${{ github.event.pull_request.head.sha }}
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
@@ -203,7 +211,7 @@ jobs:
 | 
				
			|||||||
  build:
 | 
					  build:
 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v2
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Push a commit using the built-in token
 | 
					## Push a commit using the built-in token
 | 
				
			||||||
@@ -214,7 +222,7 @@ jobs:
 | 
				
			|||||||
  build:
 | 
					  build:
 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v2
 | 
				
			||||||
      - run: |
 | 
					      - run: |
 | 
				
			||||||
          date > generated.txt
 | 
					          date > generated.txt
 | 
				
			||||||
          git config user.name github-actions
 | 
					          git config user.name github-actions
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -777,8 +777,7 @@ async function setup(testName: string): Promise<void> {
 | 
				
			|||||||
    sshKey: sshPath ? 'some ssh private key' : '',
 | 
					    sshKey: sshPath ? 'some ssh private key' : '',
 | 
				
			||||||
    sshKnownHosts: '',
 | 
					    sshKnownHosts: '',
 | 
				
			||||||
    sshStrict: true,
 | 
					    sshStrict: true,
 | 
				
			||||||
    workflowOrganizationId: 123456,
 | 
					    workflowOrganizationId: 123456
 | 
				
			||||||
    setSafeDirectory: true
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -85,7 +85,6 @@ describe('input-helper tests', () => {
 | 
				
			|||||||
    expect(settings.repositoryName).toBe('some-repo')
 | 
					    expect(settings.repositoryName).toBe('some-repo')
 | 
				
			||||||
    expect(settings.repositoryOwner).toBe('some-owner')
 | 
					    expect(settings.repositoryOwner).toBe('some-owner')
 | 
				
			||||||
    expect(settings.repositoryPath).toBe(gitHubWorkspace)
 | 
					    expect(settings.repositoryPath).toBe(gitHubWorkspace)
 | 
				
			||||||
    expect(settings.setSafeDirectory).toBe(true)
 | 
					 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  it('qualifies ref', async () => {
 | 
					  it('qualifies ref', async () => {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -68,10 +68,7 @@ inputs:
 | 
				
			|||||||
      When the `ssh-key` input is not provided, SSH URLs beginning with `git@github.com:` are
 | 
					      When the `ssh-key` input is not provided, SSH URLs beginning with `git@github.com:` are
 | 
				
			||||||
      converted to HTTPS.
 | 
					      converted to HTTPS.
 | 
				
			||||||
    default: false
 | 
					    default: false
 | 
				
			||||||
  set-safe-directory:
 | 
					 | 
				
			||||||
    description: Add repository path as safe.directory for Git global config by running `git config --global --add safe.directory <path>`
 | 
					 | 
				
			||||||
    default: true
 | 
					 | 
				
			||||||
runs:
 | 
					runs:
 | 
				
			||||||
  using: node16
 | 
					  using: node12
 | 
				
			||||||
  main: dist/index.js
 | 
					  main: dist/index.js
 | 
				
			||||||
  post: dist/index.js
 | 
					  post: dist/index.js
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										83
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										83
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							@@ -3592,7 +3592,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
 | 
				
			|||||||
    return result;
 | 
					    return result;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
Object.defineProperty(exports, "__esModule", { value: true });
 | 
					Object.defineProperty(exports, "__esModule", { value: true });
 | 
				
			||||||
exports.setSafeDirectory = exports.setSshKnownHostsPath = exports.setSshKeyPath = exports.setRepositoryPath = exports.SshKnownHostsPath = exports.SshKeyPath = exports.PostSetSafeDirectory = exports.RepositoryPath = exports.IsPost = void 0;
 | 
					exports.setSshKnownHostsPath = exports.setSshKeyPath = exports.setRepositoryPath = exports.SshKnownHostsPath = exports.SshKeyPath = exports.RepositoryPath = exports.IsPost = void 0;
 | 
				
			||||||
const coreCommand = __importStar(__webpack_require__(431));
 | 
					const coreCommand = __importStar(__webpack_require__(431));
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Indicates whether the POST action is running
 | 
					 * Indicates whether the POST action is running
 | 
				
			||||||
@@ -3602,10 +3602,6 @@ exports.IsPost = !!process.env['STATE_isPost'];
 | 
				
			|||||||
 * The repository path for the POST action. The value is empty during the MAIN action.
 | 
					 * The repository path for the POST action. The value is empty during the MAIN action.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
exports.RepositoryPath = process.env['STATE_repositoryPath'] || '';
 | 
					exports.RepositoryPath = process.env['STATE_repositoryPath'] || '';
 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * The set-safe-directory for the POST action. The value is set if input: 'safe-directory' is set during the MAIN action.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
exports.PostSetSafeDirectory = process.env['STATE_setSafeDirectory'] === 'true';
 | 
					 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * The SSH key path for the POST action. The value is empty during the MAIN action.
 | 
					 * The SSH key path for the POST action. The value is empty during the MAIN action.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@@ -3635,13 +3631,6 @@ function setSshKnownHostsPath(sshKnownHostsPath) {
 | 
				
			|||||||
    coreCommand.issueCommand('save-state', { name: 'sshKnownHostsPath' }, sshKnownHostsPath);
 | 
					    coreCommand.issueCommand('save-state', { name: 'sshKnownHostsPath' }, sshKnownHostsPath);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
exports.setSshKnownHostsPath = setSshKnownHostsPath;
 | 
					exports.setSshKnownHostsPath = setSshKnownHostsPath;
 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Save the sef-safe-directory input so the POST action can retrieve the value.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
function setSafeDirectory() {
 | 
					 | 
				
			||||||
    coreCommand.issueCommand('save-state', { name: 'setSafeDirectory' }, 'true');
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
exports.setSafeDirectory = setSafeDirectory;
 | 
					 | 
				
			||||||
// Publish a variable so that when the POST action runs, it can determine it should run the cleanup logic.
 | 
					// Publish a variable so that when the POST action runs, it can determine it should run the cleanup logic.
 | 
				
			||||||
// This is necessary since we don't have a separate entry point.
 | 
					// This is necessary since we don't have a separate entry point.
 | 
				
			||||||
if (!exports.IsPost) {
 | 
					if (!exports.IsPost) {
 | 
				
			||||||
@@ -4240,7 +4229,7 @@ module.exports = require("punycode");
 | 
				
			|||||||
/***/ 215:
 | 
					/***/ 215:
 | 
				
			||||||
/***/ (function(module) {
 | 
					/***/ (function(module) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = {"name":"@octokit/rest","version":"16.43.1","publishConfig":{"access":"public"},"description":"GitHub REST API client for Node.js","keywords":["octokit","github","rest","api-client"],"author":"Gregor Martynus (https://github.com/gr2m)","contributors":[{"name":"Mike de Boer","email":"info@mikedeboer.nl"},{"name":"Fabian Jakobs","email":"fabian@c9.io"},{"name":"Joe Gallo","email":"joe@brassafrax.com"},{"name":"Gregor Martynus","url":"https://github.com/gr2m"}],"repository":"https://github.com/octokit/rest.js","dependencies":{"@octokit/auth-token":"^2.4.0","@octokit/plugin-paginate-rest":"^1.1.1","@octokit/plugin-request-log":"^1.0.0","@octokit/plugin-rest-endpoint-methods":"2.4.0","@octokit/request":"^5.2.0","@octokit/request-error":"^1.0.2","atob-lite":"^2.0.0","before-after-hook":"^2.0.0","btoa-lite":"^1.0.0","deprecation":"^2.0.0","lodash.get":"^4.4.2","lodash.set":"^4.3.2","lodash.uniq":"^4.5.0","octokit-pagination-methods":"^1.1.0","once":"^1.4.0","universal-user-agent":"^4.0.0"},"devDependencies":{"@gimenete/type-writer":"^0.1.3","@octokit/auth":"^1.1.1","@octokit/fixtures-server":"^5.0.6","@octokit/graphql":"^4.2.0","@types/node":"^13.1.0","bundlesize":"^0.18.0","chai":"^4.1.2","compression-webpack-plugin":"^3.1.0","cypress":"^3.0.0","glob":"^7.1.2","http-proxy-agent":"^4.0.0","lodash.camelcase":"^4.3.0","lodash.merge":"^4.6.1","lodash.upperfirst":"^4.3.1","lolex":"^5.1.2","mkdirp":"^1.0.0","mocha":"^7.0.1","mustache":"^4.0.0","nock":"^11.3.3","npm-run-all":"^4.1.2","nyc":"^15.0.0","prettier":"^1.14.2","proxy":"^1.0.0","semantic-release":"^17.0.0","sinon":"^8.0.0","sinon-chai":"^3.0.0","sort-keys":"^4.0.0","string-to-arraybuffer":"^1.0.0","string-to-jsdoc-comment":"^1.0.0","typescript":"^3.3.1","webpack":"^4.0.0","webpack-bundle-analyzer":"^3.0.0","webpack-cli":"^3.0.0"},"types":"index.d.ts","scripts":{"coverage":"nyc report --reporter=html && open coverage/index.html","lint":"prettier --check '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","lint:fix":"prettier --write '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","pretest":"npm run -s lint","test":"nyc mocha test/mocha-node-setup.js \"test/*/**/*-test.js\"","test:browser":"cypress run --browser chrome","build":"npm-run-all build:*","build:ts":"npm run -s update-endpoints:typescript","prebuild:browser":"mkdirp dist/","build:browser":"npm-run-all build:browser:*","build:browser:development":"webpack --mode development --entry . --output-library=Octokit --output=./dist/octokit-rest.js --profile --json > dist/bundle-stats.json","build:browser:production":"webpack --mode production --entry . --plugin=compression-webpack-plugin --output-library=Octokit --output-path=./dist --output-filename=octokit-rest.min.js --devtool source-map","generate-bundle-report":"webpack-bundle-analyzer dist/bundle-stats.json --mode=static --no-open --report dist/bundle-report.html","update-endpoints":"npm-run-all update-endpoints:*","update-endpoints:fetch-json":"node scripts/update-endpoints/fetch-json","update-endpoints:typescript":"node scripts/update-endpoints/typescript","prevalidate:ts":"npm run -s build:ts","validate:ts":"tsc --target es6 --noImplicitAny index.d.ts","postvalidate:ts":"tsc --noEmit --target es6 test/typescript-validate.ts","start-fixtures-server":"octokit-fixtures-server"},"license":"MIT","files":["index.js","index.d.ts","lib","plugins"],"nyc":{"ignore":["test"]},"release":{"publish":["@semantic-release/npm",{"path":"@semantic-release/github","assets":["dist/*","!dist/*.map.gz"]}]},"bundlesize":[{"path":"./dist/octokit-rest.min.js.gz","maxSize":"33 kB"}]};
 | 
					module.exports = {"name":"@octokit/rest","version":"16.43.1","publishConfig":{"access":"public"},"description":"GitHub REST API client for Node.js","keywords":["octokit","github","rest","api-client"],"author":"Gregor Martynus (https://github.com/gr2m)","contributors":[{"name":"Mike de Boer","email":"info@mikedeboer.nl"},{"name":"Fabian Jakobs","email":"fabian@c9.io"},{"name":"Joe Gallo","email":"joe@brassafrax.com"},{"name":"Gregor Martynus","url":"https://github.com/gr2m"}],"repository":"https://github.com/octokit/rest.js","dependencies":{"@octokit/auth-token":"^2.4.0","@octokit/plugin-paginate-rest":"^1.1.1","@octokit/plugin-request-log":"^1.0.0","@octokit/plugin-rest-endpoint-methods":"2.4.0","@octokit/request":"^5.2.0","@octokit/request-error":"^1.0.2","atob-lite":"^2.0.0","before-after-hook":"^2.0.0","btoa-lite":"^1.0.0","deprecation":"^2.0.0","lodash.get":"^4.4.2","lodash.set":"^4.3.2","lodash.uniq":"^4.5.0","octokit-pagination-methods":"^1.1.0","once":"^1.4.0","universal-user-agent":"^4.0.0"},"devDependencies":{"@gimenete/type-writer":"^0.1.3","@octokit/auth":"^1.1.1","@octokit/fixtures-server":"^5.0.6","@octokit/graphql":"^4.2.0","@types/node":"^13.1.0","bundlesize":"^0.18.0","chai":"^4.1.2","compression-webpack-plugin":"^3.1.0","cypress":"^3.0.0","glob":"^7.1.2","http-proxy-agent":"^4.0.0","lodash.camelcase":"^4.3.0","lodash.merge":"^4.6.1","lodash.upperfirst":"^4.3.1","lolex":"^5.1.2","mkdirp":"^1.0.0","mocha":"^7.0.1","mustache":"^4.0.0","nock":"^11.3.3","npm-run-all":"^4.1.2","nyc":"^15.0.0","prettier":"^1.14.2","proxy":"^1.0.0","semantic-release":"^17.0.0","sinon":"^8.0.0","sinon-chai":"^3.0.0","sort-keys":"^4.0.0","string-to-arraybuffer":"^1.0.0","string-to-jsdoc-comment":"^1.0.0","typescript":"^3.3.1","webpack":"^4.0.0","webpack-bundle-analyzer":"^3.0.0","webpack-cli":"^3.0.0"},"types":"index.d.ts","scripts":{"coverage":"nyc report --reporter=html && open coverage/index.html","lint":"prettier --check '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","lint:fix":"prettier --write '{lib,plugins,scripts,test}/**/*.{js,json,ts}' 'docs/*.{js,json}' 'docs/src/**/*' index.js README.md package.json","pretest":"npm run -s lint","test":"nyc mocha test/mocha-node-setup.js \"test/*/**/*-test.js\"","test:browser":"cypress run --browser chrome","build":"npm-run-all build:*","build:ts":"npm run -s update-endpoints:typescript","prebuild:browser":"mkdirp dist/","build:browser":"npm-run-all build:browser:*","build:browser:development":"webpack --mode development --entry . --output-library=Octokit --output=./dist/octokit-rest.js --profile --json > dist/bundle-stats.json","build:browser:production":"webpack --mode production --entry . --plugin=compression-webpack-plugin --output-library=Octokit --output-path=./dist --output-filename=octokit-rest.min.js --devtool source-map","generate-bundle-report":"webpack-bundle-analyzer dist/bundle-stats.json --mode=static --no-open --report dist/bundle-report.html","update-endpoints":"npm-run-all update-endpoints:*","update-endpoints:fetch-json":"node scripts/update-endpoints/fetch-json","update-endpoints:typescript":"node scripts/update-endpoints/typescript","prevalidate:ts":"npm run -s build:ts","validate:ts":"tsc --target es6 --noImplicitAny index.d.ts","postvalidate:ts":"tsc --noEmit --target es6 test/typescript-validate.ts","start-fixtures-server":"octokit-fixtures-server"},"license":"MIT","files":["index.js","index.d.ts","lib","plugins"],"nyc":{"ignore":["test"]},"release":{"publish":["@semantic-release/npm",{"path":"@semantic-release/github","assets":["dist/*","!dist/*.map.gz"]}]},"bundlesize":[{"path":"./dist/octokit-rest.min.js.gz","maxSize":"33 kB"}],"_resolved":"https://registry.npmjs.org/@octokit/rest/-/rest-16.43.1.tgz","_integrity":"sha512-gfFKwRT/wFxq5qlNjnW2dh+qh74XgTQ2B179UX5K1HYCluioWj8Ndbgqw2PVqa1NnVJkGHp2ovMpVn/DImlmkw==","_from":"@octokit/rest@16.43.1"};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/***/ }),
 | 
					/***/ }),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -6583,7 +6572,7 @@ class GitAuthHelper {
 | 
				
			|||||||
            yield this.configureToken();
 | 
					            yield this.configureToken();
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    configureTempGlobalConfig() {
 | 
					    configureTempGlobalConfig(repositoryPath) {
 | 
				
			||||||
        var _a, _b;
 | 
					        var _a, _b;
 | 
				
			||||||
        return __awaiter(this, void 0, void 0, function* () {
 | 
					        return __awaiter(this, void 0, void 0, function* () {
 | 
				
			||||||
            // Already setup global config
 | 
					            // Already setup global config
 | 
				
			||||||
@@ -6619,6 +6608,14 @@ class GitAuthHelper {
 | 
				
			|||||||
            // Override HOME
 | 
					            // Override HOME
 | 
				
			||||||
            core.info(`Temporarily overriding HOME='${this.temporaryHomePath}' before making global git config changes`);
 | 
					            core.info(`Temporarily overriding HOME='${this.temporaryHomePath}' before making global git config changes`);
 | 
				
			||||||
            this.git.setEnvironmentVariable('HOME', this.temporaryHomePath);
 | 
					            this.git.setEnvironmentVariable('HOME', this.temporaryHomePath);
 | 
				
			||||||
 | 
					            // Setup the workspace as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | 
				
			||||||
 | 
					            // Otherwise all git commands we run in a container fail
 | 
				
			||||||
 | 
					            core.info(`Adding working directory to the temporary git global config as a safe directory`);
 | 
				
			||||||
 | 
					            yield this.git
 | 
				
			||||||
 | 
					                .config('safe.directory', repositoryPath !== null && repositoryPath !== void 0 ? repositoryPath : this.settings.repositoryPath, true, true)
 | 
				
			||||||
 | 
					                .catch(error => {
 | 
				
			||||||
 | 
					                core.info(`Failed to initialize safe directory with error: ${error}`);
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
            return newGitConfigPath;
 | 
					            return newGitConfigPath;
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -7355,18 +7352,7 @@ function getSource(settings) {
 | 
				
			|||||||
        try {
 | 
					        try {
 | 
				
			||||||
            if (git) {
 | 
					            if (git) {
 | 
				
			||||||
                authHelper = gitAuthHelper.createAuthHelper(git, settings);
 | 
					                authHelper = gitAuthHelper.createAuthHelper(git, settings);
 | 
				
			||||||
                if (settings.setSafeDirectory) {
 | 
					 | 
				
			||||||
                    // Setup the repository path as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | 
					 | 
				
			||||||
                    // Otherwise all git commands we run in a container fail
 | 
					 | 
				
			||||||
                yield authHelper.configureTempGlobalConfig();
 | 
					                yield authHelper.configureTempGlobalConfig();
 | 
				
			||||||
                    core.info(`Adding repository directory to the temporary git global config as a safe directory`);
 | 
					 | 
				
			||||||
                    yield git
 | 
					 | 
				
			||||||
                        .config('safe.directory', settings.repositoryPath, true, true)
 | 
					 | 
				
			||||||
                        .catch(error => {
 | 
					 | 
				
			||||||
                        core.info(`Failed to initialize safe directory with error: ${error}`);
 | 
					 | 
				
			||||||
                    });
 | 
					 | 
				
			||||||
                    stateHelper.setSafeDirectory();
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            // Prepare existing directory, otherwise recreate
 | 
					            // Prepare existing directory, otherwise recreate
 | 
				
			||||||
            if (isExisting) {
 | 
					            if (isExisting) {
 | 
				
			||||||
@@ -7514,17 +7500,7 @@ function cleanup(repositoryPath) {
 | 
				
			|||||||
        // Remove auth
 | 
					        // Remove auth
 | 
				
			||||||
        const authHelper = gitAuthHelper.createAuthHelper(git);
 | 
					        const authHelper = gitAuthHelper.createAuthHelper(git);
 | 
				
			||||||
        try {
 | 
					        try {
 | 
				
			||||||
            if (stateHelper.PostSetSafeDirectory) {
 | 
					            yield authHelper.configureTempGlobalConfig(repositoryPath);
 | 
				
			||||||
                // Setup the repository path as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | 
					 | 
				
			||||||
                // Otherwise all git commands we run in a container fail
 | 
					 | 
				
			||||||
                yield authHelper.configureTempGlobalConfig();
 | 
					 | 
				
			||||||
                core.info(`Adding repository directory to the temporary git global config as a safe directory`);
 | 
					 | 
				
			||||||
                yield git
 | 
					 | 
				
			||||||
                    .config('safe.directory', repositoryPath, true, true)
 | 
					 | 
				
			||||||
                    .catch(error => {
 | 
					 | 
				
			||||||
                    core.info(`Failed to initialize safe directory with error: ${error}`);
 | 
					 | 
				
			||||||
                });
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            yield authHelper.removeAuth();
 | 
					            yield authHelper.removeAuth();
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        finally {
 | 
					        finally {
 | 
				
			||||||
@@ -10252,7 +10228,7 @@ Object.defineProperty(Response.prototype, Symbol.toStringTag, {
 | 
				
			|||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const INTERNALS$2 = Symbol('Request internals');
 | 
					const INTERNALS$2 = Symbol('Request internals');
 | 
				
			||||||
const URL = Url.URL || whatwgUrl.URL;
 | 
					const URL = whatwgUrl.URL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// fix an issue where "format", "parse" aren't a named export for node <10
 | 
					// fix an issue where "format", "parse" aren't a named export for node <10
 | 
				
			||||||
const parse_url = Url.parse;
 | 
					const parse_url = Url.parse;
 | 
				
			||||||
@@ -10515,17 +10491,9 @@ AbortError.prototype = Object.create(Error.prototype);
 | 
				
			|||||||
AbortError.prototype.constructor = AbortError;
 | 
					AbortError.prototype.constructor = AbortError;
 | 
				
			||||||
AbortError.prototype.name = 'AbortError';
 | 
					AbortError.prototype.name = 'AbortError';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const URL$1 = Url.URL || whatwgUrl.URL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
 | 
					// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
 | 
				
			||||||
const PassThrough$1 = Stream.PassThrough;
 | 
					const PassThrough$1 = Stream.PassThrough;
 | 
				
			||||||
 | 
					const resolve_url = Url.resolve;
 | 
				
			||||||
const isDomainOrSubdomain = function isDomainOrSubdomain(destination, original) {
 | 
					 | 
				
			||||||
	const orig = new URL$1(original).hostname;
 | 
					 | 
				
			||||||
	const dest = new URL$1(destination).hostname;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return orig === dest || orig[orig.length - dest.length - 1] === '.' && orig.endsWith(dest);
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Fetch function
 | 
					 * Fetch function
 | 
				
			||||||
@@ -10613,19 +10581,7 @@ function fetch(url, opts) {
 | 
				
			|||||||
				const location = headers.get('Location');
 | 
									const location = headers.get('Location');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				// HTTP fetch step 5.3
 | 
									// HTTP fetch step 5.3
 | 
				
			||||||
				let locationURL = null;
 | 
									const locationURL = location === null ? null : resolve_url(request.url, location);
 | 
				
			||||||
				try {
 | 
					 | 
				
			||||||
					locationURL = location === null ? null : new URL$1(location, request.url).toString();
 | 
					 | 
				
			||||||
				} catch (err) {
 | 
					 | 
				
			||||||
					// error here can only be invalid URL in Location: header
 | 
					 | 
				
			||||||
					// do not throw when options.redirect == manual
 | 
					 | 
				
			||||||
					// let the user extract the errorneous redirect URL
 | 
					 | 
				
			||||||
					if (request.redirect !== 'manual') {
 | 
					 | 
				
			||||||
						reject(new FetchError(`uri requested responds with an invalid redirect URL: ${location}`, 'invalid-redirect'));
 | 
					 | 
				
			||||||
						finalize();
 | 
					 | 
				
			||||||
						return;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
				// HTTP fetch step 5.5
 | 
									// HTTP fetch step 5.5
 | 
				
			||||||
				switch (request.redirect) {
 | 
									switch (request.redirect) {
 | 
				
			||||||
@@ -10673,12 +10629,6 @@ function fetch(url, opts) {
 | 
				
			|||||||
							size: request.size
 | 
												size: request.size
 | 
				
			||||||
						};
 | 
											};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
						if (!isDomainOrSubdomain(request.url, locationURL)) {
 | 
					 | 
				
			||||||
							for (const name of ['authorization', 'www-authenticate', 'cookie', 'cookie2']) {
 | 
					 | 
				
			||||||
								requestOpts.headers.delete(name);
 | 
					 | 
				
			||||||
							}
 | 
					 | 
				
			||||||
						}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
						// HTTP-redirect fetch step 9
 | 
											// HTTP-redirect fetch step 9
 | 
				
			||||||
						if (res.statusCode !== 303 && request.body && getTotalBytes(request) === null) {
 | 
											if (res.statusCode !== 303 && request.body && getTotalBytes(request) === null) {
 | 
				
			||||||
							reject(new FetchError('Cannot follow redirect with body being a readable stream', 'unsupported-redirect'));
 | 
												reject(new FetchError('Cannot follow redirect with body being a readable stream', 'unsupported-redirect'));
 | 
				
			||||||
@@ -17327,9 +17277,6 @@ function getInputs() {
 | 
				
			|||||||
            (core.getInput('persist-credentials') || 'false').toUpperCase() === 'TRUE';
 | 
					            (core.getInput('persist-credentials') || 'false').toUpperCase() === 'TRUE';
 | 
				
			||||||
        // Workflow organization ID
 | 
					        // Workflow organization ID
 | 
				
			||||||
        result.workflowOrganizationId = yield workflowContextHelper.getOrganizationId();
 | 
					        result.workflowOrganizationId = yield workflowContextHelper.getOrganizationId();
 | 
				
			||||||
        // Set safe.directory in git global config.
 | 
					 | 
				
			||||||
        result.setSafeDirectory =
 | 
					 | 
				
			||||||
            (core.getInput('set-safe-directory') || 'true').toUpperCase() === 'TRUE';
 | 
					 | 
				
			||||||
        return result;
 | 
					        return result;
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										74
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										74
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -1929,6 +1929,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -3319,6 +3325,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -5377,6 +5389,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -7696,6 +7714,12 @@
 | 
				
			|||||||
            "minimist": "^1.2.5"
 | 
					            "minimist": "^1.2.5"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "semver": {
 | 
					        "semver": {
 | 
				
			||||||
          "version": "6.3.0",
 | 
					          "version": "6.3.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
 | 
				
			||||||
@@ -9344,6 +9368,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -11359,6 +11389,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -12904,6 +12940,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -13658,6 +13700,12 @@
 | 
				
			|||||||
            "picomatch": "^2.2.3"
 | 
					            "picomatch": "^2.2.3"
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -14585,6 +14633,12 @@
 | 
				
			|||||||
          "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
 | 
					          "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
 | 
				
			||||||
          "dev": true
 | 
					          "dev": true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
        "normalize-path": {
 | 
					        "normalize-path": {
 | 
				
			||||||
          "version": "3.0.0",
 | 
					          "version": "3.0.0",
 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
					          "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
 | 
				
			||||||
@@ -15676,6 +15730,14 @@
 | 
				
			|||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "requires": {
 | 
					      "requires": {
 | 
				
			||||||
        "minimist": "^1.2.0"
 | 
					        "minimist": "^1.2.0"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "minimist": {
 | 
				
			||||||
 | 
					          "version": "1.2.5",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "kleur": {
 | 
					    "kleur": {
 | 
				
			||||||
@@ -15872,9 +15934,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "minimist": {
 | 
					    "minimist": {
 | 
				
			||||||
      "version": "1.2.6",
 | 
					      "version": "1.2.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==",
 | 
					      "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
      "dev": true
 | 
					      "dev": true
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "ms": {
 | 
					    "ms": {
 | 
				
			||||||
@@ -15895,9 +15957,9 @@
 | 
				
			|||||||
      "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ=="
 | 
					      "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ=="
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node-fetch": {
 | 
					    "node-fetch": {
 | 
				
			||||||
      "version": "2.6.7",
 | 
					      "version": "2.6.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==",
 | 
					      "integrity": "sha512-mmlIVHJEu5rnIxgEgez6b9GgWXbkZj5YZ7fx+2r94a2E+Uirsp6HsPTPlomfdHtpt/B0cdKviwkoaM6pyvUOpQ==",
 | 
				
			||||||
      "requires": {
 | 
					      "requires": {
 | 
				
			||||||
        "whatwg-url": "^5.0.0"
 | 
					        "whatwg-url": "^5.0.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,7 +19,7 @@ export interface IGitAuthHelper {
 | 
				
			|||||||
  configureAuth(): Promise<void>
 | 
					  configureAuth(): Promise<void>
 | 
				
			||||||
  configureGlobalAuth(): Promise<void>
 | 
					  configureGlobalAuth(): Promise<void>
 | 
				
			||||||
  configureSubmoduleAuth(): Promise<void>
 | 
					  configureSubmoduleAuth(): Promise<void>
 | 
				
			||||||
  configureTempGlobalConfig(): Promise<string>
 | 
					  configureTempGlobalConfig(repositoryPath?: string): Promise<string>
 | 
				
			||||||
  removeAuth(): Promise<void>
 | 
					  removeAuth(): Promise<void>
 | 
				
			||||||
  removeGlobalConfig(): Promise<void>
 | 
					  removeGlobalConfig(): Promise<void>
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -81,7 +81,7 @@ class GitAuthHelper {
 | 
				
			|||||||
    await this.configureToken()
 | 
					    await this.configureToken()
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  async configureTempGlobalConfig(): Promise<string> {
 | 
					  async configureTempGlobalConfig(repositoryPath?: string): Promise<string> {
 | 
				
			||||||
    // Already setup global config
 | 
					    // Already setup global config
 | 
				
			||||||
    if (this.temporaryHomePath?.length > 0) {
 | 
					    if (this.temporaryHomePath?.length > 0) {
 | 
				
			||||||
      return path.join(this.temporaryHomePath, '.gitconfig')
 | 
					      return path.join(this.temporaryHomePath, '.gitconfig')
 | 
				
			||||||
@@ -121,6 +121,21 @@ class GitAuthHelper {
 | 
				
			|||||||
    )
 | 
					    )
 | 
				
			||||||
    this.git.setEnvironmentVariable('HOME', this.temporaryHomePath)
 | 
					    this.git.setEnvironmentVariable('HOME', this.temporaryHomePath)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Setup the workspace as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | 
				
			||||||
 | 
					    // Otherwise all git commands we run in a container fail
 | 
				
			||||||
 | 
					    core.info(
 | 
				
			||||||
 | 
					      `Adding working directory to the temporary git global config as a safe directory`
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					    await this.git
 | 
				
			||||||
 | 
					      .config(
 | 
				
			||||||
 | 
					        'safe.directory',
 | 
				
			||||||
 | 
					        repositoryPath ?? this.settings.repositoryPath,
 | 
				
			||||||
 | 
					        true,
 | 
				
			||||||
 | 
					        true
 | 
				
			||||||
 | 
					      )
 | 
				
			||||||
 | 
					      .catch(error => {
 | 
				
			||||||
 | 
					        core.info(`Failed to initialize safe directory with error: ${error}`)
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
    return newGitConfigPath
 | 
					    return newGitConfigPath
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -40,24 +40,7 @@ export async function getSource(settings: IGitSourceSettings): Promise<void> {
 | 
				
			|||||||
  try {
 | 
					  try {
 | 
				
			||||||
    if (git) {
 | 
					    if (git) {
 | 
				
			||||||
      authHelper = gitAuthHelper.createAuthHelper(git, settings)
 | 
					      authHelper = gitAuthHelper.createAuthHelper(git, settings)
 | 
				
			||||||
      if (settings.setSafeDirectory) {
 | 
					 | 
				
			||||||
        // Setup the repository path as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | 
					 | 
				
			||||||
        // Otherwise all git commands we run in a container fail
 | 
					 | 
				
			||||||
      await authHelper.configureTempGlobalConfig()
 | 
					      await authHelper.configureTempGlobalConfig()
 | 
				
			||||||
        core.info(
 | 
					 | 
				
			||||||
          `Adding repository directory to the temporary git global config as a safe directory`
 | 
					 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        await git
 | 
					 | 
				
			||||||
          .config('safe.directory', settings.repositoryPath, true, true)
 | 
					 | 
				
			||||||
          .catch(error => {
 | 
					 | 
				
			||||||
            core.info(
 | 
					 | 
				
			||||||
              `Failed to initialize safe directory with error: ${error}`
 | 
					 | 
				
			||||||
            )
 | 
					 | 
				
			||||||
          })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        stateHelper.setSafeDirectory()
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Prepare existing directory, otherwise recreate
 | 
					    // Prepare existing directory, otherwise recreate
 | 
				
			||||||
@@ -266,21 +249,7 @@ export async function cleanup(repositoryPath: string): Promise<void> {
 | 
				
			|||||||
  // Remove auth
 | 
					  // Remove auth
 | 
				
			||||||
  const authHelper = gitAuthHelper.createAuthHelper(git)
 | 
					  const authHelper = gitAuthHelper.createAuthHelper(git)
 | 
				
			||||||
  try {
 | 
					  try {
 | 
				
			||||||
    if (stateHelper.PostSetSafeDirectory) {
 | 
					    await authHelper.configureTempGlobalConfig(repositoryPath)
 | 
				
			||||||
      // Setup the repository path as a safe directory, so if we pass this into a container job with a different user it doesn't fail
 | 
					 | 
				
			||||||
      // Otherwise all git commands we run in a container fail
 | 
					 | 
				
			||||||
      await authHelper.configureTempGlobalConfig()
 | 
					 | 
				
			||||||
      core.info(
 | 
					 | 
				
			||||||
        `Adding repository directory to the temporary git global config as a safe directory`
 | 
					 | 
				
			||||||
      )
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      await git
 | 
					 | 
				
			||||||
        .config('safe.directory', repositoryPath, true, true)
 | 
					 | 
				
			||||||
        .catch(error => {
 | 
					 | 
				
			||||||
          core.info(`Failed to initialize safe directory with error: ${error}`)
 | 
					 | 
				
			||||||
        })
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    await authHelper.removeAuth()
 | 
					    await authHelper.removeAuth()
 | 
				
			||||||
  } finally {
 | 
					  } finally {
 | 
				
			||||||
    await authHelper.removeGlobalConfig()
 | 
					    await authHelper.removeGlobalConfig()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -78,9 +78,4 @@ export interface IGitSourceSettings {
 | 
				
			|||||||
   * Organization ID for the currently running workflow (used for auth settings)
 | 
					   * Organization ID for the currently running workflow (used for auth settings)
 | 
				
			||||||
   */
 | 
					   */
 | 
				
			||||||
  workflowOrganizationId: number | undefined
 | 
					  workflowOrganizationId: number | undefined
 | 
				
			||||||
 | 
					 | 
				
			||||||
  /**
 | 
					 | 
				
			||||||
   * Indicates whether to add repositoryPath as safe.directory in git global config
 | 
					 | 
				
			||||||
   */
 | 
					 | 
				
			||||||
  setSafeDirectory: boolean
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -122,8 +122,5 @@ export async function getInputs(): Promise<IGitSourceSettings> {
 | 
				
			|||||||
  // Workflow organization ID
 | 
					  // Workflow organization ID
 | 
				
			||||||
  result.workflowOrganizationId = await workflowContextHelper.getOrganizationId()
 | 
					  result.workflowOrganizationId = await workflowContextHelper.getOrganizationId()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  // Set safe.directory in git global config.
 | 
					 | 
				
			||||||
  result.setSafeDirectory =
 | 
					 | 
				
			||||||
    (core.getInput('set-safe-directory') || 'true').toUpperCase() === 'TRUE'
 | 
					 | 
				
			||||||
  return result
 | 
					  return result
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -120,7 +120,7 @@ function updateUsage(
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
updateUsage(
 | 
					updateUsage(
 | 
				
			||||||
  'actions/checkout@v3',
 | 
					  'actions/checkout@v2',
 | 
				
			||||||
  path.join(__dirname, '..', '..', 'action.yml'),
 | 
					  path.join(__dirname, '..', '..', 'action.yml'),
 | 
				
			||||||
  path.join(__dirname, '..', '..', 'README.md')
 | 
					  path.join(__dirname, '..', '..', 'README.md')
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,4 +5,4 @@ set -e
 | 
				
			|||||||
src/misc/licensed-download.sh
 | 
					src/misc/licensed-download.sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
echo 'Running: licensed cached'
 | 
					echo 'Running: licensed cached'
 | 
				
			||||||
_temp/licensed-3.6.0/licensed status
 | 
					_temp/licensed-3.3.1/licensed status
 | 
				
			||||||
@@ -2,23 +2,23 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
set -e
 | 
					set -e
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ ! -f _temp/licensed-3.6.0.done ]; then
 | 
					if [ ! -f _temp/licensed-3.3.1.done ]; then
 | 
				
			||||||
  echo 'Clearing temp'
 | 
					  echo 'Clearing temp'
 | 
				
			||||||
  rm -rf _temp/licensed-3.6.0 || true
 | 
					  rm -rf _temp/licensed-3.3.1 || true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  echo 'Downloading licensed'
 | 
					  echo 'Downloading licensed'
 | 
				
			||||||
  mkdir -p _temp/licensed-3.6.0
 | 
					  mkdir -p _temp/licensed-3.3.1
 | 
				
			||||||
  pushd _temp/licensed-3.6.0
 | 
					  pushd _temp/licensed-3.3.1
 | 
				
			||||||
  if [[ "$OSTYPE" == "darwin"* ]]; then
 | 
					  if [[ "$OSTYPE" == "darwin"* ]]; then
 | 
				
			||||||
    curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.6.0/licensed-3.6.0-darwin-x64.tar.gz
 | 
					    curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.3.1/licensed-3.3.1-darwin-x64.tar.gz
 | 
				
			||||||
  else
 | 
					  else
 | 
				
			||||||
    curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.6.0/licensed-3.6.0-linux-x64.tar.gz
 | 
					    curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.3.1/licensed-3.3.1-linux-x64.tar.gz
 | 
				
			||||||
  fi
 | 
					  fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  echo 'Extracting licenesed'
 | 
					  echo 'Extracting licenesed'
 | 
				
			||||||
  tar -xzf licensed.tar.gz
 | 
					  tar -xzf licensed.tar.gz
 | 
				
			||||||
  popd
 | 
					  popd
 | 
				
			||||||
  touch _temp/licensed-3.6.0.done
 | 
					  touch _temp/licensed-3.3.1.done
 | 
				
			||||||
else
 | 
					else
 | 
				
			||||||
  echo 'Licensed already downloaded'
 | 
					  echo 'Licensed already downloaded'
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,4 +5,4 @@ set -e
 | 
				
			|||||||
src/misc/licensed-download.sh
 | 
					src/misc/licensed-download.sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
echo 'Running: licensed cached'
 | 
					echo 'Running: licensed cached'
 | 
				
			||||||
_temp/licensed-3.6.0/licensed cache
 | 
					_temp/licensed-3.3.1/licensed cache
 | 
				
			||||||
@@ -11,12 +11,6 @@ export const IsPost = !!process.env['STATE_isPost']
 | 
				
			|||||||
export const RepositoryPath =
 | 
					export const RepositoryPath =
 | 
				
			||||||
  (process.env['STATE_repositoryPath'] as string) || ''
 | 
					  (process.env['STATE_repositoryPath'] as string) || ''
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * The set-safe-directory for the POST action. The value is set if input: 'safe-directory' is set during the MAIN action.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
export const PostSetSafeDirectory =
 | 
					 | 
				
			||||||
  (process.env['STATE_setSafeDirectory'] as string) === 'true'
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * The SSH key path for the POST action. The value is empty during the MAIN action.
 | 
					 * The SSH key path for the POST action. The value is empty during the MAIN action.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@@ -57,13 +51,6 @@ export function setSshKnownHostsPath(sshKnownHostsPath: string) {
 | 
				
			|||||||
  )
 | 
					  )
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Save the sef-safe-directory input so the POST action can retrieve the value.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
export function setSafeDirectory() {
 | 
					 | 
				
			||||||
  coreCommand.issueCommand('save-state', {name: 'setSafeDirectory'}, 'true')
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Publish a variable so that when the POST action runs, it can determine it should run the cleanup logic.
 | 
					// Publish a variable so that when the POST action runs, it can determine it should run the cleanup logic.
 | 
				
			||||||
// This is necessary since we don't have a separate entry point.
 | 
					// This is necessary since we don't have a separate entry point.
 | 
				
			||||||
if (!IsPost) {
 | 
					if (!IsPost) {
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user