groupguests.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. // Copyright 2019 Yunion
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package models
  15. import (
  16. "context"
  17. "yunion.io/x/jsonutils"
  18. "yunion.io/x/log"
  19. "yunion.io/x/pkg/errors"
  20. "yunion.io/x/sqlchemy"
  21. api "yunion.io/x/onecloud/pkg/apis/compute"
  22. "yunion.io/x/onecloud/pkg/cloudcommon/db"
  23. "yunion.io/x/onecloud/pkg/mcclient"
  24. "yunion.io/x/onecloud/pkg/util/stringutils2"
  25. )
  26. // +onecloud:swagger-gen-ignore
  27. type SGroupguestManager struct {
  28. SGroupJointsManager
  29. SGuestResourceBaseManager
  30. }
  31. var GroupguestManager *SGroupguestManager
  32. func init() {
  33. db.InitManager(func() {
  34. GroupguestManager = &SGroupguestManager{
  35. SGroupJointsManager: NewGroupJointsManager(
  36. SGroupguest{},
  37. "guestgroups_tbl",
  38. "groupguest",
  39. "groupguests",
  40. GuestManager,
  41. ),
  42. }
  43. GroupguestManager.SetVirtualObject(GroupguestManager)
  44. })
  45. }
  46. // +onecloud:model-api-gen
  47. type SGroupguest struct {
  48. SGroupJointsBase
  49. Tag string `width:"256" charset:"ascii" nullable:"true" list:"user" update:"user" create:"optional"`
  50. GuestId string `width:"36" charset:"ascii" nullable:"false" list:"user" create:"required"`
  51. GuestStatus string `width:"36" charset:"ascii" nullable:"false"`
  52. }
  53. func (manager *SGroupguestManager) GetSlaveFieldName() string {
  54. return "guest_id"
  55. }
  56. func (manager *SGroupguestManager) FetchCustomizeColumns(
  57. ctx context.Context,
  58. userCred mcclient.TokenCredential,
  59. query jsonutils.JSONObject,
  60. objs []interface{},
  61. fields stringutils2.SSortedStrings,
  62. isList bool,
  63. ) []api.GroupguestDetails {
  64. rows := make([]api.GroupguestDetails, len(objs))
  65. groupRows := manager.SGroupJointsManager.FetchCustomizeColumns(ctx, userCred, query, objs, fields, isList)
  66. guestIds := make([]string, len(rows))
  67. for i := range rows {
  68. rows[i] = api.GroupguestDetails{
  69. GroupJointResourceDetails: groupRows[i],
  70. }
  71. guestIds[i] = objs[i].(*SGroupguest).GuestId
  72. }
  73. guestIdMaps, err := db.FetchIdNameMap2(GuestManager, guestIds)
  74. if err != nil {
  75. log.Errorf("FetchIdNameMap2 fail %s", err)
  76. return rows
  77. }
  78. for i := range rows {
  79. if name, ok := guestIdMaps[guestIds[i]]; ok {
  80. rows[i].Guest = name
  81. rows[i].Server = name
  82. }
  83. }
  84. return rows
  85. }
  86. func (self *SGroupguest) Delete(ctx context.Context, userCred mcclient.TokenCredential) error {
  87. return db.DeleteModel(ctx, userCred, self)
  88. }
  89. func (self *SGroupguest) Detach(ctx context.Context, userCred mcclient.TokenCredential) error {
  90. return db.DetachJoint(ctx, userCred, self)
  91. }
  92. func (self *SGroupguestManager) FetchByGuestId(guestId string) ([]SGroupguest, error) {
  93. q := self.Query().Equals("guest_id", guestId)
  94. return self.fetchByQuery(q)
  95. }
  96. func (self *SGroupguestManager) fetchByQuery(q *sqlchemy.SQuery) ([]SGroupguest, error) {
  97. joints := make([]SGroupguest, 0, 1)
  98. err := db.FetchModelObjects(self, q, &joints)
  99. if err != nil {
  100. return nil, err
  101. }
  102. return joints, err
  103. }
  104. func (self *SGroupguestManager) FetchByGroupId(groupId string) ([]SGroupguest, error) {
  105. q := self.Query().Equals("group_id", groupId)
  106. return self.fetchByQuery(q)
  107. }
  108. func (self *SGroupguestManager) Attach(ctx context.Context, groupId, guestId string) (*SGroupguest, error) {
  109. joint := &SGroupguest{}
  110. joint.GuestId = guestId
  111. joint.GroupId = groupId
  112. err := self.TableSpec().Insert(ctx, joint)
  113. if err != nil {
  114. return nil, err
  115. }
  116. joint.SetModelManager(self, joint)
  117. return joint, nil
  118. }
  119. func (manager *SGroupguestManager) ListItemFilter(
  120. ctx context.Context,
  121. q *sqlchemy.SQuery,
  122. userCred mcclient.TokenCredential,
  123. query api.GroupguestListInput,
  124. ) (*sqlchemy.SQuery, error) {
  125. var err error
  126. q, err = manager.SGroupJointsManager.ListItemFilter(ctx, q, userCred, query.GroupJointsListInput)
  127. if err != nil {
  128. return nil, errors.Wrap(err, "SGroupJointsManager.ListItemFilter")
  129. }
  130. q, err = manager.SGuestResourceBaseManager.ListItemFilter(ctx, q, userCred, query.ServerFilterListInput)
  131. if err != nil {
  132. return nil, errors.Wrap(err, "SGuestResourceBaseManager.ListItemFilter")
  133. }
  134. if len(query.Tag) > 0 {
  135. q = q.In("tag", query.Tag)
  136. }
  137. return q, nil
  138. }
  139. func (manager *SGroupguestManager) OrderByExtraFields(
  140. ctx context.Context,
  141. q *sqlchemy.SQuery,
  142. userCred mcclient.TokenCredential,
  143. query api.GroupguestListInput,
  144. ) (*sqlchemy.SQuery, error) {
  145. var err error
  146. q, err = manager.SGroupJointsManager.OrderByExtraFields(ctx, q, userCred, query.GroupJointsListInput)
  147. if err != nil {
  148. return nil, errors.Wrap(err, "SGroupJointsManager.OrderByExtraFields")
  149. }
  150. q, err = manager.SGuestResourceBaseManager.OrderByExtraFields(ctx, q, userCred, query.ServerFilterListInput)
  151. if err != nil {
  152. return nil, errors.Wrap(err, "SGuestResourceBaseManager.OrderByExtraFields")
  153. }
  154. return q, nil
  155. }
  156. func (manager *SGroupguestManager) ListItemExportKeys(ctx context.Context,
  157. q *sqlchemy.SQuery,
  158. userCred mcclient.TokenCredential,
  159. keys stringutils2.SSortedStrings,
  160. ) (*sqlchemy.SQuery, error) {
  161. var err error
  162. q, err = manager.SGroupJointsManager.ListItemExportKeys(ctx, q, userCred, keys)
  163. if err != nil {
  164. return nil, errors.Wrap(err, "SGroupJointsManager.ListItemExportKeys")
  165. }
  166. if keys.ContainsAny(manager.SGuestResourceBaseManager.GetExportKeys()...) {
  167. q, err = manager.SGuestResourceBaseManager.ListItemExportKeys(ctx, q, userCred, keys)
  168. if err != nil {
  169. return nil, errors.Wrap(err, "SGuestResourceBaseManager.ListItemExportKeys")
  170. }
  171. }
  172. return q, nil
  173. }