secgroup.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  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 cloudpods
  15. import (
  16. "yunion.io/x/cloudmux/pkg/cloudprovider"
  17. "yunion.io/x/cloudmux/pkg/multicloud"
  18. api "yunion.io/x/onecloud/pkg/apis/compute"
  19. modules "yunion.io/x/onecloud/pkg/mcclient/modules/compute"
  20. )
  21. type SSecurityGroup struct {
  22. multicloud.SSecurityGroup
  23. CloudpodsTags
  24. region *SRegion
  25. api.SecgroupDetails
  26. }
  27. func (self *SSecurityGroup) GetName() string {
  28. return self.Name
  29. }
  30. func (self *SSecurityGroup) GetDescription() string {
  31. return self.Description
  32. }
  33. func (self *SSecurityGroup) GetId() string {
  34. return self.Id
  35. }
  36. func (self *SSecurityGroup) GetGlobalId() string {
  37. return self.Id
  38. }
  39. func (self *SSecurityGroup) GetStatus() string {
  40. return self.Status
  41. }
  42. func (self *SSecurityGroup) GetProjectId() string {
  43. return self.TenantId
  44. }
  45. func (self *SSecurityGroup) GetRules() ([]cloudprovider.ISecurityGroupRule, error) {
  46. ret := []cloudprovider.ISecurityGroupRule{}
  47. rules := []SecurityGroupRule{}
  48. err := self.region.list(&modules.SecGroupRules, map[string]interface{}{"scope": "system", "secgroup_id": self.Id}, &rules)
  49. if err != nil {
  50. return nil, err
  51. }
  52. for i := range rules {
  53. rules[i].region = self.region
  54. ret = append(ret, &rules[i])
  55. }
  56. return ret, nil
  57. }
  58. func (self *SSecurityGroup) GetVpcId() string {
  59. return ""
  60. }
  61. func (self *SSecurityGroup) GetReferences() ([]cloudprovider.SecurityGroupReference, error) {
  62. params := map[string]interface{}{
  63. "secgroup_id": self.Id,
  64. }
  65. servers := []SInstance{}
  66. err := self.region.list(&modules.Servers, params, &servers)
  67. if err != nil {
  68. return nil, err
  69. }
  70. ret := []cloudprovider.SecurityGroupReference{}
  71. for i := range servers {
  72. ret = append(ret, cloudprovider.SecurityGroupReference{
  73. Id: servers[i].Id,
  74. Name: servers[i].Name,
  75. })
  76. }
  77. return ret, nil
  78. }
  79. func (self *SRegion) DeleteSecRule(id string) error {
  80. return self.cli.delete(&modules.SecGroupRules, id)
  81. }
  82. func (self *SSecurityGroup) CreateRule(opts *cloudprovider.SecurityGroupRuleCreateOptions) (cloudprovider.ISecurityGroupRule, error) {
  83. return self.region.CreateSecRule(self.Id, opts)
  84. }
  85. func (self *SRegion) CreateSecRule(secId string, opts *cloudprovider.SecurityGroupRuleCreateOptions) (*SecurityGroupRule, error) {
  86. input := api.SSecgroupRuleCreateInput{}
  87. input.SecgroupId = secId
  88. input.Priority = &opts.Priority
  89. input.Action = string(opts.Action)
  90. input.Protocol = string(opts.Protocol)
  91. input.Direction = string(opts.Direction)
  92. input.Description = opts.Desc
  93. input.CIDR = opts.CIDR
  94. input.Ports = opts.Ports
  95. ret := &SecurityGroupRule{region: self}
  96. err := self.create(&modules.SecGroupRules, input, &ret)
  97. if err != nil {
  98. return nil, err
  99. }
  100. return ret, nil
  101. }
  102. func (self *SSecurityGroup) Delete() error {
  103. return self.region.cli.delete(&modules.SecGroups, self.Id)
  104. }
  105. func (self *SRegion) GetSecurityGroups() ([]SSecurityGroup, error) {
  106. params := map[string]interface{}{
  107. "cloud_env": "onpremise",
  108. }
  109. ret := []SSecurityGroup{}
  110. return ret, self.cli.list(&modules.SecGroups, params, &ret)
  111. }
  112. func (self *SRegion) GetSecurityGroup(id string) (*SSecurityGroup, error) {
  113. secgroup := &SSecurityGroup{region: self}
  114. return secgroup, self.cli.get(&modules.SecGroups, id, nil, secgroup)
  115. }
  116. func (self *SRegion) CreateISecurityGroup(opts *cloudprovider.SecurityGroupCreateInput) (cloudprovider.ICloudSecurityGroup, error) {
  117. params := map[string]interface{}{
  118. "name": opts.Name,
  119. "description": opts.Desc,
  120. }
  121. if len(opts.ProjectId) > 0 {
  122. params["project_id"] = opts.ProjectId
  123. }
  124. secgroup := &SSecurityGroup{region: self}
  125. return secgroup, self.create(&modules.SecGroups, params, secgroup)
  126. }
  127. func (self *SRegion) GetISecurityGroups() ([]cloudprovider.ICloudSecurityGroup, error) {
  128. secgroups, err := self.GetSecurityGroups()
  129. if err != nil {
  130. return nil, err
  131. }
  132. ret := []cloudprovider.ICloudSecurityGroup{}
  133. for i := range secgroups {
  134. secgroups[i].region = self
  135. ret = append(ret, &secgroups[i])
  136. }
  137. return ret, nil
  138. }
  139. func (self *SRegion) GetISecurityGroupById(secgroupId string) (cloudprovider.ICloudSecurityGroup, error) {
  140. secgroup, err := self.GetSecurityGroup(secgroupId)
  141. if err != nil {
  142. return nil, err
  143. }
  144. return secgroup, nil
  145. }