Skip to content

A React App that detects, then highlights faces in web images. Including a user profile with image upload count and a Ranking Badge served from AWS Lambda

Notifications You must be signed in to change notification settings

Sonnyburni/smart-brain-api

Repository files navigation

Smart Brain Client

A React App that detects, then highlights faces in web images. Including a user profile with image upload count and a Ranking Badge served from AWS Lambda as a serverless function.

Built with React.js, Node.js, Express, Bcrypt, PostgreSQL, Redis, Tachyon CSS, Clarifai Face Detection API, and all running on Heroku Servers 'synched' with GitHub.

Back-end Server Repo Link: https://github.com/Sonnyburni/smart-brain

Thanks to Andrei Neagoie for creating the ZTM Web Developer Zero to Mastery and ZTM Junior to Senior Web Developer courses which SmartBrain is based on.

Since completing both courses and further personal development I have also updated the SmartBrain app further extensively, adding numerous updates, bug fixes etc. With the fundamental update being to adapt it to run 100% remotely with Heroku hosting the site in tandem with PostgreSQL DB, Redis DB and AWS Lambda servers too. I have also implemented validation for both email and password fields on sign up.


Demo

🚀 View Live Demo 🚀

<img src="" width="250" height="250"/>

How to use

You can use the following test login details (ensure lowercase as case sensitive)
Email: hello@world.com
Password: world


Please note: Site may take a few seconds to initially load due to using Heroku .

Or you can click on the 'Register' tab and create your own new login details to use instead.

Once logged in simply copy, then paste an image url from the web (example: https://i.natgeofe.com/n/a66a4e3e-ba36-4ca1-bfb3-a3751bfaf110/83704.jpg) into the search input field, then click the 'DETECT' button to run the Face Detection API.

Each time you upload an image the 'Total Images Submitted' value is incremented by +1. You can view the current total in the 'View Profile' tab, along with the 'Current Rank 'Badge', which is fed from AWS Lambda as a serverless function.

The Rank Badge updates based on the current image upload count.

Total Images Submitted Current Rank 'Badge'
0 😐
1 😃
2 😀
3 😊
4 😉
5 😍
6 🔶
7 🔷
8 or over 🚀

Features

  • Multi-Face Detection using Clarifai Face Detection API

  • Ranking badge element served from external AWS Lambda as a serverless function

  • User authentication using JSON Web Tokens (JWT)

  • With a Redis Database for Token Management

  • User profile with capture of image uploads, stored via a PostgreSQL Database

  • TS Particles for background animation

  • Parallax tilt for interactive site logo

  • Form validation

  • Bcrypt user password encryption/decryption to/from PostgreSQL Database

  • Editable user profile

About

A React App that detects, then highlights faces in web images. Including a user profile with image upload count and a Ranking Badge served from AWS Lambda

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published