Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/popcodelab/mdd_mvp

Minimized social network for developers - MVP (Minimum Viable Product)
https://github.com/popcodelab/mdd_mvp

angular angular-material backend flexbox-css java jpa json jwt-authentication jwt-token material-ui oauth2 reactiveforms rest-api restful scss spring-mvc spring-security springboot sql

Last synced: about 2 months ago
JSON representation

Minimized social network for developers - MVP (Minimum Viable Product)

Awesome Lists containing this project

README

        

# MDD
## Table of contents

- Description and goals
- App features
- Installation
- Database setup
- Run application
- Swagger (OpenAPI)
- Technologies
- Compodoc
- Screenshots

## Description and goal

MDD (Monde de Dév) is a social network project dedicated to developers:
Project developed as part of the development of a project for my master's degree.
This repository contains both the frontend and backend code for a Minimum Viable Product version.

## App features

### User management
- User registration
- Profile management
- User session
- Logout

### Topic management
- List all topics
- Subscribe to topic
- Unsubscribe from topic

### Post management
- View feed with sort by date or by title
- Create post
- Read post details
- Comment post

## Installation

### Clone the Project

Clone these repositories :
> git clone https://github.com/popcodelab/MDD_MVP

### Install Dependencies

#### Back-End:

> mvn clean install

#### Front-End:

> npm install

### Configuring the Back-End

Open the `application.yml` file located in the `back/src/main/resources` directory to Replace the properties with your parameters or using an `.env` file :

```properties
spring:
datasource:
url: jdbc:mysql://${APP_DB_HOST}:${APP_DB_PORT}/${APP_DB_NAME}
username: ${APP_DB_USER}
password: ${APP_DB_PASS}

...

application:
security:
jwt:
secret: ${JWT_SECRET_KEY}
expiration: ${JWT_EXPIRATION}

client:
url: ${CLIENT_URL}

server:

port: ${APP_BACKEND_PORT}

```

here is an example of `.env` file :

```properties
APP_DB_HOST=localhost
APP_DB_PORT=3306
APP_DB_NAME=database_name
APP_DB_USER=user_name
APP_DB_PASS=passowrd
JWT_SECRET_KEY=your_secret_key
JWT_EXPIRATION=86400000
CLIENT_URL=http://localhost:4300
APP_BACKEND_PORT=3005
```

## Database setup

Make sure that you have MySQL installed on your system.

1. Log into MySQL using the following command :
> mysql -u `` -p

2. Create the database :

> CREATE DATABASE ``;

3. Select the created database :
> USE ``;

### Build the database

Use the SQL script located in `ressources\sql\creates_db.sql` to create the schema :

> SOURCE ``;

## Run application

1. Frontend

- In your terminal, run the command below.

```bash
cd front
npm run start
```

The frontend will launch in your browser at `http://localhost:4400`

2. Backend

- In a separate terminal, run the command below.

```bash
cd back
mvn spring-boot:run
```

The backend server will launch at `http://localhost:3005`

---

## Swagger documentation

Once the backend started, the documentation can be browsed at : http://localhost:3005/swagger-ui/index.html

Use the authentication endpoint to get a JWT token to access to the protected routes.

## Technologies

HTML5
HTML5

TypeScript 5.4.3
TypeScript

JavaScript
JavaScript

CSS3
CSS3


Angular 17.3.8
Angular 14.1.3


Compodoc 1.1.25
CompoDoc 1.1.23


Angular Material 17.3.0
Angular Material 14.1.0


MySQL 8
MySQL 8


Java 17
Java 17


Spring Boot 3.3.0
Spring Boot 3.3.0

## Compodoc

To generate the documentation, if compodoc is not installed, follow the instructions bellow :

instal compodoc : `npm install @compodoc/compodoc`

Once installed :
- To generate the documentation run the command : `npm run compodoc`
- To Serve it on http://127.0.0.1:8080 : `npm run compodoc:serve`

![Compodoc](./front/src/assets/screenshots/compodoc.png)

## Authors

POP's Code Lab

## Screenshots

Welcome
Register
Login
Topics
Write a post
List of posts
Profile
Responsive

---
Front-end :
![Static Badge](https://img.shields.io/badge/Angular-17.3.8-red)

Back-end :
![Static Badge](https://img.shields.io/badge/Java-17.0.10-orange)
![Static Badge](https://img.shields.io/badge/Spring_Boot-3.3.0-green)
![Static Badge](https://img.shields.io/badge/Maven-4.0.0-purple)

![Swagger](https://img.shields.io/badge/-Swagger-%23Clojure?style=for-the-badge&logo=swagger&logoColor=white)




[![forthebadge](https://forthebadge.com/images/badges/build-with-spring-boot.svg)](https://forthebadge.com)
[![forthebadge](https://forthebadge.com/images/badges/uses-git.svg)](https://forthebadge.com)
[![forthebadge](https://forthebadge.com/images/badges/made-with-typescript.svg)](https://forthebadge.com)
[![forthebadge](https://forthebadge.com/images/badges/made-with-java.svg)](https://forthebadge.com)
![MySQL](https://img.shields.io/badge/mysql-4479A1.svg?style=for-the-badge&logo=mysql&logoColor=white)