Compare commits
212 Commits
v0.18.1.2
...
github-bui
| Author | SHA1 | Date | |
|---|---|---|---|
| 9ec4749244 | |||
| 7afe4a3136 | |||
| e3b20fa518 | |||
| 96e8503960 | |||
| c911d0166e | |||
| 4f5d81c88b | |||
| d2a96ccce9 | |||
| 426d9c32de | |||
| 60ad417b9e | |||
| 4ea34bb60d | |||
| 92bdbe8192 | |||
| 93b9b26d1d | |||
| 8b7ee2d8f0 | |||
| 099fc8e394 | |||
| 8c7c1dc9d7 | |||
| 6cfbb8559b | |||
| 8953c8c5f2 | |||
| 4df7f89c84 | |||
| e9c0de9e26 | |||
| 0371a26a56 | |||
| bc6e61c66c | |||
| 6c4c702722 | |||
| f77f96f5a9 | |||
| 53e4bde4c0 | |||
| 651a1a3169 | |||
| 91abd03fd3 | |||
| ab46af6cf9 | |||
| d08422420b | |||
| 0d801f5159 | |||
| f102dad609 | |||
| c6246962d8 | |||
|
|
f0b1b8cd08 | ||
|
|
674f69f131 | ||
|
|
5d5ac6a371 | ||
|
|
0c3e2301ed | ||
|
|
29e831ccec | ||
|
|
df291702df | ||
|
|
ef555a3d72 | ||
|
|
51a43341c5 | ||
|
|
ecec7bc4b6 | ||
|
|
d809370d8a | ||
|
|
cb3d693a26 | ||
|
|
e956b4ff15 | ||
|
|
ca6b38d25a | ||
|
|
8851e71a8b | ||
|
|
dc3441f258 | ||
|
|
7791cb08a9 | ||
|
|
6ed6d6a85e | ||
|
|
df4f68fbf2 | ||
|
|
1cc631d265 | ||
|
|
1fe6765efa | ||
|
|
f284677c17 | ||
|
|
84ea1776ae | ||
|
|
bd6e5b13cc | ||
|
|
de9c53bd8d | ||
|
|
981600c935 | ||
|
|
c692fd1605 | ||
|
|
819c2f57be | ||
|
|
06ed059cba | ||
|
|
e41f3cfd13 | ||
|
|
e9cd4588ae | ||
|
|
fdd406ac95 | ||
|
|
4a7e26b812 | ||
|
|
99d2884802 | ||
|
|
7a754a4dfc | ||
|
|
70a8086366 | ||
|
|
4d39449979 | ||
|
|
a3e05195c0 | ||
|
|
5954d6ba9a | ||
|
|
420d2baec2 | ||
|
|
664d578f30 | ||
|
|
33e3f599e9 | ||
|
|
bea3032df9 | ||
|
|
ab8ac87023 | ||
|
|
588b8435b7 | ||
|
|
8983cae468 | ||
|
|
3612866f9f | ||
|
|
beb336cb93 | ||
|
|
90cbe37846 | ||
|
|
10984a0a37 | ||
|
|
f5cb2443d1 | ||
|
|
8f7de0e9fc | ||
|
|
b60a98ae6c | ||
|
|
7040e3b72f | ||
|
|
12a0966eb9 | ||
|
|
5ff03786c7 | ||
|
|
483b825a2f | ||
|
|
ca304fc63d | ||
|
|
5a1a349977 | ||
|
|
5683f76cd0 | ||
|
|
cc7d7da346 | ||
|
|
d10e4d1e50 | ||
|
|
d338e06abd | ||
|
|
145ea10d93 | ||
|
|
d42caf1fbc | ||
|
|
705cc6573f | ||
|
|
5c3544f211 | ||
|
|
f859664443 | ||
|
|
2d25364f42 | ||
|
|
8323fb02ca | ||
|
|
d442ca38dc | ||
|
|
57409a8c47 | ||
|
|
f002987edd | ||
|
|
866a7b3a78 | ||
|
|
f342d46541 | ||
|
|
f5e016930b | ||
|
|
ac9a305543 | ||
|
|
f824aebfaa | ||
|
|
7765b8b462 | ||
|
|
a65fbee213 | ||
|
|
17e3ed6c97 | ||
|
|
b6e336dbaf | ||
|
|
ddcc17b7b8 | ||
|
|
f6549f328b | ||
|
|
4cbfa5efb2 | ||
|
|
fa2241f1a5 | ||
|
|
6bd11f2270 | ||
|
|
6c4a8fb819 | ||
|
|
ad1b53fa63 | ||
|
|
a9e0affe59 | ||
|
|
371ff6105b | ||
|
|
cad8874724 | ||
|
|
5345dcc11b | ||
|
|
33310786db | ||
|
|
6ac8e7a464 | ||
|
|
434f548a87 | ||
|
|
90c4aa4ec6 | ||
|
|
7a4052f3af | ||
|
|
f650e96363 | ||
|
|
91e3d3ae04 | ||
|
|
9f33c77a47 | ||
|
|
7d9c1284f9 | ||
|
|
84899f4884 | ||
|
|
9c9ff13bd2 | ||
|
|
b117b9be61 | ||
|
|
f0ccf29f48 | ||
|
|
3e80d563df | ||
|
|
e4bdff0a0c | ||
|
|
6b82c01891 | ||
|
|
cd1eab45d0 | ||
|
|
511e2f467a | ||
|
|
4941b494cc | ||
|
|
5e949dbc15 | ||
|
|
bdf14a2520 | ||
|
|
710e3f6948 | ||
|
|
6ec9e24f2f | ||
|
|
cb9af349cd | ||
|
|
c8687a961c | ||
|
|
8a910ad4c7 | ||
|
|
e8020c86df | ||
|
|
a50491d0b2 | ||
|
|
bdd91b053d | ||
|
|
4b23148e68 | ||
|
|
e167bbce20 | ||
|
|
3338bc3741 | ||
|
|
af368c93ce | ||
|
|
5ced4ef547 | ||
|
|
198dfb338c | ||
|
|
587ea68a99 | ||
|
|
7d2f2cacbf | ||
|
|
757bc7d7b9 | ||
|
|
500dc573e4 | ||
|
|
56a91b2d1b | ||
|
|
c437dab90f | ||
|
|
b7ba9437d8 | ||
|
|
76fa06ceab | ||
|
|
4487471ada | ||
|
|
55a0bc46e4 | ||
|
|
3e17445a4d | ||
|
|
fc077fa54e | ||
|
|
70950619b8 | ||
|
|
a01dc06a54 | ||
|
|
a3b54a942c | ||
|
|
c8127f651d | ||
|
|
4cc6bcbd7d | ||
|
|
8b682fbd2b | ||
|
|
48393db2c7 | ||
|
|
faa4473b17 | ||
|
|
9924dfe8af | ||
|
|
47f336bf33 | ||
|
|
07b75fb692 | ||
|
|
6c39e82519 | ||
|
|
f8178f2e54 | ||
|
|
75290d2454 | ||
|
|
b180ac8cab | ||
|
|
58c7c9ab76 | ||
|
|
b8e6cb221b | ||
|
|
ef2e711e15 | ||
|
|
2ade733867 | ||
|
|
1735154b81 | ||
|
|
a9b52f6752 | ||
|
|
7faec48c0a | ||
|
|
9e2ae684ed | ||
|
|
6984bb8113 | ||
|
|
c0a739c9fa | ||
|
|
2d254542f3 | ||
|
|
2fa79c670e | ||
|
|
4743e443dc | ||
|
|
43cc666e77 | ||
|
|
1215a6e5d8 | ||
|
|
499c2a47fc | ||
|
|
c390afd258 | ||
|
|
3b0e66a3d0 | ||
|
|
4cd6652825 | ||
|
|
80ade41905 | ||
|
|
83921a4bc8 | ||
|
|
acf876f4b2 | ||
|
|
7954661100 | ||
|
|
22a1509316 | ||
|
|
499eeee59a | ||
|
|
8cf76cf7c2 | ||
|
|
6441d99279 |
36
.gitea/workflows/build.yml
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
name: Build
|
||||||
|
run-name: Build Docker Image
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
|
||||||
|
# Build image and push to container registry
|
||||||
|
docker-build:
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- uses: satackey/action-docker-layer-caching@v0.0.11
|
||||||
|
if: "!startsWith(github.ref, 'refs/tags/v')"
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
key: docker-linux-static-{hash}
|
||||||
|
restore-keys: |
|
||||||
|
docker-linux-static-
|
||||||
|
- name: install dependencies
|
||||||
|
run: sudo apt -y install xvfb libxcb-icccm4 libxcb-image0 libxcb-keysyms1 libxcb-randr0 libxcb-render-util0 libxcb-xkb1 libxcb-shape0 libxkbcommon-x11-0
|
||||||
|
- name: prepare build environment
|
||||||
|
run: docker build --tag monero:build-env-linux --build-arg THREADS=3 --file Dockerfile.linux .
|
||||||
|
- name: build
|
||||||
|
run: docker run --rm -v /home/runner/work/monero-gui/monero-gui:/monero-gui -w /monero-gui monero:build-env-linux sh -c 'make release-static -j3'
|
||||||
|
- name: sha256sum
|
||||||
|
run: shasum -a256 /home/runner/work/monero-gui/monero-gui/build/release/bin/monero-wallet-gui
|
||||||
|
- name: test qml
|
||||||
|
run: xvfb-run -a /home/runner/work/monero-gui/monero-gui/build/release/bin/monero-wallet-gui --test-qml
|
||||||
|
- uses: actions/upload-artifact@v2
|
||||||
|
with:
|
||||||
|
name: ${{ github.job }}
|
||||||
|
path: |
|
||||||
|
/home/runner/work/monero-gui/monero-gui/build/release/bin/monero-wallet-gui
|
||||||
|
/home/runner/work/monero-gui/monero-gui/build/release/bin/monerod
|
||||||
107
.github/qt_helper.py
vendored
@@ -1,107 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
import defusedxml.ElementTree
|
|
||||||
import hashlib
|
|
||||||
import mmap
|
|
||||||
import pathlib
|
|
||||||
import subprocess
|
|
||||||
import sys
|
|
||||||
import urllib.parse
|
|
||||||
import urllib.request
|
|
||||||
import xml.etree.ElementTree as ET
|
|
||||||
|
|
||||||
MAX_TRIES = 32
|
|
||||||
|
|
||||||
def fetch_links_to_archives(os, target, major, minor, patch, toolchain):
|
|
||||||
MAX_XML_SIZE = 1024 * 1024 * 1024
|
|
||||||
MIRROR = 'download.qt.io'
|
|
||||||
base_url = f'https://{MIRROR}/online/qtsdkrepository/{os}/{target}/qt{major}_{major}{minor}{patch}'
|
|
||||||
url = f'{base_url}/Updates.xml'
|
|
||||||
for _ in range(MAX_TRIES):
|
|
||||||
try:
|
|
||||||
resp = urllib.request.urlopen(url).read(MAX_XML_SIZE)
|
|
||||||
update_xml = defusedxml.ElementTree.fromstring(resp)
|
|
||||||
break
|
|
||||||
except KeyboardInterrupt:
|
|
||||||
raise
|
|
||||||
except BaseException as e:
|
|
||||||
print('error', e, flush=True)
|
|
||||||
else:
|
|
||||||
return
|
|
||||||
for pkg in update_xml.findall('./PackageUpdate'):
|
|
||||||
name = pkg.find('.//Name')
|
|
||||||
if name == None:
|
|
||||||
continue
|
|
||||||
if name.text != f'qt.qt{major}.{major}{minor}{patch}.{toolchain}':
|
|
||||||
continue
|
|
||||||
version = pkg.find('.//Version')
|
|
||||||
if version == None:
|
|
||||||
continue
|
|
||||||
archives = pkg.find('.//DownloadableArchives')
|
|
||||||
if archives == None or archives.text == None:
|
|
||||||
continue
|
|
||||||
for archive in archives.text.split(', '):
|
|
||||||
url = f'{base_url}/{name.text}/{version.text}{archive}'
|
|
||||||
file_name = pathlib.Path(urllib.parse.urlparse(url).path).name
|
|
||||||
yield {'name': file_name, 'url': url}
|
|
||||||
|
|
||||||
def download(links):
|
|
||||||
metalink = ET.Element('metalink', xmlns = "urn:ietf:params:xml:ns:metalink")
|
|
||||||
for link in links:
|
|
||||||
file = ET.SubElement(metalink, 'file', name = link['name'])
|
|
||||||
ET.SubElement(file, 'url').text = link['url']
|
|
||||||
data = ET.tostring(metalink, encoding='UTF-8', xml_declaration=True)
|
|
||||||
for _ in range(MAX_TRIES):
|
|
||||||
with subprocess.Popen([
|
|
||||||
'aria2c',
|
|
||||||
'--connect-timeout=8',
|
|
||||||
'--console-log-level=warn',
|
|
||||||
'--continue',
|
|
||||||
'--follow-metalink=mem',
|
|
||||||
'--max-concurrent-downloads=100',
|
|
||||||
'--max-connection-per-server=16',
|
|
||||||
'--max-file-not-found=100',
|
|
||||||
'--max-tries=100',
|
|
||||||
'--min-split-size=1MB',
|
|
||||||
'--retry-wait=1',
|
|
||||||
'--split=100',
|
|
||||||
'--summary-interval=0',
|
|
||||||
'--timeout=8',
|
|
||||||
'--user-agent=',
|
|
||||||
'--metalink-file=-',
|
|
||||||
], stdin=subprocess.PIPE) as aria:
|
|
||||||
aria.communicate(data)
|
|
||||||
if aria.wait() == 0:
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
def calc_hash_sum(files):
|
|
||||||
obj = hashlib.new('sha256')
|
|
||||||
for path in files:
|
|
||||||
with open(path, 'rb') as f:
|
|
||||||
with mmap.mmap(f.fileno(), 0, mmap.MAP_SHARED, mmap.PROT_READ) as m:
|
|
||||||
file_hash = hashlib.new('sha256', m).digest()
|
|
||||||
obj.update(file_hash)
|
|
||||||
return obj.digest().hex()
|
|
||||||
|
|
||||||
def extract_archives(files, out='.', targets=[]):
|
|
||||||
for path in files:
|
|
||||||
if subprocess.Popen(['7z', 'x', '-bd', '-y', '-aoa', f'-o{out}', path] + targets,
|
|
||||||
stdout=subprocess.DEVNULL,
|
|
||||||
).wait() != 0:
|
|
||||||
return False
|
|
||||||
return True
|
|
||||||
|
|
||||||
def main():
|
|
||||||
os, target, version, toolchain, expect = sys.argv[1:]
|
|
||||||
major, minor, patch = version.split('.')
|
|
||||||
links = [*fetch_links_to_archives(os, target, major, minor, patch, toolchain)]
|
|
||||||
print(*[l['url'].encode() for l in links], sep='\n', flush=True)
|
|
||||||
assert download(links)
|
|
||||||
result = calc_hash_sum([l['name'] for l in links])
|
|
||||||
print('result', result, 'expect', expect, flush=True)
|
|
||||||
assert result == expect
|
|
||||||
assert extract_archives([l['name'] for l in links], '.', ['{}.{}.{}'.format(major, minor, patch)])
|
|
||||||
[pathlib.Path(l['name']).unlink() for l in links]
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
||||||
188
.github/workflows/build.yml
vendored
@@ -1,188 +0,0 @@
|
|||||||
name: ci/gh-actions/gui
|
|
||||||
|
|
||||||
on: [push, pull_request]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build-macos:
|
|
||||||
runs-on: macOS-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- name: install dependencies
|
|
||||||
run: HOMEBREW_NO_AUTO_UPDATE=1 brew install boost hidapi openssl zmq libpgm libsodium miniupnpc expat libunwind-headers protobuf qt5 pkg-config
|
|
||||||
- name: build
|
|
||||||
run: DEV_MODE=ON make release -j3
|
|
||||||
- name: test qml
|
|
||||||
run: build/release/bin/monero-wallet-gui.app/Contents/MacOS/monero-wallet-gui --test-qml
|
|
||||||
|
|
||||||
build-ubuntu:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- name: remove bundled boost
|
|
||||||
run: sudo rm -rf /usr/local/share/boost
|
|
||||||
- name: set apt conf
|
|
||||||
run: |
|
|
||||||
echo "Acquire::Retries \"3\";" | sudo tee -a /etc/apt/apt.conf.d/80-custom
|
|
||||||
echo "Acquire::http::Timeout \"120\";" | sudo tee -a /etc/apt/apt.conf.d/80-custom
|
|
||||||
echo "Acquire::ftp::Timeout \"120\";" | sudo tee -a /etc/apt/apt.conf.d/80-custom
|
|
||||||
- name: update apt
|
|
||||||
run: sudo apt update
|
|
||||||
- name: install monero dependencies
|
|
||||||
run: sudo apt -y install build-essential cmake libboost-all-dev miniupnpc libunbound-dev graphviz doxygen libunwind8-dev pkg-config libssl-dev libzmq3-dev libsodium-dev libhidapi-dev libnorm-dev libusb-1.0-0-dev libpgm-dev libprotobuf-dev protobuf-compiler
|
|
||||||
- name: install monero gui dependencies
|
|
||||||
run: sudo apt -y install qtbase5-dev qt5-default qtdeclarative5-dev qml-module-qtqml-models2 qml-module-qtquick-controls qml-module-qtquick-controls2 qml-module-qtquick-dialogs qml-module-qtquick-xmllistmodel qml-module-qt-labs-settings qml-module-qt-labs-platform qml-module-qt-labs-folderlistmodel qttools5-dev-tools qml-module-qtquick-templates2 libqt5svg5-dev libgcrypt20-dev xvfb
|
|
||||||
- name: build
|
|
||||||
run: DEV_MODE=ON make release -j3
|
|
||||||
- name: test qml
|
|
||||||
run: xvfb-run -a build/release/bin/monero-wallet-gui --test-qml
|
|
||||||
|
|
||||||
build-windows:
|
|
||||||
runs-on: windows-latest
|
|
||||||
defaults:
|
|
||||||
run:
|
|
||||||
shell: msys2 {0}
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- uses: eine/setup-msys2@v2
|
|
||||||
with:
|
|
||||||
update: true
|
|
||||||
install: mingw-w64-x86_64-toolchain make mingw-w64-x86_64-pcre mingw-w64-x86_64-cmake mingw-w64-x86_64-boost mingw-w64-x86_64-openssl mingw-w64-x86_64-zeromq mingw-w64-x86_64-libsodium mingw-w64-x86_64-hidapi mingw-w64-x86_64-protobuf-c mingw-w64-x86_64-libusb mingw-w64-x86_64-unbound git mingw-w64-x86_64-qt5 mingw-w64-x86_64-libgcrypt
|
|
||||||
- name: build
|
|
||||||
run: DEV_MODE=ON make release-win64 -j2
|
|
||||||
- name: deploy
|
|
||||||
run: make deploy
|
|
||||||
working-directory: build/release
|
|
||||||
- name: test qml
|
|
||||||
run: build/release/bin/monero-wallet-gui --test-qml
|
|
||||||
|
|
||||||
macos-bundle:
|
|
||||||
runs-on: macOS-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- name: install dependencies
|
|
||||||
run: HOMEBREW_NO_AUTO_UPDATE=1 brew install boost hidapi openssl zmq libpgm miniupnpc expat libunwind-headers protobuf pkg-config python3 p7zip aria2
|
|
||||||
- name: install dependencies
|
|
||||||
run: pip3 install defusedxml
|
|
||||||
- name: download qt
|
|
||||||
run: python3 monero-gui/.github/qt_helper.py mac_x64 desktop 5.15.2 clang_64 c384008156fe63cc183bade0316828c598ff3e5074397c0c9ccc588d6cdc5aca
|
|
||||||
working-directory: ../
|
|
||||||
- name: build
|
|
||||||
run: CMAKE_PREFIX_PATH=/Users/runner/work/monero-gui/5.15.2/clang_64 make release -j3
|
|
||||||
- name: deploy
|
|
||||||
run: make deploy
|
|
||||||
working-directory: build/release
|
|
||||||
- name: test qml
|
|
||||||
run: build/release/bin/monero-wallet-gui.app/Contents/MacOS/monero-wallet-gui --test-qml
|
|
||||||
- name: create .tar
|
|
||||||
run: tar -cf monero-wallet-gui.tar monero-wallet-gui.app
|
|
||||||
working-directory: build/release/bin
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: ${{ github.job }}
|
|
||||||
path: build/release/bin/monero-wallet-gui.tar
|
|
||||||
|
|
||||||
docker-linux-static:
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- uses: satackey/action-docker-layer-caching@v0.0.11
|
|
||||||
if: "!startsWith(github.ref, 'refs/tags/v')"
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
key: docker-linux-static-{hash}
|
|
||||||
restore-keys: |
|
|
||||||
docker-linux-static-
|
|
||||||
- name: install dependencies
|
|
||||||
run: sudo apt -y install xvfb libxcb-icccm4 libxcb-image0 libxcb-keysyms1 libxcb-randr0 libxcb-render-util0 libxcb-xkb1 libxcb-shape0 libxkbcommon-x11-0
|
|
||||||
- name: prepare build environment
|
|
||||||
run: docker build --tag monero:build-env-linux --build-arg THREADS=3 --file Dockerfile.linux .
|
|
||||||
- name: build
|
|
||||||
run: docker run --rm -v /home/runner/work/monero-gui/monero-gui:/monero-gui -w /monero-gui monero:build-env-linux sh -c 'make release-static -j3'
|
|
||||||
- name: sha256sum
|
|
||||||
run: shasum -a256 /home/runner/work/monero-gui/monero-gui/build/release/bin/monero-wallet-gui
|
|
||||||
- name: test qml
|
|
||||||
run: xvfb-run -a /home/runner/work/monero-gui/monero-gui/build/release/bin/monero-wallet-gui --test-qml
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: ${{ github.job }}
|
|
||||||
path: |
|
|
||||||
/home/runner/work/monero-gui/monero-gui/build/release/bin/monero-wallet-gui
|
|
||||||
/home/runner/work/monero-gui/monero-gui/build/release/bin/monerod
|
|
||||||
|
|
||||||
docker-windows-static:
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- uses: satackey/action-docker-layer-caching@v0.0.11
|
|
||||||
if: "!startsWith(github.ref, 'refs/tags/v')"
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
key: docker-windows-static-{hash}
|
|
||||||
restore-keys: |
|
|
||||||
docker-windows-static-
|
|
||||||
- name: prepare build environment
|
|
||||||
run: docker build --tag monero:build-env-windows --build-arg THREADS=3 --file Dockerfile.windows .
|
|
||||||
- name: build
|
|
||||||
run: docker run --rm -v /home/runner/work/monero-gui/monero-gui:/monero-gui -w /monero-gui monero:build-env-windows sh -c 'make depends root=/depends target=x86_64-w64-mingw32 tag=win-x64 -j3'
|
|
||||||
- name: sha256sum
|
|
||||||
run: shasum -a256 /home/runner/work/monero-gui/monero-gui/build/x86_64-w64-mingw32/release/bin/monero-wallet-gui.exe
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: ${{ github.job }}
|
|
||||||
path: |
|
|
||||||
/home/runner/work/monero-gui/monero-gui/build/x86_64-w64-mingw32/release/bin/monero-wallet-gui.exe
|
|
||||||
/home/runner/work/monero-gui/monero-gui/build/x86_64-w64-mingw32/release/bin/monerod.exe
|
|
||||||
|
|
||||||
docker-android:
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- uses: satackey/action-docker-layer-caching@v0.0.11
|
|
||||||
if: "!startsWith(github.ref, 'refs/tags/v')"
|
|
||||||
continue-on-error: true
|
|
||||||
with:
|
|
||||||
key: docker-android-static-{hash}
|
|
||||||
restore-keys: |
|
|
||||||
docker-android-static-
|
|
||||||
- name: prepare build environment
|
|
||||||
run: docker build --tag monero:build-env-android --build-arg THREADS=3 --file Dockerfile.android .
|
|
||||||
- name: build
|
|
||||||
run: docker run --rm -v /home/runner/work/monero-gui/monero-gui:/monero-gui -e THREADS=3 monero:build-env-android
|
|
||||||
- name: Remove obsolete docker layers
|
|
||||||
run: docker images -a | grep none | awk '{ print $3; }' | xargs docker rmi || true
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: ${{ github.job }}
|
|
||||||
path: /home/runner/work/monero-gui/monero-gui/build/Android/release/android-build/monero-gui.apk
|
|
||||||
|
|
||||||
source-archive:
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- name: archive
|
|
||||||
run: |
|
|
||||||
pip install git-archive-all
|
|
||||||
export VERSION="monero-gui-$(git describe)"
|
|
||||||
export OUTPUT="$VERSION.tar"
|
|
||||||
echo "OUTPUT=$OUTPUT" >> $GITHUB_ENV
|
|
||||||
/home/runner/.local/bin/git-archive-all --prefix "$VERSION/" --force-submodules "$OUTPUT"
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: ${{ env.OUTPUT }}
|
|
||||||
path: /home/runner/work/monero-gui/monero-gui/${{ env.OUTPUT }}
|
|
||||||
@@ -4,8 +4,8 @@ project(monero-gui)
|
|||||||
message(STATUS "Initiating compile using CMake ${CMAKE_VERSION}")
|
message(STATUS "Initiating compile using CMake ${CMAKE_VERSION}")
|
||||||
|
|
||||||
set(VERSION_MAJOR "18")
|
set(VERSION_MAJOR "18")
|
||||||
set(VERSION_MINOR "1")
|
set(VERSION_MINOR "3")
|
||||||
set(VERSION_REVISION "2")
|
set(VERSION_REVISION "3")
|
||||||
set(VERSION "0.${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_REVISION}")
|
set(VERSION "0.${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_REVISION}")
|
||||||
|
|
||||||
option(STATIC "Link libraries statically, requires static Qt")
|
option(STATIC "Link libraries statically, requires static Qt")
|
||||||
|
|||||||
30
DEPLOY.md
@@ -10,7 +10,7 @@ Use macOS 10.12 - 10.13 for better backwards compability.
|
|||||||
|
|
||||||
4. Compile `monero-wallet-gui.app`
|
4. Compile `monero-wallet-gui.app`
|
||||||
|
|
||||||
```
|
```bash
|
||||||
mkdir build && cd build
|
mkdir build && cd build
|
||||||
cmake -D CMAKE_BUILD_TYPE=Release -D ARCH=default -D CMAKE_PREFIX_PATH=~/Qt5.12.8/5.12.8/clang_64 ..
|
cmake -D CMAKE_BUILD_TYPE=Release -D ARCH=default -D CMAKE_PREFIX_PATH=~/Qt5.12.8/5.12.8/clang_64 ..
|
||||||
make
|
make
|
||||||
@@ -45,3 +45,31 @@ You can check if this step worked by using `codesign -dvvv monero-wallet-gui.app
|
|||||||
5. `xcrun altool --notarization-info aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeee -u email@address.org`
|
5. `xcrun altool --notarization-info aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeee -u email@address.org`
|
||||||
|
|
||||||
6. `xcrun stapler staple -v monero-gui-mac-x64-v0.X.Y.Z.dmg`
|
6. `xcrun stapler staple -v monero-gui-mac-x64-v0.X.Y.Z.dmg`
|
||||||
|
|
||||||
|
## Compile Qt for Apple Silicon
|
||||||
|
|
||||||
|
Qt does not offer pre-built binaries for Apple Silicon, they have to be manually compiled.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/qt/qt5.git
|
||||||
|
cd qt5
|
||||||
|
git checkout v5.15.9-lts-lgpl
|
||||||
|
./init-repository
|
||||||
|
mkdir build
|
||||||
|
cd build
|
||||||
|
../configure -prefix /path/to/qt-build-dir/ -opensource -confirm-license -release -nomake examples -nomake tests -no-rpath -skip qtwebengine -skip qt3d -skip qtandroidextras -skip qtcanvas3d -skip qtcharts -skip qtconnectivity -skip qtdatavis3d -skip qtdoc -skip qtgamepad -skip qtlocation -skip qtnetworkauth -skip qtpurchasing -skip qtscript -skip qtscxml -skip qtsensors -skip qtserialbus -skip qtserialport -skip qtspeech -skip qttools -skip qtvirtualkeyboard -skip qtwayland -skip qtwebchannel -skip qtwebsockets -skip qtwebview -skip qtwinextras -skip qtx11extras -skip gamepad -skip serialbus -skip location -skip webengine
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
cd ../qttools/src/linguist/lrelease
|
||||||
|
../../../../build/qtbase/bin/qmake
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
cd ../../../../qttools/src/macdeployqt/macdeployqt/
|
||||||
|
../../../../build/qtbase/bin/qmake
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
```
|
||||||
|
|
||||||
|
For compilation with Xcode 15 the following patch has to be applied: https://raw.githubusercontent.com/Homebrew/formula-patches/086e8cf/qt5/qt5-qmake-xcode15.patch
|
||||||
|
|
||||||
|
The `CMAKE_PREFIX_PATH` has to be set to `/path/to/qt-build-dir/` during monero-gui compilation.
|
||||||
|
|||||||
@@ -5,12 +5,12 @@ ARG ANDROID_NDK_REVISION=21e
|
|||||||
ARG ANDROID_NDK_HASH=c3ebc83c96a4d7f539bd72c241b2be9dcd29bda9
|
ARG ANDROID_NDK_HASH=c3ebc83c96a4d7f539bd72c241b2be9dcd29bda9
|
||||||
ARG ANDROID_SDK_REVISION=7302050_latest
|
ARG ANDROID_SDK_REVISION=7302050_latest
|
||||||
ARG ANDROID_SDK_HASH=7a00faadc0864f78edd8f4908a629a46d622375cbe2e5814e82934aebecdb622
|
ARG ANDROID_SDK_HASH=7a00faadc0864f78edd8f4908a629a46d622375cbe2e5814e82934aebecdb622
|
||||||
ARG QT_VERSION=v5.15.6-lts-lgpl
|
ARG QT_VERSION=v5.15.7-lts-lgpl
|
||||||
|
|
||||||
WORKDIR /opt/android
|
WORKDIR /opt/android
|
||||||
ENV WORKDIR=/opt/android
|
ENV WORKDIR=/opt/android
|
||||||
|
|
||||||
ENV ANDROID_NATIVE_API_LEVEL=29
|
ENV ANDROID_NATIVE_API_LEVEL=30
|
||||||
ENV ANDROID_API=android-${ANDROID_NATIVE_API_LEVEL}
|
ENV ANDROID_API=android-${ANDROID_NATIVE_API_LEVEL}
|
||||||
ENV ANDROID_CLANG=aarch64-linux-android${ANDROID_NATIVE_API_LEVEL}-clang
|
ENV ANDROID_CLANG=aarch64-linux-android${ANDROID_NATIVE_API_LEVEL}-clang
|
||||||
ENV ANDROID_CLANGPP=aarch64-linux-android${ANDROID_NATIVE_API_LEVEL}-clang++
|
ENV ANDROID_CLANGPP=aarch64-linux-android${ANDROID_NATIVE_API_LEVEL}-clang++
|
||||||
@@ -43,9 +43,9 @@ RUN echo y | ${ANDROID_SDK_ROOT}/bin/sdkmanager --sdk_root=${ANDROID_SDK_ROOT} "
|
|||||||
ENV HOST_PATH=${PATH}
|
ENV HOST_PATH=${PATH}
|
||||||
ENV PATH=${TOOLCHAIN_DIR}/aarch64-linux-android/bin:${TOOLCHAIN_DIR}/bin:${PATH}
|
ENV PATH=${TOOLCHAIN_DIR}/aarch64-linux-android/bin:${TOOLCHAIN_DIR}/bin:${PATH}
|
||||||
|
|
||||||
ARG ZLIB_VERSION=1.2.12
|
ARG ZLIB_VERSION=1.3.1
|
||||||
ARG ZLIB_HASH=91844808532e5ce316b3c010929493c0244f3d37593afd6de04f71821d5136d9
|
ARG ZLIB_HASH=9a93b2b7dfdac77ceba5a558a580e74667dd6fede4585b91eefb60f03b72df23
|
||||||
RUN wget -q https://zlib.net/zlib-${ZLIB_VERSION}.tar.gz \
|
RUN wget -q https://github.com/madler/zlib/releases/download/v${ZLIB_VERSION}/zlib-${ZLIB_VERSION}.tar.gz \
|
||||||
&& echo "${ZLIB_HASH} zlib-${ZLIB_VERSION}.tar.gz" | sha256sum -c \
|
&& echo "${ZLIB_HASH} zlib-${ZLIB_VERSION}.tar.gz" | sha256sum -c \
|
||||||
&& tar -xzf zlib-${ZLIB_VERSION}.tar.gz \
|
&& tar -xzf zlib-${ZLIB_VERSION}.tar.gz \
|
||||||
&& rm zlib-${ZLIB_VERSION}.tar.gz \
|
&& rm zlib-${ZLIB_VERSION}.tar.gz \
|
||||||
@@ -117,15 +117,15 @@ RUN wget -q https://boostorg.jfrog.io/artifactory/main/release/${BOOST_VERSION_D
|
|||||||
install -j${THREADS} \
|
install -j${THREADS} \
|
||||||
&& rm -rf $(pwd)
|
&& rm -rf $(pwd)
|
||||||
|
|
||||||
ARG OPENSSL_VERSION=1.1.1q
|
ARG OPENSSL_VERSION=1.1.1u
|
||||||
ARG OPENSSL_HASH=d7939ce614029cdff0b6c20f0e2e5703158a489a72b2507b8bd51bf8c8fd10ca
|
ARG OPENSSL_HASH=e2f8d84b523eecd06c7be7626830370300fbcc15386bf5142d72758f6963ebc6
|
||||||
RUN wget -q https://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz \
|
RUN wget -q https://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz \
|
||||||
&& echo "${OPENSSL_HASH} openssl-${OPENSSL_VERSION}.tar.gz" | sha256sum -c \
|
&& echo "${OPENSSL_HASH} openssl-${OPENSSL_VERSION}.tar.gz" | sha256sum -c \
|
||||||
&& tar -xzf openssl-${OPENSSL_VERSION}.tar.gz \
|
&& tar -xzf openssl-${OPENSSL_VERSION}.tar.gz \
|
||||||
&& rm openssl-${OPENSSL_VERSION}.tar.gz \
|
&& rm openssl-${OPENSSL_VERSION}.tar.gz \
|
||||||
&& cd openssl-${OPENSSL_VERSION} \
|
&& cd openssl-${OPENSSL_VERSION} \
|
||||||
&& ANDROID_NDK_HOME=${ANDROID_NDK_ROOT} ./Configure CC=${ANDROID_CLANG} CXX=${ANDROID_CLANGPP} \
|
&& ANDROID_NDK_HOME=${ANDROID_NDK_ROOT} ./Configure CC=${ANDROID_CLANG} CXX=${ANDROID_CLANGPP} \
|
||||||
android-arm64 no-asm no-shared --static \
|
android-arm64 no-shared --static \
|
||||||
--with-zlib-include=${PREFIX}/include --with-zlib-lib=${PREFIX}/lib \
|
--with-zlib-include=${PREFIX}/include --with-zlib-lib=${PREFIX}/lib \
|
||||||
--prefix=${PREFIX} --openssldir=${PREFIX} \
|
--prefix=${PREFIX} --openssldir=${PREFIX} \
|
||||||
&& sed -i 's/CNF_EX_LIBS=-ldl -pthread//g;s/BIN_CFLAGS=-pie $(CNF_CFLAGS) $(CFLAGS)//g' Makefile \
|
&& sed -i 's/CNF_EX_LIBS=-ldl -pthread//g;s/BIN_CFLAGS=-pie $(CNF_CFLAGS) $(CFLAGS)//g' Makefile \
|
||||||
@@ -206,6 +206,16 @@ RUN git clone -b v3.24.2 --depth 1 https://github.com/Kitware/CMake \
|
|||||||
&& PATH=${HOST_PATH} make -j${THREADS} install \
|
&& PATH=${HOST_PATH} make -j${THREADS} install \
|
||||||
&& rm -rf $(pwd)
|
&& rm -rf $(pwd)
|
||||||
|
|
||||||
|
RUN GRADLE_VERSION=5.6.4 \
|
||||||
|
&& GRADLE_HASH=1f3067073041bc44554d0efe5d402a33bc3d3c93cc39ab684f308586d732a80d \
|
||||||
|
&& wget -q https\://services.gradle.org/distributions/gradle-${GRADLE_VERSION}-bin.zip \
|
||||||
|
&& echo "${GRADLE_HASH} gradle-${GRADLE_VERSION}-bin.zip" | sha256sum -c \
|
||||||
|
&& GRADLE_LOCAL_PATH=gradle/wrapper/dists/gradle-${GRADLE_VERSION}-bin/bxirm19lnfz6nurbatndyydux \
|
||||||
|
&& mkdir -p ${GRADLE_LOCAL_PATH} \
|
||||||
|
&& mv gradle-${GRADLE_VERSION}-bin.zip ${GRADLE_LOCAL_PATH}
|
||||||
|
|
||||||
|
ENV GRADLE_USER_HOME=${WORKDIR}/gradle
|
||||||
|
|
||||||
CMD set -ex \
|
CMD set -ex \
|
||||||
&& cd /monero-gui \
|
&& cd /monero-gui \
|
||||||
&& mkdir -p build/Android/release \
|
&& mkdir -p build/Android/release \
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
FROM ubuntu:16.04
|
FROM ubuntu:16.04
|
||||||
|
|
||||||
ARG THREADS=1
|
ARG THREADS=1
|
||||||
ARG QT_VERSION=v5.15.6-lts-lgpl
|
ARG QT_VERSION=v5.15.13-lts-lgpl
|
||||||
|
|
||||||
ENV CFLAGS="-fPIC"
|
ENV CFLAGS="-fPIC"
|
||||||
ENV CPPFLAGS="-fPIC"
|
ENV CPPFLAGS="-fPIC"
|
||||||
@@ -113,9 +113,9 @@ RUN git clone -b xkbcommon-0.5.0 --depth 1 https://github.com/xkbcommon/libxkbco
|
|||||||
make -j$THREADS install && \
|
make -j$THREADS install && \
|
||||||
rm -rf $(pwd)
|
rm -rf $(pwd)
|
||||||
|
|
||||||
RUN git clone -b v1.2.11 --depth 1 https://github.com/madler/zlib && \
|
RUN git clone -b v1.3 --depth 1 https://github.com/madler/zlib && \
|
||||||
cd zlib && \
|
cd zlib && \
|
||||||
git reset --hard cacf7f1d4e3d44d871b605da3b647f07d718623f && \
|
git reset --hard 09155eaa2f9270dc4ed1fa13e2b4b2613e6e4851 && \
|
||||||
./configure --static && \
|
./configure --static && \
|
||||||
make -j$THREADS && \
|
make -j$THREADS && \
|
||||||
make -j$THREADS install && \
|
make -j$THREADS install && \
|
||||||
@@ -130,11 +130,12 @@ RUN git clone -b VER-2-10-2 --depth 1 https://git.savannah.gnu.org/git/freetype/
|
|||||||
make -j$THREADS install && \
|
make -j$THREADS install && \
|
||||||
rm -rf $(pwd)
|
rm -rf $(pwd)
|
||||||
|
|
||||||
RUN git clone -b R_2_2_9 --depth 1 https://github.com/libexpat/libexpat && \
|
RUN wget https://github.com/libexpat/libexpat/releases/download/R_2_4_8/expat-2.4.8.tar.bz2 && \
|
||||||
cd libexpat/expat && \
|
echo "a247a7f6bbb21cf2ca81ea4cbb916bfb9717ca523631675f99b3d4a5678dcd16 expat-2.4.8.tar.bz2" | sha256sum -c && \
|
||||||
git reset --hard a7bc26b69768f7fb24f0c7976fae24b157b85b13 && \
|
tar -xf expat-2.4.8.tar.bz2 && \
|
||||||
./buildconf.sh && \
|
rm expat-2.4.8.tar.bz2 && \
|
||||||
./configure --disable-shared --enable-static && \
|
cd expat-2.4.8 && \
|
||||||
|
./configure --enable-static --disable-shared --prefix=/usr && \
|
||||||
make -j$THREADS && \
|
make -j$THREADS && \
|
||||||
make -j$THREADS install && \
|
make -j$THREADS install && \
|
||||||
rm -rf $(pwd)
|
rm -rf $(pwd)
|
||||||
@@ -164,22 +165,12 @@ RUN wget https://boostorg.jfrog.io/artifactory/main/release/1.80.0/source/boost_
|
|||||||
./b2 --with-atomic --with-system --with-filesystem --with-thread --with-date_time --with-chrono --with-regex --with-serialization --with-program_options --with-locale variant=release link=static runtime-link=static cflags="${CFLAGS}" cxxflags="${CXXFLAGS}" install -a --prefix=/usr && \
|
./b2 --with-atomic --with-system --with-filesystem --with-thread --with-date_time --with-chrono --with-regex --with-serialization --with-program_options --with-locale variant=release link=static runtime-link=static cflags="${CFLAGS}" cxxflags="${CXXFLAGS}" install -a --prefix=/usr && \
|
||||||
rm -rf $(pwd)
|
rm -rf $(pwd)
|
||||||
|
|
||||||
RUN wget https://www.openssl.org/source/openssl-1.1.1q.tar.gz && \
|
RUN wget https://www.openssl.org/source/openssl-1.1.1u.tar.gz && \
|
||||||
echo "d7939ce614029cdff0b6c20f0e2e5703158a489a72b2507b8bd51bf8c8fd10ca openssl-1.1.1q.tar.gz" | sha256sum -c && \
|
echo "e2f8d84b523eecd06c7be7626830370300fbcc15386bf5142d72758f6963ebc6 openssl-1.1.1u.tar.gz" | sha256sum -c && \
|
||||||
tar -xzf openssl-1.1.1q.tar.gz && \
|
tar -xzf openssl-1.1.1u.tar.gz && \
|
||||||
rm openssl-1.1.1q.tar.gz && \
|
rm openssl-1.1.1u.tar.gz && \
|
||||||
cd openssl-1.1.1q && \
|
cd openssl-1.1.1u && \
|
||||||
./config no-asm no-shared no-zlib-dynamic --prefix=/usr --openssldir=/usr && \
|
./config no-shared no-zlib-dynamic --prefix=/usr --openssldir=/usr && \
|
||||||
make -j$THREADS && \
|
|
||||||
make -j$THREADS install && \
|
|
||||||
rm -rf $(pwd)
|
|
||||||
|
|
||||||
RUN wget https://github.com/libexpat/libexpat/releases/download/R_2_4_8/expat-2.4.8.tar.bz2 && \
|
|
||||||
echo "a247a7f6bbb21cf2ca81ea4cbb916bfb9717ca523631675f99b3d4a5678dcd16 expat-2.4.8.tar.bz2" | sha256sum -c && \
|
|
||||||
tar -xf expat-2.4.8.tar.bz2 && \
|
|
||||||
rm expat-2.4.8.tar.bz2 && \
|
|
||||||
cd expat-2.4.8 && \
|
|
||||||
./configure --enable-static --disable-shared --prefix=/usr && \
|
|
||||||
make -j$THREADS && \
|
make -j$THREADS && \
|
||||||
make -j$THREADS install && \
|
make -j$THREADS install && \
|
||||||
rm -rf $(pwd)
|
rm -rf $(pwd)
|
||||||
@@ -242,9 +233,9 @@ RUN git clone -b v1.0.26 --depth 1 https://github.com/libusb/libusb && \
|
|||||||
make -j$THREADS install && \
|
make -j$THREADS install && \
|
||||||
rm -rf $(pwd)
|
rm -rf $(pwd)
|
||||||
|
|
||||||
RUN git clone -b hidapi-0.12.0 --depth 1 https://github.com/libusb/hidapi && \
|
RUN git clone -b hidapi-0.13.1 --depth 1 https://github.com/libusb/hidapi && \
|
||||||
cd hidapi && \
|
cd hidapi && \
|
||||||
git reset --hard 76108294092c023a4ece99eb3219559cea0d5066 && \
|
git reset --hard 4ebce6b5059b086d05ca7e091ce04a5fd08ac3ac && \
|
||||||
./bootstrap && \
|
./bootstrap && \
|
||||||
./configure --disable-shared --enable-static && \
|
./configure --disable-shared --enable-static && \
|
||||||
make -j$THREADS && \
|
make -j$THREADS && \
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
FROM ubuntu:20.04
|
FROM ubuntu:20.04
|
||||||
|
|
||||||
ARG THREADS=1
|
ARG THREADS=1
|
||||||
ARG QT_VERSION=v5.15.6-lts-lgpl
|
ARG QT_VERSION=v5.15.13-lts-lgpl
|
||||||
ENV SOURCE_DATE_EPOCH=1397818193
|
ENV SOURCE_DATE_EPOCH=1397818193
|
||||||
|
|
||||||
RUN apt update && \
|
RUN apt update && \
|
||||||
@@ -12,9 +12,9 @@ RUN apt update && \
|
|||||||
RUN update-alternatives --set x86_64-w64-mingw32-g++ $(which x86_64-w64-mingw32-g++-posix) && \
|
RUN update-alternatives --set x86_64-w64-mingw32-g++ $(which x86_64-w64-mingw32-g++-posix) && \
|
||||||
update-alternatives --set x86_64-w64-mingw32-gcc $(which x86_64-w64-mingw32-gcc-posix)
|
update-alternatives --set x86_64-w64-mingw32-gcc $(which x86_64-w64-mingw32-gcc-posix)
|
||||||
|
|
||||||
RUN git clone -b v0.18.1.0 --depth 1 https://github.com/monero-project/monero && \
|
RUN git clone -b v0.18.2.0 --depth 1 https://github.com/monero-project/monero && \
|
||||||
cd monero && \
|
cd monero && \
|
||||||
git reset --hard 727bc5b6878170332bf2d838f2c60d1c8dc685c8 && \
|
git reset --hard 99be9a044f3854f339548e2d99c539c18d7b1b01 && \
|
||||||
cp -a contrib/depends / && \
|
cp -a contrib/depends / && \
|
||||||
cd .. && \
|
cd .. && \
|
||||||
rm -rf monero
|
rm -rf monero
|
||||||
|
|||||||
2
LICENSE
@@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2014-2018, The Monero Project
|
Copyright (c) 2014-2024, The Monero Project
|
||||||
|
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
29
README.md
@@ -1,6 +1,6 @@
|
|||||||
# Monero GUI
|
# Monero GUI
|
||||||
|
|
||||||
Copyright (c) 2014-2022, The Monero Project
|
Copyright (c) 2014-2024, The Monero Project
|
||||||
|
|
||||||
## Table of Contents
|
## Table of Contents
|
||||||
* [Development resources](#development-resources)
|
* [Development resources](#development-resources)
|
||||||
@@ -86,9 +86,8 @@ Status of the translations:
|
|||||||
## Installing the Monero GUI from a package
|
## Installing the Monero GUI from a package
|
||||||
|
|
||||||
Packages are available for
|
Packages are available for
|
||||||
* Arch Linux: [monero-gui](https://www.archlinux.org/packages/community/x86_64/monero-gui/)
|
* Arch Linux: [monero-gui](https://archlinux.org/packages/extra/x86_64/monero-gui/)
|
||||||
* Debian: See the [whonix/monero-gui repository](https://gitlab.com/whonix/monero-gui#how-to-install-monero-using-apt-get)
|
* NixOS: `nix-shell -p monero-gui`
|
||||||
* Void Linux: `xbps-install -S monero-gui`
|
|
||||||
* Flatpak: [Monero GUI](https://flathub.org/apps/details/org.getmonero.Monero)
|
* Flatpak: [Monero GUI](https://flathub.org/apps/details/org.getmonero.Monero)
|
||||||
* GuixSD: `guix package -i monero-gui`
|
* GuixSD: `guix package -i monero-gui`
|
||||||
* macOS (homebrew): `brew install --cask monero-wallet`
|
* macOS (homebrew): `brew install --cask monero-wallet`
|
||||||
@@ -108,7 +107,7 @@ Packaging for your favorite distribution would be a welcome contribution!
|
|||||||
```
|
```
|
||||||
git clone --branch master --recursive https://github.com/monero-project/monero-gui.git
|
git clone --branch master --recursive https://github.com/monero-project/monero-gui.git
|
||||||
```
|
```
|
||||||
\* `master` - replace with the desired version tag (e.g. `v0.18.1.2`) to build the release binaries.
|
\* `master` - replace with the desired version tag (e.g. `v0.18.3.3`) to build the release binaries.
|
||||||
3. Prepare build environment
|
3. Prepare build environment
|
||||||
```
|
```
|
||||||
cd monero-gui
|
cd monero-gui
|
||||||
@@ -131,7 +130,7 @@ Packaging for your favorite distribution would be a welcome contribution!
|
|||||||
```
|
```
|
||||||
git clone --branch master --recursive https://github.com/monero-project/monero-gui.git
|
git clone --branch master --recursive https://github.com/monero-project/monero-gui.git
|
||||||
```
|
```
|
||||||
\* `master` - replace with the desired version tag (e.g. `v0.18.1.2`) to build the release binaries.
|
\* `master` - replace with the desired version tag (e.g. `v0.18.3.3`) to build the release binaries.
|
||||||
3. Prepare build environment
|
3. Prepare build environment
|
||||||
```
|
```
|
||||||
cd monero-gui
|
cd monero-gui
|
||||||
@@ -221,15 +220,15 @@ Packaging for your favorite distribution would be a welcome contribution!
|
|||||||
|
|
||||||
2. Install Qt:
|
2. Install Qt:
|
||||||
|
|
||||||
*Note*: The Qt 5.9.7 or newer requirement makes **some** distributions (mostly based on debian, like Ubuntu 16.x or Linux Mint 18.x) obsolete due to their repositories containing an older Qt version.
|
*Note*: The Qt 5.9.7 or newer requirement makes **some** distributions (mostly based on Debian, like Ubuntu 16.x or Linux Mint 18.x) obsolete due to their repositories containing an older Qt version.
|
||||||
|
|
||||||
The recommended way is to install 5.9.7 from the [official Qt installer](https://www.qt.io/download-qt-installer) or [compiling it yourself](https://wiki.qt.io/Install_Qt_5_on_Ubuntu). This ensures you have the correct version. Higher versions *can* work but as it differs from our production build target, slight differences may occur.
|
The recommended way is to install 5.9.7 from the [official Qt installer](https://www.qt.io/download-qt-installer) or [compiling it yourself](https://wiki.qt.io/Install_Qt_5_on_Ubuntu). This ensures you have the correct version. Higher versions *can* work but as it differs from our production build target, slight differences may occur.
|
||||||
|
|
||||||
The following instructions will fetch Qt from your distribution's repositories instead. Take note of what version it installs. Your mileage may vary.
|
The following instructions will fetch Qt from your distribution's repositories instead. Take note of what version it installs. Your mileage may vary.
|
||||||
|
|
||||||
- For Ubuntu 17.10+
|
- For Debian distributions (Debian, Ubuntu, Mint, Tails...)
|
||||||
|
|
||||||
`sudo apt install qtbase5-dev qt5-default qtdeclarative5-dev qml-module-qtqml-models2 qml-module-qtquick-controls qml-module-qtquick-controls2 qml-module-qtquick-dialogs qml-module-qtquick-xmllistmodel qml-module-qt-labs-settings qml-module-qt-labs-platform qml-module-qt-labs-folderlistmodel qttools5-dev-tools qml-module-qtquick-templates2 libqt5svg5-dev`
|
`sudo apt install qtbase5-dev qtdeclarative5-dev qml-module-qtqml-models2 qml-module-qtquick-controls qml-module-qtquick-controls2 qml-module-qtquick-dialogs qml-module-qtquick-xmllistmodel qml-module-qt-labs-settings qml-module-qt-labs-platform qml-module-qt-labs-folderlistmodel qttools5-dev-tools qml-module-qtquick-templates2 libqt5svg5-dev`
|
||||||
|
|
||||||
- For Gentoo
|
- For Gentoo
|
||||||
|
|
||||||
@@ -240,7 +239,7 @@ The following instructions will fetch Qt from your distribution's repositories i
|
|||||||
|
|
||||||
- Optional : To build the flag `WITH_SCANNER`
|
- Optional : To build the flag `WITH_SCANNER`
|
||||||
|
|
||||||
- For Ubuntu
|
- For Debian distributions (Debian, Ubuntu, Mint, Tails...)
|
||||||
|
|
||||||
`sudo apt install qtmultimedia5-dev qml-module-qtmultimedia`
|
`sudo apt install qtmultimedia5-dev qml-module-qtmultimedia`
|
||||||
|
|
||||||
@@ -258,18 +257,10 @@ The following instructions will fetch Qt from your distribution's repositories i
|
|||||||
|
|
||||||
4. Build
|
4. Build
|
||||||
|
|
||||||
If on x86-64:
|
|
||||||
|
|
||||||
```
|
```
|
||||||
make release -j4
|
make release -j4
|
||||||
```
|
```
|
||||||
|
|
||||||
If on ppc64le:
|
|
||||||
|
|
||||||
```
|
|
||||||
make release-linux-ppc64le -j4
|
|
||||||
```
|
|
||||||
|
|
||||||
\* `4` - number of CPU threads to use
|
\* `4` - number of CPU threads to use
|
||||||
\* Add `CMAKE_PREFIX_PATH` environment variable to set a custom Qt install directory, e.g. `CMAKE_PREFIX_PATH=$HOME/Qt/5.9.7/gcc_64 make release -j4`
|
\* Add `CMAKE_PREFIX_PATH` environment variable to set a custom Qt install directory, e.g. `CMAKE_PREFIX_PATH=$HOME/Qt/5.9.7/gcc_64 make release -j4`
|
||||||
|
|
||||||
@@ -319,7 +310,7 @@ The Monero GUI on Windows is 64 bits only; 32-bit Windows GUI builds are not off
|
|||||||
3. Install MSYS2 packages for Monero dependencies; the needed 64-bit packages have `x86_64` in their names
|
3. Install MSYS2 packages for Monero dependencies; the needed 64-bit packages have `x86_64` in their names
|
||||||
|
|
||||||
```
|
```
|
||||||
pacman -S mingw-w64-x86_64-toolchain make mingw-w64-x86_64-cmake mingw-w64-x86_64-boost mingw-w64-x86_64-openssl mingw-w64-x86_64-zeromq mingw-w64-x86_64-libsodium mingw-w64-x86_64-hidapi mingw-w64-x86_64-protobuf-c mingw-w64-x86_64-libusb mingw-w64-x86_64-libgcrypt
|
pacman -S mingw-w64-x86_64-toolchain make mingw-w64-x86_64-cmake mingw-w64-x86_64-boost mingw-w64-x86_64-openssl mingw-w64-x86_64-zeromq mingw-w64-x86_64-libsodium mingw-w64-x86_64-hidapi mingw-w64-x86_64-protobuf-c mingw-w64-x86_64-libusb mingw-w64-x86_64-libgcrypt mingw-w64-x86_64-unbound mingw-w64-x86_64-pcre
|
||||||
```
|
```
|
||||||
|
|
||||||
You find more details about those dependencies in the [Monero documentation](https://github.com/monero-project/monero). Note that that there is no more need to compile Boost from source; like everything else, you can install it now with a MSYS2 package.
|
You find more details about those dependencies in the [Monero documentation](https://github.com/monero-project/monero). Note that that there is no more need to compile Boost from source; like everything else, you can install it now with a MSYS2 package.
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2019, The Monero Project
|
# Copyright (c) 2014-2024, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2019, The Monero Project
|
# Copyright (c) 2014-2024, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -17,7 +17,33 @@ if(APPLE OR (WIN32 AND NOT STATIC))
|
|||||||
add_custom_command(TARGET deploy
|
add_custom_command(TARGET deploy
|
||||||
POST_BUILD
|
POST_BUILD
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy ${_qt_svg_dylib} $<TARGET_FILE_DIR:monero-wallet-gui>/../PlugIns/imageformats/
|
COMMAND ${CMAKE_COMMAND} -E copy ${_qt_svg_dylib} $<TARGET_FILE_DIR:monero-wallet-gui>/../PlugIns/imageformats/
|
||||||
COMMENT "Copying libqsvg.dylib"
|
COMMAND ${CMAKE_INSTALL_NAME_TOOL} -change "${CMAKE_PREFIX_PATH}/lib/QtGui.framework/Versions/5/QtGui" "@executable_path/../Frameworks/QtGui.framework/Versions/5/QtGui" $<TARGET_FILE_DIR:monero-wallet-gui>/../PlugIns/imageformats/libqsvg.dylib
|
||||||
|
COMMAND ${CMAKE_INSTALL_NAME_TOOL} -change "${CMAKE_PREFIX_PATH}/lib/QtWidgets.framework/Versions/5/QtWidgets" "@executable_path/../Frameworks/QtWidgets.framework/Versions/5/QtWidgets" $<TARGET_FILE_DIR:monero-wallet-gui>/../PlugIns/imageformats/libqsvg.dylib
|
||||||
|
COMMAND ${CMAKE_INSTALL_NAME_TOOL} -change "${CMAKE_PREFIX_PATH}/lib/QtSvg.framework/Versions/5/QtSvg" "@executable_path/../Frameworks/QtSvg.framework/Versions/5/QtSvg" $<TARGET_FILE_DIR:monero-wallet-gui>/../PlugIns/imageformats/libqsvg.dylib
|
||||||
|
COMMAND ${CMAKE_INSTALL_NAME_TOOL} -change "${CMAKE_PREFIX_PATH}/lib/QtCore.framework/Versions/5/QtCore" "@executable_path/../Frameworks/QtCore.framework/Versions/5/QtCore" $<TARGET_FILE_DIR:monero-wallet-gui>/../PlugIns/imageformats/libqsvg.dylib
|
||||||
|
COMMENT "Copying libqsvg.dylib, running install_name_tool"
|
||||||
|
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# libbost_filesyste-mt.dylib has a dependency on libboost_atomic-mt.dylib, maydeployqt does not copy it by itself
|
||||||
|
find_package(Boost COMPONENTS atomic)
|
||||||
|
get_target_property(BOOST_ATOMIC_LIB_PATH Boost::atomic LOCATION)
|
||||||
|
if(EXISTS ${BOOST_ATOMIC_LIB_PATH})
|
||||||
|
add_custom_command(TARGET deploy
|
||||||
|
POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy "${BOOST_ATOMIC_LIB_PATH}" "$<TARGET_FILE_DIR:monero-wallet-gui>/../Frameworks/"
|
||||||
|
COMMENT "Copying libboost_atomic-mt.dylib"
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Apple Silicon requires all binaries to be codesigned
|
||||||
|
find_program(CODESIGN_EXECUTABLE NAMES codesign)
|
||||||
|
if(CODESIGN_EXECUTABLE)
|
||||||
|
add_custom_command(TARGET deploy
|
||||||
|
POST_BUILD
|
||||||
|
COMMAND "${CODESIGN_EXECUTABLE}" --force --deep --sign - "$<TARGET_FILE_DIR:monero-wallet-gui>/../.."
|
||||||
|
COMMENT "Running codesign..."
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@@ -42,7 +68,7 @@ if(APPLE OR (WIN32 AND NOT STATIC))
|
|||||||
zlib1.dll
|
zlib1.dll
|
||||||
libzstd.dll
|
libzstd.dll
|
||||||
libwinpthread-1.dll
|
libwinpthread-1.dll
|
||||||
libtiff-5.dll
|
libtiff-6.dll
|
||||||
libstdc++-6.dll
|
libstdc++-6.dll
|
||||||
libpng16-16.dll
|
libpng16-16.dll
|
||||||
libpcre16-0.dll
|
libpcre16-0.dll
|
||||||
@@ -58,37 +84,25 @@ if(APPLE OR (WIN32 AND NOT STATIC))
|
|||||||
libglib-2.0-0.dll
|
libglib-2.0-0.dll
|
||||||
libfreetype-6.dll
|
libfreetype-6.dll
|
||||||
libbz2-1.dll
|
libbz2-1.dll
|
||||||
libssp-0.dll
|
|
||||||
libpcre2-16-0.dll
|
libpcre2-16-0.dll
|
||||||
libhidapi-0.dll
|
libhidapi-0.dll
|
||||||
libdouble-conversion.dll
|
libdouble-conversion.dll
|
||||||
libgcrypt-20.dll
|
libgcrypt-20.dll
|
||||||
libgpg-error-0.dll
|
libgpg-error-0.dll
|
||||||
libsodium-23.dll
|
libsodium-26.dll
|
||||||
libzmq.dll
|
libzmq.dll
|
||||||
#platform files
|
#platform files
|
||||||
libgcc_s_seh-1.dll
|
libgcc_s_seh-1.dll
|
||||||
#openssl files
|
#openssl files
|
||||||
libssl-1_1-x64.dll
|
libssl-3-x64.dll
|
||||||
libcrypto-1_1-x64.dll
|
libcrypto-3-x64.dll
|
||||||
|
#icu
|
||||||
|
libicudt74.dll
|
||||||
|
libicuin74.dll
|
||||||
|
libicuio74.dll
|
||||||
|
libicutu74.dll
|
||||||
|
libicuuc74.dll
|
||||||
)
|
)
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
|
||||||
list(APPEND WIN_DEPLOY_DLLS
|
|
||||||
libicudtd71.dll
|
|
||||||
libicuind71.dll
|
|
||||||
libicuiod71.dll
|
|
||||||
libicutud71.dll
|
|
||||||
libicuucd71.dll
|
|
||||||
)
|
|
||||||
else() # assume release
|
|
||||||
list(APPEND WIN_DEPLOY_DLLS
|
|
||||||
libicudt71.dll
|
|
||||||
libicuin71.dll
|
|
||||||
libicuio71.dll
|
|
||||||
libicutu71.dll
|
|
||||||
libicuuc71.dll
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
list(TRANSFORM WIN_DEPLOY_DLLS PREPEND "$ENV{MSYSTEM_PREFIX}/bin/")
|
list(TRANSFORM WIN_DEPLOY_DLLS PREPEND "$ENV{MSYSTEM_PREFIX}/bin/")
|
||||||
add_custom_command(TARGET deploy
|
add_custom_command(TARGET deploy
|
||||||
POST_BUILD
|
POST_BUILD
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2019, The Monero Project
|
# Copyright (c) 2014-2024, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2015, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2020, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2021, The Monero Project
|
// Copyright (c) 2021-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -66,7 +66,7 @@ Item {
|
|||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
color: buttonArea.containsMouse ? MoneroComponents.Style.buttonInlineBackgroundColorHover : MoneroComponents.Style.buttonInlineBackgroundColor
|
color: buttonArea.containsMouse ? MoneroComponents.Style.buttonInlineBackgroundColorHover : MoneroComponents.Style.buttonInlineBackgroundColor
|
||||||
radius: 4
|
radius: 4
|
||||||
|
border.width: parent.focus && parent.enabled ? 1 : 0
|
||||||
|
|
||||||
MoneroComponents.TextPlain {
|
MoneroComponents.TextPlain {
|
||||||
id: inlineText
|
id: inlineText
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2015, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2015, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2015, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2020, The Monero Project
|
// Copyright (c) 2020-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2020, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -40,6 +40,8 @@ ColumnLayout {
|
|||||||
default property alias content: inlineButtons.children
|
default property alias content: inlineButtons.children
|
||||||
|
|
||||||
property alias input: input
|
property alias input: input
|
||||||
|
property bool inputHasFocus: input.activeFocus
|
||||||
|
property bool tabNavigationEnabled: true
|
||||||
property alias text: input.text
|
property alias text: input.text
|
||||||
|
|
||||||
property int inputPaddingLeft: 10
|
property int inputPaddingLeft: 10
|
||||||
@@ -109,6 +111,8 @@ ColumnLayout {
|
|||||||
signal editingFinished();
|
signal editingFinished();
|
||||||
signal accepted();
|
signal accepted();
|
||||||
signal textUpdated();
|
signal textUpdated();
|
||||||
|
signal backtabPressed();
|
||||||
|
signal tabPressed();
|
||||||
|
|
||||||
onActiveFocusChanged: activeFocus && input.forceActiveFocus()
|
onActiveFocusChanged: activeFocus && input.forceActiveFocus()
|
||||||
onTextUpdated: {
|
onTextUpdated: {
|
||||||
@@ -212,8 +216,18 @@ ColumnLayout {
|
|||||||
|
|
||||||
MoneroComponents.Input {
|
MoneroComponents.Input {
|
||||||
id: input
|
id: input
|
||||||
KeyNavigation.backtab: item.KeyNavigation.backtab
|
Keys.onBacktabPressed: {
|
||||||
KeyNavigation.tab: item.KeyNavigation.tab
|
item.backtabPressed();
|
||||||
|
if (item.KeyNavigation.backtab) {
|
||||||
|
item.KeyNavigation.backtab.forceActiveFocus()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Keys.onTabPressed: {
|
||||||
|
item.tabPressed();
|
||||||
|
if (item.KeyNavigation.tab) {
|
||||||
|
item.KeyNavigation.tab.forceActiveFocus()
|
||||||
|
}
|
||||||
|
}
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: inputHeight
|
Layout.preferredHeight: inputHeight
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2021, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2021, The Monero Project
|
// Copyright (c) 2021-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -201,6 +201,7 @@ Rectangle {
|
|||||||
daemonManager.sendCommandAsync(
|
daemonManager.sendCommandAsync(
|
||||||
["set_bootstrap_daemon", "auto"],
|
["set_bootstrap_daemon", "auto"],
|
||||||
appWindow.currentWallet.nettype,
|
appWindow.currentWallet.nettype,
|
||||||
|
persistentSettings.blockchainDataDir,
|
||||||
callback);
|
callback);
|
||||||
|
|
||||||
refreshMouseArea.visible = false;
|
refreshMouseArea.visible = false;
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2020, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2021, The Monero Project
|
// Copyright (c) 2021-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2021, The Monero Project
|
// Copyright (c) 2021-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2020, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -21,6 +21,14 @@ Text {
|
|||||||
font.pixelSize: 14
|
font.pixelSize: 14
|
||||||
textFormat: Text.PlainText
|
textFormat: Text.PlainText
|
||||||
|
|
||||||
|
Rectangle {
|
||||||
|
width: root.contentWidth
|
||||||
|
height: root.height
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.top: parent.top
|
||||||
|
color: root.focus ? MoneroComponents.Style.titleBarButtonHoverColor : "transparent"
|
||||||
|
}
|
||||||
|
|
||||||
MoneroEffects.ColorTransition {
|
MoneroEffects.ColorTransition {
|
||||||
enabled: root.themeTransition
|
enabled: root.themeTransition
|
||||||
themeTransition: root.themeTransition
|
themeTransition: root.themeTransition
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2021, The Monero Project
|
// Copyright (c) 2021-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2020, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2020, The Monero Project
|
// Copyright (c) 2020-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
BIN
images/ledgerStax.png
Normal file
|
After Width: | Height: | Size: 41 KiB |
BIN
images/trezor3.png
Normal file
|
After Width: | Height: | Size: 64 KiB |
|
Before Width: | Height: | Size: 72 KiB After Width: | Height: | Size: 72 KiB |
|
Before Width: | Height: | Size: 301 KiB After Width: | Height: | Size: 301 KiB |
BIN
images/verify-white.png
Normal file
|
After Width: | Height: | Size: 956 B |
BIN
images/verify-white@2x.png
Normal file
|
After Width: | Height: | Size: 1.6 KiB |
BIN
images/verify.png
Normal file
|
After Width: | Height: | Size: 854 B |
BIN
images/verify@2x.png
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
images/write-down-white.png
Normal file
|
After Width: | Height: | Size: 779 B |
BIN
images/write-down-white@2x.png
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
images/write-down.png
Normal file
|
After Width: | Height: | Size: 728 B |
BIN
images/write-down@2x.png
Normal file
|
After Width: | Height: | Size: 1.3 KiB |
@@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2014-2020, The Monero Project
|
Copyright (c) 2014-2024, The Monero Project
|
||||||
|
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
; Monero Fluorine Fermi GUI Wallet Installer for Windows
|
; Monero Fluorine Fermi GUI Wallet Installer for Windows
|
||||||
; Copyright (c) 2017-2020, The Monero Project
|
; Copyright (c) 2017-2024, The Monero Project
|
||||||
; See LICENSE
|
; See LICENSE
|
||||||
#define GuiVersion GetFileVersion("bin\monero-wallet-gui.exe")
|
#define GuiVersion GetFileVersion("bin\monero-wallet-gui.exe")
|
||||||
|
|
||||||
@@ -167,7 +167,6 @@ Type: files; Name: "{app}\libstdc++-6.dll"
|
|||||||
Type: files; Name: "{app}\libtiff-5.dll"
|
Type: files; Name: "{app}\libtiff-5.dll"
|
||||||
Type: files; Name: "{app}\libwinpthread-1.dll"
|
Type: files; Name: "{app}\libwinpthread-1.dll"
|
||||||
Type: files; Name: "{app}\zlib1.dll"
|
Type: files; Name: "{app}\zlib1.dll"
|
||||||
Type: files; Name: "{app}\libssp-0.dll"
|
|
||||||
Type: files; Name: "{app}\libhidapi-0.dll"
|
Type: files; Name: "{app}\libhidapi-0.dll"
|
||||||
Type: files; Name: "{app}\libeay32.dll"
|
Type: files; Name: "{app}\libeay32.dll"
|
||||||
Type: files; Name: "{app}\ssleay32.dll"
|
Type: files; Name: "{app}\ssleay32.dll"
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# Monero GUI Wallet Windows Installer #
|
# Monero GUI Wallet Windows Installer #
|
||||||
|
|
||||||
Copyright (c) 2017-2020, The Monero Project
|
Copyright (c) 2017-2024, The Monero Project
|
||||||
|
|
||||||
## Introduction ##
|
## Introduction ##
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
<body style="font-family: Arial, Helvetica, sans-serif">
|
<body style="font-family: Arial, Helvetica, sans-serif">
|
||||||
<h1>Monero Fluorine Fermi GUI Wallet</h1>
|
<h1>Monero Fluorine Fermi GUI Wallet</h1>
|
||||||
|
|
||||||
<p>Copyright (c) 2014-2020, The Monero Project</p>
|
<p>Copyright (c) 2014-2024, The Monero Project</p>
|
||||||
|
|
||||||
<h2>Preface</h2>
|
<h2>Preface</h2>
|
||||||
|
|
||||||
@@ -56,11 +56,14 @@
|
|||||||
i.e. let it download the blockchain and store it locally on your computer, or you can configure your wallet to
|
i.e. let it download the blockchain and store it locally on your computer, or you can configure your wallet to
|
||||||
access a remote <i>open node</i> to get indirect access to the blockchain.</p>
|
access a remote <i>open node</i> to get indirect access to the blockchain.</p>
|
||||||
|
|
||||||
<p>Working with your own copy of the blockchain is <b>preferred</b>: It strengthens the Monero network, and it
|
<p>You can also <i>Prune</i> the blockchain in order to save 2/3 of storage space while keeping the full transaction history.
|
||||||
|
More information regarding how pruning works can be found <a href="https://www.getmonero.org/resources/moneropedia/pruning.html">here</a>.</p>
|
||||||
|
|
||||||
|
<p>Working with your own copy of the blockchain, even pruned, is <b>preferred</b>: It strengthens the Monero network, and it
|
||||||
provides the most security and privacy possible for you.</p>
|
provides the most security and privacy possible for you.</p>
|
||||||
|
|
||||||
<p>However if your Internet access makes it difficult to run a full node, or if you have simply no room to store
|
<p>However if your Internet access makes it difficult to run a full node, or if you have simply no room to store
|
||||||
the blockchain locally (about 90 GB in May 2020, and of course growing), you can compromise and try to connect
|
the blockchain locally (about 160 GB in June 2023, and of course growing), you can compromise and try to connect
|
||||||
to a remote node. One way of finding such a node is checking
|
to a remote node. One way of finding such a node is checking
|
||||||
<a href="https://moneroworld.com/#nodes">this page</a>.
|
<a href="https://moneroworld.com/#nodes">this page</a>.
|
||||||
</p>
|
</p>
|
||||||
|
|||||||
@@ -70,9 +70,43 @@ function checkSignature(signature) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function isValidOpenAliasAddress(address) {
|
function isValidOpenAliasAddress(address) {
|
||||||
address = address.trim()
|
var regex = /^[A-Za-z0-9-]+(\.[A-Za-z0-9-]+)+$/; // Basic domain structure
|
||||||
// we can get an awful lot of valid domains, including non ASCII chars... accept anything
|
|
||||||
// there should be something after the .
|
if (!regex.test(address)) {
|
||||||
// make sure it is not some kind of floating number
|
return false;
|
||||||
return address.length > 2 && isNaN(parseFloat(address)) && address.indexOf('.') >= 0
|
}
|
||||||
|
|
||||||
|
const lastPart = address.substring(address.lastIndexOf('.') + 1);
|
||||||
|
return isNaN(parseInt(lastPart)) || lastPart !== parseInt(lastPart).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleOpenAliasResolution(address, descriptionText) {
|
||||||
|
const result = walletManager.resolveOpenAlias(address);
|
||||||
|
if (!result) {
|
||||||
|
return { message: qsTr("No address found") };
|
||||||
|
}
|
||||||
|
|
||||||
|
const [isDnssecValid, resolvedAddress] = result.split("|");
|
||||||
|
const isAddressValid = walletManager.addressValid(resolvedAddress, appWindow.persistentSettings.nettype);
|
||||||
|
let updatedDescriptionText = descriptionText;
|
||||||
|
|
||||||
|
if (isDnssecValid === "true") {
|
||||||
|
if (isAddressValid) {
|
||||||
|
updatedDescriptionText = descriptionText ? `${address} ${descriptionText}` : address;
|
||||||
|
return { address: resolvedAddress, description: updatedDescriptionText };
|
||||||
|
} else {
|
||||||
|
return { message: qsTr("No valid address found at this OpenAlias address") };
|
||||||
|
}
|
||||||
|
} else if (isDnssecValid === "false") {
|
||||||
|
if (isAddressValid) {
|
||||||
|
return {
|
||||||
|
address: resolvedAddress,
|
||||||
|
message: qsTr("Address found, but the DNSSEC signatures could not be verified, so this address may be spoofed"),
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
return { message: qsTr("No valid address found at this OpenAlias address, but the DNSSEC signatures could not be verified, so this may be spoofed") };
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return { message: qsTr("Internal error") };
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
10
js/Utils.js
@@ -57,12 +57,12 @@ function ago(epoch) {
|
|||||||
|
|
||||||
if(delta < 60)
|
if(delta < 60)
|
||||||
return qsTr("%n second(s) ago", "0", Math.floor(delta))
|
return qsTr("%n second(s) ago", "0", Math.floor(delta))
|
||||||
else if (delta >= 60 && delta <= 3600)
|
else if (delta < 3600)
|
||||||
return qsTr("%n minute(s) ago", "0", Math.floor(delta / 60))
|
return qsTr("%n minute(s) ago", "0", Math.floor(delta / 60))
|
||||||
else if (delta >= 3600 && delta <= 86400)
|
else if (delta < 86400)
|
||||||
return qsTr("%n hour(s) ago", "0", Math.floor(delta / 60 / 60))
|
return qsTr("%n hour(s) ago", "0", Math.floor(delta / 3600))
|
||||||
else if (delta >= 86400)
|
else
|
||||||
return qsTr("%n day(s) ago", "0", Math.floor(delta / 24 / 60 / 60))
|
return qsTr("%n day(s) ago", "0", Math.floor(delta / 86400))
|
||||||
}
|
}
|
||||||
|
|
||||||
function netTypeToString(){
|
function netTypeToString(){
|
||||||
|
|||||||
45
main.qml
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -94,7 +94,7 @@ ApplicationWindow {
|
|||||||
readonly property string localDaemonAddress : "localhost:" + getDefaultDaemonRpcPort(persistentSettings.nettype)
|
readonly property string localDaemonAddress : "localhost:" + getDefaultDaemonRpcPort(persistentSettings.nettype)
|
||||||
property string currentDaemonAddress;
|
property string currentDaemonAddress;
|
||||||
property int disconnectedEpoch: 0
|
property int disconnectedEpoch: 0
|
||||||
property int estimatedBlockchainSize: persistentSettings.pruneBlockchain ? 40 : 105 // GB
|
property int estimatedBlockchainSize: persistentSettings.pruneBlockchain ? 55 : 150 // GB
|
||||||
property alias viewState: rootItem.state
|
property alias viewState: rootItem.state
|
||||||
property string prevSplashText;
|
property string prevSplashText;
|
||||||
property bool splashDisplayedBeforeButtonRequest;
|
property bool splashDisplayedBeforeButtonRequest;
|
||||||
@@ -379,7 +379,7 @@ ApplicationWindow {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function isTrustedDaemon() {
|
function isTrustedDaemon() {
|
||||||
return !persistentSettings.useRemoteNode || remoteNodesModel.currentRemoteNode().trusted;
|
return appWindow.walletMode >= 2 && (!persistentSettings.useRemoteNode || remoteNodesModel.currentRemoteNode().trusted);
|
||||||
}
|
}
|
||||||
|
|
||||||
function usefulName(path) {
|
function usefulName(path) {
|
||||||
@@ -469,7 +469,7 @@ ApplicationWindow {
|
|||||||
|
|
||||||
// If wallet isnt connected, advanced wallet mode and no daemon is running - Ask
|
// If wallet isnt connected, advanced wallet mode and no daemon is running - Ask
|
||||||
if (appWindow.walletMode >= 2 && !persistentSettings.useRemoteNode && !walletInitialized && disconnected) {
|
if (appWindow.walletMode >= 2 && !persistentSettings.useRemoteNode && !walletInitialized && disconnected) {
|
||||||
daemonManager.runningAsync(persistentSettings.nettype, function(running) {
|
daemonManager.runningAsync(persistentSettings.nettype, persistentSettings.blockchainDataDir, function(running) {
|
||||||
if (!running) {
|
if (!running) {
|
||||||
daemonManagerDialog.open();
|
daemonManagerDialog.open();
|
||||||
}
|
}
|
||||||
@@ -586,6 +586,9 @@ ApplicationWindow {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function onWalletUpdate() {
|
function onWalletUpdate() {
|
||||||
|
if (!currentWallet)
|
||||||
|
return;
|
||||||
|
|
||||||
console.log(">>> wallet updated")
|
console.log(">>> wallet updated")
|
||||||
updateBalance();
|
updateBalance();
|
||||||
// Update history if new block found since last update
|
// Update history if new block found since last update
|
||||||
@@ -602,6 +605,9 @@ ApplicationWindow {
|
|||||||
function connectRemoteNode() {
|
function connectRemoteNode() {
|
||||||
console.log("connecting remote node");
|
console.log("connecting remote node");
|
||||||
|
|
||||||
|
p2poolManager.exit();
|
||||||
|
p2poolManager.getStatus();
|
||||||
|
|
||||||
const callback = function() {
|
const callback = function() {
|
||||||
persistentSettings.useRemoteNode = true;
|
persistentSettings.useRemoteNode = true;
|
||||||
const remoteNode = remoteNodesModel.currentRemoteNode();
|
const remoteNode = remoteNodesModel.currentRemoteNode();
|
||||||
@@ -630,6 +636,10 @@ ApplicationWindow {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
console.log("disconnecting remote node");
|
console.log("disconnecting remote node");
|
||||||
|
|
||||||
|
p2poolManager.exit();
|
||||||
|
p2poolManager.getStatus();
|
||||||
|
|
||||||
persistentSettings.useRemoteNode = false;
|
persistentSettings.useRemoteNode = false;
|
||||||
currentDaemonAddress = localDaemonAddress
|
currentDaemonAddress = localDaemonAddress
|
||||||
currentWallet.setDaemonLogin("", "");
|
currentWallet.setDaemonLogin("", "");
|
||||||
@@ -694,7 +704,8 @@ ApplicationWindow {
|
|||||||
// Daemon connected
|
// Daemon connected
|
||||||
leftPanel.networkStatus.connected = currentWallet ? currentWallet.connected() : Wallet.ConnectionStatus_Disconnected
|
leftPanel.networkStatus.connected = currentWallet ? currentWallet.connected() : Wallet.ConnectionStatus_Disconnected
|
||||||
|
|
||||||
currentWallet.refreshHeightAsync();
|
if (currentWallet)
|
||||||
|
currentWallet.refreshHeightAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
function startDaemon(flags){
|
function startDaemon(flags){
|
||||||
@@ -714,7 +725,7 @@ ApplicationWindow {
|
|||||||
appWindow.showProcessingSplash(qsTr("Waiting for daemon to stop..."));
|
appWindow.showProcessingSplash(qsTr("Waiting for daemon to stop..."));
|
||||||
}
|
}
|
||||||
p2poolManager.exit()
|
p2poolManager.exit()
|
||||||
daemonManager.stopAsync(persistentSettings.nettype, function(result) {
|
daemonManager.stopAsync(persistentSettings.nettype, persistentSettings.blockchainDataDir, function(result) {
|
||||||
daemonStartStopInProgress = 0;
|
daemonStartStopInProgress = 0;
|
||||||
if (splash) {
|
if (splash) {
|
||||||
hideProcessingSplash();
|
hideProcessingSplash();
|
||||||
@@ -747,6 +758,12 @@ ApplicationWindow {
|
|||||||
currentWallet.startRefresh();
|
currentWallet.startRefresh();
|
||||||
informationPopup.title = qsTr("Daemon failed to start") + translationManager.emptyString;
|
informationPopup.title = qsTr("Daemon failed to start") + translationManager.emptyString;
|
||||||
informationPopup.text = error + ".\n\n" + qsTr("Please check your wallet and daemon log for errors. You can also try to start %1 manually.").arg((isWindows)? "monerod.exe" : "monerod")
|
informationPopup.text = error + ".\n\n" + qsTr("Please check your wallet and daemon log for errors. You can also try to start %1 manually.").arg((isWindows)? "monerod.exe" : "monerod")
|
||||||
|
if (middlePanel.advancedView.miningView.stopMiningEnabled == true) {
|
||||||
|
walletManager.stopMining()
|
||||||
|
p2poolManager.exit()
|
||||||
|
middlePanel.advancedView.miningView.update()
|
||||||
|
informationPopup.text += qsTr("\n\nExiting p2pool. Please check that port 18083 is available.") + translationManager.emptyString;
|
||||||
|
}
|
||||||
informationPopup.icon = StandardIcon.Critical
|
informationPopup.icon = StandardIcon.Critical
|
||||||
informationPopup.onCloseCallback = null
|
informationPopup.onCloseCallback = null
|
||||||
informationPopup.open();
|
informationPopup.open();
|
||||||
@@ -1118,6 +1135,7 @@ ApplicationWindow {
|
|||||||
middlePanel.transferView.clearFields();
|
middlePanel.transferView.clearFields();
|
||||||
middlePanel.receiveView.clearFields();
|
middlePanel.receiveView.clearFields();
|
||||||
middlePanel.historyView.clearFields();
|
middlePanel.historyView.clearFields();
|
||||||
|
middlePanel.advancedView.clearFields();
|
||||||
// disable timers
|
// disable timers
|
||||||
userInActivityTimer.running = false;
|
userInActivityTimer.running = false;
|
||||||
});
|
});
|
||||||
@@ -1395,7 +1413,7 @@ ApplicationWindow {
|
|||||||
property bool historyShowAdvanced: false
|
property bool historyShowAdvanced: false
|
||||||
property bool historyHumanDates: true
|
property bool historyHumanDates: true
|
||||||
property string blockchainDataDir: ""
|
property string blockchainDataDir: ""
|
||||||
property bool useRemoteNode: false
|
property bool useRemoteNode: isAndroid
|
||||||
property string remoteNodeAddress: "" // TODO: drop after v0.17.2.0 release
|
property string remoteNodeAddress: "" // TODO: drop after v0.17.2.0 release
|
||||||
property string remoteNodesSerialized: JSON.stringify({
|
property string remoteNodesSerialized: JSON.stringify({
|
||||||
selected: 0,
|
selected: 0,
|
||||||
@@ -1445,8 +1463,15 @@ ApplicationWindow {
|
|||||||
function getWalletProxyAddress() {
|
function getWalletProxyAddress() {
|
||||||
if (!useRemoteNode) {
|
if (!useRemoteNode) {
|
||||||
return "";
|
return "";
|
||||||
|
} else {
|
||||||
|
const remoteAddress = remoteNodesModel.currentRemoteNode().address;
|
||||||
|
// skip proxy when using localhost remote node
|
||||||
|
if (remoteAddress.startsWith("127.0.0.1:") || remoteAddress.startsWith("localhost:")) {
|
||||||
|
return "";
|
||||||
|
} else {
|
||||||
|
return getProxyAddress();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return getProxyAddress();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
@@ -2141,7 +2166,7 @@ ApplicationWindow {
|
|||||||
if (currentWallet) {
|
if (currentWallet) {
|
||||||
handler(!currentWallet.disconnected);
|
handler(!currentWallet.disconnected);
|
||||||
} else {
|
} else {
|
||||||
daemonManager.runningAsync(persistentSettings.nettype, handler);
|
daemonManager.runningAsync(persistentSettings.nettype, persistentSettings.blockchainDataDir, handler);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2164,7 +2189,7 @@ ApplicationWindow {
|
|||||||
|
|
||||||
function getBuildTag() {
|
function getBuildTag() {
|
||||||
if (isMac) {
|
if (isMac) {
|
||||||
return "mac-x64";
|
return isARM ? "mac-armv8" : "mac-x64";
|
||||||
}
|
}
|
||||||
if (isWindows) {
|
if (isWindows) {
|
||||||
return oshelper.installed ? "install-win-x64" : "win-x64";
|
return oshelper.installed ? "install-win-x64" : "win-x64";
|
||||||
|
|||||||
2
monero
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -387,34 +387,17 @@ Rectangle {
|
|||||||
visible: TxUtils.isValidOpenAliasAddress(addressLine.text)
|
visible: TxUtils.isValidOpenAliasAddress(addressLine.text)
|
||||||
enabled : visible
|
enabled : visible
|
||||||
onClicked: {
|
onClicked: {
|
||||||
var result = walletManager.resolveOpenAlias(addressLine.text)
|
const response = TxUtils.handleOpenAliasResolution(addressLine.text, descriptionLine.text);
|
||||||
if (result) {
|
if (response) {
|
||||||
var parts = result.split("|")
|
if (response.message) {
|
||||||
if (parts.length === 2) {
|
oa_message(response.message);
|
||||||
var address_ok = walletManager.addressValid(parts[1], appWindow.persistentSettings.nettype)
|
}
|
||||||
if (parts[0] === "true") {
|
if (response.address) {
|
||||||
if (address_ok) {
|
addressLine.text = response.address;
|
||||||
// prepend openalias to description
|
}
|
||||||
descriptionLine.text = descriptionLine.text ? addressLine.text + " " + descriptionLine.text : addressLine.text
|
if (response.description) {
|
||||||
addressLine.text = parts[1]
|
descriptionLine.text = response.description;
|
||||||
} else {
|
|
||||||
root.oa_message(qsTr("No valid address found at this OpenAlias address"))
|
|
||||||
}
|
|
||||||
} else if (parts[0] === "false") {
|
|
||||||
if (address_ok) {
|
|
||||||
addressLine.text = parts[1]
|
|
||||||
root.oa_message(qsTr("Address found, but the DNSSEC signatures could not be verified, so this address may be spoofed"))
|
|
||||||
} else {
|
|
||||||
root.oa_message(qsTr("No valid address found at this OpenAlias address, but the DNSSEC signatures could not be verified, so this may be spoofed"))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
root.oa_message(qsTr("Internal error"))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
root.oa_message(qsTr("Internal error"))
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
root.oa_message(qsTr("No address found"))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2021, The Monero Project
|
// Copyright (c) 2021-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -40,6 +40,8 @@ ColumnLayout {
|
|||||||
spacing: 0
|
spacing: 0
|
||||||
property int panelHeight: 900
|
property int panelHeight: 900
|
||||||
property alias miningView: stateView.miningView
|
property alias miningView: stateView.miningView
|
||||||
|
property alias signView: stateView.signView
|
||||||
|
property alias prooveView: stateView.prooveView
|
||||||
property alias state: stateView.state
|
property alias state: stateView.state
|
||||||
|
|
||||||
MoneroComponents.Navbar {
|
MoneroComponents.Navbar {
|
||||||
@@ -52,6 +54,7 @@ ColumnLayout {
|
|||||||
active: state == "Mining"
|
active: state == "Mining"
|
||||||
text: qsTr("Mining") + translationManager.emptyString
|
text: qsTr("Mining") + translationManager.emptyString
|
||||||
onSelected: state = "Mining"
|
onSelected: state = "Mining"
|
||||||
|
visible: !isAndroid
|
||||||
}
|
}
|
||||||
MoneroComponents.NavbarItem {
|
MoneroComponents.NavbarItem {
|
||||||
active: state == "Prove"
|
active: state == "Prove"
|
||||||
@@ -81,7 +84,7 @@ ColumnLayout {
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: panelHeight
|
Layout.preferredHeight: panelHeight
|
||||||
color: "transparent"
|
color: "transparent"
|
||||||
state: "Mining"
|
state: isAndroid ? "Prove" : "Mining"
|
||||||
|
|
||||||
onCurrentViewChanged: {
|
onCurrentViewChanged: {
|
||||||
if (previousView) {
|
if (previousView) {
|
||||||
@@ -120,7 +123,7 @@ ColumnLayout {
|
|||||||
|
|
||||||
StackView {
|
StackView {
|
||||||
id: stackView
|
id: stackView
|
||||||
initialItem: stateView.miningView
|
initialItem: isAndroid ? stateView.prooveView : stateView.miningView
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
clip: false // otherwise animation will affect left panel
|
clip: false // otherwise animation will affect left panel
|
||||||
|
|
||||||
@@ -146,4 +149,10 @@ ColumnLayout {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function clearFields() {
|
||||||
|
signView.clearFields();
|
||||||
|
prooveView.clearFields();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -1765,18 +1765,25 @@ Rectangle {
|
|||||||
var written = currentWallet.history.writeCSV(currentWallet.currentSubaddressAccount, dataDir);
|
var written = currentWallet.history.writeCSV(currentWallet.currentSubaddressAccount, dataDir);
|
||||||
|
|
||||||
if(written !== ""){
|
if(written !== ""){
|
||||||
informationPopup.title = qsTr("Success") + translationManager.emptyString;
|
confirmationDialog.title = qsTr("Success") + translationManager.emptyString;
|
||||||
var text = qsTr("CSV file written to: %1").arg(written) + "\n\n"
|
var text = qsTr("CSV file written to: %1").arg(written) + "\n\n"
|
||||||
text += qsTr("Tip: Use your favorite spreadsheet software to sort on blockheight.") + "\n\n" + translationManager.emptyString;
|
text += qsTr("Tip: Use your favorite spreadsheet software to sort on blockheight.") + "\n\n" + translationManager.emptyString;
|
||||||
informationPopup.text = text;
|
confirmationDialog.text = text;
|
||||||
informationPopup.icon = StandardIcon.Information;
|
confirmationDialog.icon = StandardIcon.Information;
|
||||||
|
confirmationDialog.cancelText = qsTr("Open folder") + translationManager.emptyString;
|
||||||
|
confirmationDialog.onAcceptedCallback = null;
|
||||||
|
confirmationDialog.onRejectedCallback = function() {
|
||||||
|
oshelper.openContainingFolder(written);
|
||||||
|
}
|
||||||
|
confirmationDialog.open();
|
||||||
} else {
|
} else {
|
||||||
informationPopup.title = qsTr("Error") + translationManager.emptyString;
|
informationPopup.title = qsTr("Error") + translationManager.emptyString;
|
||||||
informationPopup.text = qsTr("Error exporting transaction data.") + "\n\n" + translationManager.emptyString;
|
informationPopup.text = qsTr("Error exporting transaction data.") + "\n\n" + translationManager.emptyString;
|
||||||
informationPopup.icon = StandardIcon.Critical;
|
informationPopup.icon = StandardIcon.Critical;
|
||||||
|
informationPopup.onCloseCallback = null;
|
||||||
|
informationPopup.open();
|
||||||
|
|
||||||
}
|
}
|
||||||
informationPopup.onCloseCallback = null;
|
|
||||||
informationPopup.open();
|
|
||||||
}
|
}
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
var _folder = 'file://' + appWindow.accountsDir;
|
var _folder = 'file://' + appWindow.accountsDir;
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -41,7 +41,8 @@ Rectangle {
|
|||||||
property alias miningHeight: mainLayout.height
|
property alias miningHeight: mainLayout.height
|
||||||
property double currentHashRate: 0
|
property double currentHashRate: 0
|
||||||
property int threads: idealThreadCount / 2
|
property int threads: idealThreadCount / 2
|
||||||
|
property alias stopMiningEnabled: stopSoloMinerButton.enabled
|
||||||
|
property string args: ""
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
id: mainLayout
|
id: mainLayout
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
@@ -293,11 +294,12 @@ Rectangle {
|
|||||||
var success;
|
var success;
|
||||||
if (persistentSettings.allow_p2pool_mining) {
|
if (persistentSettings.allow_p2pool_mining) {
|
||||||
if (p2poolManager.isInstalled()) {
|
if (p2poolManager.isInstalled()) {
|
||||||
if (persistentSettings.allowRemoteNodeMining) {
|
args = daemonManager.getArgs(persistentSettings.blockchainDataDir) //updates arguments
|
||||||
|
if (persistentSettings.allowRemoteNodeMining || (args.includes("--zmq-pub tcp://127.0.0.1:18083") || args.includes("--zmq-pub=tcp://127.0.0.1:18083")) && !args.includes("--no-zmq")) {
|
||||||
startP2Pool()
|
startP2Pool()
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
daemonManager.stopAsync(persistentSettings.nettype, startP2PoolLocal)
|
daemonManager.stopAsync(persistentSettings.nettype, persistentSettings.blockchainDataDir, startP2PoolLocal)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@@ -585,12 +587,35 @@ Rectangle {
|
|||||||
|
|
||||||
function startP2PoolLocal() {
|
function startP2PoolLocal() {
|
||||||
var noSync = false;
|
var noSync = false;
|
||||||
var customDaemonArgs = persistentSettings.daemonFlags.toLowerCase();
|
//these args will be deleted because DaemonManager::start will re-add them later.
|
||||||
var daemonArgs = "--zmq-pub " + "tcp://127.0.0.1:18083 " + "--disable-dns-checkpoints "
|
//--no-zmq must be deleted. removing '--zmq-pub=tcp...' lets us blindly add '--zmq-pub tcp...' later without risking duplication.
|
||||||
if (!customDaemonArgs.includes("--zmq-pub") && !customDaemonArgs.includes("--disable-dns-checkpoints") && !customDaemonArgs.includes("--no-zmq")) {
|
var defaultArgs = ["--detach","--data-dir","--bootstrap-daemon-address","--prune-blockchain","--no-sync","--check-updates","--non-interactive","--max-concurrency","--no-zmq","--zmq-pub=tcp://127.0.0.1:18083"]
|
||||||
daemonArgs = daemonArgs + customDaemonArgs;
|
var customDaemonArgsArray = args.split(' ');
|
||||||
|
var flag = "";
|
||||||
|
var allArgs = [];
|
||||||
|
var p2poolArgs = ["--zmq-pub tcp://127.0.0.1:18083"];
|
||||||
|
//create an array (allArgs) of ['--arg value','--arg2','--arg3']
|
||||||
|
for (let i = 0; i < customDaemonArgsArray.length; i++) {
|
||||||
|
if(!customDaemonArgsArray[i].startsWith("--")) {
|
||||||
|
flag += " " + customDaemonArgsArray[i]
|
||||||
|
} else {
|
||||||
|
if(flag){
|
||||||
|
allArgs.push(flag)
|
||||||
|
}
|
||||||
|
flag = customDaemonArgsArray[i]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
var success = daemonManager.start(daemonArgs, persistentSettings.nettype, persistentSettings.blockchainDataDir, persistentSettings.bootstrapNodeAddress, noSync, persistentSettings.pruneBlockchain)
|
allArgs.push(flag)
|
||||||
|
//pop from allArgs if value is inside the deleteme array (defaultArgs)
|
||||||
|
allArgs = allArgs.filter( ( el ) => !defaultArgs.includes( el.split(" ")[0] ) )
|
||||||
|
//append required p2pool flags
|
||||||
|
for (let i = 0; i < p2poolArgs.length; i++) {
|
||||||
|
if(!allArgs.includes(p2poolArgs[i])) {
|
||||||
|
allArgs.push(p2poolArgs[i])
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var success = daemonManager.start(allArgs.join(" "), persistentSettings.nettype, persistentSettings.blockchainDataDir, persistentSettings.bootstrapNodeAddress, noSync, persistentSettings.pruneBlockchain)
|
||||||
if (success) {
|
if (success) {
|
||||||
startP2Pool()
|
startP2Pool()
|
||||||
}
|
}
|
||||||
@@ -616,10 +641,25 @@ Rectangle {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function p2poolDownloadFailed() {
|
function p2poolDownloadFailed(errorCode) {
|
||||||
statusMessage.visible = false
|
statusMessage.visible = false
|
||||||
errorPopup.title = qsTr("P2Pool Installation Failed") + translationManager.emptyString;
|
errorPopup.title = qsTr("P2Pool Installation Failed") + translationManager.emptyString;
|
||||||
errorPopup.text = qsTr("P2Pool installation failed.") + isWindows ? (" " + qsTr("Try starting the program with administrator privileges.")) : ""
|
switch (errorCode) {
|
||||||
|
case P2PoolManager.HashVerificationFailed:
|
||||||
|
errorPopup.text = qsTr("Hash verification failed.") + translationManager.emptyString;
|
||||||
|
break;
|
||||||
|
case P2PoolManager.BinaryNotAvailable:
|
||||||
|
errorPopup.text = qsTr("P2Pool download is not available.") + translationManager.emptyString;
|
||||||
|
break;
|
||||||
|
case P2PoolManager.ConnectionIssue:
|
||||||
|
errorPopup.text = qsTr("P2Pool download failed due to a connection issue.") + translationManager.emptyString;
|
||||||
|
break;
|
||||||
|
case P2PoolManager.InstallationFailed:
|
||||||
|
errorPopup.text = qsTr("P2Pool installation failed.") + (isWindows ? (" " + qsTr("Try starting the program with administrator privileges.")) : "")
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
errorPopup.text = qsTr("Unknown error.") + translationManager.emptyString;
|
||||||
|
}
|
||||||
errorPopup.icon = StandardIcon.Critical
|
errorPopup.icon = StandardIcon.Critical
|
||||||
errorPopup.open()
|
errorPopup.open()
|
||||||
update()
|
update()
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2018, The Monero Project
|
// Copyright (c) 2018-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -50,15 +50,6 @@ Rectangle {
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
function validUnsigned(s) {
|
|
||||||
if (s.length == 0)
|
|
||||||
return false
|
|
||||||
for (var i = 0; i < s.length; ++i)
|
|
||||||
if ("0123456789".indexOf(s[i]) == -1)
|
|
||||||
return false
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
function validRing(str, relative) {
|
function validRing(str, relative) {
|
||||||
var outs = str.split(" ");
|
var outs = str.split(" ");
|
||||||
if (outs.length == 0)
|
if (outs.length == 0)
|
||||||
@@ -109,136 +100,6 @@ Rectangle {
|
|||||||
color: MoneroComponents.Style.defaultFontColor
|
color: MoneroComponents.Style.defaultFontColor
|
||||||
}
|
}
|
||||||
|
|
||||||
MoneroComponents.LabelSubheader {
|
|
||||||
Layout.fillWidth: true
|
|
||||||
textFormat: Text.RichText
|
|
||||||
text: qsTr("Outputs marked as spent") + translationManager.emptyString
|
|
||||||
tooltip: qsTr(
|
|
||||||
"In order to obscure which inputs in a Monero transaction are being spent, a third party should not be able " +
|
|
||||||
"to tell which inputs in a ring are already known to be spent. Being able to do so would weaken the protection " +
|
|
||||||
"afforded by ring signatures. If all but one of the inputs are known to be already spent, then the input being " +
|
|
||||||
"actually spent becomes apparent, thereby nullifying the effect of ring signatures, one of the three main layers " +
|
|
||||||
"of privacy protection Monero uses.<br>" +
|
|
||||||
"To help transactions avoid those inputs, a list of known spent ones can be used to avoid using them in new " +
|
|
||||||
"transactions. Such a list is maintained by the Monero project and is available on the getmonero.org website, " +
|
|
||||||
"and you can import this list here.<br>" +
|
|
||||||
"Alternatively, you can scan the blockchain (and the blockchain of key-reusing Monero clones) yourself " +
|
|
||||||
"using the monero-blockchain-mark-spent-outputs tool to create a list of known spent outputs.<br>"
|
|
||||||
) + translationManager.emptyString
|
|
||||||
}
|
|
||||||
|
|
||||||
MoneroComponents.TextPlain {
|
|
||||||
textFormat: Text.RichText
|
|
||||||
font.family: MoneroComponents.Style.fontRegular.name
|
|
||||||
font.pixelSize: 14
|
|
||||||
text: qsTr("This sets which outputs are known to be spent, and thus not to be used as privacy placeholders in ring signatures. ") +
|
|
||||||
qsTr("You should only have to load a file when you want to refresh the list. Manual adding/removing is possible if needed.") + translationManager.emptyString
|
|
||||||
wrapMode: Text.Wrap
|
|
||||||
Layout.fillWidth: true;
|
|
||||||
color: MoneroComponents.Style.defaultFontColor
|
|
||||||
}
|
|
||||||
|
|
||||||
ColumnLayout {
|
|
||||||
Layout.fillWidth: true
|
|
||||||
Layout.topMargin: 12
|
|
||||||
|
|
||||||
FileDialog {
|
|
||||||
id: loadBlackballFileDialog
|
|
||||||
title: qsTr("Please choose a file from which to load outputs to mark as spent") + translationManager.emptyString;
|
|
||||||
folder: "file://"
|
|
||||||
nameFilters: ["*"]
|
|
||||||
|
|
||||||
onAccepted: {
|
|
||||||
loadBlackballFileLine.text = walletManager.urlToLocalPath(loadBlackballFileDialog.fileUrl)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
MoneroComponents.LineEdit {
|
|
||||||
id: loadBlackballFileLine
|
|
||||||
Layout.fillWidth: true
|
|
||||||
fontSize: 16
|
|
||||||
placeholderFontSize: 16
|
|
||||||
placeholderText: qsTr("Path to file") + "..." + translationManager.emptyString
|
|
||||||
labelFontSize: 14
|
|
||||||
labelText: qsTr("Filename with outputs to mark as spent") + ":" + translationManager.emptyString
|
|
||||||
copyButton: true
|
|
||||||
readOnly: false
|
|
||||||
}
|
|
||||||
|
|
||||||
RowLayout {
|
|
||||||
Layout.fillWidth: true
|
|
||||||
Layout.topMargin: 18
|
|
||||||
|
|
||||||
MoneroComponents.StandardButton {
|
|
||||||
id: selectBlackballFileButton
|
|
||||||
text: qsTr("Browse") + translationManager.emptyString
|
|
||||||
enabled: true
|
|
||||||
small: true
|
|
||||||
onClicked: {
|
|
||||||
loadBlackballFileDialog.open()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
MoneroComponents.StandardButton {
|
|
||||||
id: loadBlackballFileButton
|
|
||||||
text: qsTr("Load") + translationManager.emptyString
|
|
||||||
small: true
|
|
||||||
enabled: !!appWindow.currentWallet && loadBlackballFileLine.text !== ""
|
|
||||||
onClicked: appWindow.currentWallet.blackballOutputs(walletManager.urlToLocalPath(loadBlackballFileDialog.fileUrl), true)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
GridLayout {
|
|
||||||
Layout.fillWidth: true
|
|
||||||
columnSpacing: 20
|
|
||||||
|
|
||||||
MoneroComponents.LineEdit {
|
|
||||||
id: blackballOutputAmountLine
|
|
||||||
Layout.fillWidth: true
|
|
||||||
fontSize: 16
|
|
||||||
labelFontSize: 14
|
|
||||||
labelText: qsTr("Or manually mark a single output as spent/unspent:") + translationManager.emptyString
|
|
||||||
placeholderFontSize: 16
|
|
||||||
placeholderText: qsTr("Paste output amount") + "..." + translationManager.emptyString
|
|
||||||
readOnly: false
|
|
||||||
validator: IntValidator { bottom: 0 }
|
|
||||||
}
|
|
||||||
|
|
||||||
MoneroComponents.LineEdit {
|
|
||||||
id: blackballOutputOffsetLine
|
|
||||||
Layout.fillWidth: true
|
|
||||||
fontSize: 16
|
|
||||||
labelFontSize: 14
|
|
||||||
labelText: " "
|
|
||||||
placeholderFontSize: 16
|
|
||||||
placeholderText: qsTr("Paste output offset") + "..." + translationManager.emptyString
|
|
||||||
readOnly: false
|
|
||||||
validator: IntValidator { bottom: 0 }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
RowLayout {
|
|
||||||
Layout.fillWidth: true
|
|
||||||
Layout.topMargin: 18
|
|
||||||
|
|
||||||
MoneroComponents.StandardButton {
|
|
||||||
id: blackballButton
|
|
||||||
text: qsTr("Mark as spent") + translationManager.emptyString
|
|
||||||
small: true
|
|
||||||
enabled: !!appWindow.currentWallet && validUnsigned(blackballOutputAmountLine.text) && validUnsigned(blackballOutputOffsetLine.text)
|
|
||||||
onClicked: appWindow.currentWallet.blackballOutput(blackballOutputAmountLine.text, blackballOutputOffsetLine.text)
|
|
||||||
}
|
|
||||||
|
|
||||||
MoneroComponents.StandardButton {
|
|
||||||
id: unblackballButton
|
|
||||||
text: qsTr("Mark as unspent") + translationManager.emptyString
|
|
||||||
small: true
|
|
||||||
enabled: !!appWindow.currentWallet && validUnsigned(blackballOutputAmountLine.text) && validUnsigned(blackballOutputOffsetLine.text)
|
|
||||||
onClicked: appWindow.currentWallet.unblackballOutput(blackballOutputAmountLine.text, blackballOutputOffsetLine.text)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
MoneroComponents.LabelSubheader {
|
MoneroComponents.LabelSubheader {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.topMargin: 24
|
Layout.topMargin: 24
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -421,6 +421,16 @@ Rectangle {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function clearFields() {
|
||||||
|
verifyMessageLine.text = ""
|
||||||
|
signMessageLine.text = ""
|
||||||
|
signSignatureLine.text = ""
|
||||||
|
verifyAddressLine.text = ""
|
||||||
|
verifySignatureLine.text = ""
|
||||||
|
signFileLine.text = ""
|
||||||
|
verifyFileLine.text = ""
|
||||||
|
}
|
||||||
|
|
||||||
function onPageCompleted() {
|
function onPageCompleted() {
|
||||||
console.log("Sign/verify page loaded");
|
console.log("Sign/verify page loaded");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -51,7 +51,7 @@ Rectangle {
|
|||||||
color: "transparent"
|
color: "transparent"
|
||||||
property alias transferHeight1: pageRoot.height
|
property alias transferHeight1: pageRoot.height
|
||||||
property alias transferHeight2: advancedLayout.height
|
property alias transferHeight2: advancedLayout.height
|
||||||
property int mixin: 10 // (ring size 11)
|
property int mixin: 15 // (ring size 16)
|
||||||
property string warningContent: ""
|
property string warningContent: ""
|
||||||
property string sendButtonWarning: {
|
property string sendButtonWarning: {
|
||||||
// Currently opened wallet is not view-only
|
// Currently opened wallet is not view-only
|
||||||
@@ -415,41 +415,18 @@ Rectangle {
|
|||||||
text: qsTr("Resolve") + translationManager.emptyString
|
text: qsTr("Resolve") + translationManager.emptyString
|
||||||
visible: TxUtils.isValidOpenAliasAddress(address)
|
visible: TxUtils.isValidOpenAliasAddress(address)
|
||||||
onClicked: {
|
onClicked: {
|
||||||
var result = walletManager.resolveOpenAlias(address)
|
const response = TxUtils.handleOpenAliasResolution(address, descriptionLine.text);
|
||||||
if (result) {
|
if (response) {
|
||||||
var parts = result.split("|")
|
if (response.message) {
|
||||||
if (parts.length == 2) {
|
oa_message(response.message);
|
||||||
var address_ok = walletManager.addressValid(parts[1], appWindow.persistentSettings.nettype)
|
|
||||||
if (parts[0] === "true") {
|
|
||||||
if (address_ok) {
|
|
||||||
// prepend openalias to description
|
|
||||||
descriptionLine.text = descriptionLine.text ? address + " " + descriptionLine.text : address
|
|
||||||
descriptionCheckbox.checked = true
|
|
||||||
recipientRepeater.itemAt(index).children[1].children[0].text = parts[1];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
oa_message(qsTr("No valid address found at this OpenAlias address"))
|
|
||||||
}
|
|
||||||
else if (parts[0] === "false") {
|
|
||||||
if (address_ok) {
|
|
||||||
recipientRepeater.itemAt(index).children[1].children[0].text = parts[1];
|
|
||||||
oa_message(qsTr("Address found, but the DNSSEC signatures could not be verified, so this address may be spoofed"))
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
oa_message(qsTr("No valid address found at this OpenAlias address, but the DNSSEC signatures could not be verified, so this may be spoofed"))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
oa_message(qsTr("Internal error"))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else {
|
if (response.address) {
|
||||||
oa_message(qsTr("Internal error"))
|
recipientRepeater.itemAt(index).children[1].children[0].text = response.address;
|
||||||
|
}
|
||||||
|
if (response.description) {
|
||||||
|
descriptionLine.text = response.description;
|
||||||
|
descriptionCheckbox.checked = true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else {
|
|
||||||
oa_message(qsTr("No address found"))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -259,6 +259,17 @@ Rectangle {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function clearFields() {
|
||||||
|
checkProofAddressLine.text = ""
|
||||||
|
checkProofMessageLine.text = ""
|
||||||
|
checkProofSignatureLine.text = ""
|
||||||
|
checkProofTxIdLine.text = ""
|
||||||
|
getProofAddressLine.text = ""
|
||||||
|
getProofMessageLine.text = ""
|
||||||
|
getProofTxIdLine.text = ""
|
||||||
|
getReserveProofAmtLine.text = ""
|
||||||
|
}
|
||||||
|
|
||||||
function onPageCompleted() {
|
function onPageCompleted() {
|
||||||
console.log("TxKey page loaded");
|
console.log("TxKey page loaded");
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -74,6 +74,7 @@ ColumnLayout {
|
|||||||
active: settingsStateView.state == "Log"
|
active: settingsStateView.state == "Log"
|
||||||
text: qsTr("Log") + translationManager.emptyString
|
text: qsTr("Log") + translationManager.emptyString
|
||||||
onSelected: settingsStateView.state = "Log"
|
onSelected: settingsStateView.state = "Log"
|
||||||
|
visible: !isAndroid
|
||||||
}
|
}
|
||||||
MoneroComponents.NavbarItem {
|
MoneroComponents.NavbarItem {
|
||||||
active: settingsStateView.state == "Info"
|
active: settingsStateView.state == "Info"
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -254,7 +254,7 @@ Rectangle {
|
|||||||
onAccepted: {
|
onAccepted: {
|
||||||
if(text.length > 0) {
|
if(text.length > 0) {
|
||||||
consoleArea.logCommand(">>> " + text)
|
consoleArea.logCommand(">>> " + text)
|
||||||
daemonManager.sendCommandAsync(text.split(" "), currentWallet.nettype, function(result) {
|
daemonManager.sendCommandAsync(text.split(" "), currentWallet.nettype, persistentSettings.blockchainDataDir, function(result) {
|
||||||
if (!result) {
|
if (!result) {
|
||||||
appWindow.showStatusMessage(qsTr("Failed to send command"), 3);
|
appWindow.showStatusMessage(qsTr("Failed to send command"), 3);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2019, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -55,6 +55,7 @@ Rectangle{
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: 90
|
Layout.preferredHeight: 90
|
||||||
color: "transparent"
|
color: "transparent"
|
||||||
|
visible: !isAndroid
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: localNodeDivider
|
id: localNodeDivider
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2024, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
@@ -138,9 +138,19 @@ Rectangle {
|
|||||||
inputDialog.onAcceptedCallback = function() {
|
inputDialog.onAcceptedCallback = function() {
|
||||||
var txid = inputDialog.inputText.trim();
|
var txid = inputDialog.inputText.trim();
|
||||||
if (currentWallet.scanTransactions([txid])) {
|
if (currentWallet.scanTransactions([txid])) {
|
||||||
|
updateBalance();
|
||||||
appWindow.showStatusMessage(qsTr("Transaction successfully scanned"), 3);
|
appWindow.showStatusMessage(qsTr("Transaction successfully scanned"), 3);
|
||||||
} else {
|
} else {
|
||||||
appWindow.showStatusMessage(qsTr("Failed to scan transaction") + ": " + currentWallet.errorString, 5);
|
console.error("Error: ", currentWallet.errorString);
|
||||||
|
if (currentWallet.errorString == "The wallet has already seen 1 or more recent transactions than the scanned tx") {
|
||||||
|
informationPopup.title = qsTr("Error") + translationManager.emptyString;
|
||||||
|
informationPopup.text = qsTr("The wallet has already seen 1 or more recent transactions than the scanned transaction.\n\nIn order to rescan the transaction, you can re-sync your wallet by resetting the wallet restore height in the Settings > Info page. Make sure to use a restore height from before your wallet's earliest transaction.") + translationManager.emptyString;
|
||||||
|
informationPopup.icon = StandardIcon.Critical
|
||||||
|
informationPopup.onCloseCallback = null
|
||||||
|
informationPopup.open();
|
||||||
|
} else {
|
||||||
|
appWindow.showStatusMessage(qsTr("Failed to scan transaction") + ": " + currentWallet.errorString, 5);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
inputDialog.onRejectedCallback = null;
|
inputDialog.onRejectedCallback = null;
|
||||||
|
|||||||
19
qml.qrc
@@ -206,6 +206,7 @@
|
|||||||
<file>wizard/WizardCreateWallet2.qml</file>
|
<file>wizard/WizardCreateWallet2.qml</file>
|
||||||
<file>wizard/WizardCreateWallet3.qml</file>
|
<file>wizard/WizardCreateWallet3.qml</file>
|
||||||
<file>wizard/WizardCreateWallet4.qml</file>
|
<file>wizard/WizardCreateWallet4.qml</file>
|
||||||
|
<file>wizard/WizardCreateWallet5.qml</file>
|
||||||
<file>wizard/WizardCreateDevice1.qml</file>
|
<file>wizard/WizardCreateDevice1.qml</file>
|
||||||
<file>wizard/WizardDaemonSettings.qml</file>
|
<file>wizard/WizardDaemonSettings.qml</file>
|
||||||
<file>wizard/WizardHeader.qml</file>
|
<file>wizard/WizardHeader.qml</file>
|
||||||
@@ -280,7 +281,21 @@
|
|||||||
<file>images/ledgerNanoS.png</file>
|
<file>images/ledgerNanoS.png</file>
|
||||||
<file>images/ledgerNanoSPlus.png</file>
|
<file>images/ledgerNanoSPlus.png</file>
|
||||||
<file>images/ledgerNanoX.png</file>
|
<file>images/ledgerNanoX.png</file>
|
||||||
<file>images/trezor.png</file>
|
<file>images/ledgerStax.png</file>
|
||||||
<file>images/trezor@2x.png</file>
|
<file>images/trezor3.png</file>
|
||||||
|
<file>images/trezorT.png</file>
|
||||||
|
<file>images/trezorT@2x.png</file>
|
||||||
|
<file>qtquickcontrols2.conf</file>
|
||||||
|
<file>images/write-down.png</file>
|
||||||
|
<file>images/write-down-white.png</file>
|
||||||
|
<file>images/write-down@2x.png</file>
|
||||||
|
<file>images/write-down-white@2x.png</file>
|
||||||
|
<file>images/verify.png</file>
|
||||||
|
<file>images/verify-white.png</file>
|
||||||
|
<file>images/verify@2x.png</file>
|
||||||
|
<file>images/verify-white@2x.png</file>
|
||||||
|
<file>wizard/SeedListItem.qml</file>
|
||||||
|
<file>wizard/SeedListGrid.qml</file>
|
||||||
|
<file>wizard/template.pdf</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|||||||
2
qtquickcontrols2.conf
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
[Controls]
|
||||||
|
Style=Desktop
|
||||||