haveno/desktop/package
woodser 7e4e950710
Some checks are pending
CI / build (windows-latest) (push) Waiting to run
CI / build (macos-13) (push) Waiting to run
CI / build (ubuntu-22.04) (push) Waiting to run
Codacy Coverage Reporter / Publish coverage (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
update flatpak release date
2024-12-19 06:58:34 -05:00
..
linux update flatpak release date 2024-12-19 06:58:34 -05:00
macosx bump version to 1.0.15 2024-12-19 06:04:55 -05:00
windows Remove excess transparency from around icons 2024-07-24 14:26:51 -04:00
5BC5ED73.asc Bisq 2021-05-04 20:20:01 -04:00
29CDFD3B.asc Bisq 2021-05-04 20:20:01 -04:00
F379A1C6.asc Bisq 2021-05-04 20:20:01 -04:00
Haveno.zip fix packageInstallers for all platforms 2022-10-12 10:42:34 -04:00
package.gradle updates to flatpak installer 2024-10-08 14:02:40 -04:00
README.md updates to flatpak installer 2024-10-08 14:02:40 -04:00
signingkey.asc Bisq 2021-05-04 20:20:01 -04:00
tools-1.0.jar Bisq 2021-05-04 20:20:01 -04:00

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:

  1. sudo apt-get update
  2. sudo apt install -y rpm libfuse2 flatpak flatpak-builder appstream
  3. flatpak remote-add --if-not-exists --user flathub https://dl.flathub.org/repo/flathub.flatpakrepo
  4. ./gradlew clean build --refresh-keys --refresh-dependencies (or make clean && skip-tests after refreshed)
  5. ./gradlew packageInstallers
  6. Confirm prompts.
  7. 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:

  1. ./gradlew clean build --refresh-keys --refresh-dependencies (or make clean && skip-tests after refreshed)
  2. ./gradlew packageInstallers
  3. Confirm prompts.
  4. Path to installer printed at end.
  5. open <path>
  6. Open installer and drag Haveno.app to Applications.
  7. sudo xattr -rd com.apple.quarantine /Applications/Haveno.app
  8. 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

  1. Enable .NET Framework 3.5:
    1. Open the Control Panel on your Windows system.
    2. Click on "Programs and Features" or "Uninstall a Program."
    3. On the left-hand side, click on "Turn Windows features on or off."
    4. In the "Windows Features" dialog box, scroll down and find the ".NET Framework 3.5 (includes .NET 2.0 and 3.0)" option.
    5. Check the box next to it to select it.
    6. Click "OK" to save the changes and exit the dialog box.
    7. 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.
    8. Once the installation is complete, you will need to restart your computer to apply the changes.
  2. Install Wix Toolset 3: https://github.com/wixtoolset/wix3/releases/tag/wix314rtm
  3. Open MSYS2 for the following commands.
  4. export PATH=$PATH:$JAVA_HOME/bin:"C:\Program Files (x86)\WiX Toolset v3.14\bin"
  5. ./gradlew clean build --refresh-keys --refresh-dependencies (or make clean && skip-tests after refreshed)
  6. ./gradlew packageInstallers
  7. Confirm prompts.
  8. 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

  1. Copy the installer to a safe location because it will be deleted in the next step.
  2. make clean && make (or make 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.