From 97a5a6180d8bf8565519de941daccd6ec5949b44 Mon Sep 17 00:00:00 2001 From: Philipp Dolif Date: Tue, 9 Aug 2022 16:56:57 +0200 Subject: [PATCH] Add GitHub webhook receiver #123 --- .../SocialBotManagerService.java | 2 + .../chat/github/GitHubWebhookReceiver.java | 69 +++++++++++++++++++ 2 files changed, 71 insertions(+) create mode 100644 social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/chat/github/GitHubWebhookReceiver.java diff --git a/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/SocialBotManagerService.java b/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/SocialBotManagerService.java index dee1b68c..885bec4d 100644 --- a/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/SocialBotManagerService.java +++ b/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/SocialBotManagerService.java @@ -86,6 +86,7 @@ import i5.las2peer.restMapper.annotations.ServicePath; import i5.las2peer.security.BotAgent; import i5.las2peer.services.socialBotManagerService.chat.*; +import i5.las2peer.services.socialBotManagerService.chat.github.GitHubWebhookReceiver; import i5.las2peer.services.socialBotManagerService.chat.xAPI.ChatStatement; import i5.las2peer.services.socialBotManagerService.database.SQLDatabase; import i5.las2peer.services.socialBotManagerService.database.SQLDatabaseType; @@ -240,6 +241,7 @@ protected void initResources() { getResourceConfig().register(BotModelResource.class); getResourceConfig().register(TrainingResource.class); getResourceConfig().register(this); + getResourceConfig().register(GitHubWebhookReceiver.class); } @POST diff --git a/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/chat/github/GitHubWebhookReceiver.java b/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/chat/github/GitHubWebhookReceiver.java new file mode 100644 index 00000000..c98571bf --- /dev/null +++ b/social-bot-manager/src/main/java/i5/las2peer/services/socialBotManagerService/chat/github/GitHubWebhookReceiver.java @@ -0,0 +1,69 @@ +package i5.las2peer.services.socialBotManagerService.chat.github; + +import i5.las2peer.api.Context; +import i5.las2peer.services.socialBotManagerService.SocialBotManagerService; +import i5.las2peer.services.socialBotManagerService.chat.ChatService; +import i5.las2peer.services.socialBotManagerService.model.Bot; +import i5.las2peer.services.socialBotManagerService.model.Messenger; +import i5.las2peer.services.socialBotManagerService.model.VLE; +import io.swagger.annotations.Api; +import net.minidev.json.JSONObject; +import net.minidev.json.JSONValue; + +import javax.ws.rs.HeaderParam; +import javax.ws.rs.POST; +import javax.ws.rs.Path; +import javax.ws.rs.PathParam; +import javax.ws.rs.core.Response; +import java.util.Collection; + +@Api(value = "GitHub Webhook Receiver Resource") +@Path("/github") +public class GitHubWebhookReceiver { + + /** + * Receives incoming webhook events from a GitHub app and sends them to related GitHub chat mediators. + * + * @param body Event + * @param eventName Name of event + * @param gitHubAppId Id of GitHub app + * @return 200 + */ + @POST + @Path("/webhook/{gitHubAppId}") + public Response receiveWebhookEvent(String body, @HeaderParam("X-GitHub-Event") String eventName, + @PathParam("gitHubAppId") int gitHubAppId) { + JSONObject payload = (JSONObject) JSONValue.parse(body); + + // put name of event and payload into one JSONObject + JSONObject eventObj = new JSONObject(); + eventObj.put("event", eventName); + eventObj.put("payload", payload); + + SocialBotManagerService service = (SocialBotManagerService) Context.get().getService(); + + // need to find bot(s) that use this GitHub app id + Collection vles = service.getConfig().getVLEs().values(); + for (VLE vle : vles) { + for (Bot bot : vle.getBots().values()) { + Messenger messenger = bot.getMessenger(ChatService.GITHUB_ISSUES); + if (messenger != null) { + GitHubIssueMediator mediator = (GitHubIssueMediator) messenger.getChatMediator(); + if (mediator.getGitHubAppId() == gitHubAppId) { + mediator.handleEvent(eventObj); + } + } + + messenger = bot.getMessenger(ChatService.GITHUB_PR); + if (messenger != null) { + GitHubPRMediator mediator = (GitHubPRMediator) messenger.getChatMediator(); + if (mediator.getGitHubAppId() == gitHubAppId) { + mediator.handleEvent(eventObj); + } + } + } + } + + return Response.status(200).build(); + } +}