// simular alguns dados privados
// grupo usando intermediário de "gin.BasicAuth()"
// "gin.Accounts" é um atalho para "map[string]string"
authorized := router.Group("/admin", gin.BasicAuth(gin.Accounts{
// o destino /admin/secrets
// alcança "localhost:8080/admin/secrets"
authorized.GET("/secrets", func(c *gin.Context) {
// receber utilizador, foi definido pelo intermediário de BasicAuth
user := c.MustGet(gin.AuthUserKey).(string)
if secret, ok := secrets[user]; ok {
c.JSON(http.StatusOK, gin.H{"user": user, "secret": secret})
c.JSON(http.StatusOK, gin.H{"user": user, "secret": "NO SECRET :("})
// ouvir e servir no 0.0.0.0:8080