main.go 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  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. "sghgogs.com/micro/auth-service/utils/tracing"
  22. "sghgogs.com/micro/shopping-service-service/config"
  23. req "sghgogs.com/micro/shopping-service-service/domain/model/request"
  24. "sghgogs.com/micro/shopping-service-service/domain/repository"
  25. "sghgogs.com/micro/shopping-service-service/domain/service"
  26. "sghgogs.com/micro/shopping-service-service/handler/admin_user"
  27. handler_auth "sghgogs.com/micro/shopping-service-service/handler/auth"
  28. "sghgogs.com/micro/shopping-service-service/handler/category"
  29. "sghgogs.com/micro/shopping-service-service/handler/health"
  30. "sghgogs.com/micro/shopping-service-service/handler/order"
  31. "sghgogs.com/micro/shopping-service-service/handler/permission"
  32. "sghgogs.com/micro/shopping-service-service/handler/product"
  33. "sghgogs.com/micro/shopping-service-service/handler/role"
  34. "sghgogs.com/micro/shopping-service-service/handler/user"
  35. pb "sghgogs.com/micro/shopping-service-service/proto"
  36. "sghgogs.com/micro/shopping-service-service/utils/authutil"
  37. "sghgogs.com/micro/shopping-service-service/utils/middleware"
  38. "strings"
  39. "time"
  40. )
  41. var (
  42. name = "shoppingservice"
  43. version = "1.0.0"
  44. )
  45. func main() {
  46. if err := config.Load(); err != nil {
  47. logrus.Fatal(err)
  48. }
  49. // 1. 连接数据库
  50. var db *gorm.DB
  51. if cfg := config.DataBase(); cfg.Enable {
  52. 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)
  53. db, _ = gorm.Open(mysql.Open(address), &gorm.Config{
  54. // Logger: logger.Default.LogMode(logger.Info),
  55. NamingStrategy: schema.NamingStrategy{
  56. SingularTable: true,
  57. }})
  58. } else {
  59. // 没有配置数据库
  60. logrus.Info("There is no database configured")
  61. }
  62. fmt.Println("config.ShoppingServiceName()", config.ShoppingServiceName())
  63. if cfg := config.RedisAddress(); cfg.Enable {
  64. roles := make([]req.Role, 0)
  65. db.Model(&req.Role{}).Where("status = ?", pb.StatusEnum_ENABLED).Preload("Permissions", "status = ?", pb.StatusEnum_ENABLED).Find(&roles)
  66. authutil.NewJWTAuth(redis.NewClient(&redis.Options{
  67. Addr: cfg.URL, // Redis 服务器地址
  68. Password: cfg.Password, // Redis 密码,如果有的话
  69. DB: 0, // 默认数据库
  70. }), config.ShoppingServiceName(), config.ShoppingTeamName(), cfg.Enable)
  71. authutil.JWTAuthService.SetRuleItems(UpdateRulesItems(roles))
  72. }
  73. // 2. Create service
  74. srv := micro.NewService(
  75. micro.Server(grpcs.NewServer()),
  76. micro.Client(grpcc.NewClient()),
  77. )
  78. authService := authutil.JWTAuthService.Auth
  79. opts := []micro.Option{
  80. micro.Name(config.ShoppingServiceName()),
  81. micro.Version(version),
  82. micro.Address(config.Address()),
  83. micro.Auth(authService),
  84. }
  85. // 3.添加注册中心
  86. if cfg := config.Registry(); cfg.Enable {
  87. logrus.Info("添加注册中心")
  88. consul := consul.NewRegistry(func(options *registry.Options) {
  89. options.Addrs = []string{
  90. cfg.Consul.URL,
  91. }
  92. })
  93. opts = append(opts, micro.Registry(consul))
  94. }
  95. // 4.添加链路追踪
  96. if cfg := config.Tracing(); cfg.Enable {
  97. fmt.Println("加入进来了")
  98. tp, err := tracing.NewTracerProvider(config.ShoppingServiceName(), version, srv.Server().Options().Id, cfg.Jaeger.URL)
  99. if err != nil {
  100. logrus.Fatal(err)
  101. }
  102. defer func() {
  103. ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)
  104. defer cancel()
  105. if err = tp.Shutdown(ctx); err != nil {
  106. logrus.Fatal(err)
  107. }
  108. }()
  109. otel.SetTracerProvider(tp)
  110. otel.SetTextMapPropagator(propagation.NewCompositeTextMapPropagator(propagation.TraceContext{}, propagation.Baggage{}))
  111. traceOpts := []opentelemetry.Option{
  112. opentelemetry.WithHandleFilter(func(ctx context.Context, r server.Request) bool {
  113. if e := r.Endpoint(); strings.HasPrefix(e, "Health.") {
  114. return true
  115. }
  116. return false
  117. }),
  118. }
  119. opts = append(opts, micro.WrapHandler(opentelemetry.NewHandlerWrapper(traceOpts...)))
  120. }
  121. opts = append(opts, micro.WrapHandler(middleware.NewAuthWrapper(srv, config.ShoppingServiceName())))
  122. // middleware.NewAuthWrapper(srv))
  123. srv.Init(opts...)
  124. newRepository := repository.NewRepository(db)
  125. newRepository.InitTable()
  126. newService := service.NewService(newRepository, config.ShoppingServiceName())
  127. // 注册 Register handler
  128. pb.RegisterHealthHandler(srv.Server(), &health.Health{})
  129. // &user.User{Service: newService}
  130. pb.RegisterShoppingAdminUserServiceHandler(srv.Server(), &admin_user.AdminUser{Service: newService})
  131. pb.RegisterShoppingRoleServiceHandler(srv.Server(), &role.Role{Service: newService})
  132. pb.RegisterShoppingPermissionServiceHandler(srv.Server(), &permission.Permission{Service: newService})
  133. pb.RegisterShoppingUserServiceHandler(srv.Server(), &user.User{Service: newService})
  134. pb.RegisterShoppingProductServiceHandler(srv.Server(), &product.Product{Service: newService})
  135. pb.RegisterShoppingCategoryServiceHandler(srv.Server(), &category.Category{Service: newService})
  136. pb.RegisterShoppingAuthServiceHandler(srv.Server(), &handler_auth.Auth{Service: newService, Namespace: config.ShoppingServiceName()})
  137. pb.RegisterShoppingOrderServiceHandler(srv.Server(), &order.Order{Service: newService, Namespace: config.ShoppingServiceName()})
  138. // pb.RegisterUserShoppingServiceHandler(srv.Server(), &user.User{Service: newService})
  139. // pb.RegisterCategoryShoppingServiceHandler(srv.Server(), &category.Category{Service: newService})
  140. // pb.RegisterProductShoppingServiceHandler(srv.Server(), &product.Product{Service: newService})
  141. // pb.RegisterAuthShoppingServiceHandler(srv.Server(), &auth.Auth{Service: newService})
  142. // pb.RegisterWeChatPhoneLoginServiceHandler(srv.Server(), &auth.Auth{Service: newService})
  143. // pb.RegisterWeChatLoginServiceHandler(srv.Server(), &auth.Auth{Service: newService})
  144. // pb.RegisterAlipayLoginServiceHandler(srv.Server(), &auth.Auth{Service: newService})
  145. logrus.Info("Run service")
  146. if err := srv.Run(); err != nil {
  147. logrus.Fatal(err)
  148. }
  149. }
  150. func UpdateRulesItems(roles []req.Role) []*auth.Rule {
  151. rules := make([]*auth.Rule, 0)
  152. for _, role := range roles {
  153. for _, permission := range role.Permissions {
  154. rules = append(rules, &auth.Rule{
  155. Resource: &auth.Resource{
  156. Name: permission.Name,
  157. Type: "user",
  158. Endpoint: permission.Endpoint,
  159. },
  160. ID: uuid.New().String(),
  161. Scope: role.Name,
  162. Priority: 1,
  163. })
  164. }
  165. }
  166. return rules
  167. }