2 // ========================LICENSE_START=================================
5 // Copyright (C) 2022: Nordix Foundation
7 // Licensed under the Apache License, Version 2.0 (the "License");
8 // you may not use this file except in compliance with the License.
9 // You may obtain a copy of the License at
11 // http://www.apache.org/licenses/LICENSE-2.0
13 // Unless required by applicable law or agreed to in writing, software
14 // distributed under the License is distributed on an "AS IS" BASIS,
15 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 // See the License for the specific language governing permissions and
17 // limitations under the License.
18 // ========================LICENSE_END===================================
28 "github.com/labstack/echo/v4"
29 "oransc.org/nonrtric/capifcore/internal/discoverserviceapi"
30 "oransc.org/nonrtric/capifcore/internal/invokermanagementapi"
31 "oransc.org/nonrtric/capifcore/internal/providermanagementapi"
32 "oransc.org/nonrtric/capifcore/internal/securityapi"
34 "github.com/deepmap/oapi-codegen/pkg/middleware"
35 echomiddleware "github.com/labstack/echo/v4/middleware"
36 log "github.com/sirupsen/logrus"
37 "oransc.org/nonrtric/capifcore/internal/discoverservice"
38 "oransc.org/nonrtric/capifcore/internal/helmmanagement"
39 "oransc.org/nonrtric/capifcore/internal/invokermanagement"
40 "oransc.org/nonrtric/capifcore/internal/providermanagement"
41 "oransc.org/nonrtric/capifcore/internal/publishservice"
42 "oransc.org/nonrtric/capifcore/internal/publishserviceapi"
43 "oransc.org/nonrtric/capifcore/internal/security"
47 var helmManager helmmanagement.HelmManager
51 var port = flag.Int("port", 8090, "Port for CAPIF Core Function HTTP server")
52 flag.StringVar(&url, "url", "http://chartmuseum:8080", "ChartMuseum url")
53 flag.StringVar(&repoName, "repoName", "local-dev", "Repository name")
54 var logLevelStr = flag.String("loglevel", "Info", "Log level")
57 if loglevel, err := log.ParseLevel(*logLevelStr); err == nil {
58 log.SetLevel(loglevel)
62 fmt.Printf("Adding %s to Helm Repo\n", url)
63 helmManager = helmmanagement.NewHelmManager()
64 err := helmManager.AddToRepo(repoName, url)
66 log.Fatal(err.Error())
69 go startWebServer(getEcho(), *port)
71 log.Info("Server started and listening on port: ", *port)
76 func getEcho() *echo.Echo {
77 // This is how you set up a basic Echo router
80 e.Use(echomiddleware.Logger())
83 // Register ProviderManagement
84 providerManagerSwagger, err := providermanagementapi.GetSwagger()
86 log.Fatalf("Error loading ProviderManagement swagger spec\n: %s", err)
88 providerManagerSwagger.Servers = nil
89 providerManager := providermanagement.NewProviderManager()
90 group = e.Group("/api-provider-management/v1")
91 group.Use(middleware.OapiRequestValidator(providerManagerSwagger))
92 providermanagementapi.RegisterHandlersWithBaseURL(e, providerManager, "/api-provider-management/v1")
94 // Register PublishService
95 publishServiceSwagger, err := publishserviceapi.GetSwagger()
97 log.Fatalf("Error loading PublishService swagger spec\n: %s", err)
99 publishServiceSwagger.Servers = nil
100 publishService := publishservice.NewPublishService(providerManager, helmManager)
101 group = e.Group("/published-apis/v1")
102 group.Use(middleware.OapiRequestValidator(publishServiceSwagger))
103 publishserviceapi.RegisterHandlersWithBaseURL(e, publishService, "/published-apis/v1")
105 // Register DiscoverService
106 discoverServiceSwagger, err := discoverserviceapi.GetSwagger()
108 log.Fatalf("Error loading DiscoverService swagger spec\n: %s", err)
110 discoverServiceSwagger.Servers = nil
111 discoverService := discoverservice.NewDiscoverService(publishService)
112 group = e.Group("/service-apis/v1")
113 group.Use(middleware.OapiRequestValidator(discoverServiceSwagger))
114 discoverserviceapi.RegisterHandlersWithBaseURL(e, discoverService, "/service-apis/v1")
116 // Register InvokerManagement
117 invokerManagerSwagger, err := invokermanagementapi.GetSwagger()
119 log.Fatalf("Error loading InvokerManagement swagger spec\n: %s", err)
121 invokerManagerSwagger.Servers = nil
122 invokerManager := invokermanagement.NewInvokerManager(publishService)
123 group = e.Group("/api-invoker-management/v1")
124 group.Use(middleware.OapiRequestValidator(invokerManagerSwagger))
125 invokermanagementapi.RegisterHandlersWithBaseURL(e, invokerManager, "/api-invoker-management/v1")
128 securitySwagger, err := publishserviceapi.GetSwagger()
130 log.Fatalf("Error loading Security swagger spec\n: %s", err)
132 securitySwagger.Servers = nil
133 securityService := security.NewSecurity(providerManager, publishService, invokerManager)
134 group = e.Group("/capif-security/v1")
135 group.Use(middleware.OapiRequestValidator(securitySwagger))
136 securityapi.RegisterHandlersWithBaseURL(e, securityService, "/capif-security/v1")
143 func startWebServer(e *echo.Echo, port int) {
144 e.Logger.Fatal(e.Start(fmt.Sprintf("0.0.0.0:%d", port)))
147 func keepServerAlive() {
148 forever := make(chan int)
152 func hello(c echo.Context) error {
153 return c.String(http.StatusOK, "Hello, World!\n")