Skip to content

ICS server for Elbphilharmonie Favorites

License

Notifications You must be signed in to change notification settings

fabianzw/elphi-calendar

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Elphi Calendar

Docker Image MIT License

This simple Go server generates an ICS version of your favorites for the Elbphilharmonie.

Quick Start

The quickest way to run the calendar API is to use the docker container:

docker run -p 8080:8080 ghcr.io/codello/elphi-calendar

This will run the app on port 8080. You can now access your calendar at

http://localhost:8080/merkliste/<user-id>

See the next paragraph on how to find your user ID.

The User ID

The Elbphilharmonie favorite lists of every user is accessible without authentication. All you need is the user’s ID. To find your ID, you can do the following:

  • Open your web browser, go to Your Account.

  • Open the JavaScript Console and enter elbphilharmonie.ActivityId. This will display an activity id in your console. Copy the value (whithout quotes).

  • Run the following command that will print your account ID:

    ACTIVITY_ID=<your activity ID>
    curl -sS "https://shop-services.elbphilharmonie.de/Activities/validateactivityid.json?ActivityId=$ACTIVITY_ID" | jq -r .User.UserId

Caching

The elphi-calendar will cache event details (but not your favorites list) for one day. This dramatically reduces the number of API calls and increases update speed. The disadvantage is that changes to events will only become visible after up to a day.

Building the Project

This project is written in Go. To compile it run

# Install Dependencies
go mod download
# Compile the package
go build ./cmd/elphi-calendar

About

ICS server for Elbphilharmonie Favorites

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 97.8%
  • Dockerfile 2.2%