feat: deb package
This commit is contained in:
parent
1fb186fd2a
commit
2fbe313d2e
4
PKGBUILD
4
PKGBUILD
@ -1,5 +1,5 @@
|
|||||||
pkgname=rustdesk
|
pkgname=rustdesk
|
||||||
pkgver=1.1.9
|
pkgver=1.1.10
|
||||||
pkgrel=0
|
pkgrel=0
|
||||||
epoch=
|
epoch=
|
||||||
pkgdesc=""
|
pkgdesc=""
|
||||||
@ -27,5 +27,5 @@ package() {
|
|||||||
install -Dm 644 $HBB/rustdesk.service -t "${pkgdir}/usr/share/rustdesk/files"
|
install -Dm 644 $HBB/rustdesk.service -t "${pkgdir}/usr/share/rustdesk/files"
|
||||||
install -Dm 644 $HBB/rustdesk.desktop -t "${pkgdir}/usr/share/rustdesk/files"
|
install -Dm 644 $HBB/rustdesk.desktop -t "${pkgdir}/usr/share/rustdesk/files"
|
||||||
install -Dm 644 $HBB/pynput_service.py -t "${pkgdir}/usr/share/rustdesk/files"
|
install -Dm 644 $HBB/pynput_service.py -t "${pkgdir}/usr/share/rustdesk/files"
|
||||||
install -Dm 644 $HBB/256-no-margin.png "${pkgdir}/usr/share/rustdesk/files/rustdesk.png"
|
install -Dm 644 $HBB/128x128@2x.png "${pkgdir}/usr/share/rustdesk/files/rustdesk.png"
|
||||||
}
|
}
|
||||||
|
109
build.py
109
build.py
@ -121,6 +121,53 @@ def get_features(args):
|
|||||||
print("features:", features)
|
print("features:", features)
|
||||||
return features
|
return features
|
||||||
|
|
||||||
|
|
||||||
|
def build_flutter_deb(version):
|
||||||
|
os.chdir('flutter')
|
||||||
|
os.system('dpkg-deb -R rustdesk.deb tmpdeb')
|
||||||
|
# os.system('flutter build linux --release')
|
||||||
|
os.system('rm tmpdeb/usr/bin/rustdesk')
|
||||||
|
os.system('strip build/linux/x64/release/liblibrustdesk.so')
|
||||||
|
os.system('mkdir -p tmpdeb/usr/lib/rustdesk')
|
||||||
|
os.system('mkdir -p tmpdeb/usr/share/rustdesk/files/systemd/')
|
||||||
|
os.system(
|
||||||
|
'cp -r build/linux/x64/release/bundle/* tmpdeb/usr/lib/rustdesk/')
|
||||||
|
os.system(
|
||||||
|
'pushd tmpdeb && ln -s /usr/lib/rustdesk/flutter_hbb usr/bin/rustdesk && popd')
|
||||||
|
os.system(
|
||||||
|
'cp build/linux/x64/release/liblibrustdesk.so tmpdeb/usr/lib/rustdesk/librustdesk.so')
|
||||||
|
os.system(
|
||||||
|
'cp rustdesk.service tmpdeb/usr/share/rustdesk/files/systemd/')
|
||||||
|
os.system(
|
||||||
|
'cp rustdesk.service.user tmpdeb/usr/share/rustdesk/files/systemd/')
|
||||||
|
os.system(
|
||||||
|
'cp ../pynput_service.py tmpdeb/usr/share/rustdesk/files/')
|
||||||
|
os.system(
|
||||||
|
'cp ../128x128@2x.png tmpdeb/usr/share/rustdesk/files/rustdesk.png')
|
||||||
|
os.system(
|
||||||
|
'cp rustdesk.desktop tmpdeb/usr/share/applications/rustdesk.desktop')
|
||||||
|
os.system('mkdir -p tmpdeb/DEBIAN')
|
||||||
|
os.system('cp -a ../DEBIAN/* tmpdeb/DEBIAN/')
|
||||||
|
md5_file('usr/share/rustdesk/files/systemd/rustdesk.service')
|
||||||
|
md5_file('usr/share/rustdesk/files/systemd/rustdesk.service.user')
|
||||||
|
md5_file('usr/share/rustdesk/files/pynput_service.py')
|
||||||
|
os.system('dpkg-deb -b tmpdeb rustdesk.deb; /bin/rm -rf tmpdeb/')
|
||||||
|
os.rename('rustdesk.deb', '../rustdesk-%s.deb' % version)
|
||||||
|
os.chdir("..")
|
||||||
|
|
||||||
|
|
||||||
|
def build_flutter_arch_manjaro(version):
|
||||||
|
os.chdir('flutter')
|
||||||
|
os.system('flutter build linux --release')
|
||||||
|
os.system('strip build/linux/x64/release/liblibrustdesk.so')
|
||||||
|
os.system("sed -i 's/pkgver=.*/pkgver=%s/g' PKGBUILD" % version)
|
||||||
|
# pacman -S -needed base-devel
|
||||||
|
os.system('HBB=`pwd` makepkg -f')
|
||||||
|
os.system(
|
||||||
|
'mv rustdesk-%s-0-x86_64.pkg.tar.zst ../rustdesk-%s-manjaro-arch.pkg.tar.zst' % (version, version))
|
||||||
|
os.chdir('..')
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
parser = make_parser()
|
parser = make_parser()
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
@ -151,19 +198,11 @@ def main():
|
|||||||
else:
|
else:
|
||||||
print('Not signed')
|
print('Not signed')
|
||||||
os.system(f'cp -rf target/release/RustDesk.exe rustdesk-{version}-setdown.exe')
|
os.system(f'cp -rf target/release/RustDesk.exe rustdesk-{version}-setdown.exe')
|
||||||
elif os.path.isfile('/usr/bin/pacman'):
|
elif os.path.isfile('/usr/bin/pacman1'):
|
||||||
if flutter:
|
if flutter:
|
||||||
os.chdir('flutter')
|
build_flutter_arch_manjaro(version)
|
||||||
os.system('flutter build linux --release')
|
|
||||||
os.system('strip build/linux/x64/release/liblibrustdesk.so')
|
|
||||||
os.system("sed -i 's/pkgver=.*/pkgver=%s/g' PKGBUILD" % version)
|
|
||||||
# pacman -S -needed base-devel
|
|
||||||
os.system('HBB=`pwd` makepkg -f')
|
|
||||||
os.system(
|
|
||||||
'mv rustdesk-%s-0-x86_64.pkg.tar.zst ../rustdesk-%s-manjaro-arch.pkg.tar.zst' % (version, version))
|
|
||||||
os.chdir('..')
|
|
||||||
else:
|
else:
|
||||||
os.system('cargo build --release --features ' + features)
|
# os.system('cargo build --release --features ' + features)
|
||||||
os.system('git checkout src/ui/common.tis')
|
os.system('git checkout src/ui/common.tis')
|
||||||
os.system('strip target/release/rustdesk')
|
os.system('strip target/release/rustdesk')
|
||||||
os.system("sed -i 's/pkgver=.*/pkgver=%s/g' PKGBUILD" % version)
|
os.system("sed -i 's/pkgver=.*/pkgver=%s/g' PKGBUILD" % version)
|
||||||
@ -189,6 +228,15 @@ def main():
|
|||||||
# yum localinstall rustdesk.rpm
|
# yum localinstall rustdesk.rpm
|
||||||
else:
|
else:
|
||||||
os.system('cargo bundle --release --features ' + features)
|
os.system('cargo bundle --release --features ' + features)
|
||||||
|
if flutter:
|
||||||
|
if osx:
|
||||||
|
# todo: OSX build
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
os.system(
|
||||||
|
'mv target/release/bundle/deb/rustdesk*.deb ./flutter/rustdesk.deb')
|
||||||
|
build_flutter_deb(version)
|
||||||
|
else:
|
||||||
if osx:
|
if osx:
|
||||||
os.system(
|
os.system(
|
||||||
'strip target/release/bundle/osx/RustDesk.app/Contents/MacOS/rustdesk')
|
'strip target/release/bundle/osx/RustDesk.app/Contents/MacOS/rustdesk')
|
||||||
@ -202,40 +250,43 @@ def main():
|
|||||||
fh.write(txt.replace("</dict>", """
|
fh.write(txt.replace("</dict>", """
|
||||||
<key>LSUIElement</key>
|
<key>LSUIElement</key>
|
||||||
<string>1</string>
|
<string>1</string>
|
||||||
</dict>"""))
|
</dict>"""))
|
||||||
pa = os.environ.get('P')
|
pa = os.environ.get('P')
|
||||||
if pa:
|
if pa:
|
||||||
os.system('''
|
os.system('''
|
||||||
# buggy: rcodesign sign ... path/*, have to sign one by one
|
# buggy: rcodesign sign ... path/*, have to sign one by one
|
||||||
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./target/release/bundle/osx/RustDesk.app/Contents/MacOS/rustdesk
|
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./target/release/bundle/osx/RustDesk.app/Contents/MacOS/rustdesk
|
||||||
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./target/release/bundle/osx/RustDesk.app/Contents/MacOS/libsciter.dylib
|
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./target/release/bundle/osx/RustDesk.app/Contents/MacOS/libsciter.dylib
|
||||||
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./target/release/bundle/osx/RustDesk.app
|
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./target/release/bundle/osx/RustDesk.app
|
||||||
# goto "Keychain Access" -> "My Certificates" for below id which starts with "Developer ID Application:"
|
# goto "Keychain Access" -> "My Certificates" for below id which starts with "Developer ID Application:"
|
||||||
codesign -s "Developer ID Application: {0}" --force --options runtime ./target/release/bundle/osx/RustDesk.app/Contents/MacOS/*
|
codesign -s "Developer ID Application: {0}" --force --options runtime ./target/release/bundle/osx/RustDesk.app/Contents/MacOS/*
|
||||||
codesign -s "Developer ID Application: {0}" --force --options runtime ./target/release/bundle/osx/RustDesk.app
|
codesign -s "Developer ID Application: {0}" --force --options runtime ./target/release/bundle/osx/RustDesk.app
|
||||||
'''.format(pa))
|
'''.format(pa))
|
||||||
os.system('create-dmg target/release/bundle/osx/RustDesk.app')
|
os.system('create-dmg target/release/bundle/osx/RustDesk.app')
|
||||||
os.rename('RustDesk %s.dmg' % version, 'rustdesk-%s.dmg' % version)
|
os.rename('RustDesk %s.dmg' %
|
||||||
|
version, 'rustdesk-%s.dmg' % version)
|
||||||
if pa:
|
if pa:
|
||||||
os.system('''
|
os.system('''
|
||||||
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./rustdesk-{1}.dmg
|
#rcodesign sign --p12-file ~/.p12/rustdesk-developer-id.p12 --p12-password-file ~/.p12/.cert-pass --code-signature-flags runtime ./rustdesk-{1}.dmg
|
||||||
codesign -s "Developer ID Application: {0}" --force --options runtime ./rustdesk-{1}.dmg
|
codesign -s "Developer ID Application: {0}" --force --options runtime ./rustdesk-{1}.dmg
|
||||||
# https://pyoxidizer.readthedocs.io/en/latest/apple_codesign_rcodesign.html
|
# https://pyoxidizer.readthedocs.io/en/latest/apple_codesign_rcodesign.html
|
||||||
rcodesign notarize --api-issuer 69a6de7d-2907-47e3-e053-5b8c7c11a4d1 --api-key 9JBRHG3JHT --staple ./rustdesk-{1}.dmg
|
rcodesign notarize --api-issuer 69a6de7d-2907-47e3-e053-5b8c7c11a4d1 --api-key 9JBRHG3JHT --staple ./rustdesk-{1}.dmg
|
||||||
# verify: spctl -a -t exec -v /Applications/RustDesk.app
|
# verify: spctl -a -t exec -v /Applications/RustDesk.app
|
||||||
'''.format(pa, version))
|
'''.format(pa, version))
|
||||||
else:
|
else:
|
||||||
print('Not signed')
|
print('Not signed')
|
||||||
else:
|
else:
|
||||||
# buid deb package
|
# buid deb package
|
||||||
os.system('mv target/release/bundle/deb/rustdesk*.deb ./rustdesk.deb')
|
os.system(
|
||||||
|
'mv target/release/bundle/deb/rustdesk*.deb ./rustdesk.deb')
|
||||||
os.system('dpkg-deb -R rustdesk.deb tmpdeb')
|
os.system('dpkg-deb -R rustdesk.deb tmpdeb')
|
||||||
os.system('mkdir -p tmpdeb/usr/share/rustdesk/files/systemd/')
|
os.system('mkdir -p tmpdeb/usr/share/rustdesk/files/systemd/')
|
||||||
os.system(
|
os.system(
|
||||||
'cp rustdesk.service tmpdeb/usr/share/rustdesk/files/systemd/')
|
'cp rustdesk.service tmpdeb/usr/share/rustdesk/files/systemd/')
|
||||||
os.system(
|
os.system(
|
||||||
'cp rustdesk.service.user tmpdeb/usr/share/rustdesk/files/systemd/')
|
'cp rustdesk.service.user tmpdeb/usr/share/rustdesk/files/systemd/')
|
||||||
os.system('cp pynput_service.py tmpdeb/usr/share/rustdesk/files/')
|
os.system(
|
||||||
|
'cp pynput_service.py tmpdeb/usr/share/rustdesk/files/')
|
||||||
os.system('cp -a DEBIAN/* tmpdeb/DEBIAN/')
|
os.system('cp -a DEBIAN/* tmpdeb/DEBIAN/')
|
||||||
os.system('strip tmpdeb/usr/bin/rustdesk')
|
os.system('strip tmpdeb/usr/bin/rustdesk')
|
||||||
os.system('mkdir -p tmpdeb/usr/lib/rustdesk')
|
os.system('mkdir -p tmpdeb/usr/lib/rustdesk')
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
Version=1.2.0
|
Version=1.1.10
|
||||||
Name=RustDesk
|
Name=RustDesk
|
||||||
GenericName=Remote Desktop
|
GenericName=Remote Desktop
|
||||||
Comment=Remote Desktop
|
Comment=Remote Desktop
|
||||||
|
@ -23,7 +23,7 @@ mkdir -p %{buildroot}/usr/share/rustdesk/files/
|
|||||||
install -m 755 $HBB/target/release/rustdesk %{buildroot}/usr/bin/rustdesk
|
install -m 755 $HBB/target/release/rustdesk %{buildroot}/usr/bin/rustdesk
|
||||||
install $HBB/libsciter-gtk.so %{buildroot}/usr/lib/rustdesk/libsciter-gtk.so
|
install $HBB/libsciter-gtk.so %{buildroot}/usr/lib/rustdesk/libsciter-gtk.so
|
||||||
install $HBB/rustdesk.service %{buildroot}/usr/share/rustdesk/files/
|
install $HBB/rustdesk.service %{buildroot}/usr/share/rustdesk/files/
|
||||||
install $HBB/256-no-margin.png %{buildroot}/usr/share/rustdesk/files/rustdesk.png
|
install $HBB/128x128@2x.png %{buildroot}/usr/share/rustdesk/files/rustdesk.png
|
||||||
install $HBB/rustdesk.desktop %{buildroot}/usr/share/rustdesk/files/
|
install $HBB/rustdesk.desktop %{buildroot}/usr/share/rustdesk/files/
|
||||||
install $HBB/pynput_service.py %{buildroot}/usr/share/rustdesk/files/
|
install $HBB/pynput_service.py %{buildroot}/usr/share/rustdesk/files/
|
||||||
|
|
||||||
|
2
rpm.spec
2
rpm.spec
@ -23,7 +23,7 @@ mkdir -p %{buildroot}/usr/share/rustdesk/files/
|
|||||||
install -m 755 $HBB/target/release/rustdesk %{buildroot}/usr/bin/rustdesk
|
install -m 755 $HBB/target/release/rustdesk %{buildroot}/usr/bin/rustdesk
|
||||||
install $HBB/libsciter-gtk.so %{buildroot}/usr/lib/rustdesk/libsciter-gtk.so
|
install $HBB/libsciter-gtk.so %{buildroot}/usr/lib/rustdesk/libsciter-gtk.so
|
||||||
install $HBB/rustdesk.service %{buildroot}/usr/share/rustdesk/files/
|
install $HBB/rustdesk.service %{buildroot}/usr/share/rustdesk/files/
|
||||||
install $HBB/256-no-margin.png %{buildroot}/usr/share/rustdesk/files/rustdesk.png
|
install $HBB/128x128@2x.png %{buildroot}/usr/share/rustdesk/files/rustdesk.png
|
||||||
install $HBB/rustdesk.desktop %{buildroot}/usr/share/rustdesk/files/
|
install $HBB/rustdesk.desktop %{buildroot}/usr/share/rustdesk/files/
|
||||||
install $HBB/pynput_service.py %{buildroot}/usr/share/rustdesk/files/
|
install $HBB/pynput_service.py %{buildroot}/usr/share/rustdesk/files/
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user