//Calendar implementation for the HTWK Leipzig timetable. Evaluation and display of the individual dates in iCal format. //Copyright (C) 2024 HTWKalender support@htwkalender.de //This program is free software: you can redistribute it and/or modify //it under the terms of the GNU Affero General Public License as published by //the Free Software Foundation, either version 3 of the License, or //(at your option) any later version. //This program is distributed in the hope that it will be useful, //but WITHOUT ANY WARRANTY; without even the implied warranty of //MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //GNU Affero General Public License for more details. //You should have received a copy of the GNU Affero General Public License //along with this program. If not, see . package main import ( "github.com/gofiber/fiber/v3" "github.com/gofiber/fiber/v3/log" "github.com/gofiber/fiber/v3/middleware/logger" "htwkalender/ical/model" "htwkalender/ical/service" "htwkalender/ical/service/connector/grpc" ) // main function for the ical service // uses rest api to get the data from the data-manager // exposes rest api endpoints with fiber to serve the data for clients func main() { const host = "htwkalender-data-manager" grpcClient := grpc.ConnectGRPCServer(host) defer grpc.CloseGRPCServer(grpcClient) // Initialize a new Fiber app webdavRequestMethods := []string{"PROPFIND", "MKCOL", "COPY", "MOVE"} fiberApp := fiber.New(fiber.Config{ CaseSensitive: true, StrictRouting: true, ServerHeader: "Fiber", AppName: "App Name", RequestMethods: append(fiber.DefaultMethods[:], webdavRequestMethods...), }) var app = model.AppType{ GrpcClient: grpcClient, Host: host, Fiber: fiberApp, DataManagerURL: "http://" + host + ":8090", } fiberApp.Use(logger.New()) // Add routes to the app instance for the data-manager ical service service.AddFeedRoutes(app) log.Fatal(fiberApp.Listen(":8091")) }