package main import ( "fmt" "net/http" "github.com/go-chi/chi/v5" "github.com/go-chi/chi/v5/middleware" ) func main() { //create a new server and mount the handlers: s := CreateNewServer() s.MountHandlers() //staring up the server: http.ListenAndServe(":8000", s.Router) } type server struct { Router *chi.Mux //suggestion to add config settings or DB in here } func CreateNewServer() *server { s := &server{} s.Router = chi.NewRouter() return s } func (s *server) MountHandlers() { //Creation of the router: //logging enables as a middleware s.Router.Use(middleware.Logger) //recover from panics and send a 500 internal error s.Router.Use(middleware.Recoverer) //a middleware to check if the server is alive s.Router.Use(middleware.Heartbeat("/ping")) //a profiler to check healt of server s.Router.Mount("/debug", middleware.Profiler()) //personalized 404 s.Router.NotFound(GenericHandler404) //personalized 405 s.Router.MethodNotAllowed(GenericHandler405) //example: //example of a get function and its handler s.Router.Get("/example/{first}/{second:[0-9]+}", ExampleHandler) //Creating subrouters: //healthRouter check on the health of nodes or main server healthRouter := chi.NewRouter() //controllerRouter Agnostic openVswitch controller bridge controllerRouter := chi.NewRouter() //managementRouter Start, stop, monitoring of the core (mininet) managementRouter := chi.NewRouter() //mininetApiRouter Interface with the virtual environment inside the core (mininet) mininetApiRouter := chi.NewRouter() //might want to check https://go-chi.io/#/pages/routing?id=routing-groups //in order to make groups where you have other middleware like authentication //////////////////////////////////possible routing///////////////////////////// //s.Router.Connect(pattern string, h http.HandlerFunc) //s.Router.Delete(pattern string, h http.HandlerFunc) //s.Router.Get(pattern string, h http.HandlerFunc) //s.Router.Head(pattern string, h http.HandlerFunc) //s.Router.Options(pattern string, h http.HandlerFunc) //s.Router.Patch(pattern string, h http.HandlerFunc) //s.Router.Post(pattern string, h http.HandlerFunc) //s.Router.Put(pattern string, h http.HandlerFunc) //s.Router.Trace(pattern string, h http.HandlerFunc) /////////////////////////////////////////////////////////////////////////////// //s.Router.Get("/", ) //s.Router.Get("/access", ) //s.Router.Get("/stats", ) //s.Router.Get("/topology", ) //s.Router.Get("/health", ) //s.Router.Get("/free", )//probably do this with server side or sockets //s.Router.Get("/flowdel", )//this is an external request //s.Router.Get("/mpstat", ) //s.Router.Get("/ifstat", ) //s.Router.Get("/showtemp", ) //s.Router.Get("/gettopo", ) //s.Router.Get("/net", ) //s.Router.Get("/rpiping", )//workerping //s.Router.Get("/nodes", ) //s.Router.Get("/statusnodes", ) //s.Router.Get("/intfs", ) //s.Router.Get("/iperf", ) //s.Router.Get("/pingall", ) //s.Router.Get("/placement", ) //s.Router.Get("/getvsorcdata", ) //s.Router.Get("/getcontrollerdata", ) //s.Router.Get("/resetflows", ) //s.Router.Get("/listswitch", ) //s.Router.Get("/status", ) //s.Router.Get("/tablestatus", ) //s.Router.Get("/portsdesc", ) //s.Router.Get("/portsstat", ) //s.Router.Get("/startcontroller", ) //s.Router.Get("/startcontrollerrouter", ) //s.Router.Get("/stopcontroller", ) //s.Router.Get("/sendcommand", ) //s.Router.Get("/cancel", ) //s.Router.Get("/startvsorc", ) //s.Router.Get("/stopvsorc", ) //http.Handle("/", r) //Mounting all of the subrouters: s.Router.Mount("/health", healthRouter) s.Router.Mount("/controller", controllerRouter) s.Router.Mount("/management", managementRouter) s.Router.Mount("/virtualAPI", mininetApiRouter) } //GenericHandler404 is the universal 404 response of this front end func GenericHandler404(w http.ResponseWriter, r *http.Request){ w.WriteHeader(404) w.Write([]byte("route does not exist")) } //GenericHandler405 is the universal 405 response of this front end func GenericHandler405(w http.ResponseWriter, r *http.Request){ w.WriteHeader(405) w.Write([]byte("Method not valid")) } func ExampleHandler(w http.ResponseWriter, r *http.Request) { var1 := chi.URLParam(r, "first") var2 := chi.URLParam(r, "second") w.WriteHeader(http.StatusOK) fmt.Fprintf(w, "First: %v\nSecond: %v", var1, var2) }