Find a file
dependabot[bot] 6e99c9ef16
build(deps-dev): bump @skeletonlabs/skeleton in /frontend
Bumps [@skeletonlabs/skeleton](https://github.com/skeletonlabs/skeleton) from 2.10.2 to 2.10.3.
- [Release notes](https://github.com/skeletonlabs/skeleton/releases)
- [Commits](https://github.com/skeletonlabs/skeleton/compare/@skeletonlabs/skeleton@2.10.2...@skeletonlabs/skeleton@2.10.3)

---
updated-dependencies:
- dependency-name: "@skeletonlabs/skeleton"
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-10-28 11:48:29 +00:00
.github
cmd feat: Added node delete command 2024-09-16 23:29:15 +07:00
deployment
frontend build(deps-dev): bump @skeletonlabs/skeleton in /frontend 2024-10-28 11:48:29 +00:00
internal fix: Reject input hostname with protocol 2024-09-16 22:35:14 +07:00
.air.toml
.editorconfig
.env.example
.gitattributes
.gitignore
.golangci.yaml
go.mod build(deps): bump golang.org/x/net from 0.29.0 to 0.30.0 2024-10-07 05:16:42 +00:00
go.sum build(deps): bump golang.org/x/net from 0.29.0 to 0.30.0 2024-10-07 05:16:42 +00:00
LICENSE
main.go
Makefile
README.md
server.go
VERSION chore: Start v0.1.1 2024-09-16 23:51:25 +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
  • NodeJS >= 20

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

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.

Similar Projects

License

This project is licensed under GLWTPL.