Browse Source
the local indexer is an instance of addrindexrs (see https://github.com/Samourai-Wallet/addrindexrs) running inside dojoumbrel
kenshin-samourai
5 years ago
11 changed files with 361 additions and 2 deletions
@ -0,0 +1,42 @@ |
|||
######################################### |
|||
# CONFIGURATION OF A LOCAL INDEXER |
|||
######################################### |
|||
|
|||
# Install and run a local indexer inside Docker |
|||
# Set this option to 'off' for using an indexer hosted outside of Docker |
|||
# or when using a different data source (local bitcoind, OXT) |
|||
# Value: on | off |
|||
INDEXER_INSTALL=off |
|||
|
|||
# IP address of the local indexer used by Dojo |
|||
# Set value to 172.28.1.6 if INDEXER_INSTALL is set to 'on' |
|||
# Type: string |
|||
INDEXER_IP=172.28.1.6 |
|||
|
|||
# Port of the RPC API |
|||
# Set value to 50001 if INDEXER_INSTALL is set to 'on' |
|||
# Type: integer |
|||
INDEXER_RPC_PORT=50001 |
|||
|
|||
# Support of batch requests by the local indexer |
|||
# Set value to inactive if INDEXER_INSTALL is set to 'on' |
|||
# Value: active | inactive |
|||
INDEXER_BATCH_SUPPORT=inactive |
|||
|
|||
|
|||
# |
|||
# EXPERT SETTINGS |
|||
# (ACTIVE IF INDEXER_INSTALL IS SET TO ON) |
|||
# |
|||
|
|||
# Number of blocks to get in one JSONRPC request from bitcoind |
|||
# Type: integer |
|||
INDEXER_BATCH_SIZE=10 |
|||
|
|||
# Total size of block txids to cache (in MB) |
|||
# Type: integer |
|||
INDEXER_BLK_TXIDS_CACHE_SIZE_MB=10 |
|||
|
|||
# Number of transactions to lookup before returning an error |
|||
# Type: integer |
|||
INDEXER_TXID_LIMIT=501 |
@ -0,0 +1,46 @@ |
|||
FROM rust:1.37.0-slim |
|||
|
|||
ENV INDEXER_HOME /home/indexer |
|||
ENV INDEXER_VERSION 0..1.0 |
|||
ENV INDEXER_URL https://github.com/Samourai-Wallet/addrindexrs.git |
|||
|
|||
RUN apt-get update && \ |
|||
apt-get install -y clang cmake git && \ |
|||
apt-get install -y libsnappy-dev |
|||
|
|||
# Create group and user indexer |
|||
RUN addgroup --system -gid 1109 indexer && \ |
|||
adduser --system --ingroup indexer -uid 1106 indexer |
|||
|
|||
# Create data directory |
|||
RUN mkdir "$INDEXER_HOME/addrindexrs" && \ |
|||
chown -h indexer:indexer "$INDEXER_HOME/addrindexrs" |
|||
|
|||
# Copy restart script |
|||
COPY ./restart.sh /restart.sh |
|||
RUN chown indexer:indexer /restart.sh && \ |
|||
chmod 777 /restart.sh |
|||
|
|||
# Copy wait-for-it script |
|||
COPY ./wait-for-it.sh /wait-for-it.sh |
|||
RUN chown indexer:indexer /wait-for-it.sh && \ |
|||
chmod u+x /wait-for-it.sh && \ |
|||
chmod g+x /wait-for-it.sh |
|||
|
|||
USER indexer |
|||
|
|||
# Install addrindexrs |
|||
RUN cd "$INDEXER_HOME" && \ |
|||
git clone "$INDEXER_URL" "$INDEXER_HOME/addrindexrs" && \ |
|||
cd addrindexrs && \ |
|||
git checkout "master" |
|||
# TODO uncomment |
|||
# git checkout "tags/v$INDEXER_VERSION" |
|||
|
|||
RUN cd "$INDEXER_HOME/addrindexrs" && \ |
|||
cargo build --release && \ |
|||
cargo install --path . |
|||
|
|||
EXPOSE 50001 |
|||
|
|||
STOPSIGNAL SIGINT |
@ -0,0 +1,22 @@ |
|||
#!/bin/bash |
|||
set -e |
|||
|
|||
indexer_options=( |
|||
-vvvv |
|||
--index-batch-size="$INDEXER_BATCH_SIZE" |
|||
--jsonrpc-import |
|||
--db-dir="/home/indexer/db" |
|||
--indexer-rpc-addr="172.28.1.6:50001" |
|||
--daemon-rpc-addr="$BITCOIND_IP:$BITCOIND_RPC_PORT" |
|||
--cookie="$BITCOIND_RPC_USER:$BITCOIND_RPC_PASSWORD" |
|||
--txid-limit="$INDEXER_TXID_LIMIT" |
|||
--blocktxids-cache-size-mb="$INDEXER_BLK_TXIDS_CACHE_SIZE_MB" |
|||
) |
|||
|
|||
if [ "$COMMON_BTC_NETWORK" == "testnet" ]; then |
|||
bitcoind_options+=(--network="testnet") |
|||
else |
|||
bitcoind_options+=(--network="mainnet") |
|||
fi |
|||
|
|||
addrindexrs "${indexer_options[@]}" |
@ -0,0 +1,178 @@ |
|||
#!/usr/bin/env bash |
|||
# Use this script to test if a given TCP host/port are available |
|||
|
|||
WAITFORIT_cmdname=${0##*/} |
|||
|
|||
echoerr() { if [[ $WAITFORIT_QUIET -ne 1 ]]; then echo "$@" 1>&2; fi } |
|||
|
|||
usage() |
|||
{ |
|||
cat << USAGE >&2 |
|||
Usage: |
|||
$WAITFORIT_cmdname host:port [-s] [-t timeout] [-- command args] |
|||
-h HOST | --host=HOST Host or IP under test |
|||
-p PORT | --port=PORT TCP port under test |
|||
Alternatively, you specify the host and port as host:port |
|||
-s | --strict Only execute subcommand if the test succeeds |
|||
-q | --quiet Don't output any status messages |
|||
-t TIMEOUT | --timeout=TIMEOUT |
|||
Timeout in seconds, zero for no timeout |
|||
-- COMMAND ARGS Execute command with args after the test finishes |
|||
USAGE |
|||
exit 1 |
|||
} |
|||
|
|||
wait_for() |
|||
{ |
|||
if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then |
|||
echoerr "$WAITFORIT_cmdname: waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" |
|||
else |
|||
echoerr "$WAITFORIT_cmdname: waiting for $WAITFORIT_HOST:$WAITFORIT_PORT without a timeout" |
|||
fi |
|||
WAITFORIT_start_ts=$(date +%s) |
|||
while : |
|||
do |
|||
if [[ $WAITFORIT_ISBUSY -eq 1 ]]; then |
|||
nc -z $WAITFORIT_HOST $WAITFORIT_PORT |
|||
WAITFORIT_result=$? |
|||
else |
|||
(echo > /dev/tcp/$WAITFORIT_HOST/$WAITFORIT_PORT) >/dev/null 2>&1 |
|||
WAITFORIT_result=$? |
|||
fi |
|||
if [[ $WAITFORIT_result -eq 0 ]]; then |
|||
WAITFORIT_end_ts=$(date +%s) |
|||
echoerr "$WAITFORIT_cmdname: $WAITFORIT_HOST:$WAITFORIT_PORT is available after $((WAITFORIT_end_ts - WAITFORIT_start_ts)) seconds" |
|||
break |
|||
fi |
|||
sleep 1 |
|||
done |
|||
return $WAITFORIT_result |
|||
} |
|||
|
|||
wait_for_wrapper() |
|||
{ |
|||
# In order to support SIGINT during timeout: http://unix.stackexchange.com/a/57692 |
|||
if [[ $WAITFORIT_QUIET -eq 1 ]]; then |
|||
timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --quiet --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & |
|||
else |
|||
timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & |
|||
fi |
|||
WAITFORIT_PID=$! |
|||
trap "kill -INT -$WAITFORIT_PID" INT |
|||
wait $WAITFORIT_PID |
|||
WAITFORIT_RESULT=$? |
|||
if [[ $WAITFORIT_RESULT -ne 0 ]]; then |
|||
echoerr "$WAITFORIT_cmdname: timeout occurred after waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" |
|||
fi |
|||
return $WAITFORIT_RESULT |
|||
} |
|||
|
|||
# process arguments |
|||
while [[ $# -gt 0 ]] |
|||
do |
|||
case "$1" in |
|||
*:* ) |
|||
WAITFORIT_hostport=(${1//:/ }) |
|||
WAITFORIT_HOST=${WAITFORIT_hostport[0]} |
|||
WAITFORIT_PORT=${WAITFORIT_hostport[1]} |
|||
shift 1 |
|||
;; |
|||
--child) |
|||
WAITFORIT_CHILD=1 |
|||
shift 1 |
|||
;; |
|||
-q | --quiet) |
|||
WAITFORIT_QUIET=1 |
|||
shift 1 |
|||
;; |
|||
-s | --strict) |
|||
WAITFORIT_STRICT=1 |
|||
shift 1 |
|||
;; |
|||
-h) |
|||
WAITFORIT_HOST="$2" |
|||
if [[ $WAITFORIT_HOST == "" ]]; then break; fi |
|||
shift 2 |
|||
;; |
|||
--host=*) |
|||
WAITFORIT_HOST="${1#*=}" |
|||
shift 1 |
|||
;; |
|||
-p) |
|||
WAITFORIT_PORT="$2" |
|||
if [[ $WAITFORIT_PORT == "" ]]; then break; fi |
|||
shift 2 |
|||
;; |
|||
--port=*) |
|||
WAITFORIT_PORT="${1#*=}" |
|||
shift 1 |
|||
;; |
|||
-t) |
|||
WAITFORIT_TIMEOUT="$2" |
|||
if [[ $WAITFORIT_TIMEOUT == "" ]]; then break; fi |
|||
shift 2 |
|||
;; |
|||
--timeout=*) |
|||
WAITFORIT_TIMEOUT="${1#*=}" |
|||
shift 1 |
|||
;; |
|||
--) |
|||
shift |
|||
WAITFORIT_CLI=("$@") |
|||
break |
|||
;; |
|||
--help) |
|||
usage |
|||
;; |
|||
*) |
|||
echoerr "Unknown argument: $1" |
|||
usage |
|||
;; |
|||
esac |
|||
done |
|||
|
|||
if [[ "$WAITFORIT_HOST" == "" || "$WAITFORIT_PORT" == "" ]]; then |
|||
echoerr "Error: you need to provide a host and port to test." |
|||
usage |
|||
fi |
|||
|
|||
WAITFORIT_TIMEOUT=${WAITFORIT_TIMEOUT:-15} |
|||
WAITFORIT_STRICT=${WAITFORIT_STRICT:-0} |
|||
WAITFORIT_CHILD=${WAITFORIT_CHILD:-0} |
|||
WAITFORIT_QUIET=${WAITFORIT_QUIET:-0} |
|||
|
|||
# check to see if timeout is from busybox? |
|||
WAITFORIT_TIMEOUT_PATH=$(type -p timeout) |
|||
WAITFORIT_TIMEOUT_PATH=$(realpath $WAITFORIT_TIMEOUT_PATH 2>/dev/null || readlink -f $WAITFORIT_TIMEOUT_PATH) |
|||
if [[ $WAITFORIT_TIMEOUT_PATH =~ "busybox" ]]; then |
|||
WAITFORIT_ISBUSY=1 |
|||
WAITFORIT_BUSYTIMEFLAG="-t" |
|||
|
|||
else |
|||
WAITFORIT_ISBUSY=0 |
|||
WAITFORIT_BUSYTIMEFLAG="" |
|||
fi |
|||
|
|||
if [[ $WAITFORIT_CHILD -gt 0 ]]; then |
|||
wait_for |
|||
WAITFORIT_RESULT=$? |
|||
exit $WAITFORIT_RESULT |
|||
else |
|||
if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then |
|||
wait_for_wrapper |
|||
WAITFORIT_RESULT=$? |
|||
else |
|||
wait_for |
|||
WAITFORIT_RESULT=$? |
|||
fi |
|||
fi |
|||
|
|||
if [[ $WAITFORIT_CLI != "" ]]; then |
|||
if [[ $WAITFORIT_RESULT -ne 0 && $WAITFORIT_STRICT -eq 1 ]]; then |
|||
echoerr "$WAITFORIT_cmdname: strict mode, refusing to execute subprocess" |
|||
exit $WAITFORIT_RESULT |
|||
fi |
|||
exec "${WAITFORIT_CLI[@]}" |
|||
else |
|||
exit $WAITFORIT_RESULT |
|||
fi |
@ -0,0 +1,27 @@ |
|||
version: "3.2" |
|||
|
|||
services: |
|||
indexer: |
|||
image: "samouraiwallet/dojo-indexer:${DOJO_INDEXER_VERSION_TAG}" |
|||
container_name: indexer |
|||
build: |
|||
context: ./indexer |
|||
env_file: |
|||
- ./.env |
|||
- ./conf/docker-common.conf |
|||
- ./conf/docker-bitcoind.conf |
|||
- ./conf/docker-indexer.conf |
|||
restart: on-failure |
|||
command: "/wait-for-it.sh tor:9050 --timeout=360 --strict -- /restart.sh" |
|||
expose: |
|||
- "50001" |
|||
volumes: |
|||
- data-indexer:/home/indexer/addrindexrs |
|||
depends_on: |
|||
- tor |
|||
networks: |
|||
dojonet: |
|||
ipv4_address: 172.28.1.6 |
|||
|
|||
volumes: |
|||
data-indexer: |
Loading…
Reference in new issue