Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jonathan-foucher/gin-api-example
An example of Go API with Gin
https://github.com/jonathan-foucher/gin-api-example
gin go sqlc
Last synced: 1 day ago
JSON representation
An example of Go API with Gin
- Host: GitHub
- URL: https://github.com/jonathan-foucher/gin-api-example
- Owner: jonathan-foucher
- Created: 2024-11-02T23:13:54.000Z (3 months ago)
- Default Branch: master
- Last Pushed: 2024-11-06T22:25:26.000Z (3 months ago)
- Last Synced: 2024-11-26T14:12:46.589Z (2 months ago)
- Topics: gin, go, sqlc
- Language: Go
- Homepage:
- Size: 13.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Introduction
This project is an example of a Go API using Gin, sqlc and a postgres database.## Run the project
### Database
Install postgres locally or run it through docker with :
```
docker run -p 5432:5432 -e POSTGRES_DB=my_database -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=postgres postgres
```You will need to run the this request to create the movie table :
```
create table movie (
id integer primary key,
title varchar(50) not null,
release_date date not null
);
```### Application
Once the postgres database is started and the movie table created, you can start the Go project and try it out.Start the application
```
go run main.go
```Get all the movies
```
curl --location 'http://localhost:3000/api/movies'
```Save a movie
```
curl --request POST \
--url http://localhost:3000/api/movies \
--header 'Content-Type: application/json' \
--data '{
"id": 26,
"title": "Some movie title",
"release_date": "2022-02-26"
}'
```Delete a movie
```
curl --request DELETE \
--url http://localhost:3000/api/movies/26
```