Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/yannhulot/petstore

This is a pet store where you can look up pets and save new pets
https://github.com/yannhulot/petstore

circleci database docker docker-compose gin-gonic golang golangci-lint gorm mit-license postgresql sqlmock

Last synced: about 1 month ago
JSON representation

This is a pet store where you can look up pets and save new pets

Awesome Lists containing this project

README

        

# Pet Store

To whom it may concern,
This app will allow you to store and retrieve pets.

I believe there are a few issues in the code but it is doing 99% of what it is supposed to do.
If you see a bug, please open an issue.

## Build status

[![CircleCI](https://circleci.com/gh/YannHulot/petstore/tree/master.svg?style=svg)](https://circleci.com/gh/YannHulot/petstore/tree/master)

## Motivation

This project is demonstration of my skills in different areas such as API design and Golang development work.

## Code style

Code is formatted with Go vet and Go fmt.

The linter golangci-lint is used to ensure the highest code quality and avoid potential bugs.

## Tech/framework used

Written in Golang, this project uses may open source libraries and frameworks such as for example:

- Gin router
- Gorm database ORM
- SQLMock to mock database interactions
- PostgreSQL as a database
- Docker for easy deployment

## Examples of queries

### Save a Pet

### Example of payload when saving a new pet

```json
{
"category": {
"id": 90,
"name": "test-category"
},
"name": "pet 87",
"photoUrls": [
"testurl",
"t39"
],
"tags": [
{
"id": 8990,
"name": "test-category 2"
},{
"id": 79,
"name": "test-category 2"
}],
"status": "sold"
}
```

### Save a pet

```curl
curl -v -XPOST -H "Content-type: application/json" -d '{
"category": {
"id": 90,
"name": "test-category"
},
"name": "pet 87",
"photoUrls": [
"testurl",
"t39"
],
"tags": [
{
"id": 8990,
"name": "test-category 2"
},{
"id": 79,
"name": "test-category 2"
}],
"status": "sold"
}' 'http://localhost:8080/api/v1/pet'
```

Or use your favorite request tool creator such as Postman.

### Get a pet

```curl
curl -XGET 'http://localhost:8080/api/v1/pet/1'
```

### Delete a pet

```curl
curl -XDELETE 'http://localhost:8080/api/v1/pet/1'
```

### Get pets by status

```curl
curl -XGET 'http://localhost:8080/api/v1/pet/findByStatus?status=sold'
```

#### Get pet with multiple statuses

```curl
curl -XGET 'http://localhost:8080/api/v1/pet/findByStatus?status=sold&status=pending'
```

### Update a pet's attributes via form data

```curl
curl -X POST "http://localhost:8080/api/v1/pet/8" -H "accept: application/json" -H "Content-Type: application/x-www-form-urlencoded" -d "name=doggyboy&status=taken"
```

### Update a pet's image

```curl
curl -X POST "http://localhost:8080/api/v1/pet/1/uploadImage" -H "accept: application/json" -H "Content-Type: multipart/form-data" -F "additionalMetadata=test" -F "[email protected];type=image/png"
```

## Error responses

Errors will be returned in this format:

```json
{
"type": "error",
"message" : "this is an error"
}
```

## Installation

Steps:

```bash
git clone https://github.com/YannHulot/petstore
```

```bash
cd petstore
```

```bash
docker-compose up --build
```

Wait about 2 minutes for everything to be set up depending on your internet speed and for the different services to start.

If everything went well you should now have the server running on port 8080

## Shut down the application

```bash
docker-compose down
```

### Warning

I would suggest to not change the env variables unless you know what you are doing.

## API Reference

The API reference can be found at:

## Tests

The tests can be run by using the command: `go test ./...`

## Credits

I Found help on Stack Overflow, Medium and in other parts of the internet.

## License

MIT License

Copyright (c)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.