-
Notifications
You must be signed in to change notification settings - Fork 0
90 lines (83 loc) · 2.65 KB
/
deploy.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
name: Deploy Icon Library
on:
push:
branches:
- main
# 只有指定文件变化才运行
# paths:
# - package.json
# 允许你从 Actions 选项卡手动运行此工作流程
workflow_dispatch:
# 设置 GITHUB_TOKEN 的权限,以允许部署到 GitHub Pages
permissions:
contents: write
jobs:
# 构建工作
deploy:
runs-on: ubuntu-latest
name: Deploy
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
# 修复时间戳
- name: Restore timestamps
uses: chetan/git-restore-mtime-action@v2
- name: Setup Node
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install dependencies and build
run: |
rm -rf yarn.lock
yarn install
yarn compiler:icons
yarn build
yarn build:code
# 检查版本
- name: Check version changes
uses: EndBug/version-check@v2
id: check
with:
diff-search: true
file-url: https://unpkg.com/ksw-rpom-icon-vue@latest/package.json
static-checking: localIsNew
# check是我们在上一段中为check步骤提供的id
- name: Version update detected
if: steps.check.outputs.changed == 'true'
run: 'echo "发现版本更改!新版本: ${{ steps.check.outputs.version }} (${{ steps.check.outputs.type }})"'
# 发布到 NPM
- name: Publish the package to NPM
if: steps.check.outputs.changed == 'true'
run: yarn clean-publish
env:
NPM_AUTH_TOKEN: ${{ secrets.NPM_AUTH_TOKEN }}
# 部署 GitHub Pages
- name: Deploy GitHub Pages
uses: JamesIves/github-pages-deploy-action@v4
with:
folder: dist
git-config-name: GitHubActions
git-config-email: [email protected]
continue-on-error: true # 即使失败,也继续下一个步骤
# 部署到 Centos 服务器
- name: Deploy to Centos server
uses: easingthemes/ssh-deploy@main
with:
SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
ARGS: "-rlgoDzvc -i --delete"
SOURCE: "dist/"
REMOTE_HOST: ${{ secrets.REMOTE_HOST }}
REMOTE_PORT: ${{ secrets.REMOTE_PORT }}
REMOTE_USER: ${{ secrets.REMOTE_USER }}
TARGET: ${{ secrets.REMOTE_TARGET }}
EXCLUDE: "/dist/, /node_modules/"
SCRIPT_BEFORE: |
whoami
ls -al
SCRIPT_AFTER: |
whoami
ls -al
echo $RSYNC_STDOUT
continue-on-error: true # 即使失败,也继续下一个步骤