Skip to content

Latest commit

 

History

History
149 lines (92 loc) · 5.07 KB

README.md

File metadata and controls

149 lines (92 loc) · 5.07 KB

vmbloggr

A blogger's delight

Built using a combination of Django and DRF (the Django Rest Framework), vmbloggr is a RESTful API that serves as the backend server for a simple blogging platform. It allows users to

  • Register and login to the API
  • Create blog posts
  • Get a list of blog posts from the database
  • View the details of each post
  • Update existing blog posts
  • Delete existing blog posts

1. Project structure

The project structure follows a typical Django setup:

users/

User management - creation, authentication, update and deletion of user accounts

blog/

Content management - creation, listing, update and deletion of blogs by authorised users

grbloggr/

Main project directory

manage.py

Django's command-line utility for administrative tasks.

2. Features

Authentication: Users can register to create new accounts, login, update their accounts and logout.
Content Creation: Users can create new blog posts with titles, content, and author information. Users can update and delete their blog posts as well!

3. Installation

  • Get a copy of the source code of this project into your local repository.
git clone https://github.com/KelvinJC/vmbloggr.git
  • The code will be packaged in a directory named vmbloggr so change into that directory
cd vmbloggr
  • To begin using the application, initiate the server by running the following command to build and run the containers in one go
docker compose up --build 

4. Usage

By default, Django apps listen on port 8000 so once the server is running, copy and paste http://127.0.0.1:8000/api into your preferred browser.

To prevent clashes on port 8000, make sure no other Django app is running on localhost.

Django Admin User

This step is not critical to the usage of the app but if you are familiar with the Django Admin UI you can make use of an already created superuser

username = Admin
password = Admin

To access the Django Admin UI visit http://127.0.0.1:8000/admin

5. Documentation

While the default Django DRF documentation is available, the preference for this project is Swagger docs.
vmbloggr relies on Swagger for documentation which can be accessed at

http://127.0.0.1:8000/api/docs/swagger

You can view the full documentation of the API as well as interact with all its endpoints (even to authenticate a user!)
just as you would on Postman or any other API client.

Authentication and Authorisation.

JWT authentication ensures that users are properly authenticated. This serves to ensure that only authors can update or delete their posts

Database choice

This project makes use of a Postgres database which is within a separate docker container for persistent storage of blog posts as well as user information.

If you require a different database, customisation is possible via the settings.py file.

Credentials and .env files:

No credentials should be stored in code repositories!
They belong in .env files which must be kept secret and remain local to the appropriate context (e.g. dev, test or prod).

The admin credentials above as well as the .env file in this project were committed to the repo in this unique case to facilitate your ease in spinning up the dockerised app.

Automated tests.

Tests are pretty important. To aid test-driven development, vmbloggr comes with a test suite in each app.
Tests have been written for each endpoint of the API. To run all tests, at the moment, it is preferable to run the project locally i.e without starting the docker containers.

  1. Navigate to the src directory
cd src
  1. Run the relevant django management command to initiate all current django tests
python manage.py test

System design

The system consists of an NGINX web server to handle HTTP requests from a client browser. It in turn forwards these requests to the Django application server through an intermediary Gunicorn web server gateway interface. The persistence layer is a Postgres database. This handles data query requests from the application server.

The gateway interface and application server reside within the same Docker container while the database and web server rest in separate Docker containers. Since all services share a single Docker Compose configuration file, they share the same network within a host OS.

POSSIBLE ERROR ON WINDOWS OS: Container exits right after build

This can be fixed by taking the following steps:

  1. Open the project in VSCode, navigate to the shell script at this path

vmbloggr/docker/vmbloggr/server-entry.sh

  1. If the file ending indicator on the bottom right displays CRLF, click on it and switch to LF. (Look at the screenshot below.)

  2. Then rerun the docker compose up --build command at the project's root directory. (It is a file ending error associated with pushing shell scripts to a git repo from a Windows OS)