monerod-gui/README.md

11 KiB

Monerod GUI

Maintained Codacy Badge Make a pull request License Lint Test

Linux - AppImage Build Linux - x64 DEB Build Linux - x86_64 RPM Build

MacOS - x64 DMG Build Windows Build

Watch on GitHub Star on GitHub

XMR Donated BTC Donated

Introduction

Monerod GUI is a desktop application that provides a graphical user interface (GUI) for installing, updating, and interacting with the Monero daemon (monerod). This tool simplifies the process of managing a full Monero node, enabling users to run, configure, and monitor monerod without needing to use the command line.

Demo

https://github.com/user-attachments/assets/c4a50d2f-5bbb-48ac-9425-30ecc20ada7c

Features

1. Simple Monerod Setup

  • Automatically downloads and installs the latest version of monerod based on your operating system (Windows, macOS, Linux).
  • Provides configuration options for running monerod with custom parameters (e.g., enabling testnet, fast block sync, blockchain pruning).

2. Seamless Updates

  • Automatically checks for new monerod releases.
  • One-click updates to the latest version, keeping your node secure and up-to-date.

3. Interactive Control Panel

  • Start, stop, and monitor the status of the Monero daemon from an intuitive control panel.
  • Configure important monerod settings like RPC access, logging level, concurrency, and more from the GUI.

4. Real-Time Log Monitoring

  • Displays real-time monerod logs in a clean, readable format, helping users track sync progress, transactions, and errors.
  • Offers log filtering for easier monitoring of specific events or errors.

5. Network and Connectivity Monitoring

  • Detects whether your current connection is over Wi-Fi and provides feedback on network stability.
  • Supports external bind confirmations and allows for easy configuration of RPC access control for enhanced security.

6. Cross-Platform Support

  • Monerod GUI automatically detects the operating system and selects the appropriate monerod version to download.
  • Available for Windows, macOS, and Linux.

7. Customizable Installation

  • Users can choose the installation directory for monerod, allowing for greater flexibility in managing the software on different systems.

Usage

  1. On the first run, Monerod GUI will detect your operating system and prompt you to download the appropriate version of monerod.
  2. Once installed, you can start the Monero daemon with one click and configure various settings like testnet mode, fast sync, and more.
  3. Monitor real-time logs to keep track of blockchain synchronization and transaction details.

To Do

  • Upgrade Electron to latest version
  • Upgrade Angular to latest version
  • Detect wired/Wi-Fi connection
  • Detect battery/ac power
  • Detect preinstalled monerod
    • Linux
    • Windows
    • MacOs
  • Automatic startup at login
    • Linux
    • Windows
    • MacOS
  • Installers
    • Linux
    • Windows
    • MacOS
  • Packages
    • deb
    • rpm
    • exe
    • msi
    • dmg
    • pkg
    • flatpack
    • snap
  • Import/export monerod.conf node configuration
  • Synchronization in a specific time slot
  • Prompt user access control for administration operation
  • Blockchain tools
    • Import blockchain
    • Export blockchain
  • Mining tools
    • XMRig integration
    • P2Pool integration
  • Anonymous network tools
    • Tor integration
    • I2P integration
  • Remote node management
    • No CORS connection

Getting Started

Clone this repository locally:

git clone https://github.com/everoddandeven/monerod-gui.git

Install dependencies with npm (used by Electron renderer process):

npm install

There is an issue with yarn and node_modules when the application is built by the packager. Please use npm as dependencies manager.

Install NodeJS dependencies with npm (used by Electron main process):

cd app/
npm install

Why two package.json ? This project follow Electron Builder two package.json structure in order to optimize final bundle and be still able to use Angular ng add feature.

Project structure

Folder Description
app Electron main process folder (NodeJS)
src Electron renderer process folder (Web / Angular)

To build for development

Command Description
npm run electron:local:dev Builds your application and start electron locally (DEV MODE)

If you want to generate Angular components with Angular-cli , you MUST install @angular/cli in npm global context. Please follow Angular-cli documentation if you had installed a previous version of angular-cli.

npm install -g @angular/cli

To build for production

Command Description
npm run electron:local Builds your application and start electron locally
npm run electron:build Builds your application and creates an app and installer for Windows
npm run electron:build:deb Builds your application and creates an installer consumable for debian based operating systems
npm run electron:build:rpm Builds your application and creates an installer consumable for redhat based operating systems
npm run electron:build:mac Builds your application and creates an installer consumable for MacOS

Your application is optimised. Only /dist folder and NodeJS dependencies are included in the final bundle.

E2E Testing

E2E Test scripts can be found in e2e folder.

Command Description
npm run e2e Execute end to end tests

Note: To make it work behind a proxy, you can add this proxy exception in your terminal
export {no_proxy,NO_PROXY}="127.0.0.1,localhost"

Debug with VsCode

VsCode debug configuration is available! In order to use it, you need the extension Debugger for Chrome.

Then set some breakpoints in your application's source code.

Finally from VsCode press Ctrl+Shift+D and select Application Debug and press F5.

Please note that Hot reload is only available in Renderer process.

Donating

Please consider donating to support the development of this project.

Monero

xmrQrCode
84Q1SdQgFWaEWRn5KcvSPCQUa3NF39EJ3HPCTaiM86RHLLftqgTZpkP24jXrK5YpeedWbQAjHcFcDLpFJfr9TypfAU7pPjA

Bitcoin

btcQrCode
bc1qndc2lesy0sse9vj33a35pnfrqz4znlhhs58vfp

Wownero

wowQrCode
WW33Zj3xu6EGTyKVWaz8EQZmqsTXKdK5eG7PDRaiPuJ1LyREhGHLCRDX3AaLx4r9NFCThRvsbq99KATbswJaxd3T1iwQLJ3Tw