-
Notifications
You must be signed in to change notification settings - Fork 9
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Installer script #144
base: old-develop
Are you sure you want to change the base?
Installer script #144
Conversation
@JTvD Can we delete this branch? I think the new Nuitka compilation is oudating this work. |
@chStaiger this work is not outdated yet;) I already removed the old Nuitka branch. This one is an example for the next step: the installer. The documentation in this PR is a great starting point for the new installer branch. Therefore I would prefer to keep it for now, at least until we have decided how to move forward. |
Following the addition of Nuitka, this PR features:
• The QT installer framework
• Background info of how to set everything up for the documentation
• Background information on signing the installer
Unfortunately I don’t have access to Ubuntu & IOS machines at the moment, I know some minor changes will be required. Therefore I would like to request you to test and if needed debug the flow on those OS’es or keep them out of scope for now.
Installer
There are two issues requesting an installer, this PR makes a good start at solving both (#30, #34). There are various tools available online. For Windows https://installforge.net/ and https://jrsoftware.org/isinfo.php are recommended, for Linux some others and the same for iOS. An installer per platform is quite a hassle. There are plenty of cross platform options, unfortunately the ones I found are not cheap. During this search I came across the QT installation framework which seems to fit our use case. It’s opensource and supports the same platforms as QT itself. To keep it interesting it’s not used often or well documented. Were used to that by now😉
Luckily I found this URL which helped me get going: https://scythe-studio.com/en/blog/deploying-app-and-generating-offline-installers-for-windows-qt-installer-framework-tutorial
After installing the installer framework, from the URL below. The general idea is to make the following structure, as done by the installer script now:
• The license file
• (optional) Installerscript.qs with custom changes to the installer.
• A package.xml with meta information on the application, in the future we might want to retrieve some from git.
Note that the install folder attached to the git has a different build up. This is done to avoid duplicate files, the deploy_script puts everything in the right place.
Other helpful links
I set the paths so the installer copies the program to the 'ApplicationsDir': C:\Program Files on Windows, /opt on Linux and /Applications on OS X. On windows it additionally creates a desktop icon and start menu entry.
Singing an app
Just like SSL certificates for websites, there are certificates for application to ensure the user nobody messed with it. You probably already guessed this costs a few euro’s again, in the future we might want to do it. But for now it’s enough to be aware and know that its easy to add. For more information I can recommend: Cryptography Tools - Win32 apps | Microsoft Learn
The installerframework only has an option to sign macOS applications, as described here: https://doc.qt.io/qtinstallerframework/ifw-tools.html
On windows the signtool from the windows SDK can be used to sign programs.
As described here: How To Sign Qt Apps on Windows for Release (pakkly.com)
During the installation of windows sdk you only have to check the signtool itself, which is 16mb.
Next these 3 command’s can be run in an elevated (admin) powershell to sign the installer:
For Ubuntu I have not checked the options yet, but I suspect there will be some free solutions.