pREST (PostgreSQL REST), is a simple production-ready API, that delivers an instant, realtime, and high-performance application on top of your existing or new Postgres database.
PostgreSQL version 9.5 or higher
Contributor License Agreement - 
The pREST project is the API that addresses the need for fast and efficient solution in building RESTful APIs on PostgreSQL databases. It simplifies API development by offering:
- A lightweight server with easy configuration;
- Direct SQL queries with templating in customizable URLs;
- Optimizations for high performance;
- Enhanced developer productivity;
- Authentication and authorization features;
- Pluggable custom routes and middlewares.
Overall, pREST simplifies the process of creating secure and performant RESTful APIs on top of your new or old PostgreSQL database.
When we built pREST, we originally intended to contribute and build with the PostgREST project, although it took a lot of work as the project is in Haskell. At the time, we did not have anything similar or intended to keep working with that tech stack. We've been building production-ready Go applications for a long time, so building a similar project with Golang as its core was natural.
Additionally, as Go has taken a huge role in many other vital projects such as Kubernetes and Docker, and we've been able to use the pREST project in many different companies with success over the years, it has shown to be an excellent decision.
Deploy to Heroku and instantly get a realtime RESTFul API backed by Heroku Postgres:
Visit https://docs.prestd.com/
Run the test suite inside Docker (no local Postgres required):
make testOr directly with Docker Compose:
docker compose -f docker-compose-test.yml up --abort-on-container-exit --exit-code-from tests
docker compose -f docker-compose-test.yml down -v --remove-orphansThe tests service runs ./testdata/runtest.sh, provisioning databases and executing Go tests.
