You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

noticetenantlogic.go 1.6 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. package cloud
  2. import (
  3. "context"
  4. "gitlink.org.cn/jcce-pcm/pcm-coordinator/pkg/models"
  5. "gitlink.org.cn/jcce-pcm/pcm-coordinator/pkg/utils"
  6. "gitlink.org.cn/jcce-pcm/pcm-participant-kubernetes/kubernetes"
  7. "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc"
  8. "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/types"
  9. "github.com/zeromicro/go-zero/core/logx"
  10. )
  11. type NoticeTenantLogic struct {
  12. logx.Logger
  13. ctx context.Context
  14. svcCtx *svc.ServiceContext
  15. }
  16. func NewNoticeTenantLogic(ctx context.Context, svcCtx *svc.ServiceContext) *NoticeTenantLogic {
  17. return &NoticeTenantLogic{
  18. Logger: logx.WithContext(ctx),
  19. ctx: ctx,
  20. svcCtx: svcCtx,
  21. }
  22. }
  23. // NoticeTenant 通知更新租户数据
  24. func (l *NoticeTenantLogic) NoticeTenant() (resp *types.CloudResp, err error) {
  25. var tenants []*models.ScTenantInfo
  26. //从p端kubernetes获取租户信息
  27. namespace, err := l.svcCtx.K8sRpc.ListNamespace(context.Background(), &kubernetes.NamespaceListReq{})
  28. if err != nil {
  29. logx.Errorf("获取租户信息失败:%v", err)
  30. return nil, err
  31. }
  32. //先删除所有租户数据
  33. l.svcCtx.DbEngin.Where("type = 0").Delete(models.ScTenantInfo{})
  34. //遍历租户信息
  35. for k, v := range namespace.Data {
  36. tenants = append(tenants, &models.ScTenantInfo{
  37. Id: utils.GenSnowflakeID(),
  38. TenantName: k,
  39. Clusters: v,
  40. Type: 0,
  41. })
  42. }
  43. tx := l.svcCtx.DbEngin.Save(&tenants)
  44. if tx.Error != nil {
  45. logx.Errorf("保存租户信息失败:%v", tx.Error)
  46. return nil, err
  47. }
  48. logx.Info("更新租户数据成功")
  49. return
  50. }

PCM is positioned as Software stack over Cloud, aiming to build the standards and ecology of heterogeneous cloud collaboration for JCC in a non intrusive and autonomous peer-to-peer manner.