/StackOverFlow--Clone

Fully Functional Stack Overflow Clone, with almost every functionality.

Primary LanguagePythonMIT LicenseMIT

StackOver Flow - Clone

GitHub stars GitHub license GitHub commit activity python3.x

Clone of Stack Overflow where I implemented nearly all of its functionalities. My intention was to provide insight and demonstration to developers on the inner workings of Stack Overflow - including how tasks are performed behind the scenes and how queries are executed..

Note: Please have a look at the Blog explaining What I learned from this Project?

Images

Demo

Here is a working live demo : Demo (Removed from heroku because usage of so's production LOGO)

Technology Stack

Functionalities

  • 50+ Badges are implemented to award

  • 20 Privileges to Earn

  • Track Badges

  • Reputation Awarding

  • Privilege and Activity Notifications

  • Live Q&A MarkDown Preview

  • User @mentioning in comments

  • Create and award Bounties

  • Threading to keep track of the remaining days of Bounty.

  • Reviewing Tasks :

    • First Question Review
    • First Answer Review
    • Late Answer Review
    • Review Flag Posts
    • Review Flag Comments
    • Review Close Votes
    • Review ReOpen Votes
    • Review Low-Quality Posts
    • Review Suggested Edits
  • And much more. You can find list of all functionalities Here

Setup Commands

Clone this repository

  1. Clone this project using
$ git clone https://github.com/Yawan-1/StackOverFlow--Clone

For Postgresql usage*, you will need to download and install it.

  1. Download Postgresql from this Link
  2. After installation, create Database in postgresql shell using these commands
    1. CREATE DATABASE so_clone;
    2. CREATE USER so_clone_user WITH PASSWORD 'password';
    3. GRANT ALL PRIVILEGES ON DATABASE so_clone TO so_clone_user;
  3. and fill database name , database password and user in settings.py like
DATABASES = {
  'default': {
      'ENGINE': 'django.db.backends.postgresql_psycopg2',
      'NAME': 'so_clone',
      'USER': 'so_clone_user',
      'PASSWORD': 'password',
      'HOST': 'localhost',
      'PORT': '',
  }
}

*Note: If you are setting up this project using sqlite, you have the option to bypass the postgresql installation step. To do so, please consider commenting out the postgresql configuration and uncommenting the sqlite configuration.

Now run make migrations command, running make migrations command will perform Data Migrations to save the "Badges" in the database. then migrate to load the operations of Data Migrations in database.

$ python manage.py makemigrations
$ python manage.py migrate

Migration Operations will be automatically created on migration creation to save Tags and Tag Badges.

Then, simply run the server using this command.

$ python manage.py runserver

Deployment

The following details and steps on how to deploy this application

Heroku

See detailed Deploying django app on Heroku

Contributing

If you have any question or issues, It may have bugs that i may have missed. You can create Pull request.

Note: Frontend and complete design is also inside this project's repo (html, css).