Delete .github directory
parent
3ca8a7c535
commit
91ff4f1bb8
@ -1,13 +0,0 @@
|
|||||||
# These are supported funding model platforms
|
|
||||||
|
|
||||||
github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
|
|
||||||
patreon: # Replace with a single Patreon username
|
|
||||||
open_collective: ssh-action
|
|
||||||
ko_fi: # Replace with a single Ko-fi username
|
|
||||||
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
|
|
||||||
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
|
|
||||||
liberapay: # Replace with a single Liberapay username
|
|
||||||
issuehunt: # Replace with a single IssueHunt username
|
|
||||||
otechie: # Replace with a single Otechie username
|
|
||||||
lfx_crowdfunding: # Replace with a single LFX Crowdfunding project-name e.g., cloud-foundry
|
|
||||||
custom: ['https://www.paypal.me/appleboy46']
|
|
@ -1,41 +0,0 @@
|
|||||||
---
|
|
||||||
name: Bug report
|
|
||||||
about: Create a report to help us improve
|
|
||||||
title: ""
|
|
||||||
labels: bug
|
|
||||||
assignees: appleboy
|
|
||||||
---
|
|
||||||
|
|
||||||
## Describe the bug
|
|
||||||
|
|
||||||
A clear and concise description of what the bug is. If applicable, add screenshots to help explain your problem.
|
|
||||||
|
|
||||||
## Yaml Config
|
|
||||||
|
|
||||||
Please post your Yaml configuration file along with the output results.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
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@v1.2.2
|
|
||||||
with:
|
|
||||||
host: ${{ secrets.HOST }}
|
|
||||||
username: ${{ secrets.USERNAME }}
|
|
||||||
password: ${{ secrets.PASSWORD }}
|
|
||||||
port: ${{ secrets.PORT }}
|
|
||||||
script: whoami
|
|
||||||
```
|
|
||||||
|
|
||||||
## Related environment
|
|
||||||
|
|
||||||
Please provide the following information:
|
|
||||||
|
|
||||||
1. Your hosting provider information, such as DigitalOcean, Linode, AWS, or GCP.
|
|
||||||
2. The version information of your host's SSH service.
|
|
||||||
3. The information from your host's SSH configuration file.
|
|
@ -1,33 +0,0 @@
|
|||||||
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 }}
|
|
@ -1,739 +0,0 @@
|
|||||||
name: testing main branch
|
|
||||||
|
|
||||||
on: [push]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
default-user-name-password:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh by username and password
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
whoami
|
|
||||||
|
|
||||||
- name: ssh commands from a file
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
script_path: testdata/test.sh
|
|
||||||
|
|
||||||
# https://github.com/appleboy/ssh-action/issues/377
|
|
||||||
- name: multiple commands
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
mkdir -p /tmp/test
|
|
||||||
echo "hello world" > /tmp/test/hello.txt
|
|
||||||
cd /tmp/test
|
|
||||||
ls -al
|
|
||||||
cat /tmp/test/hello.txt
|
|
||||||
|
|
||||||
check-ssh-key:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_rsa.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_rsa.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_rsa >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_rsa
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh by private key
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: whoami
|
|
||||||
|
|
||||||
- name: wrong password but correct key
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: "abcdef"
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: whoami
|
|
||||||
|
|
||||||
- name: correct password but wrong key
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
key: password
|
|
||||||
port: 2222
|
|
||||||
script: whoami
|
|
||||||
|
|
||||||
support-key-passphrase:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh key passphrase
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
passphrase: 1234
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
- name: missing ssh key passphrase
|
|
||||||
uses: ./
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
# https://github.com/appleboy/ssh-action/issues/75#issuecomment-668314271
|
|
||||||
- name: Multiline SSH commands interpreted as single lines
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
passphrase: 1234
|
|
||||||
script: |
|
|
||||||
ls \
|
|
||||||
-lah
|
|
||||||
use_insecure_cipher: true
|
|
||||||
|
|
||||||
multiple-server:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server-01 \
|
|
||||||
--hostname=openssh-server-01 \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server-01 sh -c "hostname -i" > ip01.txt
|
|
||||||
echo "REMOTE_HOST_01<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip01.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip01.txt
|
|
||||||
echo "======================================"
|
|
||||||
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server-02 \
|
|
||||||
--hostname=openssh-server-02 \
|
|
||||||
-p 2223:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server-02 sh -c "hostname -i" > ip02.txt
|
|
||||||
echo "REMOTE_HOST_02<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip02.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip02.txt
|
|
||||||
echo "======================================"
|
|
||||||
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
# https://github.com/appleboy/ssh-action/issues/85
|
|
||||||
- name: Deployment to multiple hosts with different ports
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: "${{ env.REMOTE_HOST_01 }}:2222,${{ env.REMOTE_HOST_02 }}:2222"
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
passphrase: 1234
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
|
|
||||||
support-ed25519-key:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519 >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: testing id_ed25519 key
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
testing-with-env:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519 >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=true \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: testing id_ed25519 key
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
- name: pass environment
|
|
||||||
uses: ./
|
|
||||||
env:
|
|
||||||
FOO: "BAR"
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
envs: FOO
|
|
||||||
script: |
|
|
||||||
echo "I am $FOO, thanks"
|
|
||||||
echo "I am $BAR, thanks"
|
|
||||||
|
|
||||||
- name: pass multiple environment
|
|
||||||
uses: ./
|
|
||||||
env:
|
|
||||||
FOO: "BAR"
|
|
||||||
BAR: "FOO"
|
|
||||||
SHA: ${{ github.sha }}
|
|
||||||
PORT: ${{ secrets.PORT }}
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
envs: FOO,BAR,SHA,PORT
|
|
||||||
script: |
|
|
||||||
echo "I am $FOO, thanks"
|
|
||||||
echo "I am $BAR, thanks"
|
|
||||||
echo "sha: $SHA"
|
|
||||||
echo "port: $PORT"
|
|
||||||
|
|
||||||
- name: custom envs format
|
|
||||||
uses: ./
|
|
||||||
env:
|
|
||||||
FOO: "BAR"
|
|
||||||
AAA: "BBB"
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
envs: FOO,BAR,AAA
|
|
||||||
envs_format: export TEST_{NAME}={VALUE}
|
|
||||||
script: |
|
|
||||||
echo "I am $TEST_FOO, thanks"
|
|
||||||
echo "I am $TEST_BAR, thanks"
|
|
||||||
echo "I am $BAR, thanks"
|
|
||||||
echo "I am $TEST_AAA, thanks"
|
|
||||||
|
|
||||||
- name: pass all ENV variables to script
|
|
||||||
uses: ./
|
|
||||||
env:
|
|
||||||
INPUT_FOO: "BAR"
|
|
||||||
INPUT_AAA: "BBB"
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
allenvs: true
|
|
||||||
script: |
|
|
||||||
echo "I am $INPUT_FOO, thanks"
|
|
||||||
echo "I am $INPUT_AAA, thanks"
|
|
||||||
echo "$GITHUB_BASE_REF"
|
|
||||||
echo "$GITHUB_REF"
|
|
||||||
|
|
||||||
- name: pass secret variable in shell
|
|
||||||
uses: ./
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: cd ${{ secrets.PORT }}
|
|
||||||
|
|
||||||
- name: switch to root user
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
request_pty: true
|
|
||||||
command_timeout: 30s
|
|
||||||
script: |
|
|
||||||
whoami && echo 'hello world' && touch todo.txt
|
|
||||||
sudo whoami
|
|
||||||
|
|
||||||
testing06:
|
|
||||||
name: testing ipv6
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Set up WARP
|
|
||||||
uses: fscarmen/warp-on-actions@v1.1
|
|
||||||
with:
|
|
||||||
stack: dual
|
|
||||||
|
|
||||||
- name: testing ipv6 for command
|
|
||||||
run: |
|
|
||||||
curl -m 9 --ipv6 --verbose https://google.com
|
|
||||||
|
|
||||||
- name: testing ipv6
|
|
||||||
uses: ./
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
host: 2402:1f00:8000:800::2628
|
|
||||||
username: ubuntu
|
|
||||||
password: ${{ secrets.OVH_PASSWORD }}
|
|
||||||
protocol: tcp6
|
|
||||||
port: 22
|
|
||||||
command_timeout: 30s
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
|
|
||||||
testing07:
|
|
||||||
name: some special character
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Set Environment Variables
|
|
||||||
run: |
|
|
||||||
PASS='3HUS$?8kLu)}'
|
|
||||||
printf "PASS=${PASS}" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD='${{ env.PASS }}' \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh by username and password
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: ${{ env.PASS }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
whoami
|
|
||||||
|
|
||||||
testing-capturing-output:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- id: stdout
|
|
||||||
name: ssh command with stdout
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
capture_stdout: true
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
whoami
|
|
||||||
|
|
||||||
- name: check stdout
|
|
||||||
run: |
|
|
||||||
echo "stdout: ${{ steps.stdout.outputs.stdout }}"
|
|
||||||
|
|
||||||
testing-script-stop:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- id: stdout01
|
|
||||||
name: ssh command with stdout 01
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
capture_stdout: true
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
echo "TMP TESTING IF"
|
|
||||||
if [[ "2" == "1" ]]; then
|
|
||||||
echo "True"
|
|
||||||
else
|
|
||||||
echo "False"
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: check stdout 01
|
|
||||||
run: |
|
|
||||||
echo "stdout: ${{ steps.stdout01.outputs.stdout }}"
|
|
||||||
if echo "${{ steps.stdout01.outputs.stdout }}" | grep -q "True"; then
|
|
||||||
echo "Output contains 'True'"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
if echo "${{ steps.stdout01.outputs.stdout }}" | grep -q "False"; then
|
|
||||||
echo "Output contains 'False'"
|
|
||||||
fi
|
|
||||||
|
|
||||||
- id: stdout02
|
|
||||||
name: ssh command with stdout 01
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
capture_stdout: true
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
echo "TMP TESTING IF"
|
|
||||||
if [[ "1" == "1" ]]; then
|
|
||||||
echo "True"
|
|
||||||
else
|
|
||||||
echo "False"
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: check stdout 02
|
|
||||||
run: |
|
|
||||||
echo "stdout: ${{ steps.stdout02.outputs.stdout }}"
|
|
||||||
if echo "${{ steps.stdout02.outputs.stdout }}" | grep -q "False"; then
|
|
||||||
echo "Output contains 'False'"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
if echo "${{ steps.stdout02.outputs.stdout }}" | grep -q "True"; then
|
|
||||||
echo "Output contains 'True'"
|
|
||||||
fi
|
|
||||||
|
|
||||||
testing-script-error:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: test script error
|
|
||||||
uses: ./
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
capture_stdout: true
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
ls /nonexistent
|
|
@ -1,467 +0,0 @@
|
|||||||
name: testing stable version
|
|
||||||
|
|
||||||
on: [push]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
default-user-name-password:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh by username and password
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
whoami
|
|
||||||
|
|
||||||
- name: ssh commands from a file
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
port: 2222
|
|
||||||
script_path: testdata/test.sh
|
|
||||||
|
|
||||||
check-ssh-key:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_rsa.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_rsa.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_rsa >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_rsa
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh by private key
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: whoami
|
|
||||||
|
|
||||||
- name: wrong password but correct key
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: "abcdef"
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: whoami
|
|
||||||
|
|
||||||
- name: correct password but wrong key
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
password: password
|
|
||||||
key: password
|
|
||||||
port: 2222
|
|
||||||
script: whoami
|
|
||||||
|
|
||||||
support-key-passphrase:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: ssh key passphrase
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
passphrase: 1234
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
- name: missing ssh key passphrase
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
# https://github.com/appleboy/ssh-action/issues/75#issuecomment-668314271
|
|
||||||
- name: Multiline SSH commands interpreted as single lines
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
passphrase: 1234
|
|
||||||
script: |
|
|
||||||
ls \
|
|
||||||
-lah
|
|
||||||
use_insecure_cipher: true
|
|
||||||
|
|
||||||
multiple-server:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_passphrase >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_passphrase
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server-01 \
|
|
||||||
--hostname=openssh-server-01 \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server-01 sh -c "hostname -i" > ip01.txt
|
|
||||||
echo "REMOTE_HOST_01<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip01.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip01.txt
|
|
||||||
echo "======================================"
|
|
||||||
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server-02 \
|
|
||||||
--hostname=openssh-server-02 \
|
|
||||||
-p 2223:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server-02 sh -c "hostname -i" > ip02.txt
|
|
||||||
echo "REMOTE_HOST_02<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip02.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip02.txt
|
|
||||||
echo "======================================"
|
|
||||||
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
# https://github.com/appleboy/ssh-action/issues/85
|
|
||||||
- name: Deployment to multiple hosts with different ports
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: "${{ env.REMOTE_HOST_01 }}:2222,${{ env.REMOTE_HOST_02 }}:2222"
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
passphrase: 1234
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
|
|
||||||
support-ed25519-key:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519 >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=false \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_PASSWORD=password \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: testing id_ed25519 key
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
testing-with-env:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: add public key to env
|
|
||||||
run: |
|
|
||||||
echo "PUBLIC_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519.pub >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= public key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519.pub
|
|
||||||
echo "============================"
|
|
||||||
echo "PRIVATE_KEY<<EOF" >> $GITHUB_ENV
|
|
||||||
cat testdata/.ssh/id_ed25519 >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= private key ========="
|
|
||||||
cat testdata/.ssh/id_ed25519
|
|
||||||
echo "============================"
|
|
||||||
|
|
||||||
- name: create new ssh server
|
|
||||||
run: |
|
|
||||||
docker run -d \
|
|
||||||
--name=openssh-server \
|
|
||||||
--hostname=openssh-server \
|
|
||||||
-p 2222:2222 \
|
|
||||||
-e PUBLIC_KEY="${{ env.PUBLIC_KEY }}" \
|
|
||||||
-e SUDO_ACCESS=true \
|
|
||||||
-e PASSWORD_ACCESS=true \
|
|
||||||
-e USER_NAME=linuxserver.io \
|
|
||||||
--restart unless-stopped \
|
|
||||||
lscr.io/linuxserver/openssh-server:latest
|
|
||||||
docker exec openssh-server sh -c "hostname -i" > ip.txt
|
|
||||||
echo "REMOTE_HOST<<EOF" >> $GITHUB_ENV
|
|
||||||
cat ip.txt >> $GITHUB_ENV
|
|
||||||
echo "EOF" >> $GITHUB_ENV
|
|
||||||
echo "======= container ip address ========="
|
|
||||||
cat ip.txt
|
|
||||||
echo "======================================"
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: testing id_ed25519 key
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
script: |
|
|
||||||
whoami
|
|
||||||
ls -al
|
|
||||||
|
|
||||||
- name: pass environment
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
env:
|
|
||||||
FOO: "BAR"
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
envs: FOO
|
|
||||||
script: |
|
|
||||||
echo "I am $FOO, thanks"
|
|
||||||
echo "I am $BAR, thanks"
|
|
||||||
|
|
||||||
- name: pass multiple environment
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
env:
|
|
||||||
FOO: "BAR"
|
|
||||||
BAR: "FOO"
|
|
||||||
SHA: ${{ github.sha }}
|
|
||||||
PORT: ${{ secrets.PORT }}
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
envs: FOO,BAR,SHA,PORT
|
|
||||||
script: |
|
|
||||||
echo "I am $FOO, thanks"
|
|
||||||
echo "I am $BAR, thanks"
|
|
||||||
echo "sha: $SHA"
|
|
||||||
echo "port: $PORT"
|
|
||||||
|
|
||||||
- name: custom envs format
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
env:
|
|
||||||
FOO: "BAR"
|
|
||||||
AAA: "BBB"
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
envs: FOO,BAR,AAA
|
|
||||||
envs_format: export TEST_{NAME}={VALUE}
|
|
||||||
script: |
|
|
||||||
echo "I am $TEST_FOO, thanks"
|
|
||||||
echo "I am $TEST_BAR, thanks"
|
|
||||||
echo "I am $BAR, thanks"
|
|
||||||
echo "I am $TEST_AAA, thanks"
|
|
||||||
|
|
||||||
- name: pass all ENV variables to script
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
env:
|
|
||||||
INPUT_FOO: "BAR"
|
|
||||||
INPUT_AAA: "BBB"
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
allenvs: true
|
|
||||||
script: |
|
|
||||||
echo "I am $INPUT_FOO, thanks"
|
|
||||||
echo "I am $INPUT_AAA, thanks"
|
|
||||||
echo "$GITHUB_BASE_REF"
|
|
||||||
echo "$GITHUB_REF"
|
|
||||||
|
|
||||||
- name: switch to root user
|
|
||||||
uses: appleboy/ssh-action@v1
|
|
||||||
with:
|
|
||||||
host: ${{ env.REMOTE_HOST }}
|
|
||||||
username: linuxserver.io
|
|
||||||
key: ${{ env.PRIVATE_KEY }}
|
|
||||||
port: 2222
|
|
||||||
request_pty: true
|
|
||||||
command_timeout: 30s
|
|
||||||
script: |
|
|
||||||
whoami && echo 'hello world' && touch todo.txt
|
|
||||||
sudo whoami
|
|
Loading…
Reference in New Issue