main.go 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. package main
  2. import (
  3. "context"
  4. "fmt"
  5. grpcc "github.com/go-micro/plugins/v4/client/grpc"
  6. "github.com/go-micro/plugins/v4/registry/consul"
  7. grpcs "github.com/go-micro/plugins/v4/server/grpc"
  8. "github.com/go-micro/plugins/v4/wrapper/trace/opentelemetry"
  9. "github.com/google/uuid"
  10. "github.com/redis/go-redis/v9"
  11. "github.com/sirupsen/logrus"
  12. "go-micro.dev/v4"
  13. "go-micro.dev/v4/auth"
  14. "go-micro.dev/v4/registry"
  15. "go-micro.dev/v4/server"
  16. "go.opentelemetry.io/otel"
  17. "go.opentelemetry.io/otel/propagation"
  18. "gorm.io/driver/mysql"
  19. "gorm.io/gorm"
  20. "gorm.io/gorm/schema"
  21. req "sghgogs.com/micro/auth-service/domain/model/request"
  22. auth_service_pb "sghgogs.com/micro/auth-service/proto"
  23. "sghgogs.com/micro/k8s-service/config"
  24. "sghgogs.com/micro/k8s-service/handler/clusterrole"
  25. "sghgogs.com/micro/k8s-service/handler/clusterrolebinding"
  26. "sghgogs.com/micro/k8s-service/handler/configmap"
  27. "sghgogs.com/micro/k8s-service/handler/cronjob"
  28. "sghgogs.com/micro/k8s-service/handler/daemonset"
  29. "sghgogs.com/micro/k8s-service/handler/deployment"
  30. "sghgogs.com/micro/k8s-service/handler/ingress"
  31. "sghgogs.com/micro/k8s-service/handler/ingressroute"
  32. "sghgogs.com/micro/k8s-service/handler/job"
  33. "sghgogs.com/micro/k8s-service/handler/middleware"
  34. "sghgogs.com/micro/k8s-service/handler/namespace"
  35. "sghgogs.com/micro/k8s-service/handler/node"
  36. "sghgogs.com/micro/k8s-service/handler/persistentvolume"
  37. "sghgogs.com/micro/k8s-service/handler/persistentvolumeclaim"
  38. "sghgogs.com/micro/k8s-service/handler/pod"
  39. "sghgogs.com/micro/k8s-service/handler/role"
  40. "sghgogs.com/micro/k8s-service/handler/rolebinding"
  41. "sghgogs.com/micro/k8s-service/handler/secret"
  42. "sghgogs.com/micro/k8s-service/handler/service"
  43. "sghgogs.com/micro/k8s-service/handler/serviceaccount"
  44. "sghgogs.com/micro/k8s-service/handler/statefulset"
  45. pb "sghgogs.com/micro/k8s-service/proto"
  46. "sghgogs.com/micro/k8s-service/utils/authutil"
  47. utils_middleware "sghgogs.com/micro/k8s-service/utils/middleware"
  48. "sghgogs.com/micro/k8s-service/utils/tracing"
  49. "strings"
  50. "time"
  51. )
  52. var (
  53. name = "kubernetesservice"
  54. version = "1.0.0"
  55. )
  56. func main() {
  57. if err := config.Load(); err != nil {
  58. logrus.Fatal(err)
  59. }
  60. // 1. 连接数据库
  61. var db *gorm.DB
  62. if cfg := config.DataBase(); cfg.Enable {
  63. address := fmt.Sprintf("%v:%v@(%v:%v)/%v?charset=utf8mb4,utf8&parseTime=True&loc=Local", cfg.Mysql.User, cfg.Mysql.Password, cfg.Mysql.Host, cfg.Mysql.Port, cfg.Mysql.DataBase)
  64. db, _ = gorm.Open(mysql.Open(address), &gorm.Config{
  65. // Logger: logger.Default.LogMode(logger.Info),
  66. NamingStrategy: schema.NamingStrategy{
  67. SingularTable: true,
  68. }})
  69. } else {
  70. // 没有配置数据库
  71. logrus.Info("There is no database configured")
  72. }
  73. if cfg := config.RedisAddress(); cfg.Enable {
  74. // UpdateRulesItems
  75. roles := make([]req.AdminRole, 0)
  76. db.Model(&req.AdminRole{}).Where("status = ?", auth_service_pb.StatusEnum_ENABLED).Preload("Permissions", "status = ?", auth_service_pb.StatusEnum_ENABLED).Find(&roles)
  77. authutil.NewJWTAuth(redis.NewClient(&redis.Options{
  78. Addr: cfg.URL, // Redis 服务器地址
  79. Password: cfg.Password, // Redis 密码,如果有的话
  80. DB: 0, // 默认数据库
  81. }), name, cfg.Enable)
  82. authutil.JWTAuthService.SetRuleItems(UpdateRulesItems(roles))
  83. // cfg.Password
  84. }
  85. // 2. Create service
  86. srv := micro.NewService(
  87. micro.Server(grpcs.NewServer()),
  88. micro.Client(grpcc.NewClient()),
  89. )
  90. authService := authutil.JWTAuthService.Auth
  91. opts := []micro.Option{
  92. micro.Name(name),
  93. micro.Version(version),
  94. micro.Address(config.Address()),
  95. micro.Auth(
  96. authService,
  97. ),
  98. }
  99. // 3.添加注册中心
  100. if cfg := config.Registry(); cfg.Enable {
  101. logrus.Info("添加注册中心")
  102. consul := consul.NewRegistry(func(options *registry.Options) {
  103. options.Addrs = []string{
  104. cfg.Consul.URL,
  105. }
  106. })
  107. opts = append(opts, micro.Registry(consul))
  108. }
  109. // 4.添加链路追踪
  110. if cfg := config.Tracing(); cfg.Enable {
  111. fmt.Println("加入进来了")
  112. tp, err := tracing.NewTracerProvider(name, version, srv.Server().Options().Id, cfg.Jaeger.URL)
  113. if err != nil {
  114. logrus.Fatal(err)
  115. }
  116. defer func() {
  117. ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)
  118. defer cancel()
  119. if err = tp.Shutdown(ctx); err != nil {
  120. logrus.Fatal(err)
  121. }
  122. }()
  123. otel.SetTracerProvider(tp)
  124. otel.SetTextMapPropagator(propagation.NewCompositeTextMapPropagator(propagation.TraceContext{}, propagation.Baggage{}))
  125. traceOpts := []opentelemetry.Option{
  126. opentelemetry.WithHandleFilter(func(ctx context.Context, r server.Request) bool {
  127. if e := r.Endpoint(); strings.HasPrefix(e, "Health.") {
  128. return true
  129. }
  130. return false
  131. }),
  132. }
  133. opts = append(opts, micro.WrapHandler(opentelemetry.NewHandlerWrapper(traceOpts...)))
  134. }
  135. opts = append(opts, micro.WrapHandler(utils_middleware.NewAuthWrapper(srv)))
  136. srv.Init(opts...)
  137. // 注册
  138. pb.RegisterClusterRoleServiceHandler(srv.Server(), &clusterrole.ClusterRole{})
  139. pb.RegisterClusterRoleBindingServiceHandler(srv.Server(), &clusterrolebinding.ClusterRoleBinding{})
  140. pb.RegisterConfigMapServiceHandler(srv.Server(), &configmap.ConfigMap{})
  141. pb.RegisterCronJobServiceHandler(srv.Server(), &cronjob.CronJob{})
  142. pb.RegisterDaemonSetServiceHandler(srv.Server(), &daemonset.DaemonSet{})
  143. pb.RegisterDeploymentServiceHandler(srv.Server(), &deployment.Deployment{})
  144. pb.RegisterIngressServiceHandler(srv.Server(), &ingress.Ingress{})
  145. pb.RegisterIngressRouteServiceHandler(srv.Server(), &ingressroute.IngressRoute{})
  146. pb.RegisterJobServiceHandler(srv.Server(), &job.Job{})
  147. pb.RegisterMiddlewareServiceHandler(srv.Server(), &middleware.Middleware{})
  148. pb.RegisterNamespaceServiceHandler(srv.Server(), &namespace.Namespace{})
  149. pb.RegisterNodeServiceHandler(srv.Server(), &node.Node{})
  150. pb.RegisterPersistentVolumeServiceHandler(srv.Server(), &persistentvolume.PersistentVolume{})
  151. pb.RegisterPersistentVolumeClaimServiceHandler(srv.Server(), &persistentvolumeclaim.PersistentVolumeClaim{})
  152. pb.RegisterPodServiceHandler(srv.Server(), &pod.Pod{})
  153. pb.RegisterRoleServiceHandler(srv.Server(), &role.Role{})
  154. pb.RegisterRoleBindingServiceHandler(srv.Server(), &rolebinding.RoleBinding{})
  155. pb.RegisterSecretServiceHandler(srv.Server(), &secret.Secret{})
  156. pb.RegisterServiceServiceHandler(srv.Server(), &service.Service{})
  157. pb.RegisterServiceAccountServiceHandler(srv.Server(), &serviceaccount.ServiceAccount{})
  158. pb.RegisterStatefulSetServiceHandler(srv.Server(), &statefulset.StatefulSet{})
  159. // Run service
  160. logrus.Info("Run service")
  161. if err := srv.Run(); err != nil {
  162. logrus.Fatal(err)
  163. }
  164. }
  165. func UpdateRulesItems(roles []req.AdminRole) []*auth.Rule {
  166. rules := make([]*auth.Rule, 0)
  167. for _, role := range roles {
  168. for _, permission := range role.Permissions {
  169. rules = append(rules, &auth.Rule{
  170. Resource: &auth.Resource{
  171. Name: permission.Name,
  172. Type: "user",
  173. Endpoint: permission.Endpoint,
  174. },
  175. ID: uuid.New().String(),
  176. Scope: role.Name,
  177. Priority: 1,
  178. })
  179. }
  180. }
  181. return rules
  182. }