diff --git a/README.md b/README.md index 6cc8727..9141475 100644 --- a/README.md +++ b/README.md @@ -27,6 +27,14 @@ The configured domain URL should be in the format 'enrtree://@', for nim_waku_dns_disc_enabled: true nim_waku_dns_disc_url: 'enrtree://AOFTICU2XWDULNLZGRMQS4RIZPAZEHYMV4FYHAPW563HNRAOERP7C@test.waku.nodes.status.im' ``` +REST API is avalable to inspect the node and use protocols: +```yaml +nim_waku_rest_enabled: true +nim_waku_rest_addr: '127.0.0.1' +nim_waku_rest_port: 8645 +nim_waku_rest_apis_enabled: ['admin', 'private'] +``` +For full docs see [API docs page](https://waku-org.github.io/waku-rest-api/). # Usage diff --git a/defaults/main.yml b/defaults/main.yml index 2f006cc..ea94a9a 100644 --- a/defaults/main.yml +++ b/defaults/main.yml @@ -47,8 +47,10 @@ nim_waku_disc_v5_bootstrap_nodes: [] nim_waku_dns4_domain_name: '{{ ansible_hostname }}' nim_waku_public_address: '{{ ansible_host }}' -nim_waku_rpc_tcp_addr: '127.0.0.1' -nim_waku_rpc_tcp_port: 8545 +nim_waku_rest_enabled: true +nim_waku_rest_addr: '127.0.0.1' +nim_waku_rest_port: 8645 +nim_waku_rest_apis_enabled: ['admin'] # admin, private nim_waku_websock_port: 8000 nim_waku_disc_v5_port: 9000 nim_waku_p2p_tcp_port: 30303 diff --git a/tasks/consul.yml b/tasks/consul.yml index e0f1a6e..99d9b06 100644 --- a/tasks/consul.yml +++ b/tasks/consul.yml @@ -39,17 +39,15 @@ # Single-threated nature blocking responses due to DB I/O. disabled: true - - id: '{{ nim_waku_cont_name }}-rpc' - name: '{{ nim_waku_consul_service_name }}-rpc' - port: '{{ nim_waku_rpc_tcp_port }}' + - id: '{{ nim_waku_cont_name }}-rest' + name: '{{ nim_waku_consul_service_name }}-rest' + port: '{{ nim_waku_rest_port }}' address: '{{ ansible_local.wireguard.vpn_ip }}' - tags: ['env:{{ env }}', 'stage:{{ stage }}', 'nim', 'waku', 'rpc'] + tags: ['env:{{ env }}', 'stage:{{ stage }}', 'nim', 'waku', 'rest'] checks: - - id: '{{ nim_waku_cont_name }}-rpc-health' - type: 'script' - script: '{{ nim_waku_cont_vol }}/rpc.sh get_waku_v2_debug_v1_info' - # Single-threated nature blocking responses due to DB I/O. - disabled: true + - id: '{{ nim_waku_cont_name }}-rest-health' + type: 'http' + http: 'http://localhost:{{ nim_waku_rest_port }}/debug/v1/version' - name: Define Websocket service when: nim_waku_websocket_enabled diff --git a/tasks/container.yml b/tasks/container.yml index d1917ea..985edba 100644 --- a/tasks/container.yml +++ b/tasks/container.yml @@ -7,10 +7,10 @@ group: docker mode: 0775 -- name: Create script for calling RPC endpoint +- name: Create script for calling REST API template: - src: 'rpc.sh.j2' - dest: '{{ nim_waku_cont_vol }}/rpc.sh' + src: 'api.sh.j2' + dest: '{{ nim_waku_cont_vol }}/api.sh' owner: dockremap group: docker mode: 0755 diff --git a/tasks/query.yml b/tasks/query.yml index c75e155..eabb0a9 100644 --- a/tasks/query.yml +++ b/tasks/query.yml @@ -1,18 +1,12 @@ --- -- name: 'Wait for RPC port to be available' +- name: 'Wait for REST port to be available' wait_for: - port: '{{ nim_waku_rpc_tcp_port }}' + port: '{{ nim_waku_rest_port }}' delay: 5 - name: 'Extract address of the node for Consul' uri: - url: 'http://localhost:{{ nim_waku_rpc_tcp_port }}/' - method: POST - body: - method: 'get_waku_v2_debug_v1_info' - params: [] - jsonrpc: '2.0' - id: 1 + url: 'http://localhost:{{ nim_waku_rest_port }}/debug/v1/info' status_code: 200 body_format: json register: waku_info @@ -39,6 +33,6 @@ {{ waku_info.json.result.listenAddresses | select("contains", "/ws") | first }} -- name: Extract peer ID from RPC response +- name: Extract peer ID from API response set_fact: nim_waku_peer_id: '{{ nim_waku_libp2p_multiaddr.split("/") | last }}' diff --git a/templates/api.sh.j2 b/templates/api.sh.j2 new file mode 100644 index 0000000..663ce15 --- /dev/null +++ b/templates/api.sh.j2 @@ -0,0 +1,27 @@ +#!/usr/bin/env bash +# vim: set ft=sh: + +TIMEOUT="${TIMEOUT:-5}" +URL="http://localhost:{{ nim_waku_rest_port }}/" + +# List known useful endpoints when called without arguments. +read -r -d '' ENDPOINTS << EOF +/health +/debug/v1/info +/debug/v1/version +/admin/v1/peers +EOF +if [[ $# == 0 ]]; then + echo "${ENDPOINTS}" | fzf \ + --preview='{{ nim_waku_cont_vol }}/api.sh ${1}' \ + --preview-window=bottom,22 + exit 0 +elif [[ $# > 1 ]]; then + echo "Too many arguments!" >&2 + exit 1 +fi +ENDPOINT="${1}" + +# The jq script checks if error exists and adjusts exit code. +curl --silent --max-time "${TIMEOUT}" --show-error --fail-with-body \ + "${URL}${ENDPOINT}" | jq diff --git a/templates/docker-compose.yml.j2 b/templates/docker-compose.yml.j2 index 34ead32..234ab9d 100644 --- a/templates/docker-compose.yml.j2 +++ b/templates/docker-compose.yml.j2 @@ -24,7 +24,7 @@ services: - '{{ nim_waku_websocket_ssl_dir }}:{{ nim_waku_websocket_ssl_dir | mandatory }}' {% endif %} ports: - - '{{ nim_waku_rpc_tcp_addr }}:{{ nim_waku_rpc_tcp_port }}:{{ nim_waku_rpc_tcp_port }}/tcp' + - '{{ nim_waku_rest_addr }}:{{ nim_waku_rest_port }}:{{ nim_waku_rest_port }}/tcp' - '{{ nim_waku_p2p_tcp_port }}:{{ nim_waku_p2p_tcp_port }}/tcp' - '{{ nim_waku_p2p_udp_port }}:{{ nim_waku_p2p_udp_port }}/udp' - '{{ nim_waku_metrics_port }}:{{ nim_waku_metrics_port }}/tcp' @@ -44,7 +44,6 @@ services: {% for protocol in nim_waku_protocols_enabled %} --{{ protocol }}=true {% endfor %} - --rpc-admin=true --peer-persistence={{ nim_waku_peer_persistence | to_json }} --keep-alive={{ nim_waku_keep_alive | to_json }} --max-connections={{ nim_waku_p2p_max_connections }} @@ -103,9 +102,14 @@ services: {% endif %} --nat=extip:{{ nim_waku_public_address }} --log-level={{ nim_waku_log_level | upper }} - --rpc-port={{ nim_waku_rpc_tcp_port }} - --rpc-address=0.0.0.0 --tcp-port={{ nim_waku_p2p_tcp_port }} + --rest={{ nim_waku_rest_enabled }} +{% if nim_waku_rest_enabled %} + --rest-address={{ nim_waku_rest_addr }} + --rest-port={{ nim_waku_rest_port }} + --rest-admin={{ "admin" in nim_waku_rest_apis_enabled }} + --rest-private={{ "private" in nim_waku_rest_apis_enabled }} +{% endif %} --metrics-server={{ nim_waku_metrics_enabled }} --metrics-server-port={{ nim_waku_metrics_port }} --metrics-server-address=0.0.0.0 diff --git a/templates/rpc.sh.j2 b/templates/rpc.sh.j2 deleted file mode 100644 index e34eef5..0000000 --- a/templates/rpc.sh.j2 +++ /dev/null @@ -1,39 +0,0 @@ -#!/usr/bin/env bash -# vim: set ft=sh: - -URL="http://localhost:{{ nim_waku_rpc_tcp_port }}/" - -METHOD="$1" -shift -PARAMS=("$@") - -if [[ -z "${METHOD}" ]]; then - echo "No method specified!" >&2 - exit 1 -fi -if [[ -n "${PARAMS}" ]]; then - PARAMS_STR=$(printf '%s\",\"' "${PARAMS[@]}") - # Params are a nested array because of a bug in nim-json-rpc. - # https://github.com/status-im/nim-json-rpc/issues/90 - PARAMS_STR="[\"${PARAMS_STR%%\",\"}\"]" -else - PARAMS_STR='' -fi - -PAYLOAD="{ - \"id\": 1, - \"jsonrpc\": \"2.0\", - \"method\": \"${METHOD}\", - \"params\": [${PARAMS_STR}] -}" - -# The jq script checks if error exists and adjusts exit code. -curl --request POST \ - --silent \ - --max-time 5 \ - --show-error \ - --fail-with-body \ - --header 'Content-type:application/json' \ - --data "${PAYLOAD}" \ - "${URL}" | \ - jq -e '., if .error != null then null|halt_error(2) else halt end'