Skip to content

Latest commit

 

History

History
447 lines (354 loc) · 7.37 KB

README.md

File metadata and controls

447 lines (354 loc) · 7.37 KB

Go REST Server

Learning Go by building a TODO REST server with PostgreSql.


Database

db name: go_todo

table/s:

CREATE TABLE Tasks (
  task_id SERIAL,
  description TEXT NOT NULL,
  status VARCHAR(40) DEFAULT 'On-going',
  deadline TIMESTAMP,
  date_added TIMESTAMP DEFAULT NOW(),
  archive BOOLEAN DEFAULT FALSE,
  PRIMARY KEY (task_id)
);

Environment Variable/s

  • POSTGRESURL - database URL.
    • example: postgresql://user:password@host/db_name

Endpoints

GET /task/:taskId

Retrieves a task from the database by its ID, provided it is not archived. Requires the "taskId" parameter in the endpoint. It responds with the task details in JSON format or an error message if the task is not found or if there is a failure in querying the database.

Response:

StatusOk

{
  "task_id": 8,
  "description": "Feed the pets",
  "status": "On-going",
  "deadline": "2024-09-08T00:00:00Z",
  "date_added": "2024-06-29T19:03:00.226263Z"
}

StatusNotFound

{ "message": "Task not found" }

StatusInternalServerError

{
  "message": "Failed to query task",
  "error":   "Error object",
}

GET /tasks/all

Retrieves a list of tasks from the database where the deadline is in the future. It responds with a JSON array of tasks or an error message in case of a failure.

Response:

StatusOk

[
  {
    "task_id": 6,
    "description": "Another Task",
    "status": "On-going",
    "deadline": "2024-12-25T00:00:00Z",
    "date_added": "2024-06-29T12:54:54.404224Z"
  },
  {
    "task_id": 7,
    "description": "Another Task",
    "status": "On-going",
    "deadline": "2024-12-25T00:00:00Z",
    "date_added": "2024-06-29T19:02:02.769241Z"
  },
  {
    "task_id": 8,
    "description": "Feed the pets",
    "status": "On-going",
    "deadline": "2024-09-08T00:00:00Z",
    "date_added": "2024-06-29T19:03:00.226263Z"
  }
]

StatusInternalServerError

{
  "message": "Failed to query task",
  "error":   "Error object",
}

GET /tasks/archived

Retrieves a list of archived tasks from the database. It responds with a JSON array of archived tasks or an error message in case of a failure.

Response:

StatusOk

[
  {
    "task_id": 1,
    "description": "Task 1",
    "status": "Done",
    "deadline": "2024-06-24T12:00:00Z",
    "date_added": "2024-06-14T16:27:25.941532Z"
  },
  {
    "task_id": 2,
    "description": "Task 2",
    "status": "Done",
    "deadline": "2024-06-26T12:00:00Z",
    "date_added": "2024-06-14T16:27:25.941532Z"
  },
  {
    "task_id": 3,
    "description": "Task 3",
    "status": "Done",
    "deadline": "2024-12-25T00:00:00Z",
    "date_added": "2024-06-23T14:43:56.601526Z"
  }
]

StatusInternalServerError

{
  "message": "Failed to query task",
  "error":   "Error object",
}

GET /tasks/count

Counts all active tasks in the database where the deadline is in the future and the task is not archived. Responds with the task count or an error message in case of a failure.

Response:

StatusOk

[Integer]

StatusInternalServerError

{
  "message": "Failed to query task",
  "error":   "Error object",
}

GET /tasks/late

Retrieves a list of tasks from the database where the deadline has already passed. It responds with a JSON array of late tasks or an error message in case of a failure.

Response:

StatusOk

[
  {
    "task_id": 9,
    "description": "love them all",
    "status": "On-going",
    "deadline": "2024-02-14T00:00:00Z",
    "date_added": "2024-06-29T19:03:20.884892Z"
  }
]

StatusInternalServerError

{
  "message": "Failed to query task",
  "error":   "Error object",
}

GET /tasks/late/count

Counts all late tasks in the database where the deadline has passed and the task is not archived. Responds with the count of late tasks or an error message in case of a failure.

Response:

StatusOk

[Integer]

StatusInternalServerError

{
  "message": "Failed to query task",
  "error":   "Error object",
}

DELETE /task/:taskId

Deletes a task from the database by its ID. Requires the "taskId" parameter in the endpoint. It responds with a success message or an error message in case of a failure.

Response:

StatusOk

{ "message": "Task deleted successfully" }

StatusNotFound

{ "message": "Task not found" }

StatusInternalServerError

{
  "message": "Failed to convert int to string",
  "error":   "Error object",
}
{
  "message": "Failed to delete task",
  "error":   "Error object",
}

PATCH /task/done/:taskId

Marks a task as done and archives it in the database by its ID. Requires the "taskId" parameter in the endpoint. It responds with a success message or an error message in case of a failure.

Response:

StatusOk

{ "message": "Task archived successfully" }

StatusNotFound

{ "message": "Task not found" }

StatusInternalServerError

{
  "message": "Failed to convert int to string",
  "error":   "Error object",
}
{
  "message": "Failed to archive task",
  "error":   "Error object",
}

PATCH /task/archive/:taskId

Archives a task in the database by its ID. Requires the "taskId" parameter in the endpoint. It responds with a success message or an error message in case of a failure.

Response:

StatusOk

{ "message": "Task archived successfully" }

StatusNotFound

{ "message": "Task not found" }

StatusInternalServerError

{
  "message": "Failed to convert int to string",
  "error":   "Error object",
}
{
  "message": "Failed to archive task",
  "error":   "Error object",
}

PATCH /task/unarchive/:taskId

Unarchives a task in the database by its ID. Requires the "taskId" parameter in the endpoint. It responds with a success message or an error message in case of a failure.

Response:

StatusOk

{ "message": "Task unarchived successfully" }

StatusNotFound

{ "message": "Task not found" }

StatusInternalServerError

{
  "message": "Failed to convert int to string",
  "error":   "Error object",
}
{
  "message": "Failed to unarchive task",
  "error":   "Error object",
}

POST /create

Creates a new task in the database. It responds with a success message or an error message in case of a failure.

Request:

{
  "description": "",
  "deadline": ""
}

Response:

StatusOk

{ "message": "Task created successfully" }

StatusInternalServerError

{
  "message": "Failed to bind JSON",
  "error":   "Error object",
}
{
  "message": "Failed to create task",
  "error":   "Error object",
}

PUT /task/update

Updates a specific task in the database based on the provided JSON request format. The task to update is identified implicitly from the context of the request body. Responds with a success message or an error message in case of a failure.

Request:

{
  "task_id": 10,
  "description": "new year",
  "deadline": "2024-01-01"
}

Response:

StatusOk

{ "message": "Task updated successfully" }

StatusNotFound

{ "message": "Task not found" }

StatusInternalServerError

{
  "message": "Failed to bind JSON",
  "error":   "Error object",
}
{
  "message": "Failed to update task",
  "error":   "Error object",
}