1 Star 0 Fork 0

周洲仪/kernel-rt-5.10

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
process_pgp_certs.sh 1.42 KB
一键复制 编辑 原始数据 按行查看 历史
周洲仪 提交于 2023-10-31 14:11 . first commit
#!/bin/bash
# from: https://repo.openeuler.org/openEuler-22.03-LTS/source/RPM-GPG-KEY-openEuler
# sh256: b09bf8bf7dae9aa6b24b170b6b85dd1717e14e674f270d14da0436e8dfc4260e
CERT_2203="RPM-GPG-KEY-openEuler-22.03"
# from: https://repo.openeuler.org/openEuler-22.03-LTS-SP1/source/RPM-GPG-KEY-openEuler
# sha256: 006e79d37c10e74c24df6d07c4efc4176515cec009daa5ed493b06f5b6ef39c1
CERT_2203_SP1="RPM-GPG-KEY-openEuler-22.03-SP1"
# process result for kernel building
CERT_OUT="pubring.gpg"
# base64 decode with removing prefix and suffix
for cert in $CERT_2203 $CERT_2203_SP1; do
cat $cert | head -n -2 | tail -n +2 | base64 -d > $cert.gpg
done
# 22.03 SP1 use subkey to sign, but kernel can only parse main key. So we need to
# extract subkey information and wrap to a main key format.
# The PGP data can be parsered with https://cirw.in/gpg-decoder/
# Extra User ID Packet
# start: 400; length: 38
dd if=$CERT_2203_SP1.gpg of=$CERT_2203_SP1.userid.gpg skip=400 bs=1c count=38
# Extra Public-Subkey Packet
# start: 902 + 1(wrap cipherTypeByte); length: 400 - 1
# cipherTypeByte: 0x99 = 10 0110(wrap to a main key) 01
echo -en "\x99" > $CERT_2203_SP1.subkey.gpg
dd if=$CERT_2203_SP1.gpg of=$CERT_2203_SP1.subkey.gpg skip=903 bs=1c count=399 seek=1
# 22.03 use main key to sign, so we dont need to deal it.
# merge all cert information
cat $CERT_2203_SP1.subkey.gpg $CERT_2203_SP1.userid.gpg $CERT_2203.gpg > $CERT_OUT
# cleanup
rm -f RPM-GPG-KEY-openEuler-*
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C/C++
1
https://gitee.com/zhouyizhousihai/kernel-rt-5.10.git
[email protected]:zhouyizhousihai/kernel-rt-5.10.git
zhouyizhousihai
kernel-rt-5.10
kernel-rt-5.10
master

搜索帮助