Skip to content

Latest commit

 

History

History
58 lines (38 loc) · 2.45 KB

README.md

File metadata and controls

58 lines (38 loc) · 2.45 KB

Untis-Google

Used to synchronize webuntis events with your Google calendar. Requires a running server with NodeJS.

Functionality

Enters your specified webuntis lessons in your Google calendar with room and teacher. Cancelled lessons will be marked red.

Step by step instruction

Download or clone the repository

Download a release and unzip it.

Setting up .env.sample

Go onto webuntis and search for your school

image

Click on the school and copy the URL.

image

  1. Paste the URL at SCHOOLURL="".

Follow this introduction until step 7.

Then open your credentials.json, make everything into one line and paste it at CREDS=

Next go to Google Calendar.

  1. Create a new calendar
  2. Open the settings of the new calendar
  3. Go to "Share with specific people" and click on "Add people"
  4. Enter the "client_email" from your credentials.json and set the permissions to "Make changes and manage sharing"
  5. Now scroll "Integrate calendar" and copy the "Calendar ID" to CALENDAR_ID=

Next add the time interval the calendar shall update, it is recommended to use 30min or more. Then add the classes you want to add to your calendar in the short form that you will find on webuntis, seperated with a comma or leave empty for all classes. Lastly enter a range of days in which the synchronisation takes place.

Your file should look something like this (outdated): image

Finally save the file as .env without ".sample"

Run the program

  1. Run npm install to get all the required dependencies
  2. Run npm run start to start the program on your server
  3. Use npm run rewrite to delete all calendar events and add them again

Have fun.

Pushsaver integration (optional)

If you want push notifications you can use a pushsaver integration for your program. Click here for more information.

  1. Change PUSHENABLED= from 'false' to 'true' in your .env file
  2. Enter your API Key as well as your device ID
  3. (Re)start the program