Skip to content

Latest commit

 

History

History
135 lines (104 loc) · 2.8 KB

readme.md

File metadata and controls

135 lines (104 loc) · 2.8 KB

Cubs Coin API Documentation

Public Routes

1. Get All Transactions

GET /api/transactions
Description: Fetches all transactions.
Response: JSON array of transactions.

2. Get Transaction by ID

GET /api/transaction/{id}
Description: Fetches a transaction by its ID.
Parameters:

  • id: Transaction ID (integer)
    Response: Transaction details.

3. Sign Up

POST /api/signup
Description: Registers a new user.
Request Body:

{
  "student_id": "string",
  "name": "string",
  "password": "string"
}

Response: User creation confirmation or error message. Note: default Balance=0, Role=member

4. Sign In

POST /api/signin
Description: Logs in a user and returns a JWT token.
Request Body:

{
  "student_id": "string",
  "password": "string"
}

Response: JWT token for authenticated access.

Private Routes

1. Get My Info

GET /api/user
Description: Fetches information about the authenticated user.
Authentication: Requires Bearer token.
Response: User details.

2. Transfer Cubs Coins

POST /api/transfer
Description: Transfers Cubs Coins to another user.
Request Body:

{
  "receiver": "string",
  "amount": number
}

Response: Transfer confirmation or error message.

Admin Routes

1. Create Transaction

POST /api/transaction/create
Description: Creates a new transaction between two users.
Request Body:

{
  "sender": "string",
  "receiver": "string",
  "amount": number
}

Response: Transaction creation confirmation or error message.

2. Get All Users

GET /api/users
Description: Fetches a list of all users.
Response: JSON array of user details.

3. Get User by ID

GET /api/user/{id}
Description: Fetches a user's details by their ID.
Parameters:

  • id: User ID (integer)
    Response: User details.

4. Create User

POST /api/user/create
Description: Creates a new user.
Request Body:

{
  "student_id": "string",
  "name": "string",
  "password": "string"
}

Response: User creation confirmation or error message.

5. Change Role to Admin

PATCH /api/changetoadmin/{id}
Description: Changes a user's role to "admin".
Authentication: Requires Bearer token (admin privileges).
Parameters:

  • id: User ID (integer)
    Response: Role change confirmation or error message.

6. Change Role to Member

PATCH /api/changetomember/{id}
Description: Changes a user's role to "member".
Authentication: Requires Bearer token (admin privileges).
Parameters:

  • id: User ID (integer)
    Response: Role change confirmation or error message.

Contributors

  • Chayoot Kositwanich