Compare commits

...

47 commits
v0.1.0 ... main

Author SHA1 Message Date
vdo
9bf2d794e7 tor from vdo1138 for arm64 support 2022-09-16 12:28:10 +01:00
vdo
a570800538 Bump version 2022-09-16 12:28:10 +01:00
vdo
8a741fe0e1 disable explorer, enable p2pool 2022-09-16 12:28:10 +01:00
vdo
3f8df06058 Bump versions, add p2pool step 2022-09-16 12:28:10 +01:00
vdo
290f00e2dc adding p2pool service 2022-09-16 12:28:10 +01:00
vdo
0b40c1521d Asciinema v0.3.3 2022-06-09 10:16:10 +01:00
vdo
8d003479f7 lws extra params 2022-06-09 09:41:14 +01:00
vdo
02fad44359 add monero-lws-admin wrapper command 2022-06-09 09:41:14 +01:00
vdo
821b8cf8a1 Version bump, README, lws url 2022-06-09 09:41:14 +01:00
vdo
f0f02adb81 add restart rules 2022-06-09 09:41:14 +01:00
vdo
7b4495d551 zmq params, exec order 2022-06-09 09:41:14 +01:00
vdo
1fd10d8cde add lws service 2022-06-09 09:41:14 +01:00
vdo
b58cf52373 log config, arm64 compatible images 2022-06-09 09:41:14 +01:00
vdo
dc0932b0c9 clean comments 2022-06-06 22:37:45 +01:00
vdo
ecd5f51fda version bump 2022-06-06 22:37:45 +01:00
vdo
83d4d41092 uninstall fixes 2022-06-06 22:37:45 +01:00
vdo
ddfa6e596a optional pruning 2022-06-06 22:37:45 +01:00
vdo
b5badfc96a
Asciicast link 2022-06-03 14:33:26 +01:00
vdo
cab282cc69 Update README 2022-06-03 14:30:50 +01:00
vdo
c372efafe6 Fix sed slash 2022-06-01 19:11:46 +01:00
vdo
b2ab5d2ab5 uninstall: clean excluding data 2022-06-01 19:11:46 +01:00
vdo
3c232d9672 Exit if present 2022-06-01 19:11:46 +01:00
vdo
f201e23b16 detect pipe 2022-06-01 19:11:46 +01:00
vdo
8d18119be2 uninstall, local volumes 2022-06-01 19:11:46 +01:00
vdo
6d3b92486e pass generation fix, bump 2022-06-01 12:04:52 +01:00
vdo
5f599d84ff update todo and readme 2022-06-01 11:15:42 +01:00
vdo
eb30c499be generate a safe grafana password 2022-06-01 11:15:42 +01:00
vdo
9c92b6eaa6 fix quantiles, bump versions 2022-06-01 11:15:42 +01:00
vdo
8dd1927677 update grafana and prometheus 2022-06-01 11:15:42 +01:00
vdo
fba7d4c8aa bump to v0.3.0 2022-06-01 11:15:42 +01:00
vdo
34db57fef0 split stripprefixes 2022-06-01 11:15:42 +01:00
vdo
4573e58e83 fix quantiles 2022-06-01 11:15:42 +01:00
vdo
9e364559b7 fix graphs, grafana compose 2022-06-01 11:15:42 +01:00
vdo
720974857d add grafana labels 2022-06-01 11:15:42 +01:00
vdo
1d641da19b Add network output 2022-06-01 11:15:42 +01:00
vdo
05fb2e83f3 Rename script, port and network select 2022-06-01 11:15:42 +01:00
vdo
7946a78e73
Merge pull request #1 from vdo/development
Development
2022-05-28 12:10:45 +01:00
vdo
ce1660eae3
Bump version 2022-05-28 09:54:01 +01:00
vdo
9b30144709
explorer PathPrefix, color reset 2022-05-27 17:25:29 +01:00
vdo
32104f3d4a
Color order 2022-05-27 14:33:47 +01:00
vdo
28299e1b51
add middleware for explorer path prefix 2022-05-27 14:14:54 +01:00
vdo
7e0523abd1
Fix path prefixes 2022-05-27 12:40:14 +01:00
vdo
2000149579
Update todo 2022-05-27 11:49:16 +01:00
vdo
d46b04c943
Configure cors, tor, explorer, watchtower 2022-05-27 11:43:08 +01:00
vdo
168c0bba97
Use anchors, TLS email check 2022-05-27 11:17:18 +01:00
vdo
fd6fde001c
TLS domain input 2022-05-26 19:56:33 +01:00
vdo
f56ead56ff
README checklist 2022-05-26 16:22:21 +01:00
21 changed files with 6367 additions and 391 deletions

29
.env
View file

@ -3,7 +3,34 @@ DOMAIN=your-domain.xmr.example
TRAEFIK_TAG=2.7
TRAEFIK_ACME_EMAIL=your-email@xmr.example
TRAEFIK_LOGLEVEL=DEBUG
TRAEFIK_TLS_PORT=443
TRAEFIK_HTTP_PORT=80
MONEROD_TAG=latest
MONEROD_RPC_PORT=18081
MONEROD_RESTRICTED_RPC_PORT=18089
MONEROD_P2P_PORT=18080
MONEROD_ZMQ_RPC_PORT=18082
MONEROD_ZMQ_PUB_PORT=18083
MONEROD_EXTRA_PARAMS=
MONEROD_accessControlAllowOriginList=*
THS_TAG=latest
LWS_TAG=v0.2_0.18
LWS_PORT=8000
LWS_EXTRA_PARAMS=
#TOR_TAG=latest
TOR_TAG=v0.4.7.8-57f8867
TOR_HTTP_PORT=80
EXPLORER_TAG=v0.18
EXPLORER_PORT=8081
P2POOL_WALLET=changeme
P2POOL_STRATUM_PORT=3333
P2POOL_P2P_PORT=37889
P2POOL_PEERS=65.21.227.114:37889,node.sethforprivacy.com:37889
GRAFANA_TAG=8.5.4
GF_SECURITY_ADMIN_PASSWORD=xmrsh-admin
PROMETHEUS_TAG=v2.36.0

View file

@ -1,19 +1,50 @@
# xmr.sh
A Monero node installer in a single command
**xmr.sh** script wizard sets up a new server running a monero node daemon with Docker compose, with your choice of SSL certificates for your domain, network selection, a Tor hidden service, Grafana dashboard and more.
Tested in:
## Distribution support
Compatible and tested on:
- Debian 11
- Ubuntu Focal
- Fedora 36
- CentOS 10 Stream
ToDo:
Other distributions with docker pre-installed would probably be compatible as well.
[ ] Add wizard for DNS domain selection.
[ ] Status and node info at finish.
[ ] Make tor service optional
[ ] Optional block explorer
[ ] Grafana with stats
[ ] Add monerod-proxy
## Demo
[![asciicast](https://asciinema.org/a/1gL7tNhb3XgPUr26losgZaeCJ.svg)](https://asciinema.org/a/1gL7tNhb3XgPUr26losgZaeCJ)
## FAQ
Check the [wiki](https://github.com/vdo/xmr.sh/wiki/FAQ)
## ToDo
- [x] Add wizard for DNS domain selection.
- [x] Status and node info at finish.
- [x] Mainnet / Stagenet / Testnet selection
- [x] Pruning enabled
- [x] Clearnet TLS port selection
- [x] Uninstall script
- [x] Make tor service optional
- [x] Block explorer (disabled)
- [x] Grafana dashboard
- [x] arm64 support for all images
- [x] monerod-lws support (experimental)
- [ ] Shellcheck via Github Actions
- [ ] Documentation
- [ ] monerod-proxy support for random node forwarding
- [ ] i2p service
- [ ] p2pool mining
# Credits
[@cirocosta](https://github.com/cirocosta) for the metrics exporter and grafana dashboard.
[@sethforprivacy](https://github.com/sethforprivacy) for providing and maintaining Monero Docker images.
# Donate XMR 🍕
86GwmtuKWtjJBWT8Srn4oqZHbP41k2kpG79xXKKgauJzCmZkFJ5ihwjVnRodVbVjAx64JeB7VyGbF6hEdwpcPcR7Go8x2YZ

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,29 @@
[analytics]
reporting_enabled = false
check_for_updates = false
[auth]
disable_login_form = false
; [auth.anonymous]
; enabled = true
; org_role = Admin
[dashboards]
min_refresh_interval = 1m
default_home_dashboard_path = /var/lib/grafana/dashboards/monero.json
[paths]
provisioning = /etc/grafana/provisioning
[server]
root_url = https://127.0.0.1/grafana
enable_gzip = true
read_timeout = 2m
[snapshots]
external_enabled = false
[security]
admin_user = admin
admin_password = xmrsh-admin

View file

@ -0,0 +1,12 @@
apiVersion: 1
providers:
- name: 'fs'
orgId: 1
folder: ''
type: 'file'
updateIntervalSeconds: 30
allowUiUpdates: true
options:
path: '/var/lib/grafana/dashboards'
foldersFromFilesStructure: true

View file

@ -0,0 +1,12 @@
apiVersion: 1
datasources:
- name: prometheus
type: prometheus
access: proxy
orgId: 1
url: http://prometheus:9090
isDefault: true
version: 1
editable: false
timeInterval: 30s

View file

@ -0,0 +1,8 @@
global:
scrape_interval: "10s"
evaluation_interval: "10s"
scrape_configs:
- job_name: "monerod"
static_configs:
- targets:
- "monero-exporter:9000"

4
data/grafana/.gitignore vendored Normal file
View file

@ -0,0 +1,4 @@
# Ignore everything in this directory
*
# Except this file
!.gitignore

4
data/letsencrypt/.gitignore vendored Normal file
View file

@ -0,0 +1,4 @@
# Ignore everything in this directory
*
# Except this file
!.gitignore

4
data/monero-lws/.gitignore vendored Normal file
View file

@ -0,0 +1,4 @@
# Ignore everything in this directory
*
# Except this file
!.gitignore

4
data/monero/.gitignore vendored Normal file
View file

@ -0,0 +1,4 @@
# Ignore everything in this directory
*
# Except this file
!.gitignore

4
data/prometheus/.gitignore vendored Normal file
View file

@ -0,0 +1,4 @@
# Ignore everything in this directory
*
# Except this file
!.gitignore

4
data/tor/.gitignore vendored Normal file
View file

@ -0,0 +1,4 @@
# Ignore everything in this directory
*
# Except this file
!.gitignore

View file

@ -1,59 +0,0 @@
version: "3.7"
services:
traefik:
image: traefik:${TRAEFIK_TAG}
container_name: traefik
ports:
- 80:80
- 443:443
volumes:
- "./letsencrypt:/letsencrypt"
- "/var/run/docker.sock:/var/run/docker.sock:ro"
command:
- "--log.level=${TRAEFIK_LOGLEVEL}"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
- "--entrypoints.web.address=:80"
- "--entrypoints.web.http.redirections.entryPoint.to=websecure"
- "--entrypoints.web.http.redirections.entryPoint.scheme=https"
- "--entrypoints.web.http.redirections.entrypoint.permanent=true"
- "--entrypoints.websecure.address=:443"
- "--certificatesresolvers.le.acme.httpchallenge=true"
- "--certificatesresolvers.le.acme.httpchallenge.entrypoint=web"
- "--certificatesresolvers.le.acme.email=${TRAEFIK_ACME_EMAIL}"
- "--certificatesresolvers.le.acme.storage=/letsencrypt/acme.json"
restart: always
monerod:
container_name: monerod
image: sethsimmons/simple-monerod:${MONEROD_TAG}
command: >-
--restricted-rpc --public-node --no-igd --no-zmq
--enable-dns-blocklist --rpc-restricted-bind-ip=0.0.0.0 --rpc-restricted-bind-port=18089 --confirm-external-bind
--prune-blockchain
ports:
- "18080:18080" # Exposes P2P port
- "18089"
volumes:
- "monerod-data:/home/monero/.bitmonero"
labels:
- "traefik.enable=true"
- "traefik.http.routers.monerod.rule=(Host(`${DOMAIN}`))"
- "traefik.http.routers.monerod.entrypoints=websecure"
- "traefik.http.routers.monerod.tls.certresolver=le"
- "traefik.http.routers.monerod.service=monerod"
- "traefik.http.services.monerod.loadbalancer.server.port=18089"
- "traefik.http.middlewares.corsheader.headers.accessControlAllowOriginList=*"
- "traefik.http.routers.monerod.middlewares=corsheader"
restart: unless-stopped
watchtower:
container_name: watchtower
image: containrrr/watchtower
volumes:
- /var/run/docker.sock:/var/run/docker.sock
labels:
- com.centurylinklabs.watchtower.enable="false"
command: --interval 360 --include-stopped
volumes:
monerod-data: {}

View file

@ -1,56 +0,0 @@
services:
traefik:
image: traefik:${TRAEFIK_TAG}
container_name: traefik
ports:
- 80:80
- 443:443
volumes:
- "./letsencrypt:/letsencrypt"
- "/var/run/docker.sock:/var/run/docker.sock:ro"
command:
- "--log.level=${TRAEFIK_LOGLEVEL}"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
- "--entrypoints.web.address=:80"
- "--entrypoints.web.http.redirections.entryPoint.to=websecure"
- "--entrypoints.web.http.redirections.entryPoint.scheme=https"
- "--entrypoints.web.http.redirections.entrypoint.permanent=true"
- "--entrypoints.websecure.address=:443"
restart: always
monerod:
container_name: monerod
image: sethsimmons/simple-monerod:${MONEROD_TAG}
command: >-
--restricted-rpc --public-node --no-igd --no-zmq
--enable-dns-blocklist --rpc-restricted-bind-ip=0.0.0.0 --rpc-restricted-bind-port=18089 --confirm-external-bind
--prune-blockchain
ports:
- "18080:18080" # Exposes P2P port
- "18089"
volumes:
- "monerod-data:/home/monero/.bitmonero"
labels:
- "traefik.enable=true"
- "traefik.http.routers.monerod.rule=(PathPrefix(`/`))"
- "traefik.http.routers.monerod.entrypoints=websecure"
- "traefik.http.routers.monerod.tls"
- "traefik.http.routers.monerod.service=monerod"
- "traefik.http.services.monerod.loadbalancer.server.port=18089"
- "traefik.http.middlewares.corsheader.headers.accessControlAllowOriginList=*"
- "traefik.http.routers.monerod.middlewares=corsheader"
restart: unless-stopped
watchtower:
image: containrrr/watchtower
volumes:
- /var/run/docker.sock:/var/run/docker.sock
labels:
- com.centurylinklabs.watchtower.enable="false"
command: --interval 360 --include-stopped
volumes:
monerod-data: {}
networks:
xmrsh:
name: xmrsh

View file

@ -1,26 +0,0 @@
version: "3.7"
services:
tor:
container_name: tor
image: goldy/tor-hidden-service:${THS_TAG}
links:
- monerod
environment:
MONEROD_TOR_SERVICE_HOSTS: "80:monerod:18089"
volumes:
- tor-keys:/var/lib/tor/hidden_service/
# secrets:
# - monerod
volumes:
tor-keys:
{}
# driver: local
# secrets:
# monerod:
# file: ./private_key_monerod_v3
networks:
default:
name: ${NETWORK:-xmrsh_default}

237
docker-compose.yml Normal file
View file

@ -0,0 +1,237 @@
version: "3.7"
x-log-config: &log-config
logging:
driver: json-file
options:
max-size: "50m"
max-file: "20"
x-traefik-command-le: &traefik-command-le
command:
- "--log.level=${TRAEFIK_LOGLEVEL}"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
- "--entrypoints.web.address=:${TRAEFIK_HTTP_PORT}"
- "--entrypoints.web.http.redirections.entryPoint.to=websecure"
- "--entrypoints.web.http.redirections.entryPoint.scheme=https"
- "--entrypoints.web.http.redirections.entrypoint.permanent=true"
- "--entrypoints.websecure.address=:${TRAEFIK_TLS_PORT}"
- "--certificatesresolvers.le.acme.httpchallenge=true"
- "--certificatesresolvers.le.acme.httpchallenge.entrypoint=web"
- "--certificatesresolvers.le.acme.email=${TRAEFIK_ACME_EMAIL}"
- "--certificatesresolvers.le.acme.storage=/letsencrypt/acme.json"
x-traefik-command-nole: &traefik-command-nole
command:
- "--log.level=${TRAEFIK_LOGLEVEL}"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
- "--entrypoints.web.address=:${TRAEFIK_HTTP_PORT}"
- "--entrypoints.web.http.redirections.entryPoint.to=websecure"
- "--entrypoints.web.http.redirections.entryPoint.scheme=https"
- "--entrypoints.web.http.redirections.entrypoint.permanent=true"
- "--entrypoints.websecure.address=:${TRAEFIK_TLS_PORT}"
x-monerod-command: &monerod-command
command: >-
--public-node --no-igd
--enable-dns-blocklist --rpc-restricted-bind-ip=0.0.0.0
--rpc-restricted-bind-port=${MONEROD_RESTRICTED_RPC_PORT} --confirm-external-bind
--zmq-pub tcp://0.0.0.0:${MONEROD_ZMQ_PUB_PORT} --zmq-rpc-bind-port=${MONEROD_ZMQ_RPC_PORT} --zmq-rpc-bind-ip=0.0.0.0
--rpc-bind-port=${MONEROD_RPC_PORT} --rpc-bind-ip=0.0.0.0
${MONEROD_EXTRA_PARAMS}
x-tor-service: &tor-service
tor:
container_name: tor
image: vdo1138/tor-hidden-service:${TOR_TAG}
restart: unless-stopped
links:
- monerod
environment:
MONEROD_TOR_SERVICE_HOSTS: "${TOR_HTTP_PORT}:monerod:${MONEROD_RESTRICTED_RPC_PORT}"
volumes:
- ./data/tor:/var/lib/tor/hidden_service/
<<: *log-config
x-explorer-service: &explorer-service
explorer:
image: vdo1138/xmrblocks:${EXPLORER_TAG}
container_name: explorer
restart: unless-stopped
volumes:
- ./data/monero:/home/monero/.bitmonero
ports:
- ${EXPLORER_PORT}
depends_on:
- monerod
labels:
- "traefik.enable=true"
- "traefik.http.routers.explorer.rule=(PathPrefix(`/explorer`) )" #!nole
# - "traefik.http.routers.explorer.rule=(Host(`${DOMAIN}`) && PathPrefix(`/explorer`) )" #!le
# - "traefik.http.routers.explorer.tls.certresolver=le" #!le
- "traefik.http.middlewares.stripprefix-explorer.stripprefix.prefixes=/explorer"
- "traefik.http.routers.explorer.middlewares=stripprefix-explorer"
- "traefik.http.routers.explorer.entrypoints=websecure"
- "traefik.http.routers.explorer.tls"
- "traefik.http.routers.explorer.service=explorer"
- "traefik.http.services.explorer.loadbalancer.server.port=${EXPLORER_PORT}"
<<: *log-config
x-monero-lws-service: &monero-lws-service
monero-lws:
image: vdo1138/monero-lws:${LWS_TAG}
container_name: monero-lws
restart: unless-stopped
security_opt:
- "no-new-privileges:true"
command: >-
--rest-server http://0.0.0.0:8000 --daemon=tcp://monerod:${MONEROD_ZMQ_RPC_PORT}
--sub=tcp://monerod:${MONEROD_ZMQ_PUB_PORT} --log-level=4
--confirm-external-bind ${LWS_EXTRA_PARAMS}
volumes:
- ./data/monero-lws:/home/monero-lws/.bitmonero/
depends_on:
- monerod
labels:
- "traefik.enable=true"
- "traefik.http.routers.monero-lws.rule=(PathPrefix(`/lws`) )" #!nole
# - "traefik.http.routers.monero-lws.rule=(Host(`${DOMAIN}`) && PathPrefix(`/lws`) )" #!le
# - "traefik.http.routers.monero-lws.tls.certresolver=le" #!le
- "traefik.http.middlewares.stripprefix-monero-lws.stripprefix.prefixes=/lws"
- "traefik.http.routers.monero-lws.middlewares=stripprefix-monero-lws"
- "traefik.http.routers.monero-lws.entrypoints=websecure"
- "traefik.http.routers.monero-lws.tls"
- "traefik.http.routers.monero-lws.service=monero-lws"
- "traefik.http.services.monero-lws.loadbalancer.server.port=${LWS_PORT}"
<<: *log-config
x-monero-exporter-service: &monero-exporter-service
monero-exporter:
command:
- --monero-addr=http://monerod:${MONEROD_RPC_PORT}
container_name: monero-exporter
restart: unless-stopped
image: vdo1138/monero-exporter:0.0.2
<<: *log-config
x-p2pool-service: &p2pool-service
p2pool:
image: sethsimmons/p2pool:latest
restart: unless-stopped
container_name: p2pool
#tty: true
#stdin_open: true
volumes:
- ./data/p2pool:/home/p2pool
# - /dev/hugepages:/dev/hugepages:rw
ports:
- ${P2POOL_STRATUM_PORT}:${P2POOL_STRATUM_PORT}
- ${P2POOL_P2P_PORT}:${P2POOL_P2P_PORT}
command: >-
--wallet "${P2POOL_WALLET}"
--stratum "0.0.0.0:${P2POOL_STRATUM_PORT}" --p2p "0.0.0.0:${P2POOL_P2P_PORT}" --rpc-port "${MONEROD_RPC_PORT}"
--addpeers "P2POOL_PEERS" --host "monerod" --no-randomx
x-grafana-service: &grafana-service
grafana:
user: "1000"
command:
- -config=/etc/grafana/grafana.ini
container_name: grafana
restart: unless-stopped
image: grafana/grafana:${GRAFANA_TAG}
ports:
- 3000
volumes:
- ./data/grafana:/var/lib/grafana
- ./config/grafana/grafana.ini:/etc/grafana/grafana.ini:ro
- ./config/grafana/provisioning:/etc/grafana/provisioning:ro
- ./config/grafana/dashboards:/var/lib/grafana/dashboards:ro
environment:
GF_SECURITY_ADMIN_PASSWORD: ${GF_SECURITY_ADMIN_PASSWORD}
labels:
- "traefik.enable=true"
- "traefik.http.routers.grafana.rule=(PathPrefix(`/grafana`) )" #!nole
# - "traefik.http.routers.grafana.rule=(Host(`${DOMAIN}`) && PathPrefix(`/grafana`) )" #!le
# - "traefik.http.routers.grafana.tls.certresolver=le" #!le
- "traefik.http.middlewares.stripprefix-grafana.stripprefix.prefixes=/grafana"
- "traefik.http.routers.grafana.middlewares=stripprefix-grafana"
- "traefik.http.routers.grafana.entrypoints=websecure"
- "traefik.http.routers.grafana.tls"
- "traefik.http.routers.grafana.service=grafana"
- "traefik.http.services.grafana.loadbalancer.server.port=3000"
<<: *log-config
x-prometheus-service: &prometheus-service
prometheus:
user: "1000"
command:
- --config.file=/etc/prometheus/config.yaml
- --storage.tsdb.path=/data
- --storage.tsdb.retention.time=30d
container_name: prometheus
restart: unless-stopped
image: prom/prometheus:${PROMETHEUS_TAG}
volumes:
- ./data/prometheus:/data
- ./config/prometheus/config.yaml:/etc/prometheus/config.yaml:ro
<<: *log-config
x-watchtower-service: &watchtower-service
watchtower:
container_name: watchtower
restart: unless-stopped
image: containrrr/watchtower:latest
volumes:
- /var/run/docker.sock:/var/run/docker.sock
labels:
- com.centurylinklabs.watchtower.enable="false"
command: --interval 360 --include-stopped
<<: *log-config
services:
traefik:
image: traefik:${TRAEFIK_TAG}
container_name: traefik
ports:
- ${TRAEFIK_HTTP_PORT}:${TRAEFIK_HTTP_PORT}
- ${TRAEFIK_TLS_PORT}:${TRAEFIK_TLS_PORT}
volumes:
- "./data/letsencrypt:/letsencrypt" #!le
- "/var/run/docker.sock:/var/run/docker.sock:ro"
<<: *traefik-command-nole #!traefik-command
restart: always
<<: *log-config
monerod:
container_name: monerod
image: sethsimmons/simple-monerod:${MONEROD_TAG}
<<: *monerod-command
ports:
- "${MONEROD_P2P_PORT}:${MONEROD_P2P_PORT}" # Exposes P2P port
volumes:
- "./data/monero:/home/monero/.bitmonero"
labels:
- "traefik.enable=true"
# - "traefik.http.routers.monerod.rule=(Host(`${DOMAIN}`) && PathPrefix(`/`))" #!le
# - "traefik.http.routers.monerod.tls.certresolver=le" #!le
- "traefik.http.routers.monerod.rule=(PathPrefix(`/`))" #!nole
- "traefik.http.routers.monerod.entrypoints=websecure"
- "traefik.http.routers.monerod.tls"
- "traefik.http.routers.monerod.service=monerod"
- "traefik.http.services.monerod.loadbalancer.server.port=${MONEROD_RESTRICTED_RPC_PORT}"
# - "traefik.http.middlewares.corsheader.headers.accessControlAllowOriginList=${MONEROD_accessControlAllowOriginList}" #!cors
# - "traefik.http.routers.monerod.middlewares=corsheader" #!cors
restart: unless-stopped
<<: *log-config
# <<: *tor-service #!tor
# <<: *explorer-service #!explorer
# <<: *monero-lws-service #!lws
# <<: *monero-exporter-service #!monero-exporter
# <<: *p2pool-service #!p2pool
# <<: *grafana-service #!grafana
# <<: *prometheus-service #!prometheus
# <<: *watchtower-service #!watchtower

480
install Executable file
View file

@ -0,0 +1,480 @@
#!/bin/bash
################################################################
# Colors #
################################################################
# Reset
Off='\033[0m' # Text Reset
# Regular Colors
Red='\033[0;31m' # Red
Green='\033[0;32m' # Green
Yellow='\033[0;33m' # Yellow
Purple='\033[0;35m' # Purple
White='\033[0;37m' # White
# Background
On_Black='\033[40m' # Black
OkBullet="${Green}${On_Black}:: ${White}${On_Black}"
WarnBullet="${Yellow}${On_Black}:: ${White}${On_Black}"
ErrBullet="${Red}${On_Black}:: ${White}${On_Black}"
Ok="${Green}${On_Black} ok.${Off}"
Fail="${Red}${On_Black} failed!${Off}"
Nok="${Yellow}${On_Black} nok.${Off}"
Stat="${Purple}${On_Black}"
StatInfo="${White}${On_Black}"
################################################################
# Vars #
################################################################
VERSION="v0.4.0"
XMRSH_INSTALL_CMD="sudo bash -c \"\$(curl -sLSf https://get.xmr.sh)\""
XMRSH_DIR="/opt/xmr.sh"
XMRSH_BRANCH="main"
XMRSH_URL="https://github.com/vdo/xmr.sh"
XMRSH_LOG_FILE="/tmp/xmr.sh-$(date +%Y%m%d-%H%M%S).log"
DOCKER_INSTALLED=false
DOCKER_COMPOSE_INSTALLED=false
DOCKER_COMPOSE_VERSION="v2.5.0"
DEPENDENCIES="git curl"
ONION="Not Available"
TLS_PORT="443"
TLS_DOMAIN=""
TLS_EMAIL=""
NETWORK="mainnet"
ENABLE_GRAFANA=""
################################################################
# Functions #
################################################################
header() {
echo -e "${Red}${On_Black} _ "
echo -e "__ ___ __ ___ _ __ ___| |__ "
echo -e "\ \/ / '_ ' _ \| '__/ __| '_ \ "
echo -e " > <| | | | | | | _\__ \ | | |"
echo -e "/_/\_\_| |_| |_|_|(_)___/_| |_|"
echo -e " Version ${VERSION}${Off}\n"
}
detect_root() {
echo -ne "${OkBullet}Checking root... ${Off}"
if [[ $EUID -ne 0 ]]; then
echo -e "${Fail}"
echo -e "${ErrBullet}You need to run this script as root (UID=0).${Off}"
exit 1
fi
echo -e "${Ok}"
}
detect_pipe() {
echo -ne "${OkBullet}Checking script execution... ${Off}"
if [ -p /dev/stdin ]; then
echo -e "${Fail}"
echo -e "${ErrBullet}This script can't be piped! Instead, use the command: ${XMRSH_INSTALL_CMD}${Off}"
exit 1
fi
echo -e "${Ok}"
}
check_deps() {
echo -ne "${OkBullet}Checking and installing dependencies... ${Off}"
# shellcheck disable=SC2068
for pkg in ${DEPENDENCIES[@]}; do
if ! command -v "${pkg}" >>"${XMRSH_LOG_FILE}" 2>&1; then
install_pkg "${pkg}"
check_return $?
fi
done
echo -e "${Ok}"
}
install_pkg() {
# This detects both ubuntu and debian
if grep -q "debian" /etc/os-release; then
apt-get update >>"${XMRSH_LOG_FILE}" 2>&1
apt-get install -y "$1" >>"${XMRSH_LOG_FILE}" 2>&1
elif grep -q "fedora" /etc/os-release || grep -q "centos" /etc/os-release; then
dnf install -y "$1" >>"${XMRSH_LOG_FILE}" 2>&1
else
echo -e "${ErrBullet}Cannot detect your distribution package manager.${Off}"
exit 1
fi
}
detect_curl() {
echo -ne "${OkBullet}Checking curl... ${Off}"
# docker --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker version"
if curl --version >>"${XMRSH_LOG_FILE}" 2>&1; then
echo -e "${Ok}"
else
echo -e "${Nok}"
echo -e "${ErrBullet}Please install curl first.${Off}"
exit 1
fi
}
detect_docker() {
echo -ne "${OkBullet}Checking docker... ${Off}"
if docker --version >>"${XMRSH_LOG_FILE}" 2>&1; then
DOCKER_INSTALLED=true
echo -e "${Ok}"
else
echo -e "${Nok}"
fi
}
detect_docker_compose() {
echo -ne "${OkBullet}Checking docker compose... ${Off}"
if docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1; then
DOCKER_COMPOSE_INSTALLED=true
echo -e "${Ok}"
else
echo -e "${Nok}"
fi
}
install_docker() {
echo -ne "${OkBullet}Installing docker... ${Off}"
# Docker Installer as provided in
curl -fsSL https://get.docker.com -o - | bash >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
# Fedora and Centos need to enable & start the daemon
if grep -q "fedora" /etc/os-release || grep -q "centos" /etc/os-release; then
systemctl enable docker >>"${XMRSH_LOG_FILE}" 2>&1
systemctl start docker >>"${XMRSH_LOG_FILE}" 2>&1
fi
echo -e "${Ok}"
}
install_docker_compose() {
echo -ne "${OkBullet}Installing compose... ${Off}"
# Install docker-compose binary, even if "docker compose" exists, for consistency.
curl -SL "https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-linux-$(uname -m)" -o /usr/local/bin/docker-compose >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
chmod +x /usr/local/bin/docker-compose >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
echo -e "${Ok}"
}
install_xmrsh() {
echo -ne "${OkBullet}Installing xmr.sh... ${Off}"
if [ ! -d "$XMRSH_DIR" ]; then
git clone -b "${XMRSH_BRANCH}" "${XMRSH_URL}" "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
pushd "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1 || return
chown -R "1000:1000" ./data >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
else
echo -e "${Ok}"
echo -e "${ErrBullet}Error: xmr.sh already present in ${XMRSH_DIR}. Run the uninstall script first."
exit 1
fi
echo -e "${Ok}"
}
configure_network() {
echo -e "${OkBullet}Select the desired node network (mainnet, testnet, stagenet)"
PS3=":: Enter a number: "
options=("mainnet" "testnet" "stagenet")
select opt in "${options[@]}"; do
case $opt in
"mainnet")
break
;;
"testnet")
NETWORK="testnet"
sed -i "s/MONEROD_P2P_PORT=.*/MONEROD_P2P_PORT=28080/g" .env
sed -i "/MONEROD_EXTRA_PARAMS/s/$/ --testnet/g" .env
sed -i "/LWS_EXTRA_PARAMS/s/$/ --network test/g" .env
break
;;
"stagenet")
NETWORK="stagenet"
sed -i "s/MONEROD_P2P_PORT=.*/MONEROD_P2P_PORT=38080/g" .env
sed -i "/MONEROD_EXTRA_PARAMS/s/$/ --stagenet/g" .env
sed -i "/LWS_EXTRA_PARAMS/s/$/ --network stage/g" .env
break
;;
*) echo "Invalid network choice!" ;;
esac
done
}
configure_tls_domain() {
echo -e "${OkBullet}Enter the desired domain for the Let's Encrypt SSL certificate."
read -r -e -p " Leave empty to use a self signed certificate []: " TLS_DOMAIN
if [ -n "${TLS_DOMAIN}" ]; then
while ! echo "${TLS_DOMAIN}" | grep -qP '(?=^.{5,254}$)(^(?:(?!\d+\.)[a-zA-Z0-9_\-]{1,63}\.?)+(?:[a-zA-Z]{2,})$)'; do
echo -e "${WarnBullet}Domain not valid."
read -r -p " Enter again your desired domain []: " TLS_DOMAIN
done
echo -e "${OkBullet}Enter the desired email for the Let's Encrypt SSL certificate."
read -r -e -p " Enter a valid email. Let's Encrypt validates it! []: " TLS_EMAIL
while ! echo "${TLS_EMAIL}" | grep -qP '^[A-Za-z0-9+._-]+@([a-zA-Z0-9-]+\.)+[a-zA-Z]{2,6}$'; do
echo -e "${WarnBullet}Email not valid."
read -r -p " Enter again your desired email []: " TLS_EMAIL
done
# Set domain and email address in vars
sed -i "s/DOMAIN=.*/DOMAIN=${TLS_DOMAIN}/g" .env
sed -i "s/TRAEFIK_ACME_EMAIL=.*/TRAEFIK_ACME_EMAIL=${TLS_EMAIL}/g" .env
# Enable Let's Encrypt settings in compose
sed -i '/#!le/s/# //g' docker-compose.yml
sed -i '/#!nole/s/- /# - /g' docker-compose.yml
sed -i "/#\!traefik-command/s/\*traefik-command-nole/\*traefik-command-le/g" docker-compose.yml
fi
}
configure_tls_port() {
echo -e "${OkBullet}Enter the desired TLS/HTTPS port."
read -r -e -p " Leave empty to use the default [443]: " TLS_PORT
if [ -n "${TLS_PORT}" ]; then
while ! echo "${TLS_PORT}" | grep -qP '^([1-9][0-9]{0,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$'; do
echo -e "${WarnBullet}Port not valid."
read -r -p " Enter again your desired port: " TLS_PORT
done
# Set port in vars
sed -i "s/TRAEFIK_TLS_PORT=.*/TRAEFIK_TLS_PORT=${TLS_PORT}/g" .env
else
TLS_PORT="443"
fi
}
configure_pruning() {
echo -e "${OkBullet}Configuring pruning..."
while true; do
read -r -e -p " Do you want to enable blockchain pruning? [y/n]: " yn
case $yn in
[Yy]*)
sed -i "/MONEROD_EXTRA_PARAMS/s/$/ --prune-blockchain/g" .env
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_cors() {
echo -e "${OkBullet}Configuring CORS..."
while true; do
read -r -e -p " Do you want to enable CORS headers so the node can be used in web apps? [y/n]: " yn
case $yn in
[Yy]*)
sed -i '/#!cors/s/# //g' docker-compose.yml
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_tor() {
echo -e "${OkBullet}Configuring tor..."
while true; do
read -r -e -p " Do you want to enable a Tor hidden service? [y/n]: " yn
case $yn in
[Yy]*)
sed -i '/#!tor/s/# //g' docker-compose.yml
ENABLE_TOR=true
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_explorer() {
echo -e "${OkBullet}Configuring explorer..."
while true; do
read -r -e -p " Do you want to enable an explorer service? [y/n]: " yn
case $yn in
[Yy]*)
sed -i '/#!explorer/s/# //g' docker-compose.yml
ENABLE_EXPLORER=true
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_lws() {
echo -e "${OkBullet}Configuring LWS..."
while true; do
read -r -e -p " Do you want to enable the light wallet service (experimental)? [y/n]: " yn
case $yn in
[Yy]*)
sed -i '/#!lws/s/# //g' docker-compose.yml
ENABLE_LWS=true
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_p2pool() {
echo -e "${OkBullet}Configuring p2pool..."
while true; do
read -r -e -p " Do you want to enable the p2pool service? [y/n]: " yn
case $yn in
[Yy]*)
read -r -e -p " Enter the desired primary address which will recieve the rewards. []: " P2P_ADDRESS
while ! echo "${P2P_ADDRESS}" | grep -qP '(4|5|9|A)[a-zA-Z|\d]{94}'; do
echo -e "${WarnBullet}Address is not valid. Remember: subaddresses are not supported by p2pool."
read -r -p " Enter again your primary address: " P2P_ADDRESS
done
sed -i "s/P2POOL_WALLET=.*/P2POOL_WALLET=${P2P_ADDRESS}/g" .env
sed -i '/#!p2pool/s/# //g' docker-compose.yml
ENABLE_P2POOL=true
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_grafana() {
echo -e "${OkBullet}Configuring grafana..."
while true; do
read -r -e -p " Do you want to enable a grafana monitoring dashboard? [y/n]: " yn
case $yn in
[Yy]*)
ENABLE_GRAFANA=true
sed -i '/#!monero-exporter/s/# //g' docker-compose.yml
sed -i '/#!grafana/s/# //g' docker-compose.yml
sed -i '/#!prometheus/s/# //g' docker-compose.yml
GRAFANA_PASSWORD="$(openssl rand -base64 9 | tr '\/' '-')"
sed -i "s/GF_SECURITY_ADMIN_PASSWORD=.*/GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_PASSWORD}/g" .env
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
configure_watchtower() {
echo -e "${OkBullet}Configuring watchtower..."
while true; do
read -r -e -p " Do you want to enable automatic node updates using watchtower? [y/n]: " yn
case $yn in
[Yy]*)
sed -i '/#!watchtower/s/# //g' docker-compose.yml
break
;;
[Nn]*) break ;;
*) echo " Please answer yes or no." ;;
esac
done
}
# get_public_ip() {
# # Using dig:
# # dig +short txt ch whoami.cloudflare @1.0.0.1
# PUBLIC_IP=$(curl -s ifconfig.co)
# }
start_xmrsh() {
echo -ne "${OkBullet}Starting monero node and services... ${Off}"
docker-compose pull >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
docker-compose up -d >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
if [[ $ENABLE_TOR == true ]]; then
sleep 4
ONION=$(docker logs tor 2>&1 | grep Entrypoint | cut -d " " -f 8)
fi
echo -e "${Ok}"
}
check_return() {
if [ "$1" -ne 0 ]; then
echo -e "${Fail}"
echo -e "${ErrBullet}Installation failed. Check the logs in ${XMRSH_LOG_FILE}${Off}"
exit "$1"
fi
}
completed() {
echo -e "${OkBullet}Deployment complete.${Off}"
PUBLIC_IP=$(curl -4 -s ifconfig.co 2>>"${XMRSH_LOG_FILE}")
if [ -n "$TLS_DOMAIN" ]; then
HOST="${TLS_DOMAIN}"
else
HOST="${PUBLIC_IP}"
fi
if [[ $TLS_PORT == "443" ]]; then
PORT_SUFF=""
else
PORT_SUFF=":${TLS_PORT}"
fi
echo
echo -e " ${Red}┌───────────────────────────────────────────────────────────────────────────[info]──"
echo -e " ${Red}│${Stat} Network: ${StatInfo}${NETWORK}"
echo -e " ${Red}│${Stat} Public URL: ${StatInfo}https://${HOST}${PORT_SUFF}"
echo -e " ${Red}│${Stat} Public IP: ${StatInfo}${PUBLIC_IP}"
if [ "$ENABLE_TOR" = true ]; then
echo -e " ${Red}│${Stat} Onion Service: ${StatInfo}$ONION"
fi
if [ "$ENABLE_EXPLORER" = true ]; then
echo -e " ${Red}│${Stat} Explorer URL: ${StatInfo}https://${HOST}${PORT_SUFF}/explorer"
fi
if [ "$ENABLE_LWS" = true ]; then
echo -e " ${Red}│${Stat} LWS URL: ${StatInfo}https://${HOST}${PORT_SUFF}/lws"
fi
if [ "$ENABLE_P2POOL" = true ]; then
echo -e " ${Red}│${Stat} P2Pool stratum: ${StatInfo}${HOST}:3333"
fi
if [ "$ENABLE_GRAFANA" = true ]; then
echo -e " ${Red}│${Stat} Grafana URL: ${StatInfo}https://${HOST}${PORT_SUFF}/grafana"
echo -e " ${Red}│${Stat} Grafana user: ${StatInfo}admin"
echo -e " ${Red}│${Stat} Grafana password: ${StatInfo}${GRAFANA_PASSWORD}"
fi
echo -e " ${Red}│${Stat} Project files installed in: ${StatInfo}${XMRSH_DIR}"
echo -e " ${Red}│${Off}"
echo
}
header
detect_root
detect_pipe
check_deps
detect_docker
detect_docker_compose
if [ $DOCKER_INSTALLED = false ]; then
install_docker
install_docker_compose
fi
if [ $DOCKER_INSTALLED = true ] && [ $DOCKER_COMPOSE_INSTALLED = false ]; then
install_docker_compose
fi
install_xmrsh
configure_network
configure_tls_domain
configure_tls_port
configure_pruning
configure_cors
configure_tor
configure_lws
configure_p2pool
# Deployment of explorer disabled until it's stable.
# configure_explorer
configure_grafana
configure_watchtower
start_xmrsh
completed
exit 0

View file

@ -1,239 +0,0 @@
#!/bin/bash
################################################################
# Color Aliases #
################################################################
# Reset
Off='\033[0m' # Text Reset
# Regular Colors
Black='\033[0;30m' # Black
Red='\033[0;31m' # Red
Green='\033[0;32m' # Green
Yellow='\033[0;33m' # Yellow
Blue='\033[0;34m' # Blue
Purple='\033[0;35m' # Purple
Cyan='\033[0;36m' # Cyan
White='\033[0;37m' # White
# Bold
BBlack='\033[1;30m' # Black
BRed='\033[1;31m' # Red
BGreen='\033[1;32m' # Green
BYellow='\033[1;33m' # Yellow
BBlue='\033[1;34m' # Blue
BPurple='\033[1;35m' # Purple
BCyan='\033[1;36m' # Cyan
BWhite='\033[1;37m' # White
# Underline
UBlack='\033[4;30m' # Black
URed='\033[4;31m' # Red
UGreen='\033[4;32m' # Green
UYellow='\033[4;33m' # Yellow
UBlue='\033[4;34m' # Blue
UPurple='\033[4;35m' # Purple
UCyan='\033[4;36m' # Cyan
UWhite='\033[4;37m' # White
# Background
On_Black='\033[40m' # Black
On_Red='\033[41m' # Red
On_Green='\033[42m' # Green
On_Yellow='\033[43m' # Yellow
On_Blue='\033[44m' # Blue
On_Purple='\033[45m' # Purple
On_Cyan='\033[46m' # Cyan
On_White='\033[47m' # White
OkBullet="${OnBlack}${Green}:: ${White}"
WarnBullet="${OnBlack}${Yellow}:: ${White}"
ErrBullet="${OnBlack}${Red}:: ${White}"
Ok="${OnBlack}${Green} ok.${Off}"
Fail="${OnBlack}${Red} failed!${Off}"
Nok="${OnBlack}${Yellow} nok.${Off}"
################################################################
# Vars #
################################################################
VERSION="v0.1.0"
XMRSH_DIR="/opt/xmr.sh"
XMRSH_LOG_FILE="/tmp/xmr.sh-$(date +%Y%m%d-%H%M%S).log"
DOCKER_INSTALLED=false
DOCKER_COMPOSE_INSTALLED=false
DOCKER_COMPOSE_VERSION="v2.5.0"
DEPENDENCIES="git curl"
################################################################
# Functions #
################################################################
header() {
echo -e "${OnBlack}${Red} _ "
echo -e "__ ___ __ ___ _ __ ___| |__ "
echo -e "\ \/ / '_ ' _ \| '__/ __| '_ \ "
echo -e " > <| | | | | | | _\__ \ | | |"
echo -e "/_/\_\_| |_| |_|_|(_)___/_| |_|"
echo -e " Version ${VERSION}${Off}\n"
}
detect_root() {
echo -ne "${OkBullet}Checking root... ${Off}"
if [[ $EUID -ne 0 ]]; then
echo -e "${Fail}"
echo -e "${ErrBullet}You need to run this script as root (UID=0).${Off}"
exit 1
fi
echo -e "${Ok}"
}
check_deps() {
echo -ne "${OkBullet}Checking and installing dependencies... ${Off}"
for pkg in ${DEPENDENCIES[@]}; do
if ! which ${pkg} >>"${XMRSH_LOG_FILE}" 2>&1; then
install_pkg ${pkg}
check_return $?
fi
done
echo -e "${Ok}"
}
install_pkg() {
# This detects both ubuntu and debian
if grep -q "debian" /etc/os-release; then
apt-get update >>"${XMRSH_LOG_FILE}" 2>&1
apt-get install -y $1 >>"${XMRSH_LOG_FILE}" 2>&1
elif grep -q "fedora" /etc/os-release || grep -q "centos" /etc/os-release; then
dnf install -y $1 >>"${XMRSH_LOG_FILE}" 2>&1
else
echo -e "${ErrBullet}Cannot detect your distribution package manager.${Off}"
exit 1
fi
}
detect_curl() {
echo -ne "${OkBullet}Checking curl... ${Off}"
# docker --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker version"
if curl --version >>"${XMRSH_LOG_FILE}" 2>&1; then
echo -e "${Ok}"
else
echo -e "${Nok}"
echo -e "${ErrBullet}Please install curl first.${Off}"
exit 1
fi
}
detect_docker() {
echo -ne "${OkBullet}Checking docker... ${Off}"
# docker --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker version"
if docker --version >>"${XMRSH_LOG_FILE}" 2>&1; then
DOCKER_INSTALLED=true
echo -e "${Ok}"
else
echo -e "${Nok}"
fi
}
detect_docker_compose() {
echo -ne "${OkBullet}Checking docker compose... ${Off}"
#docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker Compose version"
if docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1; then
DOCKER_COMPOSE_INSTALLED=true
echo -e "${Ok}"
else
echo -e "${Nok}"
fi
}
install_docker() { (
echo -ne "${OkBullet}Installing docker... ${Off}"
# Docker Installer as provided in
curl -fsSL https://get.docker.com -o - | bash >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
# Fedora and Centos need to enable & start the daemon
if grep -q "fedora" /etc/os-release || grep -q "centos" /etc/os-release; then
systemctl enable docker >>"${XMRSH_LOG_FILE}" 2>&1
systemctl start docker >>"${XMRSH_LOG_FILE}" 2>&1
fi
echo -e "${Ok}"
); }
install_docker_compose() {
echo -ne "${OkBullet}Installing compose... ${Off}"
# Install docker-compose binary, even if "docker compose" exists, for consistency.
curl -SL "https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-linux-$(uname -m)" -o /usr/local/bin/docker-compose >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
chmod +x /usr/local/bin/docker-compose >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
echo -e "${Ok}"
}
install_xmrsh() {
echo -ne "${OkBullet}Installing xmr.sh... ${Off}"
if [ ! -d "$XMRSH_DIR" ]; then
git clone https://github.com/vdo/xmr.sh "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
else
echo -e "${Ok}"
echo -e "${WarnBullet}Warning: xmr.sh already present in ${XMRSH_DIR}"
return
fi
echo -e "${Ok}"
}
start_xmrsh() {
pushd "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1
cp docker-compose.nole.yml docker-compose.yml ## FIXME: Temporal deploy w/o Let's Encrypt
echo -ne "${OkBullet}Starting monero node... ${Off}"
docker-compose pull >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
docker-compose up -d >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
echo -e "${Ok}"
}
start_xmrsh_tor() {
pushd "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1
echo -ne "${OkBullet}Starting tor hidden service... ${Off}"
docker-compose -f docker-compose.yml -f docker-compose.tor.yml up -d >>"${XMRSH_LOG_FILE}" 2>&1
check_return $?
sleep 3
ONION=$(docker logs tor 2>&1 | grep Entrypoint | cut -d " " -f 8)
echo -e "${Ok}"
echo -e "${OkBullet}Tor hidden service ready at: ${ONION} ${Off}"
}
check_return() {
if [ $1 -ne 0 ]; then
echo -e "${Fail}"
echo -e "${ErrBullet}Installation failed. Check the logs in ${XMRSH_LOG_FILE}${Off}"
exit "$1"
fi
}
completed() {
# FIXME: Show domain / public IP
echo -e "${OkBullet}Deployment complete!!${Off}"
}
header
detect_root
check_deps
detect_docker
detect_docker_compose
if [ $DOCKER_INSTALLED = false ]; then
install_docker
install_docker_compose
fi
if [ $DOCKER_INSTALLED = true ] && [ $DOCKER_COMPOSE_INSTALLED = false ]; then
install_docker_compose
fi
install_xmrsh
start_xmrsh
start_xmrsh_tor
completed
exit 0

2
monero-lws-admin Executable file
View file

@ -0,0 +1,2 @@
#!/bin/bash
docker exec -ti monero-lws /usr/local/bin/monero-lws-admin ${@}

86
uninstall Executable file
View file

@ -0,0 +1,86 @@
#!/bin/bash
################################################################
# Colors #
################################################################
# Reset
Off='\033[0m' # Text Reset
# Regular Colors
Red='\033[0;31m' # Red
Green='\033[0;32m' # Green
#Yellow='\033[0;33m' # Yellow
#Purple='\033[0;35m' # Purple
White='\033[0;37m' # White
# Background
On_Black='\033[40m' # Black
OkBullet="${Green}${On_Black}:: ${White}${On_Black}"
#WarnBullet="${Yellow}${On_Black}:: ${White}${On_Black}"
ErrBullet="${Red}${On_Black}:: ${White}${On_Black}"
Ok="${Green}${On_Black} ok.${Off}"
Fail="${Red}${On_Black} failed!${Off}"
#Nok="${Yellow}${On_Black} nok.${Off}"
################################################################
# Vars #
################################################################
XMRSH_DIR="/opt/xmr.sh"
XMRSH_LOG_FILE="/tmp/xmr.sh-$(date +%Y%m%d-%H%M%S).log"
################################################################
# Functions #
################################################################
check_root() {
echo -ne "${OkBullet}Checking root... ${Off}"
if [[ $EUID -ne 0 ]]; then
echo -e "${Fail}"
echo -e "${ErrBullet}You need to run this script as root (UID=0).${Off}"
exit 1
fi
echo -e "${Ok}"
}
check_return() {
if [ "$1" -ne 0 ]; then
echo -e "${Fail}"
echo -e "${ErrBullet}Installation failed. Check the logs in ${XMRSH_LOG_FILE}${Off}"
exit "$1"
fi
}
uninstall() {
pushd $XMRSH_DIR >>"${XMRSH_LOG_FILE}" 2>&1 || check_return $?
echo -e "${OkBullet}Uninstalling xmr.sh..."
if [ -f docker-compose.yml ]; then
docker-compose down >>"${XMRSH_LOG_FILE}" 2>&1
fi
check_return $?
while true; do
read -r -e -p " Do you want to keep the data directory with the blockchain and other data files? [y/n]: " yn
case $yn in
[Yy]*)
find . -type f -not -name 'data' -print0 | xargs -0 -I {} rm {}
check_return $?
popd >>"${XMRSH_LOG_FILE}" 2>&1 || check_return $?
break
;;
[Nn]*)
popd >>"${XMRSH_LOG_FILE}" 2>&1 || check_return $?
rm -rf "${XMRSH_DIR}"
check_return $?
break
;;
*) echo " Please answer yes or no." ;;
esac
done
echo -e "${OkBullet}Uninstall complete."
}
check_root
uninstall
exit 0