8 Commits
1.1 ... v1.2.3

Author SHA1 Message Date
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
5 changed files with 68 additions and 46 deletions

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

@@ -0,0 +1,21 @@
name: Continuous Deploy #action名称
on: [push] #在推送的时候运行此action
jobs:
deploy_job:
runs-on: ubuntu-latest #运行环境
name: sftp
steps:
- name: Checkout
uses: actions/checkout@v2
# 利用action把build好的文件上传到服务器/var/www/react-app路径下,需要确认此目录已在服务端创建
- name: deploy file to server
uses: ./ # Uses an action in the root directory
with:
username: 'root' #ssh user name
server: '${{ secrets.SERVER_IP }}'
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
local_path: './action.yml' # 对应我们项目build的文件夹路径
remote_path: '/var/www/react-app/'
# delete_remote_files: true

View File

@@ -1,5 +1,5 @@
# Container image that runs your code
FROM alpine:3.10
FROM alpine:3.13
# Copies your code file from your action repository to the filesystem path `/` of the container
COPY entrypoint.sh /entrypoint.sh
@@ -12,4 +12,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"]

View File

@@ -3,41 +3,21 @@
> Use this action to deploy your files to server using `SSH Private Key`
> 使用此`action`部署你的项目到服务器上,`仅支持密钥对连接`
中文介绍链接:[使用Github Action 部署项目到云服务器](https://zhuanlan.zhihu.com/p/107545396)
> [使用Github Action 部署项目到云服务器](https://zhuanlan.zhihu.com/p/107545396)
## Inputs
### `username`
**Required** sftp username.
### `server`
**Required** sftp server address.
### `port`
sftp srever port , default `22`
### `ssh_private_key`
**Required** you can copy private_key from your `ssh_private_key.pem file`, keep format, and save at`repo/settings/secrets`
![](./resource/secret.jpg)
### `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`
## 1. Inputs
| Name | Required | Default | Description |
|------------------------|----------------------|---------|-----------------------------------------------|
`username` | yes| | SSH username
`server` | yes| | Remote host
`port`| yes | 22 | Remote host port
`ssh_private_key`| yes| | You can copy private key from your `ssh_private_key.pem` 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.
`args` | no| | other args yor want to use of sftp, E.g.`-o ConnectTimeout=5`
`delete_remote_files` | no | false | Set `true` will delete all files in the remote path before upload. Please be `careful` set this to true
## Action Example
@@ -52,7 +32,7 @@ args of sftp cmd, E.g.`-o ConnectTimeout=5`
- name: Checkout
uses: actions/checkout@v2
- name: deploy file
uses: wlixcc/SFTP-Deploy-Action@v1.0
uses: wlixcc/SFTP-Deploy-Action@v1.2.3
with:
username: 'root'
server: 'your server ip'
@@ -82,7 +62,7 @@ args of sftp cmd, E.g.`-o ConnectTimeout=5`
run: yarn build
- name: deploy file to server
uses: wlixcc/SFTP-Deploy-Action@v1.0
uses: wlixcc/SFTP-Deploy-Action@v1.2.3
with:
username: 'root'
server: '${{ secrets.SERVER_IP }}'
@@ -116,7 +96,7 @@ args of sftp cmd, E.g.`-o ConnectTimeout=5`
run: yarn build
- name: deploy file to server
uses: wlixcc/SFTP-Deploy-Action@v1.0
uses: wlixcc/SFTP-Deploy-Action@v1.2.3
with:
username: 'root'
server: '${{ secrets.SERVER_IP }}'

View File

@@ -22,11 +22,17 @@ inputs:
remote_path:
description: 'files will copy to under remote_path'
required: true
default: /
sftp_only:
description: 'connection via sftp protocol only'
required: false
default: false
args:
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
runs:
@@ -39,7 +45,9 @@ runs:
- ${{ inputs.ssh_private_key }}
- ${{ inputs.local_path }}
- ${{ inputs.remote_path }}
- ${{ inputs.sftp_only }}
- ${{ inputs.args }}
- ${{ inputs.delete_remote_files }}
branding:
icon: 'upload-cloud'

View File

@@ -7,21 +7,34 @@ set -eu
TEMP_SSH_PRIVATE_KEY_FILE='../private_key.pem'
TEMP_SFTP_FILE='../sftp'
if [ -z "$6" ]; then
echo 'remote_path is empty'
exit 1
fi
# keep string format
printf "%s" "$4" >$TEMP_SSH_PRIVATE_KEY_FILE
# avoid Permissions too open
chmod 600 $TEMP_SSH_PRIVATE_KEY_FILE
echo 'ssh start'
# create directory if needed
ssh -o StrictHostKeyChecking=no -p $3 -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2 mkdir -p $5
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
echo 'sftp start'
if test $7 = "true"; then
echo "Connection via sftp protocol only, skip the command to create a directory"
else
echo 'SSH Start'
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