-
Notifications
You must be signed in to change notification settings - Fork 7
110 lines (108 loc) · 3.64 KB
/
deb_loong64.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
name: deb-build
on:
push:
tags: [ "v*" ]
jobs:
package:
runs-on: loong64
strategy:
matrix:
target:
[
"lcr.loongnix.cn/library/debian",
# "linuxdeepin/deepin:beige-loong64-v1.4.0", 编译 cargo-deb 会卡住
]
container:
image: "${{ matrix.target }}"
steps:
- name: Install Dependencies
shell: bash
env:
TARGET_DISTRO: "${{ matrix.target }}"
run: |
if [[ "${TARGET_DISTRO}" = "linuxdeepin/deepin:beige-loong64-v1.4.0" ]]; then
sed -e 's|https://community-packages.deepin.com|https://mirrors.bfsu.edu.cn/deepin|g' -i /etc/apt/sources.list;
fi
apt-get update
env DEBIAN_FRONTEND=noninteractive apt-get install -y build-essential zlib1g-dev libssl-dev pkgconf nettle-dev libapt-pkg-dev curl xz-utils clang openssh-client rsync nodejs libbz2-dev liblzma-dev
- name: Checkout repository
uses: actions/checkout@v4
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
toolchain: stable
cache: false
- uses: Swatinem/rust-cache@v2
with:
key: "${{ matrix.target }}"
- name: Install cargo-deb
run: cargo install -f cargo-deb
- name: Build deb package
shell: bash
run: |
cargo deb -Z xz
VER_SUFFIX="${TARGET_DISTRO/:/}"
VER_SUFFIX="${VER_SUFFIX##*\/}"
case "${TARGET_DISTRO}" in
'lcr.loongnix.cn/library/debian')
CODENAME='trixie'
VER_SUFFIX='debian13'
;;
'linuxdeepin/deepin:beige-loong64-v1.4.0')
CODENAME='beige'
VER_SUFFIX="${VER_SUFFIX}23"
;;
esac
for i in target/debian/*.deb; do
mv -v "${i}" "${i/\.deb/-$VER_SUFFIX.deb}"
done
echo "VER_SUFFIX=${VER_SUFFIX}" >> "${GITHUB_ENV}"
echo "CODENAME=${CODENAME}" >> "${GITHUB_ENV}"
env:
TARGET_DISTRO: "${{ matrix.target }}"
- name: Setup SSH private key
env:
KEY: ${{ secrets.KEY }}
run: |
mkdir -p ~/.ssh/
chmod 0700 ~/.ssh/
echo "$KEY" > ~/.ssh/id_ed25519
cp .github/workflows/known_hosts ~/.ssh/known_hosts
chmod 0600 ~/.ssh/id_ed25519 ~/.ssh/known_hosts
- name: Upload packages (repository)
shell: bash
run: |
rsync \
--ignore-existing \
-v \
-e "ssh \
-o IdentityFile=$HOME/.ssh/id_ed25519 \
-o UserKnownHostsFile=$HOME/.ssh/known_hosts" \
target/debian/*-"${VER_SUFFIX}".deb \
${USER}@repo.aosc.io:/mirror/oma/pool/"${CODENAME}"/main/o/
ssh \
-v \
-o IdentityFile=~/.ssh/id_ed25519 \
-o UserKnownHostsFile=~/.ssh/known_hosts \
${USER}@repo.aosc.io \
touch /mirror/.updated
env:
TARGET_DISTRO: "${{ matrix.target }}"
USER: ${{ secrets.USER }}
- name: Upload packages (GitHub Release)
uses: actions/upload-artifact@v4
with:
name: ${{ env.VER_SUFFIX }}
path: "target/debian/*.deb"
# Release stage
release:
runs-on: ubuntu-latest
needs: package
if: ${{ startsWith(github.ref, 'refs/tags/') }}
steps:
- uses: actions/download-artifact@v4
- name: Upload artifacts
uses: alexellis/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
asset_paths: '["./**/*.tar.*","./**/*.deb"]'