Skip to content

Latest commit

 

History

History
437 lines (343 loc) · 6.59 KB

README.md

File metadata and controls

437 lines (343 loc) · 6.59 KB

Twain Backend

The backend for the Twain scheduling app

Makefile commands

  • make: Runs make build and make run
  • make build: Builds the docker container
  • make run: Runs the server and postgres
  • make run_background: Runs the server and postgres in the background (i.e. you will see no output)
  • make stop: If you run make run_background, use this to stop the server
  • make p_shell: Opens an interactive psql shell connected to our postgres instance
  • make reset_db: CAUTION THIS WILL DELETE ALL DATA IN THE DB. Use when you change schemas and you are ok losing data. Tables will be recreated on the next re-start of server.

Note: Both make p_shell and make reset_db can only be run while the server is running

How to do authorized requests

Use the access_token from Chrome to do requests

  • Add Authorization: Bearer <ACCESS_TOKEN> to the header of the request

API Definitions

User Model Definition

{
  "id": <TWAIN_USER_ID>,
  "first_name": "<user_first_name>",
  "last_name": "<user_last_name>",
  "email": "<user_email>",
  "google_id": "<user_google_id>",
  "picture_url": "<profile_picture_url_from_google>",
  "hours_start": "<time_to_begin_scheduling_tasks, formatted as hh:mm (initially null)>",
  "hours_end": "<time_to_end_scheduling_tasks, formatted as hh:mm (initially null)>",
  "primary_calendar": "<primary_calendar_of_user>",
  "relevant_calendars": "<comma_separated_relevant_calendars_of_user>",
  "created_at": "<CREATED_AT_TIMESTAMP>",
  "updated_at": "<UPDATED_AT_TIMESTAMP>"
}

Create new user

POST /api/users/signup (No access token in header needed for this request)

{
  "token": "<ACCESS_TOKEN_FROM_CHROME>"
}

returns

{
  "data": <USER_MODEL_ABOVE>,
  "message": "<ERROR_MESSAGE>",
}

Get user info of logged in user

GET /api/users/me

returns

{
  "data": <USER_MODEL_ABOVE>,
  "message": "<ERROR_MESSAGE>",
}

Modify current user's scheduling hours of availability

POST /api/users/hours

{
  "start": <hour_to_begin_scheduling_tasks>,
  "end": <hour_to_end_scheduling_tasks>
}

returns

{
  "data": <USER_MODEL_ABOVE>,
  "message": "<ERROR_MESSAGE>",
}

Modify current user's preference for scheduling on weekends

POST /api/users/weekend

{
  "weekend_setting": <true_or_false>
}

returns

{
  "data": <USER_MODEL_ABOVE>,
  "message": "<ERROR_MESSAGE>",
}

Modify current user's primary calendar

POST /api/users/calendars/primary

{
  "primary_calendar": "<primary_calendar_of_user>"
}

returns

{
  "data": <USER_MODEL_ABOVE>,
  "message": "<ERROR_MESSAGE>",
}

Modify current user's relevant calendars (to avoid conflicts in Twain)

POST /api/users/calendars/relevant

{
  "relevant_calendars": "<comma_separated_relevant_calendars_of_user>"
}

returns

{
  "data": <USER_MODEL_ABOVE>,
  "message": "<ERROR_MESSAGE>",
}

Get all calendars for a user

GET /api/users/calendars/

returns

{
  "data":
    [
      {
          "id": "<calendar_1_id>",
          "summary": "<calendar_1_summary>"
      },
      {
          "id": "<calendar_2_id>",
          "summary": "<calendar_2_summary>"
      },
      ...
    ],
  "message": "<ERROR_MESSAGE>",
}

Task Model

{
  "id": <task_id>,
  "user_id": <TWAIN_USER_ID>
  "name": "<task_name>",
  "description": "<task_description>",
  "duration": <task_duration_in_minutes>,
  "due_date": <timestamp>,
  "completed": <boolean>,
  "completed_time": <timestamp>,
  "scheduled": <boolean>,
  "scheduled_time": <timestamp>,
  "calendar_id" <google_calendar_id>,
  "event_id": <google_event_id>,
  "start_time": <timestamp>,
  "end_time": <timestamp>,
  "created_time" <timestamp>,
  "updated_time" <timestamp>
}

Create new task

POST /api/tasks/

{
  "name": "<task_name>"
  "description": "<task_description>",
  "duration": <task_duration_in_minutes>
}

returns

{
  "data": <TASK_MODEL_ABOVE>,
  "error": "<ERROR_MESSAGE>"
}

Get task by ID

GET /api/tasks/{id}

returns

{
  "data": <TASK_MODEL_ABOVE>,
  "error": "<ERROR_MESSAGE>"
}

Get all tasks for a user

GET /api/tasks/me

returns

{
  "data": {
    "not_scheduled": [
      <TASK_MODEL_ABOVE>,
      <TASK_MODEL_ABOVE>,
      ...
    ],
    "scheduled": [
      <TASK_MODEL_ABOVE>,
      <TASK_MODEL_ABOVE>,
      ...
    ]
  },
  "error": "<ERROR_MESSAGE>"
}

Note: _not_scheduled is ordered by most recently added at the top _scheduled is ordered by increasing chronological order

Set Tasks Complete by ID (Array of IDs)

POST /api/tasks/complete

{
	"ids": [<array_of_task_ids>]
}

returns

{
    "data": [
      <TASK_MODEL_ABOVE>
      <TASK_MODEL_ABOVE>,
      ...
    ],
    "error": "<ERROR_MESSAGE>"
}

Get all completed tasks for a user

GET /api/tasks/completedTasks

returns

{
    "data": [
      <TASK_MODEL_ABOVE>,
      <TASK_MODEL_ABOVE>,
      ...
    ],
    "error": "<ERROR_MESSAGE>"
}

Delete Tasks by ID (Array of IDs)

POST /api/tasks/delete

{
	"ids": [<array_of_task_ids>]
}

returns

{
	"data": "Success" (if successful, otherwise null),
	"error": "<ERROR_MESSAGE(S)>"
}

Note: This will also remove scheduled events from the user's Google Calendar.

Edit Task by ID

PATCH /api/tasks/{id}

{
  "name": "<task_name>",
  "description": "<task_description>",
  "duration": <task_duration_in_minutes>,
  "due_date": <timestamp>
}

Note: Not all above fields needed, only fields being changed

returns

{
  "task": <TASK_MODEL_ABOVE>,
  "error": "<ERROR_MESSAGE>"
}

Schedule Tasks (Array of Task objects)

POST /api/schedule

{
  "ids": [<array_of_task_ids>],
  "timeMin": <ISO String (UTC)>,
  "timeZone": <timezone string>
}

returns

{
    "data": [
      <TASK_MODEL_ABOVE>,
      <TASK_MODEL_ABOVE>,
      ...
    ],
    "error": "<ERROR_MESSAGE>"
}

POST /api/schedule/confirm

{
  "good_ids": [<array_of_task_ids>],
  "force": [
        {
	 "id": <task_id>,
         "time": <ISO String (UTC)>
	},
	...
   ],
  "timeZone": <timezone string>
}

returns

{
    "data": [
      <TASK_MODEL_ABOVE>,
      <TASK_MODEL_ABOVE>,
      ...
    ],
    "error": "<ERROR_MESSAGE>"
}

Create Event

POST /api/events/

{
  "name": "<event_name>"
}

returns

{
  "data": {
    "id": <event_id>,
    "created_at": <timestamp>
    "name": "<event_name>"
  },
  "error": "<ERROR_MESSAGE>"
}

Get event by ID

GET /api/events/{id}

returns

{
  "data": {
    "id": <event_id>,
    "created_at": <timestamp>
    "name": "<event_name>"
  },
  "error": "<ERROR_MESSAGE>"
}