Skip to content
/ statum Public

🗺️ A data-driven website oriented around Twitch. Written in Python + Flask, with MongoDB.

License

Notifications You must be signed in to change notification settings

k9mil/statum

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 

Repository files navigation

What is statum? 🗺️

statum, a side project, is a web app built in Python, Flask & MongoDB which serves as a tool to make the usage of Twitch more enjoyable, with unique features & the ability to get in-depth information of your most beloved streamers.

Preview

Below you can see a few screenshots from the current UI, though subject to change.

Home Page Dashboard
Home Page Dashboard
Random VODs
Random VODs
Streamer Page Favourite VODs
Streamer Page favVODs

Features

  • Incorporated Twitch OAuth, which allows for your followers to be loaded instantaneously.
  • Ability to view a random twitch stream between 10 and 100 viewers to help to support smaller streamers.
  • An aesthetically pleasing dashboard with a list of your followed streamers, top streamers & top circulating LSF clips.
  • If the streamer is live, it displays the category they are in & length of stream.
  • List of VODs for each streamer.
  • List of the current most popular twitch clips, alongside with their metrics.
  • Unique Streamer Data insights for each streamer on the platform.
  • Utilization of MongoDB for indexing streamers to minimize the amount of requests & user sessions.
  • Ability to add streamers to favourites.
  • See VODs of your favourite streamers.

& much more!

Working on

The backlog of the features yet to be implemented are available on a public Trello workspace which can be viewed at statum, board.

Demo Server

A demo server is available, on a DigitalOcean droplet, alongside a custom load-balanced multi architecture built with Docker, Nginx & uWSGI: statum. *note: may or may not be up-to-date (or down).

Installation process

If you wish to run this web app locally, Python will be necessary for you to be able to run this web application.

MongoDB is necessary for the functionality of the web app, so some knowledge is required and MongoDB is required to be installed on your local machine.

  1. To host this web app, you need to register a Twitch Application which will server as the basis of this program.
  2. After you have registered the Twitch Application, you have to click "Manage" and locate the "CLIENT ID" which you can paste in the config.py file.
  3. Generate an OAuth token, after that, you have to put that in the config.py file aswell.
  4. Open your terminal/command line where the source code for statum is located.
  5. Install the dependencies needed via "pip install -r requirements.txt" (if that doesn't work, try pip3 instead of pip)
  6. Setup the app for flask: $env:FLASK_APP="statum"
  7. Setup the environment variables for flask: "$env:FLASK_ENV="development" (optional, debug mode)
  8. Run the flask web app via "flask run".

After that, you're set.

Contributing

If you wish to contribute, f.e, making an improvement to this web app, then feel free to make a pull request as this app definitely has a lot of flaws. Or, alternatively, you can open an issue :)

License

Licensed under the MIT License - see the LICENSE file for more details.

About

🗺️ A data-driven website oriented around Twitch. Written in Python + Flask, with MongoDB.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published