-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.go
122 lines (103 loc) · 3.68 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package main
import (
"fmt"
"log"
"github.com/gin-contrib/cors"
"github.com/gin-gonic/gin"
"github.com/joho/godotenv"
"github.com/ernestomr87/go-resourceapi/auth"
"github.com/ernestomr87/go-resourceapi/controllers"
"github.com/ernestomr87/go-resourceapi/database"
)
func main() {
err := godotenv.Load(".env")
if err != nil {
log.Fatalf("Error loading .env file")
}
r := gin.Default()
// cors
config := cors.DefaultConfig()
config.AllowOrigins = []string{"http://localhost:8088", "http://localhost:9090"}
r.Use(cors.New(config))
// init db and controllers
db := database.InitDB()
todoController := controllers.NewTodoController(db)
userController := controllers.NewUserController(db)
userRoleController := controllers.NewUserRoleController(db)
r.GET("/", func(c *gin.Context) {
c.JSON(200, gin.H{
"message": "welcome todo app",
})
})
r1 := r.Group("/api")
{
// todo
r1.POST("/todo", todoController.CreateTodo)
r1.GET("/todo", todoController.GetTodos)
r1.GET("/todo/:id", todoController.GetTodo)
r1.PUT("/todo/:id", todoController.UpdateTodo)
r1.DELETE("/todo/:id", todoController.DeleteTodo)
// register
r1.POST("/register", userController.Register)
r1.GET("/users", userController.GetUsers)
r1.GET("/user/:username", userController.GetUser)
// change pass and profile
r1.PUT("/changepassword", userController.ChangePassword)
r1.PUT("/changeprofile", userController.ChangeProfile)
// delete user
r1.DELETE("/user/:username", userController.DeleteUser)
}
// basic auth Especificamente con los usuarios de estaticos que se configuran en gin.Accounts
authorized := r.Group("/admin", gin.BasicAuth(gin.Accounts{
"admin": "pass123",
"user1": "pass123",
}))
authorized.GET("/todo", todoController.GetTodos)
authorized.POST("/todo", todoController.CreateTodo)
// basic auth with db Especificamente con los usuarios de la BD
basicAuth := auth.InitBasicAuth(db)
authorized2 := r.Group("/admin2", basicAuth.BasicAuth())
{
authorized2.GET("/todo", todoController.GetTodos)
authorized2.POST("/todo", todoController.CreateTodo)
}
// jwt
jwtMiddleware, _ := auth.InitJwt(db)
authHelper := auth.InitHelper(db)
// login
r.POST("/login", jwtMiddleware.LoginHandler)
// logout for persistence token
r.GET("/logout", authHelper.VerifyToken, jwtMiddleware.LogoutHandler)
// Refresh time can be longer than token timeout
//r.GET("/refresh_token", jwtMiddleware.RefreshHandler)
// Refresh for persistence token
r.GET("/refresh_token", authHelper.VerifyToken, jwtMiddleware.RefreshHandler)
//jwtRoute := r.Group("/member", jwtMiddleware.MiddlewareFunc())
jwtRoute := r.Group("/member", authHelper.VerifyToken, jwtMiddleware.MiddlewareFunc())
{
jwtRoute.GET("/todo", todoController.GetTodos)
// roles based
jwtRoute.GET("/todo2", authHelper.CheckRoles([]string{"USER", "ADMIN", "MANAGER"}), todoController.GetTodos)
jwtRoute.POST("/todo", authHelper.CheckRoles([]string{"USER", "ADMIN", "MANAGER"}), todoController.CreateTodo)
jwtRoute.GET("/admin", authHelper.CheckRoles([]string{"ADMIN"}), func(c *gin.Context) {
c.JSON(200, gin.H{
"message": "this api for admin member",
})
})
jwtRoute.GET("/manager", authHelper.CheckRoles([]string{"MANAGER"}), func(c *gin.Context) {
c.JSON(200, gin.H{
"message": "this api for manager member",
})
})
jwtRoute.GET("/adminmanager", authHelper.CheckRoles([]string{"ADMIN", "MANAGER"}), func(c *gin.Context) {
c.JSON(200, gin.H{
"message": "this api for admin and manager member",
})
})
// roles
jwtRoute.POST("/addrole", userRoleController.AddRoleToUser)
jwtRoute.POST("/removerole", userRoleController.DeleteUserRole)
}
r.Run("localhost:8080")
fmt.Println("Server is running")
}