func StartServer() *Server { db = &storage.BoltDb{} // RAM db.Init() storage.CreateSampleData(db) router := gin.Default() server := &Server{db, router} // This handler will match /conf/appname but will not match neither /conf/ or /conf server.GET("/conf/:appname", handlers.GetConfig) // Return list of placeholders server.GET("/conf/:appname/placeholders", handlers.GetPlaceHolders) // Return list of set values server.GET("/conf/:appname/values", handlers.GetValues(db)) // Return list of set values server.POST("/conf/:appname/values", handlers.SetValues(db)) // Return list of set labels server.GET("/conf/:appname/labels", handlers.GetLabels(db)) server.Run(getPort()) return server }
func main() { router := gin.Default() router.SetHTMLTemplate(html) router.GET("/room/:roomid", roomGET) router.POST("/room/:roomid", roomPOST) router.DELETE("/room/:roomid", roomDELETE) router.GET("/stream/:roomid", stream) router.Run(":8080") }
func main() { r := gin.Default() // Ping test r.GET("/ping", func(c *gin.Context) { c.String(200, "pong") }) // Get user value r.GET("/user/:name", func(c *gin.Context) { user := c.Params.ByName("name") value, ok := DB[user] if ok { c.JSON(200, gin.H{"user": user, "value": value}) } else { c.JSON(200, gin.H{"user": user, "status": "no value"}) } }) // Authorized group (uses gin.BasicAuth() middleware) // Same than: // authorized := r.Group("/") // authorized.Use(gin.BasicAuth(gin.Credentials{ // "foo": "bar", // "manu": "123", //})) authorized := r.Group("/", gin.BasicAuth(gin.Accounts{ "foo": "bar", // user:foo password:bar "manu": "123", // user:manu password:123 })) authorized.POST("admin", func(c *gin.Context) { user := c.MustGet(gin.AuthUserKey).(string) // Parse JSON var json struct { Value string `json:"value" binding:"required"` } if c.Bind(&json) == nil { DB[user] = json.Value c.JSON(200, gin.H{"status": "ok"}) } }) // Listen and Server in 0.0.0.0:8080 r.Run(":8080") }