REST server to interact with NeoFS.
--- [data:image/s3,"s3://crabby-images/88c84/88c847920858a473cd1802ba3c5a3c494b11bd3e" alt="Report"](https://goreportcard.com/report/github.com/nspcc-dev/neofs-rest-gw) data:image/s3,"s3://crabby-images/6b779/6b7796ada472f2ec1b81a4df5b2a3f5a1aca3b56" alt="GitHub release (latest SemVer)" data:image/s3,"s3://crabby-images/74283/74283458c9e3739a8513d974f106d0aec4b5f95a" alt="License" # neofs-rest-gw NeoFS REST Gateway bridges NeoFS internal protocol and REST API server. ## Installation ### Building Before building make sure you have the following tools: * go * make * git * curl * docker First clone this repository: ```shell $ git clone https://github.com/nspcc-dev/neofs-rest-gw ``` Then run make to build `bin/neofs-rest-gw` binary: ```shell $ make ``` Or you can build it using docker: ```shell $ make docker/all ``` #### Generate go-swagger boilerplate code If you change the [spec file](./spec/rest.yaml) you have to re-generate go-swagger server code. You have several approaches: 1. Run make. It automatically downloads `swagger` and generates boilerplate. ```shell $ make ``` 2. Generate code separately: ```shell $ make generate-server ``` Or using docker: ```shell $ make docker/generate-server ``` #### Other targets Notable make targets: ``` dep Check and ensure dependencies image Build clean docker image image-dirty Build dirty docker image with host-built binaries formats Run all code formatters lint Run linters version Show current version generate-server Generate boilerplate by spec ``` ### Docker Or you can also use a [Docker image](https://hub.docker.com/r/nspccdev/neofs-rest-gw) provided for released (and occasionally unreleased) versions of gateway (`:latest` points to the latest stable release). ## Execution REST gateway itself is not a NeoFS node, so to access NeoFS it uses node's gRPC interface and you need to provide some node that it will connect to. This can be done either via `-p` parameter or via `REST_GW_PEERS_