4.5 KiB
Follow these instructions to create installers for the Haveno Java desktop application on each platform.
Note
These steps will delete the previously built Haveno binaries, so they'll need rebuilt after.
Linux
From x86_64 machine:
sudo apt-get update
sudo apt install -y rpm fuse flatpak flatpak-builder
./gradlew clean build --refresh-keys --refresh-dependencies
(ormake clean && skip-tests
after refreshed)./gradlew packageInstallers
- Confirm prompts.
- Path to installer is printed at the end. Execute to install, e.g.:
sudo dpkg -i <path>.deb
or open<path>.deb
with Software Install.
Note: Please see flatpak.md for information on distributing Haveno via Flatpak.
Haveno data folder on Linux: /home/<username>/.local/share/Haveno/
macOS
From x86_64 machine:
./gradlew clean build --refresh-keys --refresh-dependencies
(ormake clean && skip-tests
after refreshed)./gradlew packageInstallers
- Confirm prompts.
- Path to installer printed at end.
open <path>
- Open installer and drag Haveno.app to Applications.
sudo xattr -rd com.apple.quarantine /Applications/Haveno.app
- Right click /Applications/Haveno.app > Open. Repeat again if necessary, despite being "damaged".
Haveno data folder on Mac: /Users/<username>/Library/Application Support/Haveno/
Windows
- Enable .NET Framework 3.5:
- Open the Control Panel on your Windows system.
- Click on "Programs and Features" or "Uninstall a Program."
- On the left-hand side, click on "Turn Windows features on or off."
- In the "Windows Features" dialog box, scroll down and find the ".NET Framework 3.5 (includes .NET 2.0 and 3.0)" option.
- Check the box next to it to select it.
- Click "OK" to save the changes and exit the dialog box.
- Windows will download and install the required files and components to enable the .NET Framework 3.5. This may take several minutes, depending on your internet connection speed and system configuration.
- Once the installation is complete, you will need to restart your computer to apply the changes.
- Install Wix Toolset 3: https://github.com/wixtoolset/wix3/releases/tag/wix314rtm
- Open MSYS2 for the following commands.
export PATH=$PATH:$JAVA_HOME/bin:"C:\Program Files (x86)\WiX Toolset v3.14\bin"
./gradlew clean build --refresh-keys --refresh-dependencies
(ormake clean && skip-tests
after refreshed)./gradlew packageInstallers
- Confirm prompts.
- Path to installer is printed at the end. Execute to install.
Haveno data folder on Windows: ~\AppData\Roaming\Haveno\
Copying installer and rebuilding Haveno binaries
- Copy the installer to a safe location because it will be deleted in the next step.
make clean && make
(ormake clean && make skip-tests
) to rebuild Haveno apps.
Additional Notes
Icons
Icons (Haveno.zip) were obtained from https://github.com/haveno-dex/haveno-meta/issues/1#issuecomment-819741689.
Building for Linux
The linux package requires the correct packaging tools installed. You may run into the following errors:
Error: Invalid or unsupported type: [deb]
Error: Invalid or unsupported type: [rpm]
On Ubuntu, resolve by running sudo apt install rpm
. For deb, ensure dpkg is installed.
Exception in thread "main" java.io.IOException: Failed to rename /tmp/Haveno-stripped15820156885694375398.tmp to /storage/src/haveno/desktop/build/libs/fatJar/desktop-1.0.0-SNAPSHOT-all.jar
at haveno.tools.Utils.renameFile(Utils.java:36)
at io.github.zlika.reproducible.StipZipFile.strip(StipZipFile.java:35)
at haveno.tools.DeterministicBuildTool.main(DeterministicBuildTool.java:24)
This may happen if the source folder is on a different hard drive than the system tmp
folder. The tools-1.0.jar calls renameTo to rename the deterministic jar back to the fat jar location. You can temporarily change your temp directory on linux:
export _JAVA_OPTIONS="-Djava.io.tmpdir=/storage/tmp"
Building for macOS
Svg was converted into a 1024x1024 pixel PNG using https://webkul.github.io/myscale/, then converted to icns for macosx here https://cloudconvert.com/png-to-icns
Known Issues
Signing is not implemented.
Building for Windows
Pngs were resized and pasted into the WixUi images using paint. CloudConvert was used to convert the Haveno png icon to ico.
Known Issues
The installer's final step "Launch Haveno" has a different background color. The setup executable does not have an icon.