-
Notifications
You must be signed in to change notification settings - Fork 1
92 lines (80 loc) · 3 KB
/
nvchecker.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
91
92
name: nvchecker
on:
workflow_dispatch:
push:
branches:
- master
paths:
- "config.toml"
- ".github/workflows/nvchecker.yml"
pull_request:
branches:
- master
paths:
- "config.toml"
- ".github/workflows/nvchecker.yml"
schedule:
- cron: "0 */12 * * *"
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
jobs:
check-new-versions:
name: Check New Versions
runs-on: ubuntu-latest
container:
# image: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
image: ghcr.io/sunlei/nvchecker
credentials:
username: ${{ github.actor }}
password: ${{ secrets.github_token }}
steps:
- uses: actions/checkout@v4
- name: Set environment variables
run: |
echo "LOG_FILE=nvchecker_$(date +'%Y-%m-%d_%H-%M-%S').log" >> $GITHUB_ENV
sed -i -e "s/__GITHUB_ACCESS_TOKEN__/${{ secrets.GITHUB_TOKEN }}/g" keyfile.toml
- name: Check version
run: |
nvchecker --file config.toml --keyfile keyfile.toml 2>&1 | tee ${{ env.LOG_FILE }}
nvcmp --file config.toml > result.tmp
nvtake --file config.toml --all
- name: Send Email
shell: bash
# -F attachment=@${{ env.LOG_FILE }} \
run: |
LOG=$(cat ${{ env.LOG_FILE }}) \
RESULT=$(cat result.tmp) \
DATE=$(date +"%Y-%m-%d") \
&& [[ ! -z $LOG ]] || [[ ! -z $RESULT ]] \
&& curl \
-s \
--user 'api:${{ secrets.MAILGUN_API_KEY }}' \
https://api.mailgun.net/v3/${{ secrets.MAILGUN_DOMAIN_NAME }}/messages \
-F from='nvchecker <postmaster@${{ secrets.MAILGUN_DOMAIN_NAME }}>' \
-F to=${{ secrets.EMAIL_TO }} -F subject="New version check result · $DATE" \
-F text="$RESULT" --form-string html="<html><pre><code>$RESULT</code></pre><hr /><pre><code>$LOG</code></pre></html>" \
|| echo "No new versions"
rm -f result.tmp ${{ env.LOG_FILE }}
# - https://github.com/actions/runner/issues/2033
# - https://github.com/actions/checkout/issues/1048
# - https://github.com/actions/runner-images/issues/6775
- name: Fix git safe.directory in container
run: git config --global --add safe.directory /__w/${{ github.event.repository.name }}/${{ github.event.repository.name }}
- name: Commit version record files
uses: stefanzweifel/git-auto-commit-action@v4
with:
commit_message: "chore: apply version record files changes"
# branch: ${{ github.head_ref }}
branch: master
commit_options: "--no-verify --signoff"
file_pattern: ./*.json
repository: .
commit_user_name: GitHub Actions Bot
commit_user_email: [email protected]
commit_author: GitHub Actions Bot <[email protected]>
# - name: nvchecker-action
# id: nvchecker-action
# uses: guizai/nvchecker-action@master
# with:
# source-file: 'config.toml'