Webhooks bieten eine einfache Möglichkeit, wie Apps über einen http-Endpunkt von anderen Diensten über Ereignisse benachrichtigt werden können. In diesem Teil unseres Workshops nutzen wir die Webhook-Funktion von GitHub zum Aktualisieren einer Wiki-Seite.
Ein fertig definierter Webhook bei GitHub, der ein Wiki über Änderungen am Repository informiert.
(Bild: Drilling / GitHub)
Auf GitHub lassen sich Webhooks für eine Organisation oder ein ausgewähltes Verzeichnis einrichten. Ausgelöst wird der Webhook immer dann, wenn mindestens ein oder mehrere der abonnierten Ereignisse auftreten.
Für unseren Zweck interessant ist hier das Ereignis „Gollum“. Damit kann der Entwickler einen Webhook erstellen, der z. B. auf Updates für sein GitHub-Wiki in Bezug auf die Erstellung und Aktualisieren einer Wiki-Seite horcht. Dazu navigiert man in GitHub zur Seite „Settings“ seines Repositorys im GitHub-Portal und klickt auf „Webhooks“ …
Webhooks sind eine in GitHub integrierte Funktion.
(Bild: Drilling / GitHub)
… und dort auf die Schaltfläche „Add webhook“. Auf der entsprechenden Seite sind nun einige Einstellungen vorzunehmen. Dazu muss man sich zunächst grundsätzlich darüber im Klaren sein, was man unter einem Event versteht und welche Event-Typen z. B. GitHub unterstützt, denn Events sind der Dreh- und Angelpunkt bei Webhooks. Sie treten z. B. auf, wenn im Repository Aktionen durchgeführt werden.
In diesem Fall wird der Webhook ausgelöst, ruft die bei „Payload URL“ angegebene URL auf und sendet die Nutzlast sowie weitere Ereignisinformationen an diese URL. Sämtliche von GitHub unterstützten Webhook-Ereignisse und Informationen dazu, wann diese ausgeführt werden können, finden sich auf der GitHub-Seite „Webhook events and payloads“.
Die Konfigurations-Seite für einen GitHub-Webhook.
(Bild: Drilling / GitHub)
Kommen wir also zurück zu den Einstellungsmöglichkeiten auf der GitHub-„Add webhook“-Seite. Die betreffenden Begrifflichkeiten sind Folgende: Bei der „Payload URL“ handelt es sich also um die URL des Servers, die die Webhook-POST-Anforderungen empfängt.
Jeder Ereignistyp hat dabei ein bestimmtes Nutzlast-Format. Diese Nutzlast enthält dann die Informationen über das Ereignis, das den Webhook ausgelöst hat. Wir haben die URL unseres http-Triggers für die Azure-Function in Teil 1 unseres Workshops ermittelt. Sie sieht etwa so aus:
Wir wollen unsere externe Azure-Function über Änderungen auf der Wiki-Seite informieren.
(Bild: Drilling / GitHub)
Bei „Content type“ geht es darum, dass Webhooks anhand zweier verschiedener Inhaltstypen übermittelt werden: Mit dem Inhaltstyp „application/json“ wird die JSON-Nutzlast direkt als Text der POST-Anforderung übermittelt. Mit dem Inhaltstyp „application/x-www-form-urlencoded“ wird die JSON-Nutzlast als Formular-Parameter mit dem Namen „Nutzlast“ übermittelt.
Der fertig konfigurierte Webhook auf GitHub.
(Bild: Drilling / GitHub)
Bei „Which events would you like to trigger this webhook?“ wählen wir dann die Option „Let me select individual events.“ und setzen dort ein Häkchen bei „Wiki“, um auf Updates im Wiki unseres Repository zu lauschen. Hierbei handelt es sich dann exakt um das oben erwähnte Gollum-Event. Dann klicken wir auf „Add webhook“. Das Ergebnis sollte etwa so aussehen, wie in der vorangestellten Abbildung.
Webhook testen
Ein erster Test unseres Webhooks.
(Bild: Drilling / GitHub)
Zum Testen unseres Webhooks klicken wir im GitHub-Portal für unser Repository auf die Registerkarte „Wiki“, wählen dort die zuvor von uns erstellte Seite aus und klicken auf „Bearbeiten“. Dort geben wir z. B. „Webhook Test“ ein.
Die Request-Playload unseres Webhooks.
(Bild: Drilling / GitHub)
Dann navigieren wir wieder zu „Einstellungen / Webhooks“, wo wir einen entsprechenden Push-Eintrag finden. Dort klicken wir auf „Edit“ und navigieren dann zum Abschnitt „Recent Deliveries“. Hier ist zunächst nur eine ID der Form „a18aa670-49c7-11eb-836f-4c9fe122677e“ zu sehen. Klickt man dort aber auf die drei Punkte rechts, sehen wir auch „Header“ und „Payload“ im Reiter „Request“ ….
Der Response-Body der Antwort auf den Webhook.
(Bild: Drilling / GitHub)
… sowie „Header“ und „Body“ im Reiter „Response“, jeweils mit dem erfolgreichen http-Status-Code 200. Zudem können wir der Payload z. B. auch die Detail-Information entnehmen, dass unsere Wiki-Seite bearbeitet wurde. Die Nutzlast besteht aus den Abschnitten „pages“, „repository“, und „sender“.
Fazit
In diesem Teil des Workshops haben wir gesehen, wie wir auf Gollum-Ereignisse in unserem GitHub-Repository, speziell auf Änderungen an der Wiki-Seite horchen können, indem wir einen passenden Webhook auf GitHub einrichten. In Teil 1 haben wir zudem gezeigt, wie eine serverlose Azure-Function durch einen externen http-Trigger ausgelöst werden kann.
Im dritten Teil werden wir die Nutzlast aus dem Ereignis „Gollum“ genauer betrachten, um dann unsere Azure-Funktion so anzupassen, dass sie die Payload aus dem Webhook-Event in unserem Sinne analysiert und passend darauf antwortet.
Stand: 08.12.2025
Es ist für uns eine Selbstverständlichkeit, dass wir verantwortungsvoll mit Ihren personenbezogenen Daten umgehen. Sofern wir personenbezogene Daten von Ihnen erheben, verarbeiten wir diese unter Beachtung der geltenden Datenschutzvorschriften. Detaillierte Informationen finden Sie in unserer Datenschutzerklärung.
Einwilligung in die Verwendung von Daten zu Werbezwecken
Ich bin damit einverstanden, dass die Vogel IT-Medien GmbH, Max-Josef-Metzger-Straße 21, 86157 Augsburg, einschließlich aller mit ihr im Sinne der §§ 15 ff. AktG verbundenen Unternehmen (im weiteren: Vogel Communications Group) meine E-Mail-Adresse für die Zusendung von Newslettern und Werbung nutzt. Auflistungen der jeweils zugehörigen Unternehmen können hier abgerufen werden.
Der Newsletterinhalt erstreckt sich dabei auf Produkte und Dienstleistungen aller zuvor genannten Unternehmen, darunter beispielsweise Fachzeitschriften und Fachbücher, Veranstaltungen und Messen sowie veranstaltungsbezogene Produkte und Dienstleistungen, Print- und Digital-Mediaangebote und Services wie weitere (redaktionelle) Newsletter, Gewinnspiele, Lead-Kampagnen, Marktforschung im Online- und Offline-Bereich, fachspezifische Webportale und E-Learning-Angebote. Wenn auch meine persönliche Telefonnummer erhoben wurde, darf diese für die Unterbreitung von Angeboten der vorgenannten Produkte und Dienstleistungen der vorgenannten Unternehmen und Marktforschung genutzt werden.
Meine Einwilligung umfasst zudem die Verarbeitung meiner E-Mail-Adresse und Telefonnummer für den Datenabgleich zu Marketingzwecken mit ausgewählten Werbepartnern wie z.B. LinkedIN, Google und Meta. Hierfür darf die Vogel Communications Group die genannten Daten gehasht an Werbepartner übermitteln, die diese Daten dann nutzen, um feststellen zu können, ob ich ebenfalls Mitglied auf den besagten Werbepartnerportalen bin. Die Vogel Communications Group nutzt diese Funktion zu Zwecken des Retargeting (Upselling, Crossselling und Kundenbindung), der Generierung von sog. Lookalike Audiences zur Neukundengewinnung und als Ausschlussgrundlage für laufende Werbekampagnen. Weitere Informationen kann ich dem Abschnitt „Datenabgleich zu Marketingzwecken“ in der Datenschutzerklärung entnehmen.
Falls ich im Internet auf Portalen der Vogel Communications Group einschließlich deren mit ihr im Sinne der §§ 15 ff. AktG verbundenen Unternehmen geschützte Inhalte abrufe, muss ich mich mit weiteren Daten für den Zugang zu diesen Inhalten registrieren. Im Gegenzug für diesen gebührenlosen Zugang zu redaktionellen Inhalten dürfen meine Daten im Sinne dieser Einwilligung für die hier genannten Zwecke verwendet werden. Dies gilt nicht für den Datenabgleich zu Marketingzwecken.
Recht auf Widerruf
Mir ist bewusst, dass ich diese Einwilligung jederzeit für die Zukunft widerrufen kann. Durch meinen Widerruf wird die Rechtmäßigkeit der aufgrund meiner Einwilligung bis zum Widerruf erfolgten Verarbeitung nicht berührt. Um meinen Widerruf zu erklären, kann ich als eine Möglichkeit das unter https://contact.vogel.de abrufbare Kontaktformular nutzen. Sofern ich einzelne von mir abonnierte Newsletter nicht mehr erhalten möchte, kann ich darüber hinaus auch den am Ende eines Newsletters eingebundenen Abmeldelink anklicken. Weitere Informationen zu meinem Widerrufsrecht und dessen Ausübung sowie zu den Folgen meines Widerrufs finde ich in der Datenschutzerklärung.