Skip to content

Commit

Permalink
Docs: Add documentation for docker setup
Browse files Browse the repository at this point in the history
  • Loading branch information
sandviklee committed Jan 4, 2024
1 parent 1da0217 commit 1897385
Showing 1 changed file with 72 additions and 19 deletions.
91 changes: 72 additions & 19 deletions backend/README.md
Original file line number Diff line number Diff line change
@@ -1,18 +1,70 @@
# Backend

## Django Basics

How to generate project:

```bash
django-admin startproject tutorai
cd tutorai
```

## How to run the server
## Docker

For ease of use and version management control, we use Docker to keep track of our containers and virtual environments.

#### Our Project

Our project uses docker to run the PostgreSQL server (database) and the Django Server.

#### Download Docker

To use docker, download docker engine [here](https://www.docker.com/get-started/)

#### How to run the Backend

To run the backend write the following commands in the terminal

To build the project:

```bash
docker-compose build
```

To run the project:

```bash
python manage.py runserver
docker-compose up
```

#### Migrate the DB

To migrate django to the database

```bash
docker-compose run tutorai python manage.py migrate
```

#### Create superuser

To log into the django database, create a superuser

```bash
docker-compose run tutorai python manage.py createsuperuser
```

And follow the steps it gives you.

#### Finish!

Now you can access the django server through

```bash
http://127.0.0.1:8000/admin/
```

Enjoy!

## How to create a new application in the backend

To create a new application This command creates a new directory named "api" within your "backend" directory, along with the basic files needed for a Django app.
Expand All @@ -32,30 +84,31 @@ INSTALLED_APPS = [

Develop Your App: Now that your app is set up, you can start building its models, views, templates, URLs, etc


## Backend Structure

The backend of our project is organized into several Django apps, each dedicated to handling a specific set of functionalities within our TutorAI platform. Below is an overview of the directory structure and the role of each component:

### Directory Overview

- `backend/`
- `api/` - This app serves as the gateway for our RESTful API, defining the endpoints that the frontend will consume. It is where serializers and viewsets are defined to expose our models over HTTP.
- `migrations/` - Contains database migrations for the `api` app, allowing changes to be tracked and propagated to the database schema.
- `admin.py` - Configuration for the Django admin interface specific to the `api` app.
- `apps.py` - Configuration file for the `api` application, including any app-specific settings.
- `models.py` - Defines the data models for the `api` app, which Django ORM will use to construct database tables.
- `tests.py` - Contains tests for the `api` app to ensure endpoints work as expected.
- `views.py` - Contains the views for the `api` app that handle requests and return responses.

- `documents/` - Responsible for managing document-related functionalities, such as PDF uploads and storage.
- Similar structure to `api/` with `migrations/`, `models.py`, `views.py`, etc.
- `backend/`

- `api/` - This app serves as the gateway for our RESTful API, defining the endpoints that the frontend will consume. It is where serializers and viewsets are defined to expose our models over HTTP.
- `migrations/` - Contains database migrations for the `api` app, allowing changes to be tracked and propagated to the database schema.
- `admin.py` - Configuration for the Django admin interface specific to the `api` app.
- `apps.py` - Configuration file for the `api` application, including any app-specific settings.
- `models.py` - Defines the data models for the `api` app, which Django ORM will use to construct database tables.
- `tests.py` - Contains tests for the `api` app to ensure endpoints work as expected.
- `views.py` - Contains the views for the `api` app that handle requests and return responses.
- `documents/` - Responsible for managing document-related functionalities, such as PDF uploads and storage.

- Similar structure to `api/` with `migrations/`, `models.py`, `views.py`, etc.

- `tutorai/` - The core app that includes settings and root configurations for the entire backend project.

- `tutorai/` - The core app that includes settings and root configurations for the entire backend project.
- Similar structure to `api/` but also includes global settings like `settings.py` and root URL configurations in `urls.py`.
- Similar structure to `api/` but also includes global settings like `settings.py` and root URL configurations in `urls.py`.

- `users/` - Manages user authentication, profiles, and permissions. It is crucial for handling user data securely and efficiently.
- Similar structure to `api/` with `migrations/`, `models.py`, `views.py`, etc.
- `users/` - Manages user authentication, profiles, and permissions. It is crucial for handling user data securely and efficiently.

- Similar structure to `api/` with `migrations/`, `models.py`, `views.py`, etc.

- `manage.py` - A command-line utility that lets you interact with this Django project in various ways, such as running the server or creating migrations.
- `manage.py` - A command-line utility that lets you interact with this Django project in various ways, such as running the server or creating migrations.

0 comments on commit 1897385

Please sign in to comment.