Compare commits
28 Commits
Author | SHA1 | Date | |
---|---|---|---|
9085f3ea5b | |||
696aab4627 | |||
a88f6f2013 | |||
6f091cd9e3 | |||
aa1ecdd19a | |||
bffdd4e1f4 | |||
f4890bec77 | |||
9aaf218321 | |||
a2d5832a97 | |||
49e81b4a32 | |||
04535147e0 | |||
533a062133 | |||
ef697c0ac1 | |||
480ff5e05e | |||
ccece0c886 | |||
7e0bb7cd75 | |||
dc9ae8e2e3 | |||
d0bd170212 | |||
54eb169e33 | |||
1a6f86cece | |||
917a1df2a4 | |||
b87ddeff00 | |||
4f7d6491f3 | |||
1f7ce4dfab | |||
46adad98f2 | |||
215a0580d7 | |||
b305709c8d | |||
fd26aa3ca7 |
45
.github/main.workflow
vendored
45
.github/main.workflow
vendored
@ -1,45 +0,0 @@
|
|||||||
workflow "Remote ssh commands" {
|
|
||||||
on = "push"
|
|
||||||
resolves = [
|
|
||||||
"Executing remote ssh commands",
|
|
||||||
"Support Private Key",
|
|
||||||
"Multiple Commands",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
action "Executing remote ssh commands" {
|
|
||||||
uses = "appleboy/ssh-action@master"
|
|
||||||
secrets = [
|
|
||||||
"HOST",
|
|
||||||
"PASSWORD",
|
|
||||||
]
|
|
||||||
args = [
|
|
||||||
"--user", "actions",
|
|
||||||
"--script", "whoami",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
action "Support Private Key" {
|
|
||||||
uses = "appleboy/ssh-action@master"
|
|
||||||
secrets = [
|
|
||||||
"HOST",
|
|
||||||
"KEY",
|
|
||||||
]
|
|
||||||
args = [
|
|
||||||
"--user", "actions",
|
|
||||||
"--script", "'ls -al'",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
action "Multiple Commands" {
|
|
||||||
uses = "appleboy/ssh-action@master"
|
|
||||||
secrets = [
|
|
||||||
"HOST",
|
|
||||||
"KEY",
|
|
||||||
]
|
|
||||||
args = [
|
|
||||||
"--user", "actions",
|
|
||||||
"--script", "'whoami'",
|
|
||||||
"--script", "'ls -al'",
|
|
||||||
]
|
|
||||||
}
|
|
62
.github/workflows/ci.yml
vendored
Normal file
62
.github/workflows/ci.yml
vendored
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
name: remote ssh command
|
||||||
|
on: [push]
|
||||||
|
jobs:
|
||||||
|
|
||||||
|
build:
|
||||||
|
name: Build
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: executing remote ssh commands using password
|
||||||
|
uses: appleboy/ssh-action@master
|
||||||
|
with:
|
||||||
|
host: ${{ secrets.HOST }}
|
||||||
|
username: ${{ secrets.USERNAME }}
|
||||||
|
password: ${{ secrets.PASSWORD }}
|
||||||
|
port: ${{ secrets.PORT }}
|
||||||
|
script: whoami
|
||||||
|
|
||||||
|
- name: executing remote ssh commands using ssh key
|
||||||
|
uses: appleboy/ssh-action@master
|
||||||
|
with:
|
||||||
|
host: ${{ secrets.HOST }}
|
||||||
|
username: ${{ secrets.USERNAME }}
|
||||||
|
key: ${{ secrets.KEY }}
|
||||||
|
port: ${{ secrets.PORT }}
|
||||||
|
script: whoami
|
||||||
|
|
||||||
|
- name: multiple command
|
||||||
|
uses: appleboy/ssh-action@master
|
||||||
|
with:
|
||||||
|
host: ${{ secrets.HOST }}
|
||||||
|
username: ${{ secrets.USERNAME }}
|
||||||
|
key: ${{ secrets.KEY }}
|
||||||
|
port: ${{ secrets.PORT }}
|
||||||
|
script: |
|
||||||
|
whoami
|
||||||
|
ls -al
|
||||||
|
|
||||||
|
# - name: stop script if command error
|
||||||
|
# uses: appleboy/ssh-action@master
|
||||||
|
# with:
|
||||||
|
# host: ${{ secrets.HOST }}
|
||||||
|
# username: ${{ secrets.USERNAME }}
|
||||||
|
# key: ${{ secrets.KEY }}
|
||||||
|
# port: ${{ secrets.PORT }}
|
||||||
|
# script_stop: true
|
||||||
|
# script: |
|
||||||
|
# mkdir abc/def
|
||||||
|
# ls -al
|
||||||
|
|
||||||
|
- name: pass environment
|
||||||
|
uses: appleboy/ssh-action@master
|
||||||
|
env:
|
||||||
|
FOO: "BAR"
|
||||||
|
with:
|
||||||
|
host: ${{ secrets.HOST }}
|
||||||
|
username: ${{ secrets.USERNAME }}
|
||||||
|
key: ${{ secrets.KEY }}
|
||||||
|
port: ${{ secrets.PORT }}
|
||||||
|
envs: FOO
|
||||||
|
script: |
|
||||||
|
echo "I am $FOO, thanks"
|
||||||
|
echo "I am $BAR, thanks"
|
13
Dockerfile
13
Dockerfile
@ -1,15 +1,4 @@
|
|||||||
FROM appleboy/drone-ssh:1.5.1-linux-amd64
|
FROM appleboy/drone-ssh:1.5.4-linux-amd64
|
||||||
|
|
||||||
# Github labels
|
|
||||||
LABEL "com.github.actions.name"="SSH Commands"
|
|
||||||
LABEL "com.github.actions.description"="Executing remote ssh commands"
|
|
||||||
LABEL "com.github.actions.icon"="terminal"
|
|
||||||
LABEL "com.github.actions.color"="gray-dark"
|
|
||||||
|
|
||||||
LABEL "repository"="https://github.com/appleboy/ssh-action"
|
|
||||||
LABEL "homepage"="https://github.com/appleboy"
|
|
||||||
LABEL "maintainer"="Bo-Yi Wu <appleboy.tw@gmail.com>"
|
|
||||||
LABEL "version"="0.0.2"
|
|
||||||
|
|
||||||
ADD entrypoint.sh /entrypoint.sh
|
ADD entrypoint.sh /entrypoint.sh
|
||||||
RUN chmod +x /entrypoint.sh
|
RUN chmod +x /entrypoint.sh
|
||||||
|
231
README.md
231
README.md
@ -1,132 +1,167 @@
|
|||||||
# 🚀 SSH for GitHub Actions
|
# 🚀 SSH for GitHub Actions
|
||||||
|
|
||||||
[GitHub Action](https://developer.github.com/actions/) for executing remote ssh commands.
|
[GitHub Action](https://github.com/features/actions) for executing remote ssh commands.
|
||||||
|
|
||||||
<img src="./images/ssh-workflow.png">
|

|
||||||
|
|
||||||
|
[](https://github.com/appleboy/ssh-action/actions)
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
Executing remote ssh commands.
|
Executing remote ssh commands.
|
||||||
|
|
||||||
```
|
```yaml
|
||||||
action "Executing remote ssh commands" {
|
name: remote ssh command
|
||||||
uses = "appleboy/ssh-action@master"
|
on: [push]
|
||||||
secrets = [
|
jobs:
|
||||||
"HOST",
|
|
||||||
"PASSWORD",
|
build:
|
||||||
]
|
name: Build
|
||||||
args = [
|
runs-on: ubuntu-latest
|
||||||
"--user", "actions",
|
steps:
|
||||||
"--script", "whoami",
|
- name: executing remote ssh commands using password
|
||||||
]
|
uses: appleboy/ssh-action@master
|
||||||
}
|
with:
|
||||||
|
host: ${{ secrets.HOST }}
|
||||||
|
username: ${{ secrets.USERNAME }}
|
||||||
|
password: ${{ secrets.PASSWORD }}
|
||||||
|
port: ${{ secrets.PORT }}
|
||||||
|
script: whoami
|
||||||
```
|
```
|
||||||
|
|
||||||
## Environment variables
|
output:
|
||||||
|
|
||||||
* HOST - ssh server host
|
```sh
|
||||||
* PORT - ssh server port
|
======CMD======
|
||||||
* USERNAME - ssh server username
|
whoami
|
||||||
* PASSWORD - ssh server password
|
======END======
|
||||||
* KEY - ssh server private key
|
out: ***
|
||||||
* SCRIPT - execute the scripts
|
==============================================
|
||||||
|
✅ Successfully executed commands to all host.
|
||||||
|
==============================================
|
||||||
|
```
|
||||||
|
|
||||||
|
## Input variables
|
||||||
|
|
||||||
|
See [action.yml](./action.yml) for more detailed information.
|
||||||
|
|
||||||
|
* host - remote host
|
||||||
|
* port - remote port, default is `22`
|
||||||
|
* username - ssh username
|
||||||
|
* password - ssh password
|
||||||
|
* timeout - timeout for ssh to remote host, default is `30s`
|
||||||
|
* command_timeout - timeout for ssh command, default is `10m`
|
||||||
|
* key - content of ssh private key. ex raw content of ~/.ssh/id_rsa
|
||||||
|
* key_path - path of ssh private key
|
||||||
|
* script - execute commands
|
||||||
|
* script_stop - stop script after first failure
|
||||||
|
* envs - pass environment variable to shell script
|
||||||
|
* debug - enable debug mode
|
||||||
|
|
||||||
### Example
|
### Example
|
||||||
|
|
||||||
Executing remote ssh commands.
|
Executing remote ssh commands using password.
|
||||||
|
|
||||||
```
|
```yaml
|
||||||
action "Executing remote ssh commands" {
|
- name: executing remote ssh commands using password
|
||||||
uses = "appleboy/ssh-action@master"
|
uses: appleboy/ssh-action@master
|
||||||
secrets = [
|
with:
|
||||||
"PASSWORD",
|
host: ${{ secrets.HOST }}
|
||||||
]
|
username: ${{ secrets.USERNAME }}
|
||||||
args = [
|
password: ${{ secrets.PASSWORD }}
|
||||||
"--host", "foo.com"
|
port: ${{ secrets.PORT }}
|
||||||
"--user", "bar",
|
script: whoami
|
||||||
"--script", "whoami",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Using private key
|
Using private key
|
||||||
|
|
||||||
```
|
```yaml
|
||||||
action "Support Private Key" {
|
- name: executing remote ssh commands using ssh key
|
||||||
uses = "appleboy/ssh-action@master"
|
uses: appleboy/ssh-action@master
|
||||||
secrets = [
|
with:
|
||||||
"HOST",
|
host: ${{ secrets.HOST }}
|
||||||
"KEY",
|
username: ${{ secrets.USERNAME }}
|
||||||
]
|
key: ${{ secrets.KEY }}
|
||||||
args = [
|
port: ${{ secrets.PORT }}
|
||||||
"--user", "actions",
|
script: whoami
|
||||||
"--script", "'ls -al'",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Multiple Commands
|
Multiple Commands
|
||||||
|
|
||||||
```
|
```yaml
|
||||||
action "Multiple Commands" {
|
- name: multiple command
|
||||||
uses = "appleboy/ssh-action@master"
|
uses: appleboy/ssh-action@master
|
||||||
secrets = [
|
with:
|
||||||
"HOST",
|
host: ${{ secrets.HOST }}
|
||||||
"KEY",
|
username: ${{ secrets.USERNAME }}
|
||||||
]
|
key: ${{ secrets.KEY }}
|
||||||
args = [
|
port: ${{ secrets.PORT }}
|
||||||
"--user", "actions",
|
script: |
|
||||||
"--script", "'whoami'",
|
whoami
|
||||||
"--script", "'ls -al'",
|
ls -al
|
||||||
]
|
|
||||||
}
|
|
||||||
```
|
```
|
||||||
|
|
||||||
<img src="./images/multiple-command-result.png">
|

|
||||||
|
|
||||||
Multiple Hosts
|
Multiple Hosts
|
||||||
|
|
||||||
```
|
```diff
|
||||||
action "Multiple Hosts" {
|
- name: multiple host
|
||||||
uses = "appleboy/ssh-action@master"
|
uses: appleboy/ssh-action@master
|
||||||
secrets = [
|
with:
|
||||||
"KEY",
|
- host: "foo.com"
|
||||||
]
|
+ host: "foo.com,bar.com"
|
||||||
args = [
|
username: ${{ secrets.USERNAME }}
|
||||||
"--host", "foo.com",
|
key: ${{ secrets.KEY }}
|
||||||
"--host", "bar.com",
|
port: ${{ secrets.PORT }}
|
||||||
"--user", "actions",
|
script: |
|
||||||
"--script", "'whoami'",
|
whoami
|
||||||
"--script", "'ls -al'",
|
ls -al
|
||||||
"--script", "'cat test.txt'",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
```
|
```
|
||||||
|
|
||||||
see the detail of `drone-ssh` command
|
Pass environment variable to shell script
|
||||||
|
|
||||||
```
|
```diff
|
||||||
--ssh-key value private ssh key [$PLUGIN_SSH_KEY, $PLUGIN_KEY, $SSH_KEY, $KEY]
|
- name: pass environment
|
||||||
--key-path value, -i value ssh private key path [$PLUGIN_KEY_PATH, $SSH_KEY_PATH, $PATH]
|
uses: appleboy/ssh-action@master
|
||||||
--username value, --user value, -u value connect as user (default: "root") [$PLUGIN_USERNAME, $PLUGIN_USER, $SSH_USERNAME, $USERNAME]
|
+ env:
|
||||||
--password value, -P value user password [$PLUGIN_PASSWORD, $SSH_PASSWORD, $PASSWORD]
|
+ FOO: "BAR"
|
||||||
--host value, -H value connect to host [$PLUGIN_HOST, $SSH_HOST, $HOST]
|
with:
|
||||||
--port value, -p value connect to port (default: 22) [$PLUGIN_PORT, $SSH_PORT, $PORT]
|
host: ${{ secrets.HOST }}
|
||||||
--sync sync mode [$PLUGIN_SYNC, $SYNC]
|
username: ${{ secrets.USERNAME }}
|
||||||
--timeout value, -t value connection timeout (default: 0s) [$PLUGIN_TIMEOUT, $SSH_TIMEOUT, $TIMEOUT]
|
key: ${{ secrets.KEY }}
|
||||||
--command.timeout value, -T value command timeout (default: 1m0s) [$PLUGIN_COMMAND_TIMEOUT, $SSH_COMMAND_TIMEOUT, $COMMAND_TIMEOUT]
|
port: ${{ secrets.PORT }}
|
||||||
--script value, -s value execute commands [$PLUGIN_SCRIPT, $SSH_SCRIPT, $SCRIPT]
|
+ envs: FOO
|
||||||
--script.stop stop script after first failure [$PLUGIN_SCRIPT_STOP, $STOP]
|
script: |
|
||||||
--proxy.ssh-key value private ssh key of proxy [$PLUGIN_PROXY_SSH_KEY, $PLUGIN_PROXY_KEY, $PROXY_SSH_KEY]
|
echo "I am $FOO"
|
||||||
--proxy.key-path value ssh private key path of proxy [$PLUGIN_PROXY_KEY_PATH, $PROXY_SSH_KEY_PATH]
|
echo "I am $BAR"
|
||||||
--proxy.username value connect as user of proxy (default: "root") [$PLUGIN_PROXY_USERNAME, $PLUGIN_PROXY_USER, $PROXY_SSH_USERNAME]
|
|
||||||
--proxy.password value user password of proxy [$PLUGIN_PROXY_PASSWORD, $PROXY_SSH_PASSWORD]
|
|
||||||
--proxy.host value connect to host of proxy [$PLUGIN_PROXY_HOST, $PROXY_SSH_HOST]
|
|
||||||
--proxy.port value connect to port of proxy (default: "22") [$PLUGIN_PROXY_PORT, $PROXY_SSH_PORT]
|
|
||||||
--proxy.timeout value proxy connection timeout (default: 0s) [$PLUGIN_PROXY_TIMEOUT, $PROXY_SSH_TIMEOUT]
|
|
||||||
```
|
```
|
||||||
|
|
||||||
## Secrets
|
Stop script after first failure. ex: missing `abc` folder
|
||||||
|
|
||||||
* `PASSWORD` - ssh server password
|
```diff
|
||||||
* `KEY` - ssh server private key
|
- name: stop script if command error
|
||||||
|
uses: appleboy/ssh-action@master
|
||||||
|
with:
|
||||||
|
host: ${{ secrets.HOST }}
|
||||||
|
username: ${{ secrets.USERNAME }}
|
||||||
|
key: ${{ secrets.KEY }}
|
||||||
|
port: ${{ secrets.PORT }}
|
||||||
|
+ script_stop: true
|
||||||
|
script: |
|
||||||
|
mkdir abc/def
|
||||||
|
ls -al
|
||||||
|
```
|
||||||
|
|
||||||
|
output:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
======CMD======
|
||||||
|
mkdir abc/def
|
||||||
|
ls -al
|
||||||
|
|
||||||
|
======END======
|
||||||
|
2019/11/21 01:16:21 Process exited with status 1
|
||||||
|
err: mkdir: cannot create directory ‘abc/def’: No such file or directory
|
||||||
|
##[error]Docker run failed with exit code 1
|
||||||
|
```
|
||||||
|
40
action.yml
Normal file
40
action.yml
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
name: 'SSH Remote Commands'
|
||||||
|
description: 'Executing remote ssh commands'
|
||||||
|
author: 'Bo-Yi Wu'
|
||||||
|
inputs:
|
||||||
|
host:
|
||||||
|
description: 'ssh remote host'
|
||||||
|
port:
|
||||||
|
description: 'ssh remote port'
|
||||||
|
default: 22
|
||||||
|
username:
|
||||||
|
description: 'ssh username'
|
||||||
|
password:
|
||||||
|
description: 'ssh password'
|
||||||
|
timeout:
|
||||||
|
description: 'timeout for ssh to remote host'
|
||||||
|
default: "30s"
|
||||||
|
command_timeout:
|
||||||
|
description: 'timeout for ssh command'
|
||||||
|
default: "10m"
|
||||||
|
key:
|
||||||
|
description: 'content of ssh private key. ex raw content of ~/.ssh/id_rsa'
|
||||||
|
key_path:
|
||||||
|
description: 'path of ssh private key'
|
||||||
|
script:
|
||||||
|
description: 'execute commands'
|
||||||
|
script_stop:
|
||||||
|
description: 'stop script after first failure'
|
||||||
|
default: false
|
||||||
|
envs:
|
||||||
|
description: 'pass environment variable to shell script'
|
||||||
|
debug:
|
||||||
|
description: 'enable debug mode'
|
||||||
|
default: false
|
||||||
|
runs:
|
||||||
|
using: 'docker'
|
||||||
|
image: 'Dockerfile'
|
||||||
|
|
||||||
|
branding:
|
||||||
|
icon: 'terminal'
|
||||||
|
color: 'gray-dark'
|
Binary file not shown.
Before Width: | Height: | Size: 104 KiB |
BIN
images/output-result.png
Normal file
BIN
images/output-result.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 193 KiB |
Reference in New Issue
Block a user