Main idea standing behind this project is to allow any registered user upload memes. There is only one restriction: each user can upload one meme at a time and won't be allowed to upload another one until the last uploaded "dies". After lifecycle of the meme ends it is deleted from the servers and the user can upload new meme again. Likes and dislikes gathered by the uploaded content are stored permanently.
- Node.js
- Express
- PostgreSQL
- Sequelize
- Vue
- Vuex
- VueRouter
- Buefy/Bulma
- SASS/SCSS
- Webpack
- Mocha
- Chai
- Chai-http
Frontend |
---|
Navbar with: Logo, Add, Categories[dropdown] and if session inactive (Sign In, Sign Up) if active (profile, Log Out) |
Background with memes |
News feed |
News object: title, category, image, author, like, dislike |
Pagination if sites count > 1 |
Communicaton with rest api: fetching memes by (category or category and page or page) + pagination, fetching user info, fetching categories into navbar and add meme form in select input, fetching likes and dislikes for each meme (inluding logged user opinion) |
Add meme form: title {1,50} characters, category (Games, Black Humor, Other [if you want then add more]), image file |
Registration form: Username max 20 characters, Password min 8 characters, one min one big letter, min one number (added regex), password confirmation, recaptcha |
Login form: Username, Password, field for error |
Profile info site: username, join date, likes and dislikes |
Backend |
---|
Made 4 models: user, meme, category and vote |
Made session for 1 hour |
Made schedule job which delete all memes older than 1 hour every minute |
Configured database with Sequelize |
Exported sql database into src/config folder |
Middleware wrappers which executes function if session is active or inactive |
REST api for fetching memes, votes, categories and for upload memes and evaluate them |
Used 3 http methods, GET for getting json informations, POST for login/registration/add meme, PUT for evaluate memes |
Controller checking recaptcha |
Testing |
---|
Made test for authentication which check result on correct and incorrect authorization |
Made tests for user model which check validation |
Made test which ckeck if user was insert into database correct |
Made some integration tests which check add meme functionality |
- Make RWD for all pages
- Make more beautiful design
- Learn how to write better BEM
- Learn more about semantics
- Make report meme system
- Search and resolve all vulnerabilities
- Make protection from website flooding
- Learn more about S.O.L.I.D and clean code
- Contrib note: DDD or EDD
- Learn more about TDD
- Write code with TDD more often
- Learn something about other testing metodologies
- Learn how to write better tests
- Make more tests for this project
- Install postgres on your computer. tutorial If you use other system than Ubuntu then search alternative tutorial.
- Create new database, name it e.g memento
-
$ psql memento < src/config/database.pgsql
-
$ sudo npm install --unsafe-perm
-
$ npm run build
- You have to generate recaptcha keys and insert these into src/config/recaptcha.js this file looks:
module.exports = { SECRET: 'your_secret_key', SITE: 'your_key_on_website' };
-
$ node app.js
- Enter browser to address: localhost:8081