36 Commits

Author SHA1 Message Date
JackWhh
7d36dbb31e 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 07:52:28 +00:00
JackWhh
dcd5527d19 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 07:47:03 +00:00
JackWhh
9e32c074c6 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 07:39:35 +00:00
JackWhh
527eabc0b7 ·
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 07:33:01 +00:00
JackWhh
90843aab03 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 07:30:13 +00:00
JackWhh
6009d21da7 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 07:25:54 +00:00
JackWhh
6ed6f6ca38 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 06:21:31 +00:00
JackWhh
34d9c5f647 1
Signed-off-by: JackWhh <5264499+jack_whh@user.noreply.gitee.com>
2024-07-18 06:14:10 +00:00
wl
89e97d73f9 1. update readme 2023-08-21 14:45:05 +08:00
wl
675755b272 1. Update readme about issues #51 2023-03-17 10:12:18 +08:00
wl
067de34294 Merge pull request #34 from alfreddagenais/master
Ajustement for Readme file
2022-07-14 13:42:29 +08:00
Alfred Dagenais
834e1ad841 CHG: ajustement wording explication 2022-07-13 16:56:43 -04:00
Alfred Dagenais
259119b427 ADD: s 2022-07-13 16:55:23 -04:00
Alfred Dagenais
f944ea4c67 CHG: ajustement tab vs spacing 2022-07-13 16:54:30 -04:00
Alfred Dagenais
7589349f24 CHG: ajustement into documentation 2022-07-13 16:49:23 -04:00
wl
da88a4dbe9 fix password typo 2022-07-01 09:29:31 +08:00
wl
e57406ff6c 1. update readme 2022-07-01 09:26:31 +08:00
wl
6596a6c48c 1. support password 2022-07-01 09:23:58 +08:00
wl
33436f92f1 1. require remote_path 2022-06-29 21:49:29 +08:00
wl
3586e619fa 1. Option to let delete existing files 2022-06-29 20:47:36 +08:00
wl
8392b571c7 Merge pull request #17 from Bunyod545/patch-1
Docker file Alpine version changed to 3.13
2022-06-29 13:31:52 +08:00
wl
c6e4d76ad9 Merge pull request #26 from leoppro/master
Add an option named `sftp_only` to connect via sftp only
2022-02-22 08:43:07 +08:00
leoppro
3a6bd36ae1 Add an option named sftp_only to connect via sftp only 2021-09-19 20:50:48 +08:00
Bunyod545
00c712f732 Docker file Alpine version changed to 3.13 2021-06-08 15:53:46 +05:00
wl
28d6168ebf 1. fix mkdir issue 2021-03-31 12:50:09 +08:00
wl
f19d10cf6b 1. fix mkdir issue 2021-03-31 12:06:37 +08:00
wl
cf8d9e5b50 Merge pull request #8 from stan-chen/fix-ssh-port
mkdir cannot connect non 22 port
2020-11-26 09:15:07 +08:00
StanleyChen
6ff9f12bc8 mkdir cannot connect non 22 port 2020-11-10 08:23:18 +08:00
wl
b2206dcb19 Merge pull request #4 from JulianGro/ssh_mkdir
Create directory if needed
2020-07-05 15:43:27 +08:00
wl
19ad014b34 Merge pull request #3 from JulianGro/readme
Fix first example in readme
2020-07-05 15:33:42 +08:00
Julian Groß
1f1ab26f78 remove "make sure dir exists" 2020-07-03 11:35:24 +02:00
Julian Groß
564673d595 disable StrictHostKeyChecking 2020-07-03 11:28:33 +02:00
Julian Groß
7fd32bff94 make directory when needed 2020-07-03 11:17:29 +02:00
motofckr9k
610ec6e1c9 Fix first example in readme 2020-07-03 03:36:27 +02:00
william
f1b3556b75 1. update readme 2020-02-18 22:57:55 +08:00
william
6b5c2a4271 1. update readme 2020-02-18 10:09:16 +08:00
9 changed files with 200 additions and 56 deletions

23
.github/workflows/main.yml vendored Normal file
View File

@@ -0,0 +1,23 @@
name: Continuous Deploy
on: [push]
jobs:
deploy_job:
runs-on: ubuntu-latest
name: sftp
steps:
- name: Checkout
uses: actions/checkout@v2
- name: deploy file to server
uses: ./ # Uses an action in the root directory
with:
username: 'wl'
server: '${{ secrets.MAC_IP }}'
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
local_path: './*'
remote_path: '/Users/wl/Downloads/t/a'
sftpArgs: '-o ConnectTimeout=5'
# sftp_only: true
password: ${{secrets.SSH_PASSWORD}}
# delete_remote_files: true

View File

@@ -1,5 +1,8 @@
# Container image that runs your code
FROM alpine:3.10
FROM alpine:3.13
RUN echo "http://mirrors.aliyun.com/alpine/v3.13/main" > /etc/apk/repositories
RUN echo "http://mirrors.aliyun.com/alpine/v3.13/community" >> /etc/apk/repositories
# Copies your code file from your action repository to the filesystem path `/` of the container
COPY entrypoint.sh /entrypoint.sh
@@ -12,4 +15,4 @@ RUN apk add --no-cache openssh
# Code file to execute when the docker container starts up (`entrypoint.sh`)
ENTRYPOINT ["/entrypoint.sh"]
ENTRYPOINT ["/entrypoint.sh"]

145
README.md
View File

@@ -2,56 +2,113 @@
> Use this action to deploy your files to server using `SSH Private Key`
> 使用此`action`部署你的项目到服务器上,`仅支持密钥对连接`
> 使用此`action`部署你的项目到服务器上,中文介绍链接:[使用Github Action 部署项目到云服务器](https://zhuanlan.zhihu.com/p/107545396)
## 1. Inputs
| Name | Required | Default | Description |
|------------------------|----------------------|---------|-----------------------------------------------|
`username` | yes| | SSH username
`server` | yes| | Remote host
`port`| yes | 22 | Remote host port
`ssh_private_key`| no| | You can copy private key from your `ssh_private_key` file, and save to`repo/settings/secrets`![](./resource/secret.jpg)
`local_path`| yes| ./* | `local_path` of you project, if you want put single file:use path like `./myfile`, if you want put directory: use path like `./static/*`, it will put all files under `static` directory. Default to `./*`(will put all files in your repo).
`remote_path`|yes|| Remote path
`sftp_only`| no| | If your port only accepts the sftp protocol, set this option to `true`. However, please note that when this option is set to `true`, the remote folder will not be created automatically.
<strike>args</strike> `sftpArgs` | no| | other args yor want to use of sftp, E.g.`-o ConnectTimeout=5`
`delete_remote_files` | no | false | Set to `true` will delete remote path folder and all files in it.
`password`| no| | SSH passswordIf a password is set, `ssh_private_key` is ignored. `for @v1.2.4 and greater`
> **Warning**
> Be careful when use `delete_remote_files`, This will delete remote path folder and all files in it
-----
## 2.Action Examples
```yaml
on: [push]
jobs:
deploy_job:
runs-on: ubuntu-latest
name: deploy
steps:
- name: Checkout
uses: actions/checkout@v2
- name: deploy file
uses: wlixcc/SFTP-Deploy-Action@v1.2.4
with:
username: 'root'
server: 'your server ip'
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
local_path: './static/*'
remote_path: '/var/www/app'
sftpArgs: '-o ConnectTimeout=5'
```
```yaml
on: [push]
jobs:
deploy_job:
runs-on: ubuntu-latest
name: deploy
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Deploy file
uses: wlixcc/SFTP-Deploy-Action@v1.2.4
with:
username: ${{ secrets.FTP_USERNAME }}
server: ${{ secrets.FTP_SERVER }}
port: ${{ secrets.FTP_PORT }}
local_path: './static/*'
remote_path: '/var/www/app'
sftp_only: true
password: ${{ secrets.FTP_PASSWORD }}
```
## 3. [Deploy React App Example](https://github.com/wlixcc/React-Deploy)
## Inputs
```yaml
on: [push]
### `username`
jobs:
deploy_job:
runs-on: ubuntu-latest
name: build&deploy
steps:
# To use this repository's private action, you must check out the repository
- name: Checkout
uses: actions/checkout@v2
> **Required** sftp username.
- name: Install Dependencies
run: yarn
- name: Build
run: yarn build
### `server`
- name: deploy file to server
uses: wlixcc/SFTP-Deploy-Action@v1.2.4
with:
username: 'root'
server: '${{ secrets.SERVER_IP }}'
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
local_path: './build/*'
remote_path: '/var/www/react-app'
sftpArgs: '-o ConnectTimeout=5'
```
> **Required** sftp server address.
![](./resource/reactExample.jpg)
--------
### `port`
## 4.Invalid format? You need keep format
> sftp srever port , default `22`.
If you use the Ed25519 algorithm to generate an SSH key pair `ssh-keygen -t ed25519 -C "your_email@example.com"`,
you need to note that the last line of the private key is a blank line. You need to keep this line when adding Repository secrets, otherwise it may lead to an `invalid format` error.
![](./resource/keepformat.jpg)
### `ssh_private_key`
> **Required** you can copy private_key from your `ssh_private_key.pem file`, keep format, and save at`repo/settings/secrets`
### `local_path`
> **Required** `local_path` of you project, if you want put single file:use path like `./myfile`, if you want put directory: use path like `./static/*`, it will put all files under `static` directory. Default to `./*`(will put all files in your repo).
### `remote_path`
> **Required** remote_path
### `args`
> args of sftp cmd, E.g.`-o ConnectTimeout=5`
## Example usage
on: [push]
jobs:
deploy_job:
runs-on: ubuntu-latest
name: deploy
steps:
- name: Checkout
uses: actions/checkout@v2
- name: deploy file
uses: ./ # Uses an action in the root directory
with:
username: 'root'
server: 'your server ip'
private_key: ${{ secrets.SSH_PRIVATE_KEY }}
local_path: './static/*'
remote_path: '/var/www/app' #make sure dir exist
args: '-o ConnectTimeout=5'

View File

@@ -22,11 +22,20 @@ inputs:
remote_path:
description: 'files will copy to under remote_path'
required: true
default: /
args:
sftp_only:
description: 'connection via sftp protocol only'
required: false
default: false
sftpArgs:
description: 'sftp args'
required: false
delete_remote_files:
description: 'This operation will delete all files in the remote path before upload. Please be careful set this to true'
required: false
default: false
password:
description: "SSH passswordIf a password is set, the secret key pair is ignored"
required: false
runs:
@@ -39,7 +48,10 @@ runs:
- ${{ inputs.ssh_private_key }}
- ${{ inputs.local_path }}
- ${{ inputs.remote_path }}
- ${{ inputs.args }}
- ${{ inputs.sftp_only }}
- ${{ inputs.sftpArgs }}
- ${{ inputs.delete_remote_files }}
- ${{ inputs.password }}
branding:
icon: 'upload-cloud'

View File

@@ -3,22 +3,71 @@
#set -e at the top of your script will make the script exit with an error whenever an error occurs (and is not explicitly handled)
set -eu
TEMP_SSH_PRIVATE_KEY_FILE='../private_key.pem'
TEMP_SSH_PRIVATE_KEY_FILE='../private_wdhcr.pem'
TEMP_SFTP_FILE='../sftp'
# make sure remote path is not empty
if [ -z "$6" ]; then
echo 'remote_path is empty'
exit 1
fi
# use password
if [ -z != ${10} ]; then
echo 'use sshpass'
apk add sshpass
if test $9 == "true";then
echo 'Start delete remote files'
sshpass -p ${10} ssh -o StrictHostKeyChecking=no -p $3 $1@$2 rm -rf $6
fi
if test $7 = "true"; then
echo "Connection via sftp protocol only, skip the command to create a directory"
else
echo 'Create directory if needed'
sshpass -p ${10} ssh -o StrictHostKeyChecking=no -p $3 $1@$2 mkdir -p $6
fi
echo 'SFTP Start'
# create a temporary file containing sftp commands
printf "%s" "put -r $5 $6" >$TEMP_SFTP_FILE
#-o StrictHostKeyChecking=no avoid Host key verification failed.
SSHPASS=${10} sshpass -e sftp -oBatchMode=no -b $TEMP_SFTP_FILE -P $3 $8 -o StrictHostKeyChecking=no $1@$2
echo 'Deploy Success'
exit 0
fi
# keep string format
printf "%s" "$4" >$TEMP_SSH_PRIVATE_KEY_FILE
echo "-------"
cat $TEMP_SSH_PRIVATE_KEY_FILE
echo "======="
echo "$4" >$TEMP_SSH_PRIVATE_KEY_FILE
echo "-------"
cat $TEMP_SSH_PRIVATE_KEY_FILE
# avoid Permissions too open
chmod 600 $TEMP_SSH_PRIVATE_KEY_FILE
echo 'sftp start'
# delete remote files if needed
if test $9 == "true";then
echo 'Start delete remote files'
ssh -o StrictHostKeyChecking=no -p $3 -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2 rm -rf $6
fi
if test $7 = "true"; then
echo "Connection via sftp protocol only, skip the command to create a directory"
else
echo 'Create directory if needed'
ssh -o StrictHostKeyChecking=no -p $3 -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2 mkdir -p $6
fi
echo 'SFTP Start'
# create a temporary file containing sftp commands
printf "%s" "put -r $5 $6" >$TEMP_SFTP_FILE
#-o StrictHostKeyChecking=no avoid Host key verification failed.
sftp -b $TEMP_SFTP_FILE -P $3 $7 -o StrictHostKeyChecking=no -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2
sftp -b $TEMP_SFTP_FILE -P $3 $8 -o StrictHostKeyChecking=no -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2
echo 'deploy success'
echo 'Deploy Success'
exit 0

BIN
resource/keepformat.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 54 KiB

BIN
resource/reactExample.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 123 KiB

BIN
resource/secret.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 176 KiB

BIN
resource/umiExample.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 94 KiB