Skip to content

Latest commit

 

History

History
134 lines (78 loc) · 3.06 KB

README.md

File metadata and controls

134 lines (78 loc) · 3.06 KB

A Bookstore Backend

This is a Book Store backend application implementing RESTful API and CRUD operations using Django Rest Framework, Python and SQLite3 as the database.



Prerequisites

  • Python=>3.10


Getting started

First, you will need to clone the project onto your local machine

  1. Create a new directory on your local machine.

  2. Navigate into the newly created directory and open a terminal here.

  3. You can now clone the repository using several ways;

#option 1 - HTTPS

git clone https://github.com/Asif-GD/a-django-book-store.git



#option 2 - Download.zip (in case you do not have git)

you will have the option to download the entire repository as an archived folder on github.com
  1. Navigate into the project directory; a-django-book-store-master. I will refer this as root directory
cd a-django-book-store-master
  1. Inside the root directory, let's setup the virtual environment for the project.
python -m venv venv
  1. Now, activate this virtual environment.
# windows machine

venv\Scripts\Activate

  

#mac/linux

source venv/bin/activate

You will know your virtual environment is active when your terminal displays the following:

(venv) <path\to\project>\a-django-book-store-master>
  1. Packages and requirements - This project will rely on a lot of 3rd party packages (requirements) to function. I have created a requirements.txt file. Check out /a-django-book-store-master/requirements.txt. Install them all using the command as below
pip install -r requirements.txt

This should successfully setup the project on your local machine and ready for use.

  1. Start the server. The command below is used to start our Django server on our local machine with default values of local host and port.
python manage.py runserver

You should now have a server running on http://127.0.0.1:8000/



Some Useful Links

  1. The local server - http://127.0.0.1:8000/
  2. Swagger UI - http://127.0.0.1:8000/api/schema/swagger-ui/
  3. ReDoc - http://127.0.0.1:8000/api/schema/redoc/
  4. Django admin interface - http://127.0.0.1:8000/admin/

Additional Information

  1. The credentials for the Django admin interface can be found in admin1_credentials.txt file; inside the meta_data folder in the project directory
\a-django-book-store\meta_data\admin1_credentials.txt
  1. Some sample data to be used when making API calls can be found in the sample_data folder; inside the meta_data folder in the project directory
\a-django-book-store\meta_data\sample_data


Features

1. Retrieve All Books with Filtering and Pagination (Read)

2. Retrieve a Single Book with Related Data (Read)

3. Create a New Book (Create)

4. Update a Book with Transactions (Update)

5. Delete a Book with Soft Deletion (Delete)

6. User authentication and authorization using a token-based system, allowing only authorized users to perform CRUD operations.

7. Caching of frequently requested data to improve API performance.