Skip to content

Latest commit

 

History

History
90 lines (63 loc) · 3.13 KB

README.md

File metadata and controls

90 lines (63 loc) · 3.13 KB

API ENV SETUP

Run in Postman

Db dump and setup

  • Dump Folder : /db - Manually Import db to mysql
  • Setup : update .env with your mysql user pwd

database.default.hostname = YOUR_HOST
database.default.database = YOUR_DB_NAME
database.default.username = YOUR_DB_USERNAME
database.default.password = YOUR_DB_PASSWORD
database.default.DBDriver = MySQLi

Summary

The idea of the app is that a user can register/login to the App and is able to create new notes and to update/delete previous ToDos. ToDos themselves are simple entity which has a title, description and timestamps.

All routes are defined in app/Config/Routes

Frontend

Design Choices

All controllers extend BaseController.

  • Login screen :
    only accessible to guest users
    Once user is validated creates jwt and logged them in

  • Register screen :
    accessible to guest users

  • ToDo list
    Display tasks
    Add/delete/ edit tasks

Directory Structure

| Directory               | Purpose                                     |
|:-----------------------:|:-------------------------------------------:|
| App\Controllers         | handles frontend request                    |
| App\view                | respond with the corresponding view         |
| public\assets\css       | contain entire frontend application styling |                        
| public\assets\css       | Contain entire frontend application styling |            

Backend

Design Choices

All controllers extend BaseAPIController.

Brief logic overview:

  • Ensure the JSON Web Token is present and valid.
  • Run a validation check.
  • Convert response to an array.
  • Display converted response to user.

Namespace Breakdown

| Namespace               | Purpose                                     |
|:-----------------------:|:-------------------------------------------:|
| App\Controllers\API     | Assist with API endpints                    |
| App\Controllers\API     | Assist with API endpints                    |
| App\Models              | Assist with db operation                    |
| App\Traits              | Contain small repetative logic              |              
| App\Helpers             | Contain small repetative logic              |            

Contributing

We welcome contributions from the community.

Please read the Contributing to CodeIgniter section in the development repository.

Server Requirements

PHP version 7.3 or higher is required, with the following extensions installed:

  • intl
  • libcurl if you plan to use the HTTP\CURLRequest library

Additionally, make sure that the following extensions are enabled in your PHP:

  • json (enabled by default - don't turn it off)
  • mbstring
  • mysqlnd
  • xml (enabled by default - don't turn it off)