The Pet Agency API allows users to register, login, add pet listings, edit their listings, and toggle the status of their listings. The API is secured with JWT (JSON Web Token) and users can only edit the data they created. There are two public endpoints that return all available pets for adoption and the details of a single animal.
{
go build -o pet-agency.exe .\cmd\
}
- Language: Golang
- Framework: Echo
- Database: PostgreSQL
- Endpoint:
GET /api/pets
- Description: Returns a list of all available pets for adoption.
- Response:
[ { "id": 1, "name": "Bella", "species": "Dog", "breed": "Labrador", "age": 3, "status": "Available" }, ... ]
- Endpoint:
GET /api/pets/:id
- Description: Returns details of a single pet.
- Response:
{ "id": 1, "name": "Bella", "species": "Dog", "breed": "Labrador", "age": 3, "description": "Friendly and energetic", "status": "Available" }
- Endpoint:
POST /api/auth/register
- Description: Registers a new user.
- Request:
{ "username": "user1", "email": "user1@example.com", "password": "password123" }
- Response:
{ "message": "User registered successfully" }
- Endpoint:
POST /api/auth/login
- Description: Logs in a user and returns a JWT token.
- Request:
{ "email": "user1@example.com", "password": "password123" }
- Response:
{ "token": "JWT_TOKEN" }
- Endpoint:
POST /api/pets
- Description: Adds a new pet listing. Requires JWT.
- Request:
{ "name": "Bella", "species": "Dog", "breed": "Labrador", "age": 3, "description": "Friendly and energetic" }
- Response:
{ "message": "Pet listing created successfully" }
- Endpoint:
PUT /api/pets/:id
- Description: Edits an existing pet listing. Requires JWT and ownership.
- Request:
{ "name": "Bella", "species": "Dog", "breed": "Labrador", "age": 3, "description": "Friendly and very energetic" }
- Response:
{ "message": "Pet listing updated successfully" }
- Endpoint:
PATCH /api/pets/:id/status
- Description: Toggles the status of a pet listing (Available/Adopted). Requires JWT and ownership.
- Request:
{ "status": "Adopted" }
- Response:
{ "message": "Pet status updated successfully" }
Column | Type | Constraints |
---|---|---|
id | SERIAL | PRIMARY KEY |
username | VARCHAR(255) | NOT NULL, UNIQUE |
VARCHAR(255) | NOT NULL, UNIQUE | |
password | VARCHAR(255) | NOT NULL |
Column | Type | Constraints |
---|---|---|
id | SERIAL | PRIMARY KEY |
name | VARCHAR(255) | NOT NULL |
species | VARCHAR(255) | NOT NULL |
breed | VARCHAR(255) | |
age | INT | |
description | TEXT | |
status | VARCHAR(50) | NOT NULL |
user_id | INT | FOREIGN KEY (users.id) |
- JWT is used to secure the API endpoints.
- Users must include the JWT token in the Authorization header for protected endpoints.
- JWT Middleware: Ensures that the token is valid and the user is authenticated.
- Ownership Middleware: Ensures that the user can only edit or toggle the status of pets they created.
- Proper error messages and status codes are returned for invalid requests and unauthorized actions.
Feel free to adjust any details or add any additional sections as needed.