Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/thesaltree/blog-capital

Personal blog platform
https://github.com/thesaltree/blog-capital

authentication-middleware blog-platform express frontend fullstack mysql next-cookies nextjs nodejs react relational-databases responsive-design styled-components

Last synced: 3 months ago
JSON representation

Personal blog platform

Awesome Lists containing this project

README

        

# Personal Blog Platform

## Table of Contents
1. [Introduction](#Introduction)
2. [Project Structure](#project-structure)
3. [Prerequisites](#prerequisites)
4. [Getting Started](#getting-started)
5. [Application Components](#application-components)
- [Backend](#backend)
- [Frontend](#frontend)
- [Database](#database)
6. [Authentication](#authentication)
7. [Development](#development)
8. [Testing](#testing)
9. [Continuous Integration](#continuous-integration)
10. [Troubleshooting](#troubleshooting)
11. [Screenshots](#screenshots)

## Introduction
This project is a monorepo containing a full-stack blog application with a Next.js frontend, Express.js backend, and MySQL database.

![Screenshot 2024-08-08 at 0 45 25](https://github.com/user-attachments/assets/e9d054d6-3c34-43aa-a33b-349fa8d532d4)

## Project Structure
The project follows a monorepo structure:

```
blog-capital/
├── applications/
│ ├── frontend/ # Next.js TypeScript frontend
│ ├── backend/ # Express.js backend
│ └── db/ # MySQL database scripts
├── infrastructure/
│ ├── k8s/ # Kubernetes configuration files (not implemented)
│ └── terraform/ # Terraform configuration files (not implemented)
|── .github/
| └── workflows/ # GitHub Actions CI/CD workflows
└── docker-compose.yml
```

**Note:** Due to time constraints, the Kubernetes and Terraform configurations for deploying in a cloud environment are not implemented. The `docker-compose.yml` file is used to define the development environment.

## Prerequisites
- [Docker](https://www.docker.com/products/docker-desktop)
- [Git](https://git-scm.com/downloads)
- [Make](https://www.gnu.org/software/make/) (usually pre-installed on macOS and Linux)

## Getting Started
1. Clone the repository:
```bash
git clone https://github.com/thesaltree/blog-capital
cd blog-capital
```

2. Build the project:
```bash
make build
```

3. Start the development environment:
```bash
make up
```
This step takes time for initialization.

4. Access the applications:
- Frontend: http://localhost:3001
- Backend: http://localhost:3000

## Application Components

### Backend
The Express.js backend provides the following API endpoints:

- `POST /signup`: User registration
- `POST /login`: User authentication
- `GET /posts`: Retrieve all posts
- `POST /post`: Create a new post
- `GET /posts/:id`: Get details of a specific post
- `GET /posts?author=:authorId`: Get all posts by a specific author

### Frontend
The Next.js frontend includes the following pages:

- `/`: Home page (SSR) - displays all posts
- `/login`: Login page (CSR)
- `/signup`: Signup page (CSR)
- `/posts/:id`: Post details page (ISR)
- `/posts/dashboard`: User dashboard (CSR) - create posts and view own posts
- `/authors/:id`: Author posts (CSR) - filtered posts by author

### Database
The application uses MySQL as its database. The schema is defined in `applications/db/init.sql`.

#### Schema

| Table Name | Column Name | Data Type | Constraints |
|------------|--------------|-----------|-------------------------------------------------------|
| user | id | INT | PRIMARY KEY, AUTO_INCREMENT |
| | name | VARCHAR(255) | NOT NULL |
| | email | VARCHAR(255) | UNIQUE, NOT NULL |
| | passwordHash | VARCHAR(255) | NOT NULL |
| post | id | INT | PRIMARY KEY, AUTO_INCREMENT |
| | title | VARCHAR(255) | NOT NULL |
| | content | TEXT | |
| | authorId | INT | NOT NULL, FOREIGN KEY (references user.id) |
| | createdAt | TIMESTAMP | DEFAULT CURRENT_TIMESTAMP |
| | updatedAt | TIMESTAMP | DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP |

#### Indexes
- `PRIMARY KEY` on `id` for both `user` and `post` tables
- `UNIQUE` index on `user.email`
- Index `idx_post_authorId` on `post.authorId` for improved query performance

#### Relationships
- `post.authorId` is a foreign key that references `user.id`, establishing a one-to-many relationship between users and posts.

#### Initial Data
The `init.sql` script also includes sample data:
- 3 users are created with example email addresses and hashed passwords
- 5 posts are created and associated with three of the sample users

#### Usage
To interact with the database during development:

1. Access the database shell:
```bash
make db-shell
```

2. Once in the MySQL shell, you can run queries, e.g.:
```sql
SELECT * FROM user;
SELECT * FROM post;
```

## Authentication
The application uses JWT (JSON Web Tokens) for authentication. Tokens are stored in the cookies which is secure and works with sever-side checks and sent with each request to the backend. Passwords are hashed using bcrypt before storage in the mysqldb.

## Development
Use the following commands to manage the development environment:

```bash
# Start the development environment
make up

# Stop the development environment
make down

# View logs
make logs

# Access the database shell
make db-shell

# Clean up containers and volumes
make clean
```

## Testing
Frontend tests have been written in Jest. Use the following command in the frontend directory to run tests:

```bash
npm test
```

## Continuous Integration
This project uses GitHub Actions for continuous integration. The workflow includes the following steps:

1. Install dependencies for both frontend and backend:
```bash
npm install
```

2. Run linting for both frontend and backend:
```bash
npm run lint
```

3. Run tests for the frontend:
```bash
npm test
```

These checks are automatically run on every push to the repository and pull request to ensure code quality and catch potential issues early.

## Troubleshooting
If you encounter any issues:

1. Ensure Docker is running and up-to-date
2. Check the logs using `make logs`
3. Try cleaning and rebuilding the environment:
```bash
make clean
make build
make up
```

## Screenshots
![Screenshot 2024-08-08 at 0 45 25](https://github.com/user-attachments/assets/c7c133da-9bd6-4fba-8673-5c7596b7d971)

![Screenshot 2024-08-08 at 0 46 13](https://github.com/user-attachments/assets/d82fb26a-d220-41e1-b66f-91f2d8189d63)

![Screenshot 2024-08-08 at 0 46 27](https://github.com/user-attachments/assets/d2b112eb-c576-424d-86fc-f6b34b72f9f2)

![Screenshot 2024-08-08 at 0 46 59](https://github.com/user-attachments/assets/8a338258-2554-4f25-a8b4-e942c2ab9e39)

![Screenshot 2024-08-08 at 0 47 26](https://github.com/user-attachments/assets/f68c2cdc-e795-4793-a3a8-e7d7253bed5f)

![Screenshot 2024-08-08 at 0 47 57](https://github.com/user-attachments/assets/23f2b5f9-c36d-4cae-b999-84f8edee38be)

![Screenshot 2024-08-08 at 0 44 53](https://github.com/user-attachments/assets/aa6d58e7-9f08-42ca-8d47-14ff38236103)