This repo defines a standard of creating a REST API that interfaces with a relational database.
- It's using the grip-framework to wire up the RESTful endpoints.
- Clear is being used as the ORM. This means PostgreSQL is the target database.
- Micrate handles database migrations against a Postgres DB.
- Your
.env
file will be loaded via dotenv. - Hardwire handles the dependency injection!
Make sure you have crystal installed on your Linux/MacOS/WSL environment.
Install the shards.
shards install
Create a .env
file with the DB connection URL. You can copy the sample.env
file for this.
Modify the docker-compose.yaml
file with details on your database, or keep it as is.
Bring up the Postgres DB using docker-compose.
docker-compose up
Run migrations against your DB.
./migrations/micrate up
Run the application.
crystal src/main.cr
Test it via a curl
command.
curl "http://0.0.0.0:8080/"
Use this template to quickly create a REST microservice.
It's crystal. Have fun!
- Fork it (https://github.com/your-github-user/crystal-rest-api-template/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- Jose Chavez - creator and maintainer