45 lines
1.2 KiB
YAML
45 lines
1.2 KiB
YAML
name: Deploy to Server
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- main
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Setup Node
|
|
uses: actions/setup-node@v4
|
|
with:
|
|
node-version: 20
|
|
cache: npm
|
|
|
|
- name: Install dependencies
|
|
run: npm ci
|
|
|
|
- name: Build
|
|
run: npm run build
|
|
|
|
- name: Debug SSH key
|
|
run: |
|
|
echo "=== key line count ==="
|
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" | wc -l
|
|
echo "=== first line ==="
|
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" | head -1
|
|
echo "=== last line ==="
|
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" | tail -1
|
|
|
|
- name: Deploy via SCP
|
|
run: |
|
|
mkdir -p ~/.ssh
|
|
printf '%s' "${{ secrets.SSH_PRIVATE_KEY }}" | tr -d '\r' > ~/.ssh/deploy_key
|
|
chmod 600 ~/.ssh/deploy_key
|
|
echo "=== key validation ==="
|
|
ssh-keygen -l -f ~/.ssh/deploy_key || echo "KEY INVALID"
|
|
ssh-keyscan -p ${{ secrets.SSH_PORT }} -H ${{ secrets.SSH_HOST }} >> ~/.ssh/known_hosts
|
|
scp -P ${{ secrets.SSH_PORT }} -i ~/.ssh/deploy_key -o IdentitiesOnly=yes -r dist/* root@${{ secrets.SSH_HOST }}:/var/www/proto.bodalab.diffthink.kr/
|