Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/pixelcaliber/musical-couscous

ToDo App using PHP, symfony, mysql and redis could be used to maintain day-to-day tasks or list everything that we have to do and we can add more new tasks and delete the old ones once they are complete.
https://github.com/pixelcaliber/musical-couscous

docker mysql nginx php redis session-management symfony

Last synced: 1 day ago
JSON representation

ToDo App using PHP, symfony, mysql and redis could be used to maintain day-to-day tasks or list everything that we have to do and we can add more new tasks and delete the old ones once they are complete.

Awesome Lists containing this project

README

        

# ToDo App using PHP, symfony, mysql and redis

#### Could be used to maintain day-to-day tasks or list everything that we have to do and we can add more new tasks and delete the old ones once they are complete.

- User can login and register, session is stored in form of cookies and added to redis
- Utilized mysql as database for storing users and their tasks, one-to-many mapping
- Utilized redis to store sessions as a central cache storing service for all the instances to minimize cache miss
- Created multiple instances of the application using nginx
- Utilized Docker to containerize the application
- User can archive and unarchive tasks anytime they want

#### Tech-Stack: PHP, symfony, redis, nginx, Mysql, docker

Primary Product requirements:

1. User should be able login and signup to the application.
2. Users can view a comprehensive list of all tasks in their to-do list.
3. Users can easily add new tasks to their to-do list, specifying relevant details like title, description, due date.
4. Users can edit existing tasks to update details such as title, description, due date as needed.
5. User should be able to remove the items from the todo list once he/she is done with the task.

Secondary product requirements:

1. Users can set reminders or notifications for important tasks to ensure timely completion.
2. Users can attach files or links to tasks for additional reference or context.
3. Users can archive tasks for future reference or to maintain a record of completed tasks.

NF requirements:

1. Data consistency should be maintained while dealing with large number of users and there long todo lists.
2. Availability should also be maintained for the todo application.
3. The application should have secure authentication to prevent unauthorized access to user accounts.
4. The application should be fault tolerant and secure the user data to prevent loss or corruption and provide a restoration process.
5. Scalability should also be considered when dealing with large amount of users and large volume of task items.

## Summary

* Create APIs for user registration and login to the web application. User credentials will be stored in mysql in the Users table.
* Once user is logged in, the home page will have the dashboard with user to-do list.
* Add more task button could be used to add more tasks into the to-do list.
* Delete task button will mark that task as complete and remove it from the list.
* Archive task button will mark it achieved and move it to the archive page.
* User can go to the archive page to see all the archived tasks.
* Tasks will have attributes like title, created by, due date, description, etc which can be updated by the user if it wants.
* Tasks will be stored in mysql database based on user_id.
* Since we have strong relationship between the user and the task we are using the relational database as it seems good fit for us.
* We’ll create a new table for the archive tasks based on the user_id and store them into that table this will help us to reduce the load on our unarchived task table.
* We can use NGINX as load balancer and reverse proxy for our server.

## API Contracts:

```
POST /login
req
{
"username": String,
"password": String
}
res: this api returns a Response type object with cookies set to sessionID

GET /login
- this api render the login.html.twig page
```

```
POST /register
req
{
"username": String,
"password": String
}
res: this api redirects to login page

GET /register
- this api renders the register.html.twig page
```

```
GET /logout
- this api returns a Response type object with refreshed cookies
```

```
POST /addTask
req
{
"title": String,
"description": String,
"IsArchived": Boolean,
"dueDate": String,
}
- this api add new task into the Task entity
- after successful addition redirects to '/' route
```

```
GET /deleteTask/{taskId}

- this api deletes a particular task based on taskId only if it belongs to the logged in user
- after successful deletion redirects to '/' route
```

## Database

### User
User Table Model

* User entity stores the user credentials such as username, password.
* We generate a new UUID and assign it to every new user.
* id is primary key
* We have creates index on username to find user by username quickly

### Task

User Table Model

* Task entity stores the task created by the users
* id is the primary key
* user_id is the foreign key referencing to the user table
* media would be the url of media files if user wants to add some images etc to their tasks
* created_at is an autogenerated timestamp of time of creation of a task.

How to handle archived tasks?

Using a boolean flag in the main task table:

Advantages:

* Simplifies data management by keeping all tasks in a single table.
* Avoids the need for additional database operations to move tasks between tables.
* Can be more efficient for smaller datasets or applications with less frequent archiving.

Disadvantages:

* May lead to performance issues as the size of the main task table grows, especially if there are frequent queries filtering by the isArchived flag.
* Can make querying for active tasks more complex, as you need to filter out archived tasks explicitly.
* May result in decreased query performance over time as the size of the table increases.

How to prevent slow queries of task?

To optimize the query speed and time for retrieving all tasks belonging to a user based on user ID and where is_archived is true or false, we tried:

* Indexing: user_id column is indexed since we'll be frequently querying tasks based on this column.
* Composite Index: The combination of user_id and is_archived is used in queries, so we created a composite index on both columns.

Future Scope

* Have a notification system which can deliver reminders to users whenever there due date is close.
* Users can add images, or any other media items while creating tasks into there todo list.