-
Notifications
You must be signed in to change notification settings - Fork 0
/
router_api.go
111 lines (96 loc) · 4.92 KB
/
router_api.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
package router
import (
"github.com/zhimma/go-gin-api/internal/api/admin"
"github.com/zhimma/go-gin-api/internal/api/article"
"github.com/zhimma/go-gin-api/internal/api/authorized"
"github.com/zhimma/go-gin-api/internal/api/config"
"github.com/zhimma/go-gin-api/internal/api/cron"
"github.com/zhimma/go-gin-api/internal/api/helper"
"github.com/zhimma/go-gin-api/internal/api/menu"
"github.com/zhimma/go-gin-api/internal/api/tool"
"github.com/zhimma/go-gin-api/internal/pkg/core"
)
func setApiRouter(r *resource) {
// helper
helperHandler := helper.New(r.logger, r.db, r.cache)
helpers := r.mux.Group("/helper")
{
helpers.GET("/md5/:str", helperHandler.Md5())
helpers.POST("/sign", helperHandler.Sign())
}
// admin
adminHandler := admin.New(r.logger, r.db, r.cache)
// 需要签名验证,无需登录验证,无需 RBAC 权限验证
login := r.mux.Group("/api", r.interceptors.CheckSignature())
{
login.POST("/login", adminHandler.Login())
}
// 需要签名验证、登录验证,无需 RBAC 权限验证
notRBAC := r.mux.Group("/api", core.WrapAuthHandler(r.interceptors.CheckLogin), r.interceptors.CheckSignature())
{
notRBAC.POST("/admin/logout", adminHandler.Logout())
notRBAC.PATCH("/admin/modify_password", adminHandler.ModifyPassword())
notRBAC.GET("/admin/info", adminHandler.Detail())
notRBAC.PATCH("/admin/modify_personal_info", adminHandler.ModifyPersonalInfo())
}
// 需要签名验证、登录验证、RBAC 权限验证
api := r.mux.Group("/api", core.WrapAuthHandler(r.interceptors.CheckLogin), r.interceptors.CheckSignature(), r.interceptors.CheckRBAC())
{
// authorized
authorizedHandler := authorized.New(r.logger, r.db, r.cache)
api.POST("/authorized", authorizedHandler.Create())
api.GET("/authorized", authorizedHandler.List())
api.PATCH("/authorized/used", authorizedHandler.UpdateUsed())
api.DELETE("/authorized/:id", core.AliasForRecordMetrics("/api/authorized/info"), authorizedHandler.Delete())
api.POST("/authorized_api", authorizedHandler.CreateAPI())
api.GET("/authorized_api", authorizedHandler.ListAPI())
api.DELETE("/authorized_api/:id", core.AliasForRecordMetrics("/api/authorized_api/info"), authorizedHandler.DeleteAPI())
api.POST("/admin", adminHandler.Create())
api.GET("/admin", adminHandler.List())
api.PATCH("/admin/used", adminHandler.UpdateUsed())
api.PATCH("/admin/offline", adminHandler.Offline())
api.PATCH("/admin/reset_password/:id", core.AliasForRecordMetrics("/api/admin/reset_password"), adminHandler.ResetPassword())
api.DELETE("/admin/:id", core.AliasForRecordMetrics("/api/admin"), adminHandler.Delete())
api.POST("/admin/menu", adminHandler.CreateAdminMenu())
api.GET("/admin/menu/:id", core.AliasForRecordMetrics("/api/admin/menu"), adminHandler.ListAdminMenu())
// menu
menuHandler := menu.New(r.logger, r.db, r.cache)
api.POST("/menu", menuHandler.Create())
api.GET("/menu", menuHandler.List())
api.GET("/menu/:id", core.AliasForRecordMetrics("/api/menu"), menuHandler.Detail())
api.PATCH("/menu/used", menuHandler.UpdateUsed())
api.PATCH("/menu/sort", menuHandler.UpdateSort())
api.DELETE("/menu/:id", core.AliasForRecordMetrics("/api/menu"), menuHandler.Delete())
api.POST("/menu_action", menuHandler.CreateAction())
api.GET("/menu_action", menuHandler.ListAction())
api.DELETE("/menu_action/:id", core.AliasForRecordMetrics("/api/menu_action"), menuHandler.DeleteAction())
// tool
toolHandler := tool.New(r.logger, r.db, r.cache)
api.GET("/tool/hashids/encode/:id", core.AliasForRecordMetrics("/api/tool/hashids/encode"), toolHandler.HashIdsEncode())
api.GET("/tool/hashids/decode/:id", core.AliasForRecordMetrics("/api/tool/hashids/decode"), toolHandler.HashIdsDecode())
api.POST("/tool/cache/search", toolHandler.SearchCache())
api.PATCH("/tool/cache/clear", toolHandler.ClearCache())
api.GET("/tool/data/dbs", toolHandler.Dbs())
api.POST("/tool/data/tables", toolHandler.Tables())
api.POST("/tool/data/mysql", toolHandler.SearchMySQL())
api.POST("/tool/send_message", toolHandler.SendMessage())
// config
configHandler := config.New(r.logger, r.db, r.cache)
api.PATCH("/config/email", configHandler.Email())
// cron
cronHandler := cron.New(r.logger, r.db, r.cache, r.cronServer)
api.POST("/cron", cronHandler.Create())
api.GET("/cron", cronHandler.List())
api.GET("/cron/:id", core.AliasForRecordMetrics("/api/cron/detail"), cronHandler.Detail())
api.POST("/cron/:id", core.AliasForRecordMetrics("/api/cron/modify"), cronHandler.Modify())
api.PATCH("/cron/used", cronHandler.UpdateUsed())
api.PATCH("/cron/exec/:id", core.AliasForRecordMetrics("/api/cron/exec"), cronHandler.Execute())
// article
articleHandler := article.New(r.logger, r.db, r.cache)
api.GET("/articles", articleHandler.Index())
api.GET("/articles/:id", articleHandler.Show())
api.POST("/articles", articleHandler.Store())
api.PUT("/articles/:id", articleHandler.Update())
api.DELETE("/articles/:id", articleHandler.Destroy())
}
}