Skip to content

Latest commit

 

History

History
104 lines (74 loc) · 2.35 KB

README.md

File metadata and controls

104 lines (74 loc) · 2.35 KB

Quality gate

#Garip Tipici

Development Started: 28 July

Total time spent on development: 3.5 - 4 Hours

Pet Fish Co. REST Service

A minimal Spring Boot Web app.

Requirements

For building and running the application you need:

Running the application locally

There are several ways to run Petfish Docker container on your local machine. One way is to execute the docker compose command:

docker-compose up  

App will start to listen the local port 8081, so please kill the processes that uses this port before running the application.

You can use any tool to send requests to the service, I recommend PostMan.

API Endpoints and samples

To create a new aquarium you need to POST an aquarium data. Please use GALLON or LITER as measurement unit.

http://localhost:8081/aquariums
{
  "glassType": "sapphire",
  "shape": "sphere",
  "size": 444.8,
  "unit": "LITER"
}

To read the aquariums you created, you should GETto same endpoint:

http://localhost:8081/aquariums

You can GET a specific aquarium by id in path:

http://localhost:8081/aquariums/1

To create a new fish, you need an aquarium, so you need an aquarium id to create a fish. You should POST the fish to:

http://localhost:8081/aquariums/1/fishes

You can create only HAMSI, GUPPY and GOLDFISH for now.

{
  "species": "HAMSI",
  "color": "white",
  "numberOfFins": 3
}

You can update the fish you created even you can PUT it in a new aquarium by specifying a new aquarium id in object.

http://localhost:8081/aquariums/1/fishes/2
{
  "aquariumId": 9,
  "species": "HAMSI",
  "color": "gray",
  "numberOfFins": 4
}

You can GET all of the fishes in a specific aquarium

http://localhost:8081/aquariums/1/fishes

or you can GET a specific fish in a specific aquarium.

http://localhost:8081/aquariums/1/fishes/2

You also can use this service in USA. By adding ?locale=US to all queries, you can see USA measurement units in responses:

http://localhost:8081/aquariums?locale=US