Skip to content

Rocket-Rescue-Node/rescue-api

Repository files navigation

golangci-lint

Rescue-API

The Rescue-API allows Node Operators to request credentials for the Rescue Node (GitHub).

Building

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Requirements

Build

make build

Usage

Usage of ./rescue-api:
  -addr string
        Address on which to listen to HTTP requests (default "0.0.0.0:8080")
  -allowed-origins string
        Comma-separated list of allowed CORS origins (default "localhost")
  -auth-valid-for string
        The duration after which a credential should be considered invalid, eg, 360h for 15 days (default "360h")
  -db-path string
        sqlite3 database path (default "db.sqlite3")
  -debug
        Whether to enable verbose logging
  -hmac-secret string
        The secret to use for HMAC (default "test-secret")
  -rescue-proxy-api-addr string
        Address for the Rescue Proxy gRPC API
  -rocketscan-api-url string
        URL for the Rocketscan REST API
  • -hmac-secret must match the one used with the Credentials library that generated the username, password

Docker

If you need to publish a new version of the Docker image, you can use the following commands. You will need to be logged into Docker Hub.

Requirements

Prepare the build environment

This step is needed only once.

make docker-prepare

Build and publish the image

The following commands will build and publish the image with the specified version. If you need to create a multi-arch image, you can edit Makefile and add additional architectures to the PLATFORMS variable.

VERSION=<version> make docker-publish

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

AGPL Copyright (C) 2022 Jacob Shufro and João Poupino