Skip to content

ccrsxx/autobsi

Repository files navigation

autobsi is a script that allows you to automatically attend your class on the My Best BSI site. It features a scheduler that will automatically start the script when your class starts, it is also able to run when you are inside your class schedule. You can run it on your computer or host it on a cloud server like Heroku.

Prerequisites

Make sure you have installed all of the following prerequisites on your machine:

Setup

First before running the script. You need to set up the src/config.json to allow the script to log in and attend the class. Follow these steps:

  1. In the timetable section, you can find days for classes that you have to take per week. Change those days based on your schedule. Make sure it's written in English and typed correctly.
  2. Inside the timetable you can find the name, time, and link. The name is for your class name, you can name it whatever you want here. The time is your class schedule, it's a list that consists of when your class starts and ends, it's formatted as 'HH:MM' i.e '12:30'. The link is the URL of the class that you attend, you can get it on My Best in your class attendance section.
  3. The last section is the username (nim) and password. This data is used to allow the script to log in to your My Best Account.

Cloud tutorial coming soon...

Note: If you have multiple classes a day, you will need to wrap your class name, time, and link to a list. The time section is always a list, so it's nested inside a list when you have more than one class a day. See the example at Thursday class on the default src/config.json.

Installation

Follow all these steps shown below to use the script.

  1. Clone this repository. Run:

    git clone https://github.com/ccrsxx/autobsi.git
  2. Change the directory to the autobsi folder. Run:

    cd autobsi
  3. Install the dependencies with pip. Run:

    pip install -r requirements.txt
  4. Install the webdriver for selenium. Run:

    python setup.py
  5. Run the script:

    python main.py

Note: If you are running the script locally or on a Windows machine, follow these additional steps in the main.py:

  1. Change the get method from get_from_heroku to get_from_config.
  2. Change the cloud parameter from True to False.
  3. Change the mail parameter from True to False to prevent an authentication error traceback. If you have a google mail API, don't change this parameter.