Blog engine for my personal blog at : https://ayzminy.blog.
The core folder is the backend of the server. It's written with Rust and uses Actix web. The ORM used is diesel combined to r2d2 for the connection pool.
It implements the following features :
- Registers an Article metadata on the database.
- Listing all registered articles.
- Requesting a registered article via its
uuid
.
The app is a React app.
The app request the core for articles and generates the page using react-markdown
to take into account the content.
A postgres database must be setup. You can do so quickly with a docker image :
docker run -e POSTGRES_USER=blogdev -e POSTGRES_DB=blogdb -e POSTGRES_PASSWORD=blogdev -p 5432:5432 postgres:latest
Additionally, some packages might be required :
sudo apt install -y libpq-dev build-essential
Running the core doing cargo run :
DATABASE_URL="postgresql://blogdev:[email protected]:5432/blogdb" RUST_LOG=info cargo run
DATABASE_URL
must be specified.- You can choose the log level with
RUST_LOG
. PORT
(Optional), can also be specified, default at 8080.
Specifying the React APP url env variable :
the app/blog/.env
file specifies the REACT_APP_API_URL
which is set to communicate with the core at http://127.0.0.1:8080/
.
Running the React app with npm run :
npm install
npm run
The docker engine and Docker compose must be installed to run the core.
Database URL : The database URL must be specified so that the server can connect to it.
Database credentials : The database credentials are also needed.
React App API URL : The react app API url, which is basically the API url access to the core. REACT_APP_API_URL
Creating a random password for postgres :
openssl rand -hex 20 > db_secrets.txt
A docker compose file is available to run directly the postgres with the precedently created password, the core and the app :
docker compose -f compose.yaml build
docker compose -f compose.yaml up
For development purposes another compose file is available:
docker compose -f compose.dev.yaml build
docker compose -f compose.dev.yaml up
Create an issue please 😄 ! I'll take care of it ASAP!! Some of the things that I'm working on adding:
- Adding units tests for the API
- Adding fuzzing targets as an example
- Adding github workflow for transparency build with rust builder and SLSA
- Implementing a search on the rendered articles (Must be optimized)
- Tags filtering (Ongoing)