# PublAPI [![Go Version](https://img.shields.io/github/go-mod/go-version/projectsegfault/publapi?logo=Go&style=for-the-badge)](https://go.dev/doc/devel/release) [![License](https://img.shields.io/github/license/projectsegfault/publapi?style=for-the-badge)](./LICENSE) [![Matrix](https://img.shields.io/matrix/pubnix:projectsegfau.lt?logo=matrix&style=for-the-badge)](https://matrix.to/#/#pubnix:projectsegfau.lt) PublAPI is a simple API for Project Segfault's upcoming public shared system (pubnix). ## Install An installation of Go 1.22+ is required. ``` git clone https://github.com/ProjectSegfault/publapi go mod download go build ./publapi ``` By default publapi listens on 127.0.0.1:3000. You can change the port with the environment variable PUBLAPI_PORT. Additionally, you need to set the variable PUBLAPI_EMAIL_SHOUTRRRURL and PUBLAPI_NOTIFY_SHOUTRRRURL in order for signup notifications to work. URL Format can be found at https://containrrr.dev/shoutrrr/v0.5. You can also set PUBLAPI_SIGNUP_IP to make sure signup requests can only be made from one IP. ## Usage Currently, PublAPI has only two routes, /users and /signup. | ROUTE | TYPE | EXTRA ARGS | DESCRIPTION | |---------|------|----------------------|---------------------------------| | /users | GET | N/A | Return information about users. | | /signup | POST | username, email, ssh | Creates a register script and notifies admins that a new registration request was sent.|