Compare commits
	
		
			15 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 4241e60706 | ||
|   | b03d7257ae | ||
|   | f042d742db | ||
|   | ad9a378b7f | ||
|   | 172d4632fe | ||
|   | 93e17a47f9 | ||
|   | c6ff96b7f6 | ||
|   | 7622c01418 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9ba62064d2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f314a5399e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 699fa1181c | ||
|   | 9f34cc3e55 | ||
|   | 917f8b81df | ||
|   | 78e7f475f3 | ||
|   | dfde1f50eb | 
							
								
								
									
										2
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -100,7 +100,7 @@ jobs: | ||||
|  | ||||
|       - name: Get changed files | ||||
|         id: changed-files | ||||
|         uses: tj-actions/changed-files@v41 | ||||
|         uses: tj-actions/changed-files@v45 | ||||
|         with: | ||||
|           since_last_remote_commit: true | ||||
|           separator: "," | ||||
|   | ||||
							
								
								
									
										33
									
								
								.github/workflows/goreleaser.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								.github/workflows/goreleaser.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| name: Goreleaser | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     tags: | ||||
|       - "*" | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|  | ||||
| jobs: | ||||
|   goreleaser: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Setup go | ||||
|         uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: "^1" | ||||
|  | ||||
|       - name: Run GoReleaser | ||||
|         uses: goreleaser/goreleaser-action@v6 | ||||
|         with: | ||||
|           # either 'goreleaser' (default) or 'goreleaser-pro' | ||||
|           distribution: goreleaser | ||||
|           version: latest | ||||
|           args: release --clean | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
							
								
								
									
										28
									
								
								.goreleaser.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								.goreleaser.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| builds: | ||||
|   - # If true, skip the build. | ||||
|     # Useful for library projects. | ||||
|     # Default is false | ||||
|     skip: true | ||||
|  | ||||
| changelog: | ||||
|   use: github | ||||
|   groups: | ||||
|     - title: Features | ||||
|       regexp: "^.*feat[(\\w)]*:+.*$" | ||||
|       order: 0 | ||||
|     - title: "Bug fixes" | ||||
|       regexp: "^.*fix[(\\w)]*:+.*$" | ||||
|       order: 1 | ||||
|     - title: "Enhancements" | ||||
|       regexp: "^.*chore[(\\w)]*:+.*$" | ||||
|       order: 2 | ||||
|     - title: "Refactor" | ||||
|       regexp: "^.*refactor[(\\w)]*:+.*$" | ||||
|       order: 3 | ||||
|     - title: "Build process updates" | ||||
|       regexp: ^.*?(build|ci)(\(.+\))??!?:.+$ | ||||
|       order: 4 | ||||
|     - title: "Documentation updates" | ||||
|       regexp: ^.*?docs?(\(.+\))??!?:.+$ | ||||
|       order: 4 | ||||
|     - title: Others | ||||
| @@ -1,4 +1,4 @@ | ||||
| FROM ghcr.io/appleboy/drone-scp:1.6.13 | ||||
| FROM ghcr.io/appleboy/drone-scp:1.6.14 | ||||
|  | ||||
| COPY entrypoint.sh /bin/entrypoint.sh | ||||
|  | ||||
|   | ||||
							
								
								
									
										145
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										145
									
								
								README.md
									
									
									
									
									
								
							| @@ -14,59 +14,60 @@ Copy files and artifacts via SSH: | ||||
| name: scp files | ||||
| on: [push] | ||||
| jobs: | ||||
|  | ||||
|   build: | ||||
|     name: Build | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v3 | ||||
|     - name: copy file via ssh password | ||||
|       uses: appleboy/scp-action@v0.1.5 | ||||
|       with: | ||||
|         host: ${{ secrets.HOST }} | ||||
|         username: ${{ secrets.USERNAME }} | ||||
|         password: ${{ secrets.PASSWORD }} | ||||
|         port: ${{ secrets.PORT }} | ||||
|         source: "tests/a.txt,tests/b.txt" | ||||
|         target: your_server_target_folder_path | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: copy file via ssh password | ||||
|         uses: appleboy/scp-action@v0.1.7 | ||||
|         with: | ||||
|           host: ${{ secrets.HOST }} | ||||
|           username: ${{ secrets.USERNAME }} | ||||
|           password: ${{ secrets.PASSWORD }} | ||||
|           port: ${{ secrets.PORT }} | ||||
|           source: "tests/a.txt,tests/b.txt" | ||||
|           target: your_server_target_folder_path | ||||
| ``` | ||||
|  | ||||
| ## Input variables | ||||
|  | ||||
| See the [action.yml](./action.yml) file for more detail information. | ||||
|  | ||||
| * host - scp remote host | ||||
| * port - scp remote port, default is `22` | ||||
| * username - scp username | ||||
| * password - scp password | ||||
| * passphrase - the passphrase is usually to encrypt the private key | ||||
| * fingerprint - fingerprint SHA256 of the host public key, default is to skip verification | ||||
| * timeout - timeout for ssh to remote host, default is `30s` | ||||
| * command_timeout - timeout for scp command, default is `10m` | ||||
| * key - content of ssh private key. ex raw content of ~/.ssh/id_rsa | ||||
| * key_path - path of ssh private key | ||||
| * target - target path on the server, must be a directory (**required**) | ||||
| * source - scp file list (**required**) | ||||
| * rm - remove target folder before upload data, default is `false` | ||||
| * strip_components - remove the specified number of leading path elements. | ||||
| * overwrite - use `--overwrite` flag with tar, overwrite existing files when extracting | ||||
| * tar_tmp_path - temporary path for tar file on the dest host | ||||
| * tar_exec - path to tar executable on the dest host. default is `tar` | ||||
| * tar_dereference - use `--dereference` flag with tar, follow symlinks; archive and dump the files they point to | ||||
| * use_insecure_cipher - include more ciphers with use_insecure_cipher (see [#15](https://github.com/appleboy/scp-action/issues/15)) | ||||
| - host - scp remote host | ||||
| - port - scp remote port, default is `22` | ||||
| - username - scp username | ||||
| - password - scp password | ||||
| - passphrase - the passphrase is usually to encrypt the private key | ||||
| - protocol - The IP protocol to use. Valid values are `tcp`. `tcp4` or `tcp6`. Default to `tcp`. | ||||
| - fingerprint - fingerprint SHA256 of the host public key, default is to skip verification | ||||
| - timeout - timeout for ssh to remote host, default is `30s` | ||||
| - command_timeout - timeout for scp command, default is `10m` | ||||
| - key - content of ssh private key. ex raw content of ~/.ssh/id_rsa | ||||
| - key_path - path of ssh private key | ||||
| - target - target path on the server, must be a directory (**required**) | ||||
| - source - scp file list (**required**) | ||||
| - rm - remove target folder before upload data, default is `false` | ||||
| - strip_components - remove the specified number of leading path elements. | ||||
| - overwrite - use `--overwrite` flag with tar, overwrite existing files when extracting | ||||
| - tar_tmp_path - temporary path for tar file on the dest host | ||||
| - tar_exec - path to tar executable on the dest host. default is `tar` | ||||
| - tar_dereference - use `--dereference` flag with tar, follow symlinks; archive and dump the files they point to | ||||
| - use_insecure_cipher - include more ciphers with use_insecure_cipher (see [#15](https://github.com/appleboy/scp-action/issues/15)) | ||||
|  | ||||
| SSH Proxy Setting: | ||||
|  | ||||
| * proxy_host - proxy host | ||||
| * proxy_port - proxy port, default is `22` | ||||
| * proxy_username - proxy username | ||||
| * proxy_password - proxy password | ||||
| * proxy_passphrase - the passphrase is usually to encrypt the private key | ||||
| * proxy_timeout - timeout for ssh to proxy host, default is `30s` | ||||
| * proxy_key - content of ssh proxy private key. | ||||
| * proxy_key_path - path of ssh proxy private key | ||||
| * proxy_fingerprint - fingerprint SHA256 of the host public key, default is to skip verification | ||||
| * proxy_use_insecure_cipher - include more ciphers with use_insecure_cipher (see [#15](https://github.com/appleboy/scp-action/issues/15)) | ||||
| - proxy_host - proxy host | ||||
| - proxy_port - proxy port, default is `22` | ||||
| - proxy_username - proxy username | ||||
| - proxy_password - proxy password | ||||
| - proxy_protocol - The IP protocol to use. Valid values are `tcp`. `tcp4` or `tcp6`. Default to `tcp`. | ||||
| - proxy_passphrase - the passphrase is usually to encrypt the private key | ||||
| - proxy_timeout - timeout for ssh to proxy host, default is `30s` | ||||
| - proxy_key - content of ssh proxy private key. | ||||
| - proxy_key_path - path of ssh proxy private key | ||||
| - proxy_fingerprint - fingerprint SHA256 of the host public key, default is to skip verification | ||||
| - proxy_use_insecure_cipher - include more ciphers with use_insecure_cipher (see [#15](https://github.com/appleboy/scp-action/issues/15)) | ||||
|  | ||||
| ## Setting up a SSH Key | ||||
|  | ||||
| @@ -106,9 +107,9 @@ See the detail information about [SSH login without password](http://www.linuxpr | ||||
|  | ||||
| **A note** from one of our readers: Depending on your version of SSH you might also have to do the following changes: | ||||
|  | ||||
| * Put the public key in `.ssh/authorized_keys2` | ||||
| * Change the permissions of `.ssh` to 700 | ||||
| * Change the permissions of `.ssh/authorized_keys2` to 640 | ||||
| - Put the public key in `.ssh/authorized_keys2` | ||||
| - Change the permissions of `.ssh` to 700 | ||||
| - Change the permissions of `.ssh/authorized_keys2` to 640 | ||||
|  | ||||
| ### If you are using OpenSSH | ||||
|  | ||||
| @@ -137,7 +138,7 @@ Copy file via a SSH password: | ||||
|  | ||||
| ```yaml | ||||
| - name: copy file via ssh password | ||||
|   uses: appleboy/scp-action@v0.1.5 | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
|     host: example.com | ||||
|     username: foo | ||||
| @@ -147,11 +148,25 @@ Copy file via a SSH password: | ||||
|     target: your_server_target_folder_path | ||||
| ``` | ||||
|  | ||||
| Using the environment variables | ||||
|  | ||||
| ```yaml | ||||
| - name: copy file via ssh password | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
|     host: ${{ env.HOST }} | ||||
|     username: ${{ env.USERNAME }} | ||||
|     password: ${{ secrets.PASSWORD }} | ||||
|     port: ${{ env.PORT }} | ||||
|     source: "tests/a.txt,tests/b.txt" | ||||
|     target: ${{ env.TARGET_PATH }} | ||||
| ``` | ||||
|  | ||||
| Copy file via a SSH key: | ||||
|  | ||||
| ```yaml | ||||
| - name: copy file via ssh key | ||||
|   uses: appleboy/scp-action@v0.1.5 | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
|     host: ${{ secrets.HOST }} | ||||
|     username: ${{ secrets.USERNAME }} | ||||
| @@ -165,7 +180,7 @@ Example configuration for ignore list: | ||||
|  | ||||
| ```yaml | ||||
| - name: copy file via ssh key | ||||
|   uses: appleboy/scp-action@v0.1.5 | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
|     host: ${{ secrets.HOST }} | ||||
|     username: ${{ secrets.USERNAME }} | ||||
| @@ -178,7 +193,7 @@ Example configuration for ignore list: | ||||
| Example configuration for multiple servers: | ||||
|  | ||||
| ```diff | ||||
|   uses: appleboy/scp-action@v0.1.5 | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
| -   host: "example.com" | ||||
| +   host: "foo.com,bar.com" | ||||
| @@ -192,7 +207,7 @@ Example configuration for multiple servers: | ||||
| Example configuration for exclude custom files: | ||||
|  | ||||
| ```yaml | ||||
|   uses: appleboy/scp-action@v0.1.5 | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
|     host: "example.com" | ||||
|     username: foo | ||||
| @@ -206,27 +221,27 @@ Example configuration for exclude custom files: | ||||
| Upload artifact files to remote server: | ||||
|  | ||||
| ```yaml | ||||
|   deploy: | ||||
|     name: deploy artifact | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
| deploy: | ||||
|   name: deploy artifact | ||||
|   runs-on: ubuntu-latest | ||||
|   steps: | ||||
|     - name: checkout | ||||
|       uses: actions/checkout@v3 | ||||
|       uses: actions/checkout@v4 | ||||
|  | ||||
|     - run: echo hello > world.txt | ||||
|  | ||||
|     - uses: actions/upload-artifact@v3 | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       with: | ||||
|         name: my-artifact | ||||
|         path: world.txt | ||||
|  | ||||
|     - uses: actions/download-artifact@v3 | ||||
|     - uses: actions/download-artifact@v4 | ||||
|       with: | ||||
|         name: my-artifact | ||||
|         path: distfiles | ||||
|  | ||||
|     - name: copy file to server | ||||
|       uses: appleboy/scp-action@v0.1.5 | ||||
|       uses: appleboy/scp-action@v0.1.7 | ||||
|       with: | ||||
|         host: ${{ secrets.HOST }} | ||||
|         username: ${{ secrets.USERNAME }} | ||||
| @@ -240,7 +255,7 @@ Remove the specified number of leading path elements: | ||||
|  | ||||
| ```yaml | ||||
| - name: remove the specified number of leading path elements | ||||
|   uses: appleboy/scp-action@v0.1.5 | ||||
|   uses: appleboy/scp-action@v0.1.7 | ||||
|   with: | ||||
|     host: ${{ secrets.HOST }} | ||||
|     username: ${{ secrets.USERNAME }} | ||||
| @@ -271,12 +286,12 @@ foobar | ||||
| Only copy files that are newer than the corresponding destination files: | ||||
|  | ||||
| ```yaml | ||||
|   changes: | ||||
|     name: test changed-files | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
| changes: | ||||
|   name: test changed-files | ||||
|   runs-on: ubuntu-latest | ||||
|   steps: | ||||
|     - name: checkout | ||||
|       uses: actions/checkout@v3 | ||||
|       uses: actions/checkout@v4 | ||||
|  | ||||
|     - name: Get changed files | ||||
|       id: changed-files | ||||
| @@ -286,7 +301,7 @@ Only copy files that are newer than the corresponding destination files: | ||||
|         separator: "," | ||||
|  | ||||
|     - name: copy file to server | ||||
|       uses: appleboy/scp-action@v0.1.5 | ||||
|       uses: appleboy/scp-action@v0.1.7 | ||||
|       with: | ||||
|         host: ${{ secrets.HOST }} | ||||
|         username: ${{ secrets.USERNAME }} | ||||
| @@ -300,7 +315,7 @@ Protecting a Private Key. The purpose of the passphrase is usually to encrypt th | ||||
|  | ||||
| ```diff | ||||
|   - name: ssh key with passphrase | ||||
|     uses: appleboy/scp-action@v0.1.5 | ||||
|     uses: appleboy/scp-action@v0.1.7 | ||||
|     with: | ||||
|       host: ${{ secrets.HOST }} | ||||
|       username: ${{ secrets.USERNAME }} | ||||
| @@ -329,7 +344,7 @@ Convert the target path to a Unix path: `/c/path/to/target/` | ||||
|  | ||||
| ```diff | ||||
|   - name: Copy to Windows | ||||
|       uses: appleboy/scp-action@v0.1.5 | ||||
|       uses: appleboy/scp-action@v0.1.7 | ||||
|       with: | ||||
|         host: ${{ secrets.HOST }} | ||||
|         username: ${{ secrets.USERNAME }} | ||||
|   | ||||
							
								
								
									
										90
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										90
									
								
								action.yml
									
									
									
									
									
								
							| @@ -1,84 +1,80 @@ | ||||
| name: 'SCP Command to Transfer Files' | ||||
| description: 'How to Use SCP Command to Transfer Files/Folders in Linux' | ||||
| author: 'Bo-Yi Wu' | ||||
| name: "SCP Command to Transfer Files" | ||||
| description: "How to Use SCP Command to Transfer Files/Folders in Linux" | ||||
| author: "Bo-Yi Wu" | ||||
| inputs: | ||||
|   host: | ||||
|     description: 'scp remote host' | ||||
|     description: "scp remote host" | ||||
|   port: | ||||
|     description: 'scp remote port' | ||||
|     default: 22 | ||||
|     description: "scp remote port" | ||||
|     default: "22" | ||||
|   username: | ||||
|     description: 'scp username' | ||||
|     description: "scp username" | ||||
|   password: | ||||
|     description: 'scp password' | ||||
|     description: "scp password" | ||||
|   protocol: | ||||
|     description: "The IP protocol to use. Valid values are 'tcp'. 'tcp4' or 'tcp6'. Default to tcp." | ||||
|     default: "tcp" | ||||
|   timeout: | ||||
|     description: 'timeout for ssh to remote host' | ||||
|     description: "timeout for ssh to remote host" | ||||
|     default: "30s" | ||||
|   command_timeout: | ||||
|     description: 'timeout for scp command' | ||||
|     description: "timeout for scp command" | ||||
|     default: "10m" | ||||
|   key: | ||||
|     description: 'content of ssh private key. ex raw content of ~/.ssh/id_rsa' | ||||
|     description: "content of ssh private key. ex raw content of ~/.ssh/id_rsa" | ||||
|   key_path: | ||||
|     description: 'path of ssh private key' | ||||
|     description: "path of ssh private key" | ||||
|   passphrase: | ||||
|     description: 'ssh key passphrase' | ||||
|     description: "ssh key passphrase" | ||||
|   fingerprint: | ||||
|     description: 'fingerprint SHA256 of the host public key, default is to skip verification' | ||||
|     description: "fingerprint SHA256 of the host public key, default is to skip verification" | ||||
|   use_insecure_cipher: | ||||
|     description: 'include more ciphers with use_insecure_cipher' | ||||
|     default: false | ||||
|     description: "include more ciphers with use_insecure_cipher" | ||||
|   target: | ||||
|     description: 'target path on the server, must be a directory path.' | ||||
|     description: "target path on the server, must be a directory path." | ||||
|   source: | ||||
|     description: 'scp file list' | ||||
|     description: "scp file list" | ||||
|   rm: | ||||
|     description: 'remove target folder before upload data' | ||||
|     default: false | ||||
|     description: "remove target folder before upload data" | ||||
|   debug: | ||||
|     description: 'enable debug message' | ||||
|     default: false | ||||
|     description: "enable debug message" | ||||
|   strip_components: | ||||
|     description: 'remove the specified number of leading path elements' | ||||
|     default: 0 | ||||
|     description: "remove the specified number of leading path elements" | ||||
|   overwrite: | ||||
|     description: 'use --overwrite flag with tar' | ||||
|     default: false | ||||
|     description: "use --overwrite flag with tar" | ||||
|   tar_dereference: | ||||
|     description: 'use --dereference flag with tar' | ||||
|     default: false | ||||
|     description: "use --dereference flag with tar" | ||||
|   tar_tmp_path: | ||||
|     description: 'temporary path for tar file on the dest host' | ||||
|     description: "temporary path for tar file on the dest host" | ||||
|   tar_exec: | ||||
|     description: 'temporary path for tar file on the dest host' | ||||
|     default: 'tar' | ||||
|     description: "temporary path for tar file on the dest host" | ||||
|     default: "tar" | ||||
|   proxy_host: | ||||
|     description: 'ssh proxy remote host' | ||||
|     description: "ssh proxy remote host" | ||||
|   proxy_port: | ||||
|     description: 'ssh proxy remote port' | ||||
|     default: 22 | ||||
|     description: "ssh proxy remote port" | ||||
|     default: "22" | ||||
|   proxy_username: | ||||
|     description: 'ssh proxy username' | ||||
|     description: "ssh proxy username" | ||||
|   proxy_password: | ||||
|     description: 'ssh proxy password' | ||||
|     description: "ssh proxy password" | ||||
|   proxy_passphrase: | ||||
|     description: 'ssh proxy key passphrase' | ||||
|     description: "ssh proxy key passphrase" | ||||
|   proxy_timeout: | ||||
|     description: 'timeout for ssh to proxy host' | ||||
|     description: "timeout for ssh to proxy host" | ||||
|     default: "30s" | ||||
|   proxy_key: | ||||
|     description: 'content of ssh proxy private key. ex raw content of ~/.ssh/id_rsa' | ||||
|     description: "content of ssh proxy private key. ex raw content of ~/.ssh/id_rsa" | ||||
|   proxy_key_path: | ||||
|     description: 'path of ssh proxy private key' | ||||
|     description: "path of ssh proxy private key" | ||||
|   proxy_fingerprint: | ||||
|     description: 'fingerprint SHA256 of the host public key, default is to skip verification' | ||||
|     description: "fingerprint SHA256 of the host public key, default is to skip verification" | ||||
|   proxy_use_insecure_cipher: | ||||
|     description: 'include more ciphers with use_insecure_cipher' | ||||
|     default: false | ||||
|     description: "include more ciphers with use_insecure_cipher" | ||||
| runs: | ||||
|   using: 'docker' | ||||
|   image: 'Dockerfile' | ||||
|   using: "docker" | ||||
|   image: "Dockerfile" | ||||
|  | ||||
| branding: | ||||
|   icon: 'copy' | ||||
|   color: 'gray-dark' | ||||
|   icon: "copy" | ||||
|   color: "gray-dark" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user