153 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| name: remote ssh command
 | |
| on: [push]
 | |
| 
 | |
| env:
 | |
|   FOO: "BAR"
 | |
|   BAR: "FOO"
 | |
| 
 | |
| jobs:
 | |
| 
 | |
|   build:
 | |
|     name: Build
 | |
|     runs-on: ubuntu-latest
 | |
|     steps:
 | |
|     - name: checkout
 | |
|       uses: actions/checkout@v1
 | |
| 
 | |
|     - name: executing remote ssh commands using password
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         password: ${{ secrets.PASSWORD }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         script: whoami
 | |
| 
 | |
|     - name: executing remote ssh commands using ssh key
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         key: ${{ secrets.KEY }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         script: whoami
 | |
| 
 | |
|     - name: multiple command
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         key: ${{ secrets.KEY }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         script: |
 | |
|           whoami
 | |
|           ls -al
 | |
| 
 | |
|     # - name: stop script if command error
 | |
|     #   if: always()
 | |
|     #   uses: ./
 | |
|     #   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: ./
 | |
|       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"
 | |
| 
 | |
|     - name: pass multiple environment
 | |
|       uses: ./
 | |
|       env:
 | |
|         FOO: "BAR"
 | |
|         BAR: "FOO"
 | |
|         SHA: ${{ github.sha }}
 | |
|         PORT: ${{ secrets.PORT }}
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         key: ${{ secrets.KEY }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         envs: FOO,BAR,SHA,PORT
 | |
|         script: |
 | |
|           echo "I am $FOO, thanks"
 | |
|           echo "I am $BAR, thanks"
 | |
|           echo "sha: $SHA"
 | |
|           echo "port: $PORT"
 | |
|           sh test.sh
 | |
| 
 | |
|     - name: ssh key passphrase
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         key: ${{ secrets.SSH2 }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         passphrase: ${{ secrets.PASSPHRASE }}
 | |
|         script: |
 | |
|           whoami
 | |
|           ls -al
 | |
| 
 | |
|     - name: use insecure cipher
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         password: ${{ secrets.PASSWORD }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         script: |
 | |
|             ls \
 | |
|               -lah
 | |
|         use_insecure_cipher: true
 | |
| 
 | |
|     # https://github.com/appleboy/ssh-action/issues/75#issuecomment-668314271
 | |
|     - name: Multiline SSH commands interpreted as single lines
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: ${{ secrets.HOST }}
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         password: ${{ secrets.PASSWORD }}
 | |
|         port: ${{ secrets.PORT }}
 | |
|         script_stop: true
 | |
|         script: |
 | |
|             ls \
 | |
|               -lah
 | |
|         use_insecure_cipher: true
 | |
| 
 | |
|     # https://github.com/appleboy/ssh-action/issues/85
 | |
|     - name: Deployment to multiple hosts with different ports
 | |
|       uses: ./
 | |
|       with:
 | |
|         host: "${{ secrets.HOST }}:${{ secrets.PORT }}"
 | |
|         username: ${{ secrets.USERNAME }}
 | |
|         password: ${{ secrets.PASSWORD }}
 | |
|         port: 1024
 | |
|         script_stop: true
 | |
|         script: |
 | |
|             ls \
 | |
|               -lah
 | |
|         use_insecure_cipher: true
 | |
| 
 | |
|     # - name: SSH ED25519 Private Key
 | |
|     #   uses: ./
 | |
|     #   with:
 | |
|     #     host: ${{ secrets.TUNNEL_HOST }}
 | |
|     #     username: ${{ secrets.TUNNEL_USERNAME }}
 | |
|     #     key: ${{ secrets.ID_ED25519 }}
 | |
|     #     port: ${{ secrets.TUNNEL_PORT }}
 | |
|     #     script: whoami
 | 
