mirror of
https://github.com/haveno-dex/haveno.git
synced 2025-01-10 12:54:32 +00:00
Revert "feat: add flatpak builds (#1230)"
This reverts commit 662eaee7c3
.
This commit is contained in:
parent
5b9f205658
commit
3d94ac8ceb
9 changed files with 23 additions and 243 deletions
21
.github/workflows/build.yml
vendored
21
.github/workflows/build.yml
vendored
|
@ -40,8 +40,7 @@ jobs:
|
||||||
if: ${{ matrix.os == 'ubuntu-22.04' }}
|
if: ${{ matrix.os == 'ubuntu-22.04' }}
|
||||||
run: |
|
run: |
|
||||||
sudo apt update
|
sudo apt update
|
||||||
sudo apt install -y rpm libfuse2 flatpak flatpak-builder appstream
|
sudo apt install -y rpm fuse
|
||||||
flatpak remote-add --if-not-exists --user flathub https://dl.flathub.org/repo/flathub.flatpakrepo
|
|
||||||
- name: Install WiX Toolset
|
- name: Install WiX Toolset
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' }}
|
||||||
run: |
|
run: |
|
||||||
|
@ -74,19 +73,17 @@ jobs:
|
||||||
if [ "${{ matrix.os }}" == "ubuntu-22.04" ]; then
|
if [ "${{ matrix.os }}" == "ubuntu-22.04" ]; then
|
||||||
mkdir ${{ github.workspace }}/release-rpm
|
mkdir ${{ github.workspace }}/release-rpm
|
||||||
mkdir ${{ github.workspace }}/release-deb
|
mkdir ${{ github.workspace }}/release-deb
|
||||||
mkdir ${{ github.workspace }}/release-flat
|
|
||||||
mkdir ${{ github.workspace }}/release-appimage
|
mkdir ${{ github.workspace }}/release-appimage
|
||||||
mv desktop/build/temp-*/binaries/haveno-*.rpm ${{ github.workspace }}/release-rpm/Haveno-v${{ env.VERSION }}-linux-x86_64-installer.rpm
|
mv desktop/build/temp-*/binaries/haveno-*.rpm ${{ github.workspace }}/release-rpm/Haveno-${{ env.VERSION }}-linux-x86_64-installer.rpm
|
||||||
mv desktop/build/temp-*/binaries/haveno_*.deb ${{ github.workspace }}/release-deb/Haveno-v${{ env.VERSION }}-linux-x86_64-installer.deb
|
mv desktop/build/temp-*/binaries/haveno_*.deb ${{ github.workspace }}/release-deb/Haveno-${{ env.VERSION }}-linux-x86_64-installer.deb
|
||||||
mv desktop/build/temp-*/binaries/*.flatpak ${{ github.workspace }}/release-flat/Haveno-v${{ env.VERSION }}-linux-x86_64.flatpak
|
mv desktop/build/temp-*/binaries/haveno_*.AppImage ${{ github.workspace }}/release-appimage/Haveno-${{ env.VERSION }}-linux-x86_64.AppImage
|
||||||
mv desktop/build/temp-*/binaries/haveno_*.AppImage ${{ github.workspace }}/release-appimage/Haveno-v${{ env.VERSION }}-linux-x86_64.AppImage
|
|
||||||
else
|
else
|
||||||
mv desktop/build/temp-*/binaries/Haveno-*.dmg ${{ github.workspace }}/release/Haveno-v${{ env.VERSION }}-mac-installer.dmg
|
mv desktop/build/temp-*/binaries/Haveno-*.dmg ${{ github.workspace }}/release/Haveno-v${{ env.VERSION }}-mac-installer.dmg
|
||||||
fi
|
fi
|
||||||
|
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release
|
||||||
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-deb
|
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-deb
|
||||||
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-rpm
|
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-rpm
|
||||||
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-appimage
|
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-appimage
|
||||||
cp desktop/build/temp-*/binaries/desktop-*.jar.SHA-256 ${{ github.workspace }}/release-flat
|
|
||||||
shell: bash
|
shell: bash
|
||||||
- name: Move Release Files on Windows
|
- name: Move Release Files on Windows
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' }}
|
||||||
|
@ -123,17 +120,9 @@ jobs:
|
||||||
with:
|
with:
|
||||||
name: haveno-linux-rpm
|
name: haveno-linux-rpm
|
||||||
path: ${{ github.workspace }}/release-rpm
|
path: ${{ github.workspace }}/release-rpm
|
||||||
|
|
||||||
- uses: actions/upload-artifact@v3
|
- uses: actions/upload-artifact@v3
|
||||||
name: "Linux - AppImage artifact"
|
name: "Linux - AppImage artifact"
|
||||||
if: ${{ matrix.os == 'ubuntu-22.04' }}
|
if: ${{ matrix.os == 'ubuntu-22.04' }}
|
||||||
with:
|
with:
|
||||||
name: haveno-linux-appimage
|
name: haveno-linux-appimage
|
||||||
path: ${{ github.workspace }}/release-appimage
|
path: ${{ github.workspace }}/release-appimage
|
||||||
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
name: "Linux - flatpak artifact"
|
|
||||||
if: ${{ matrix.os == 'ubuntu-22.04' }}
|
|
||||||
with:
|
|
||||||
name: haveno-linux-flatpak
|
|
||||||
path: ${{ github.workspace }}/release-flat
|
|
||||||
|
|
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -37,5 +37,3 @@ deploy
|
||||||
.vscode
|
.vscode
|
||||||
.vim/*
|
.vim/*
|
||||||
*/.factorypath
|
*/.factorypath
|
||||||
.flatpak-builder
|
|
||||||
exchange.haveno.Haveno.yaml
|
|
||||||
|
|
|
@ -82,8 +82,6 @@ import java.util.concurrent.atomic.AtomicInteger;
|
||||||
@Slf4j
|
@Slf4j
|
||||||
public abstract class HavenoExecutable implements GracefulShutDownHandler, HavenoSetup.HavenoSetupListener, UncaughtExceptionHandler {
|
public abstract class HavenoExecutable implements GracefulShutDownHandler, HavenoSetup.HavenoSetupListener, UncaughtExceptionHandler {
|
||||||
|
|
||||||
// TODO: regular expression is used to parse application name for the flatpak manifest, a more stable approach would be nice
|
|
||||||
// Don't edit the next line unless you're only editing in between the quotes.
|
|
||||||
public static final String DEFAULT_APP_NAME = "Haveno";
|
public static final String DEFAULT_APP_NAME = "Haveno";
|
||||||
|
|
||||||
public static final int EXIT_SUCCESS = 0;
|
public static final int EXIT_SUCCESS = 0;
|
||||||
|
|
|
@ -3,23 +3,20 @@ Follow these instructions to create installers for the Haveno Java desktop appli
|
||||||
> **Note**
|
> **Note**
|
||||||
> These steps will delete the previously built Haveno binaries, so they'll need rebuilt after.
|
> These steps will delete the previously built Haveno binaries, so they'll need rebuilt after.
|
||||||
|
|
||||||
## Linux
|
### Linux
|
||||||
|
|
||||||
From x86_64 machine:
|
From x86_64 machine:
|
||||||
|
|
||||||
1. `sudo apt-get update`
|
1. `sudo apt-get update`
|
||||||
2. `sudo apt install -y rpm fuse flatpak flatpak-builder`
|
2. `sudo apt install -y rpm fuse`
|
||||||
1. `./gradlew clean build --refresh-keys --refresh-dependencies` (or `make clean && skip-tests` after refreshed)
|
1. `./gradlew clean build --refresh-keys --refresh-dependencies` (or `make clean && skip-tests` after refreshed)
|
||||||
2. `./gradlew packageInstallers`
|
2. `./gradlew packageInstallers`
|
||||||
3. Confirm prompts.
|
3. Confirm prompts.
|
||||||
4. 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.
|
4. 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](../../docs/flatpak.md) for information on
|
|
||||||
distributing Haveno via Flatpak.
|
|
||||||
|
|
||||||
Haveno data folder on Linux: `/home/<username>/.local/share/Haveno/`
|
Haveno data folder on Linux: `/home/<username>/.local/share/Haveno/`
|
||||||
|
|
||||||
## macOS
|
### macOS
|
||||||
|
|
||||||
From x86_64 machine:
|
From x86_64 machine:
|
||||||
|
|
||||||
|
@ -34,7 +31,7 @@ From x86_64 machine:
|
||||||
|
|
||||||
Haveno data folder on Mac: `/Users/<username>/Library/Application Support/Haveno/`
|
Haveno data folder on Mac: `/Users/<username>/Library/Application Support/Haveno/`
|
||||||
|
|
||||||
## Windows
|
### Windows
|
||||||
|
|
||||||
1. Enable .NET Framework 3.5:
|
1. Enable .NET Framework 3.5:
|
||||||
1. Open the Control Panel on your Windows system.
|
1. Open the Control Panel on your Windows system.
|
||||||
|
@ -45,7 +42,7 @@ Haveno data folder on Mac: `/Users/<username>/Library/Application Support/Haveno
|
||||||
6. Click "OK" to save the changes and exit the dialog box.
|
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.
|
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.
|
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>
|
2. Install Wix Toolset 3: https://github.com/wixtoolset/wix3/releases/tag/wix314rtm
|
||||||
3. Open MSYS2 for the following commands.
|
3. Open MSYS2 for the following commands.
|
||||||
4. `export PATH=$PATH:$JAVA_HOME/bin:"C:\Program Files (x86)\WiX Toolset v3.14\bin"`
|
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)
|
5. `./gradlew clean build --refresh-keys --refresh-dependencies` (or `make clean && skip-tests` after refreshed)
|
||||||
|
@ -55,32 +52,32 @@ Haveno data folder on Mac: `/Users/<username>/Library/Application Support/Haveno
|
||||||
|
|
||||||
Haveno data folder on Windows: `~\AppData\Roaming\Haveno\`
|
Haveno data folder on Windows: `~\AppData\Roaming\Haveno\`
|
||||||
|
|
||||||
## Copying installer and rebuilding Haveno binaries
|
## Copy installer and rebuild Haveno binaries
|
||||||
|
|
||||||
1. Copy the installer to a safe location because it will be deleted in the next step.
|
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.
|
2. `make clean && make` (or `make clean && make skip-tests`) to rebuild Haveno apps.
|
||||||
|
|
||||||
|
|
||||||
## Additional Notes
|
## Additional Notes
|
||||||
|
|
||||||
### Icons
|
### Icons
|
||||||
|
|
||||||
Icons (Haveno.zip) were obtained from <https://github.com/haveno-dex/haveno-meta/issues/1#issuecomment-819741689>.
|
Icons (Haveno.zip) were obtained from https://github.com/haveno-dex/haveno-meta/issues/1#issuecomment-819741689.
|
||||||
|
|
||||||
### Building for Linux
|
#### Linux
|
||||||
|
|
||||||
The linux package requires the correct packaging tools installed. You may run into the following errors:
|
The linux package requires the correct packaging tools installed. You may run into the following errors:
|
||||||
|
|
||||||
```sh
|
```
|
||||||
Error: Invalid or unsupported type: [deb]
|
Error: Invalid or unsupported type: [deb]
|
||||||
```
|
```
|
||||||
|
```
|
||||||
```sh
|
|
||||||
Error: Invalid or unsupported type: [rpm]
|
Error: Invalid or unsupported type: [rpm]
|
||||||
```
|
```
|
||||||
|
|
||||||
On Ubuntu, resolve by running `sudo apt install rpm`. For deb, ensure dpkg is installed.
|
On Ubuntu, resolve by running `sudo apt install rpm`. For deb, ensure dpkg is installed.
|
||||||
|
|
||||||
```sh
|
```
|
||||||
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
|
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 haveno.tools.Utils.renameFile(Utils.java:36)
|
||||||
at io.github.zlika.reproducible.StipZipFile.strip(StipZipFile.java:35)
|
at io.github.zlika.reproducible.StipZipFile.strip(StipZipFile.java:35)
|
||||||
|
@ -90,21 +87,20 @@ Exception in thread "main" java.io.IOException: Failed to rename /tmp/Haveno-str
|
||||||
|
|
||||||
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:
|
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:
|
||||||
|
|
||||||
```sh
|
```
|
||||||
export _JAVA_OPTIONS="-Djava.io.tmpdir=/storage/tmp"
|
export _JAVA_OPTIONS="-Djava.io.tmpdir=/storage/tmp"
|
||||||
```
|
```
|
||||||
|
|
||||||
### Building for macOS
|
#### MacOs
|
||||||
|
|
||||||
Svg was converted into a 1024x1024 pixel PNG using
|
Svg was converted into a 1024x1024 pixel PNG using https://webkul.github.io/myscale/, then converted to icns for macosx
|
||||||
<https://webkul.github.io/myscale/>, then converted to icns for macosx
|
here https://cloudconvert.com/png-to-icns
|
||||||
here <https://cloudconvert.com/png-to-icns>
|
|
||||||
|
|
||||||
#### Known Issues
|
##### Known Issues
|
||||||
|
|
||||||
Signing is not implemented.
|
Signing is not implemented.
|
||||||
|
|
||||||
### Building for Windows
|
#### Windows
|
||||||
|
|
||||||
Pngs were resized and pasted into the WixUi images using paint. [CloudConvert](https://cloudconvert.com) was used to convert the Haveno png icon to ico.
|
Pngs were resized and pasted into the WixUi images using paint. [CloudConvert](https://cloudconvert.com) was used to convert the Haveno png icon to ico.
|
||||||
|
|
||||||
|
|
|
@ -11,4 +11,3 @@ Terminal=false
|
||||||
Type=Application
|
Type=Application
|
||||||
MimeType=
|
MimeType=
|
||||||
X-AppImage-Name=Haveno
|
X-AppImage-Name=Haveno
|
||||||
StartupWMClass=Haveno
|
|
||||||
|
|
|
@ -1,66 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<component type="desktop-application">
|
|
||||||
<id>exchange.haveno.Haveno</id>
|
|
||||||
<!-- <icon type="stock">exchange.haveno.Haveno</icon> -->
|
|
||||||
<launchable type="desktop-id">exchange.haveno.Haveno.desktop</launchable>
|
|
||||||
<name>Haveno</name>
|
|
||||||
<summary>Decentralized P2P exchange built on Monero and Tor</summary>
|
|
||||||
<categories>
|
|
||||||
<category>Office</category>
|
|
||||||
<category>Finance</category>
|
|
||||||
<category>P2P</category>
|
|
||||||
</categories>
|
|
||||||
<keywords>
|
|
||||||
<keyword>cryptocurrency</keyword>
|
|
||||||
<keyword>monero</keyword>
|
|
||||||
</keywords>
|
|
||||||
|
|
||||||
|
|
||||||
<metadata_license>CC-BY-4.0</metadata_license>
|
|
||||||
<project_license>AGPL-3.0-only</project_license>
|
|
||||||
<branding>
|
|
||||||
<color type="primary" scheme_preference="light">#e5a29f</color>
|
|
||||||
<color type="primary" scheme_preference="dark">#562c63</color>
|
|
||||||
</branding>
|
|
||||||
<supports>
|
|
||||||
<control>pointing</control>
|
|
||||||
<control>keyboard</control>
|
|
||||||
<control>touch</control>
|
|
||||||
</supports>
|
|
||||||
|
|
||||||
<description>
|
|
||||||
<p>Haveno (pronounced ha‧ve‧no) is a platform for people who want to exchange Monero for fiat currencies like EUR, GBP, and USD or other cryptocurrencies like BTC, ETH, and BCH.</p>
|
|
||||||
<ul>
|
|
||||||
<li>All communications are routed through Tor, to preserve your privacy
|
|
||||||
</li>
|
|
||||||
<li>Trades are peer-to-peer: trades on Haveno will happen between people only, there is no central authority.
|
|
||||||
</li>
|
|
||||||
<li>Trades are non-custodial: Haveno provides arbitration in case something goes wrong during the trade, but we will never have access to your funds.
|
|
||||||
</li>
|
|
||||||
<li>There is No token, because we don't need it. Transactions between traders are secured by non-custodial multisignature transactions on the Monero network.
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
</description>
|
|
||||||
<screenshots>
|
|
||||||
<screenshot type="default">
|
|
||||||
<image>https://files.catbox.moe/8pahgg.png</image>
|
|
||||||
<caption>Recent Trades page</caption>
|
|
||||||
</screenshot>
|
|
||||||
</screenshots>
|
|
||||||
|
|
||||||
<developer id="exchange.haveno">
|
|
||||||
<name>woodser</name>
|
|
||||||
</developer>
|
|
||||||
<url type="homepage">https://haveno.exchange</url>
|
|
||||||
<url type="bugtracker">https://github.com/haveno-dex/haveno/issues</url>
|
|
||||||
<content_rating type="oars-1.1">
|
|
||||||
<content_attribute id="social-chat">moderate</content_attribute>
|
|
||||||
<content_attribute id="social-info">moderate</content_attribute>
|
|
||||||
<content_attribute id="social-contacts">intense</content_attribute>
|
|
||||||
<content_attribute id="money-purchasing">intense</content_attribute>
|
|
||||||
</content_rating>
|
|
||||||
|
|
||||||
|
|
||||||
<launchable type="desktop-id">Haveno.desktop</launchable>
|
|
||||||
</component>
|
|
|
@ -1,52 +0,0 @@
|
||||||
id: exchange.haveno.Haveno
|
|
||||||
runtime: org.freedesktop.Platform
|
|
||||||
runtime-version: "23.08"
|
|
||||||
sdk: org.freedesktop.Sdk
|
|
||||||
sdk-extensions:
|
|
||||||
- org.freedesktop.Sdk.Extension.openjdk21
|
|
||||||
command: /app/bin/Haveno
|
|
||||||
modules:
|
|
||||||
- name: openjdk
|
|
||||||
buildsystem: simple
|
|
||||||
build-commands:
|
|
||||||
- /usr/lib/sdk/openjdk21/install.sh
|
|
||||||
- name: Haveno
|
|
||||||
buildsystem: simple
|
|
||||||
sources:
|
|
||||||
# - type: git
|
|
||||||
# url: https://github.com/haveno-dex/haveno
|
|
||||||
- type: dir
|
|
||||||
path: build
|
|
||||||
- type: file
|
|
||||||
path: package/linux/Haveno.desktop
|
|
||||||
- type: file
|
|
||||||
path: package/linux/exchange.haveno.Haveno.metainfo.xml
|
|
||||||
- type: file
|
|
||||||
path: package/linux/icon.png
|
|
||||||
build-commands:
|
|
||||||
- ls
|
|
||||||
- pwd
|
|
||||||
# TODO: consider switching from reading from a deb to reading from jpackage's image
|
|
||||||
- mv temp-*/binaries/haveno_*.deb haveno.deb
|
|
||||||
- ar x haveno.deb
|
|
||||||
- tar xf data.tar.*
|
|
||||||
- cp -r opt/haveno/lib /app/lib
|
|
||||||
- install -D opt/haveno/bin/Haveno /app/bin/Haveno
|
|
||||||
- mkdir -p /app/share/icons/hicolor/128x128/apps/
|
|
||||||
- mkdir -p /app/share/applications/
|
|
||||||
- mkdir -p /app/share/metainfo/
|
|
||||||
- mv icon.png /app/share/icons/hicolor/128x128/apps/haveno.png
|
|
||||||
- mv Haveno.desktop /app/share/applications/exchange.haveno.Haveno.desktop
|
|
||||||
- mv exchange.haveno.Haveno.metainfo.xml /app/share/metainfo/
|
|
||||||
|
|
||||||
# TODO: xdg-open fails
|
|
||||||
finish-args:
|
|
||||||
- --env=PATH=/app/jre/bin:/usr/bin:$PATH
|
|
||||||
# - --env=JAVA_HOME=/app/jre
|
|
||||||
- --env=JAVA_HOME=/usr/lib/sdk/openjdk21/
|
|
||||||
- --device=dri
|
|
||||||
- --talk-name=org.freedesktop.Notifications
|
|
||||||
- --talk-name=org.freedesktop.secrets
|
|
||||||
- --share=network
|
|
||||||
- --share=ipc
|
|
||||||
- --socket=x11
|
|
|
@ -1,7 +1,6 @@
|
||||||
import org.apache.tools.ant.taskdefs.condition.Os
|
import org.apache.tools.ant.taskdefs.condition.Os
|
||||||
|
|
||||||
import java.time.LocalDateTime
|
import java.time.LocalDateTime
|
||||||
import java.util.regex.Pattern
|
|
||||||
|
|
||||||
task jpackageSanityChecks {
|
task jpackageSanityChecks {
|
||||||
description 'Interactive sanity checks on the version of the code that will be packaged'
|
description 'Interactive sanity checks on the version of the code that will be packaged'
|
||||||
|
@ -395,54 +394,6 @@ task packageInstallers {
|
||||||
executeCmd(jPackageFilePath + commonOpts + linuxOpts +
|
executeCmd(jPackageFilePath + commonOpts + linuxOpts +
|
||||||
" --linux-rpm-license-type AGPLv3" + // https://fedoraproject.org/wiki/Licensing:Main?rd=Licensing#Good_Licenses
|
" --linux-rpm-license-type AGPLv3" + // https://fedoraproject.org/wiki/Licensing:Main?rd=Licensing#Good_Licenses
|
||||||
" --type rpm")
|
" --type rpm")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Define Flatpak-related properties
|
|
||||||
String flatpakManifestFile = 'package/linux/exchange.haveno.Haveno.yml'
|
|
||||||
String linuxDir = 'package/linux'
|
|
||||||
String flatpakOutputDir = 'package/linux/build'
|
|
||||||
String flatpakExportDir = "${binariesFolderPath}/fpexport"
|
|
||||||
String flatpakBundleFile = "${binariesFolderPath}/haveno.flatpak"
|
|
||||||
|
|
||||||
// Read the default app name from the HavenoExecutable.java file
|
|
||||||
def filer = file('../core/src/main/java/haveno/core/app/HavenoExecutable.java')
|
|
||||||
def content = filer.text
|
|
||||||
def matcher = Pattern.compile(/public static final String DEFAULT_APP_NAME = "(.*?)";/).matcher(content)
|
|
||||||
def defaultAppName = "Haveno"
|
|
||||||
if (matcher.find()) {
|
|
||||||
defaultAppName = matcher.group(1)
|
|
||||||
} else {
|
|
||||||
throw new GradleException("DEFAULT_APP_NAME not found in HavenoExecutable.java")
|
|
||||||
}
|
|
||||||
// copy the manifest to a new tmp one in the same place
|
|
||||||
// and add a --filesystem=.local/share/${name} to the flatpak manifest
|
|
||||||
def manifest = file(flatpakManifestFile)
|
|
||||||
def newManifest = file('exchange.haveno.Haveno.yaml')
|
|
||||||
newManifest.write(manifest.text.replace("- --share=network", "- --share=network\n - --filesystem=~/.local/share/${defaultAppName}:create"))
|
|
||||||
flatpakManifestFile = 'exchange.haveno.Haveno.yaml'
|
|
||||||
|
|
||||||
// Command to build the Flatpak
|
|
||||||
exec {
|
|
||||||
commandLine 'flatpak-builder', '--force-clean', flatpakOutputDir, flatpakManifestFile, '--user', '--install-deps-from=flathub'
|
|
||||||
}
|
|
||||||
|
|
||||||
// Command to export the Flatpak
|
|
||||||
exec {
|
|
||||||
commandLine 'flatpak', 'build-export', flatpakExportDir, flatpakOutputDir
|
|
||||||
}
|
|
||||||
|
|
||||||
// Command to create the Flatpak bundle
|
|
||||||
exec {
|
|
||||||
commandLine 'flatpak', 'build-bundle', flatpakExportDir, flatpakBundleFile, 'exchange.haveno.Haveno', '--runtime-repo=https://flathub.org/repo/flathub.flatpakrepo'
|
|
||||||
}
|
|
||||||
|
|
||||||
// delete the flatpak build directory
|
|
||||||
delete(flatpakOutputDir)
|
|
||||||
delete(flatpakExportDir)
|
|
||||||
delete(flatpakManifestFile)
|
|
||||||
|
|
||||||
println "Flatpak package created at ${flatpakBundleFile}"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Env variable can be set by calling "export HAVENO_SHARED_FOLDER='Some value'"
|
// Env variable can be set by calling "export HAVENO_SHARED_FOLDER='Some value'"
|
||||||
|
|
|
@ -1,33 +0,0 @@
|
||||||
# Flatpak distribution
|
|
||||||
|
|
||||||
The `.flatpak` binary files (known as "bundles") that
|
|
||||||
`./gradlew packageInstallers` creates can be used to download and install
|
|
||||||
Haveno, but there are several security issues that arise in Flatpak when only
|
|
||||||
using the bundle files:
|
|
||||||
|
|
||||||
- There is no
|
|
||||||
[digital signature](https://en.wikipedia.org/wiki/Digital_signature),
|
|
||||||
if a bad actor were to upload a malicious `.flatpak` the users would have no
|
|
||||||
way to tell when upgrading.
|
|
||||||
- Upgrading isn't as easy, your users need to find the new Flatpak bundle file,
|
|
||||||
and you cannot update multiple apps easily.
|
|
||||||
- This also makes an accidental downgrade much more likely.
|
|
||||||
|
|
||||||
Flatpak has a solution for these issues, a
|
|
||||||
[Flatpak repository](https://docs.flatpak.org/en/latest/repositories.html).
|
|
||||||
Flatpak repos store the data of their apps within an OSTree (almost like git)
|
|
||||||
repository, and the commits can be signed with a GPG key. The nature of OSTree
|
|
||||||
also allows for easy updates, as the Flatpak client can download deltas of the
|
|
||||||
changes instead of the entire file.
|
|
||||||
|
|
||||||
If you plan on distributing Haveno as a Flatpak, it's recommended to create a
|
|
||||||
Flatpak repository as well. This guide will show you how to create a Flatpak
|
|
||||||
repository for Haveno. The official documentation states that [it's possible to
|
|
||||||
use GitHub/Lab Pages](https://docs.flatpak.org/en/latest/hosting-a-repository.html#hosting-a-repository-on-gitlab-github-pages)
|
|
||||||
to host the repository, but this hasn't been tested. The more common way is to
|
|
||||||
use a web server, or something like
|
|
||||||
[flat-manager](https://github.com/flatpak/flat-manager).
|
|
||||||
|
|
||||||
An example Haveno flat-manager solution using `docker-compose` has been created
|
|
||||||
and documented at <https://github.com/haveno-dex/flatman-haveno-test> if you
|
|
||||||
want a quick way to get started. Note that this does require an always-on server.
|
|
Loading…
Reference in a new issue