Skip to content

Latest commit

 

History

History
306 lines (290 loc) · 6.77 KB

README.md

File metadata and controls

306 lines (290 loc) · 6.77 KB

ShelfSync_backend

Databases

  • MongoDB Atlas
  • AWS S3

API Documentation

GET "/"

Check API status

Request

  • Headers: None
  • Body: None

Response

  • Status: 200 OK
  • Body: OK

POST "/auth/login"

Log user in and retrieve JWT Token

Request

  • Headers: None
  • Body: { email: string, password: string }

Response

  • Status:
    • 200 OK if login is successful
    • 401 Unauthorized if email or password is incorrect
  • Body: { "token": <JWTSessionToken> }

POST "/auth/register"

Register a new user and retrieve JWT Token

Request

  • Headers: None
  • Body: { name: string, email: string, password: string }

Response

  • Status:
    • 201 Created if registration is successful
    • 409 Conflict if user already exists
  • Body: { "token": <JWTSessionToken> }

GET "/spaces"

Retrieve all spaces for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body: None

Response

  • Status:
    • 200 OK if spaces are retrieved successfully
    • 401 Unauthorized if the user is not authenticated
  • Body:
    [
      {
        "_id": "string",
        "user_id": "string",
        "name": "string",
        "description?": "string",
        "coords1": number[2],
        "coords2": number[2],
        "superSpace": Space,
        "subSpaces": Space[],
        "thingList": Thing[]
      }
    ]
    

GET "/spaces/:id"

Retrieve a specific space by ID for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body: None

Response

  • Status:
    • 200 OK if space are retrieved successfully
    • 401 Unauthorized if the user is not authenticated
    • 404 Not Found if the space is not found
  • Body:
    {
      "_id": "string",
      "user_id": "string",
      "name": "string",
      "description?": "string",
      "coords1": number[2],
      "coords2": number[2],
      "superSpace": Space,
      "subSpaces": Space[],
      "thingList": Thing[]
    }
    

POST "/spaces"

Create a new space for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
    • Body:
    {
      "name": "string",
      "description?": "string",
      "coords1": number[2],
      "coords2": number[2],
      "superSpace": Space,
      "image?" File
    }

Response

  • Status:
    • 201 Created if space are created successfully
    • 401 Unauthorized if the user is not authenticated
  • Body:
    {
      "_id": "string",
      "user_id": "string",
      "name": "string",
      "description?": "string",
      "coords1": number[2],
      "coords2": number[2],
      "superSpace": Space,
      "subSpaces": Space[],
      "thingList": Thing[],
      "image?": URL
    }
    

PUT "/spaces/:id"

Update a specific space by ID for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body:
    {
      "name?": "string",
      "description?": "string",
      "coords1?": number[2],
      "coords2?": number[2],
      "superSpace?": Space,
      "subSpaces?": Space[],
      "thingList?": Thing[],
      "image?": File
    }

Response

  • Status:
  • 200 OK if space are updated successfully
  • 401 Unauthorized if the user is not authenticated
  • 404 Not Found if the space is not found
  • Body:
  {
    "_id": "string",
    "user_id": "string",
    "name": "string",
    "description?": "string",
    "coords1": number[2],
    "coords2": number[2],
    "superSpace": Space,
    "subSpaces": Space[],
    "thingList": Thing[],
    "image?": URL
  }

DELETE "/spaces/:id"

Delete a specific space by ID for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body: None

Response

  • Status:
  • 200 OK if space are updated successfully
  • 401 Unauthorized if the user is not authenticated
  • 404 Not Found if the space is not found
  • Body:
{
  "message": "Space deleted successfully"
}

GET "/things"

Retrieve all things for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Query Params:
    • ?recursive: boolean, if true, recursively return all things in subspaces
    • ?space: string, if provided, returns from specific space
  • Body: None

Response

  • Status:
    • 200 OK if things are retrieved successfully
    • 401 Unauthorized if the user is not authenticated
    • 404 Not Found if the space is not found
  • Body:
    [
      {
        "_id": "string",
        "user_id": "string",
        "name": "string",
        "description?": "string",
        "space": Space,
        "image?": "string"
      }
    ]
    

GET "/things/:id"

Retrieve a specific thing by ID for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body: None

Response

  • Status:
    • 200 OK if thing are retrieved successfully
    • 401 Unauthorized if the user is not authenticated
    • 404 Not Found if the thing is not found
  • Body:
    {
      "_id": "string",
      "user_id": "string",
      "name": "string",
      "description?": "string",
      "space": Space,
      "image?": "string"
    }
    

POST "/things"

Create a new thing for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
    • Body:
    {
      "name": "string",
      "description?": "string",
      "space": "string",
      "image?": File
    }

Response

  • Status:
    • 201 Created if thing are created successfully
    • 401 Unauthorized if the user is not authenticated
    • 404 Not Found if the space is not found
  • Body:
    {
      "_id": "string",
      "user_id": "string",
      "name": "string",
      "description?": "string",
      "space": Space,
      "image?": URL
    }
    

PUT "/things/:id"

Update a specific thing by ID for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body:
    {
      "name?": "string",
      "description?": "string",
      "space?": "string",
      "image?": File
    }

Response

  • Status:
  • 200 OK if thing is updated successfully
  • 401 Unauthorized if the user is not authenticated
  • 404 Not Found if the thing is not found
  • Body:
  {
    "_id": "string",
    "user_id": "string",
    "name": "string",
    "description?": "string",
    "space": Space,
    "image?": URL
  }

DELETE "/spaces/:id"

Delete a specific thing by ID for the authenticated user

Request

  • Headers:
    • Authorization: Bearer <JWTSessionToken>
  • Body: None

Response

  • Status:
  • 200 OK if thing is deleted successfully
  • 401 Unauthorized if the user is not authenticated
  • 404 Not Found if the thing is not found
  • Body:
{
  "message": "Thing deleted successfully"
}