Source code of https://xmr.ditatompel.com, a website that helps you monitor your favourite Monero remote nodes.
Find a file
Christian Ditaputratama b68f626ce2
refactor!: Use function method for routes
Will be useful for future development using standard `net/http`.
2024-11-06 22:15:53 +07:00
.github chore(ci): Temporary add htmx branch to test workflow 2024-11-03 16:26:52 +07:00
cmd feat: Added favicon 2024-10-31 18:55:31 +07:00
deployment chore: Rename tools directory to deployment 2024-05-30 12:02:11 +07:00
internal refactor!: Use function method for routes 2024-11-06 22:15:53 +07:00
utils feat: Convert DatabaseSize and Difficulty to human readable format 2024-11-06 17:34:41 +07:00
.air.toml feat!: templ + htmx build system 2024-10-29 20:41:22 +07:00
.editorconfig Copying my other project structure to this project 2024-05-04 00:11:56 +07:00
.env.example feat: Added permalink header 2024-11-06 18:00:25 +07:00
.gitattributes chore: Update .gitattributes Nginx cfg location 2024-06-23 22:29:11 +07:00
.gitignore feat!: templ + htmx build system 2024-10-29 20:41:22 +07:00
.golangci.yaml fix(lint): Deprecated linters.errcheck.ignore 2024-06-19 16:54:40 +07:00
bun.lockb feat: Added modal 2024-11-04 16:36:22 +07:00
go.mod feat: Added paging package 2024-10-31 22:44:20 +07:00
go.sum feat: Added paging package 2024-10-31 22:44:20 +07:00
LICENSE Switching to BSD-3-Clause license 2024-10-31 10:59:08 +07:00
main.go feat!: Change the module name to "URL based" 2024-07-07 01:28:44 +07:00
Makefile feat: Added clipboard functionality 2024-10-31 18:09:02 +07:00
package.json feat: Added modal 2024-11-04 16:36:22 +07:00
README.md chore: Moving Monero QR donation image location 2024-10-31 16:21:43 +07:00
server.go feat!: Change the module name to "URL based" 2024-07-07 01:28:44 +07:00
tailwind.config.js feat: Added modal 2024-11-04 16:36:22 +07:00
VERSION chore: Start v0.2.0 (HTMX) 2024-10-29 20:25:03 +07:00

XMR Remote Nodes

Test BUild Release Binaries Go Report Card

Source code of https://xmr.ditatompel.com, a website that helps you monitor your favourite Monero remote nodes.

⚠️ 🚧 This project is not mature enough 🚧, If you want to use it on your server, please use it with caution.

How does it work?

Apart from CPU architecture type, you can build two types of binaries from this project: a server and a client.

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.

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.

Requirements

To build the executable binaries, you need:

  • Go >= 1.22
  • Bun >= 1.1.26
  • templ v0.2.778

Note

:

  • If you want to contribute to the code, please use exact templ version (v0.2.778).
  • The UI is using Preline UI that uses [Lucide Icons][lucide-icons], use that for SVG icons.

Server & Prober requirements

  • Linux Machines (AMD64 or ARM64)

Server requirements

Installation

For initial server setup:

  1. Download GeoIP Database and place it to ./assets/geoip. (see ./internal/ip/geo/geoip.go).
  2. Pepare your MySQL/MariaDB.
  3. Copy .env.example to .env and edit it to match with server environment.
  4. Build the binary with make server (or make build to build both server and client binaries).
  5. Run the service with ./bin/xmr-nodes-server-linux-<YOUR_CPU_ARCH> serve.

Systemd example: xmr-nodes-server.service.

For initial prober setup:

  1. Create API key for prober
  2. Copy .env.example to .env and edit it to match with prober environment.
  3. Build the binary with make client (or make build to build both server and client binaries).
  4. Run the service with ./bin/xmr-nodes-client-linux-<YOUR_CPU_ARCH> probe.

Systemd example: xmr-nodes-prober.service and xmr-nodes-prober.timer.

Development and Deployment

  1. Clone or fork this repository.
  2. Prepare the assets: make prepare,
  3. Run air serve (live reload using air-verse/air).

See the Makefile.

ToDo's

  • Accept IPv6 nodes.
  • Use a-h/templ and HTMX instead of Svelte.
  • Use Go standard net/http instead of fiber.

Acknowledgement

The creators and contributors of these projects have provided valuable resources, which I am grateful for:

Similar Projects

Donation

The servers costs are currently covered by myself. If you find this project useful, please consider making a donation to help cover the ongoing expenses. Your contribution will go towards ensuring the continued availability of the website and my stagenet and testnet public remote nodes.

XMR Donation address:

8BWYe6GzbNKbxe3D8mPkfFMQA2rViaZJFhWShhZTjJCNG6EZHkXRZCKHiuKmwwe4DXDYF8KKcbGkvNYaiRG3sNt7JhnVp7D

Thank you!

License

This project is licensed under GLWTPL.