2024-05-09 18:29:48 +07:00
|
|
|
# XMR Remote Nodes
|
|
|
|
|
2024-07-07 00:51:54 +07:00
|
|
|
[![Test](https://github.com/ditatompel/xmr-remote-nodes/actions/workflows/test.yml/badge.svg)](https://github.com/ditatompel/xmr-remote-nodes/actions/workflows/test.yml)
|
2024-06-10 23:44:01 +07:00
|
|
|
[![BUild](https://github.com/ditatompel/xmr-remote-nodes/actions/workflows/build.yml/badge.svg)](https://github.com/ditatompel/xmr-remote-nodes/actions/workflows/build.yml)
|
2024-06-11 14:53:15 +07:00
|
|
|
[![Release Binaries](https://github.com/ditatompel/xmr-remote-nodes/actions/workflows/release.yml/badge.svg)](https://github.com/ditatompel/xmr-remote-nodes/actions/workflows/release.yml)
|
2024-07-16 17:47:55 +07:00
|
|
|
[![Go Report Card](https://goreportcard.com/badge/github.com/ditatompel/xmr-remote-nodes)](https://goreportcard.com/report/github.com/ditatompel/xmr-remote-nodes)
|
2024-06-10 22:40:44 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
Source code of [https://xmr.ditatompel.com](https://xmr.ditatompel.com),
|
|
|
|
a website that helps you monitor your favourite Monero remote nodes.
|
2024-05-05 02:20:54 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
> :warning: :construction: This project is not mature enough :construction:,
|
2024-06-10 22:40:44 +07:00
|
|
|
> If you want to use it on your server, please use it with caution.
|
|
|
|
|
2024-05-31 18:24:45 +07:00
|
|
|
## How does it work?
|
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
Apart from CPU architecture type, you can build two types of binaries from
|
|
|
|
this project: a **server** and a **client**.
|
2024-05-31 18:24:45 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
The **clients** is used to fetch node information given by the server. First,
|
|
|
|
it will ask the server which node to fetch. Then, it will fetch the information
|
|
|
|
and report back to the server.
|
2024-05-31 18:24:45 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
The **server** serves an embedded Svelte static site for the Web UI. It also
|
|
|
|
serves the `/api` endpoint that is used by the clients and the Web UI itself.
|
2024-05-31 18:24:45 +07:00
|
|
|
|
2024-05-05 02:20:54 +07:00
|
|
|
## Requirements
|
|
|
|
|
2024-06-03 13:37:18 +07:00
|
|
|
To build the executable binaries, you need:
|
2024-05-17 17:40:22 +07:00
|
|
|
|
2024-05-28 10:03:29 +07:00
|
|
|
- Go >= 1.22
|
2024-06-03 13:37:18 +07:00
|
|
|
- NodeJS >= 20
|
|
|
|
|
|
|
|
### Server & Prober requirements
|
|
|
|
|
2024-05-30 12:02:11 +07:00
|
|
|
- Linux Machines (AMD64 or ARM64)
|
2024-05-17 17:40:22 +07:00
|
|
|
|
|
|
|
### Server requirements
|
|
|
|
|
2024-05-28 10:03:29 +07:00
|
|
|
- MySQL/MariaDB
|
2024-09-05 20:34:42 +07:00
|
|
|
- [GeoIP Database][geoip_doc] (optional). Place it to `./assets/geoip`,
|
|
|
|
see [./internal/geo/ip.go](./internal/geo/ip.go).
|
2024-05-05 02:20:54 +07:00
|
|
|
|
2024-05-06 19:59:43 +07:00
|
|
|
## Installation
|
2024-05-05 02:20:54 +07:00
|
|
|
|
2024-05-09 18:29:48 +07:00
|
|
|
### For initial server setup:
|
2024-05-06 19:59:43 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
1. Download [GeoIP Database][geoip_doc] and place it to `./assets/geoip`.
|
|
|
|
(see [./internal/geo/ip.go](./internal/geo/ip.go)).
|
2024-06-03 13:37:18 +07:00
|
|
|
2. Pepare your MySQL/MariaDB.
|
|
|
|
3. Copy `.env.example` to `.env` and edit it to match with server environment.
|
2024-09-05 20:34:42 +07:00
|
|
|
4. Build the binary with `make server` (or `make build` to build both
|
|
|
|
**server** and **client** binaries).
|
2024-06-03 13:37:18 +07:00
|
|
|
5. Run the service with `./bin/xmr-nodes-server-linux-<YOUR_CPU_ARCH> serve`.
|
2024-05-06 19:59:43 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
Systemd example: [xmr-nodes-server.service][server_systemd_service].
|
2024-05-06 21:45:33 +07:00
|
|
|
|
2024-05-09 18:29:48 +07:00
|
|
|
### For initial prober setup:
|
2024-05-06 21:45:33 +07:00
|
|
|
|
|
|
|
1. Create API key for prober
|
|
|
|
2. Copy `.env.example` to `.env` and edit it to match with prober environment.
|
2024-09-05 20:34:42 +07:00
|
|
|
3. Build the binary with `make client` (or `make build` to build both
|
|
|
|
**server** and **client** binaries).
|
2024-05-18 18:05:53 +07:00
|
|
|
4. Run the service with `./bin/xmr-nodes-client-linux-<YOUR_CPU_ARCH> probe`.
|
2024-05-06 21:45:33 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
Systemd example: [xmr-nodes-prober.service][prober_systemd_service] and
|
|
|
|
[xmr-nodes-prober.timer][prober_systemd_timer].
|
2024-05-31 18:24:45 +07:00
|
|
|
|
|
|
|
## Development and Deployment
|
|
|
|
|
|
|
|
See the [Makefile](./Makefile).
|
2024-06-10 21:32:01 +07:00
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
## ToDo's
|
|
|
|
|
|
|
|
- [] Accept IPv6 nodes.
|
|
|
|
- [] Use `a-h/templ` and `HTMX` instead of `Svelte`.
|
|
|
|
- [] Use Go standard `net/http` instead of `fiber`.
|
|
|
|
|
2024-06-10 21:32:01 +07:00
|
|
|
## Similar Projects
|
|
|
|
|
2024-09-05 20:34:42 +07:00
|
|
|
- [lalanza808/monero.fail][monerofail_gh]
|
|
|
|
- [cake-tech/upptime-monerocom][uptime_monerocom_gh]
|
2024-06-10 22:40:44 +07:00
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
This project is licensed under [GLWTPL](./LICENSE).
|
2024-09-05 20:34:42 +07:00
|
|
|
|
|
|
|
[geoip_doc]: https://dev.maxmind.com/geoip/geoip2/geolite2/ "GeoIP documentation"
|
|
|
|
[server_systemd_service]: ./deployment/init/xmr-nodes-server.service "systemd service example for server"
|
|
|
|
[prober_systemd_service]: ./deployment/init/xmr-nodes-prober.service "systemd service example for prober"
|
|
|
|
[prober_systemd_timer]: ./deployment/init/xmr-nodes-prober.timer "systemd timer example for prober"
|
|
|
|
[monerofail_gh]: https://github.com/lalanza808/monero.fail "Lalanza808's monero.fail GitHub repository"
|
|
|
|
[uptime_monerocom_gh]: https://github.com/cake-tech/upptime-monerocom "monero.com uptime GitHub repository"
|