secgroup.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  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 baidu
  15. import (
  16. "fmt"
  17. "net/url"
  18. "time"
  19. api "yunion.io/x/cloudmux/pkg/apis/compute"
  20. "yunion.io/x/cloudmux/pkg/cloudprovider"
  21. "yunion.io/x/cloudmux/pkg/multicloud"
  22. "yunion.io/x/jsonutils"
  23. "yunion.io/x/pkg/errors"
  24. "yunion.io/x/pkg/util/secrules"
  25. "yunion.io/x/pkg/utils"
  26. )
  27. type SSecurityGroup struct {
  28. multicloud.SSecurityGroup
  29. SBaiduTag
  30. region *SRegion
  31. Id string
  32. Name string
  33. VpcId string
  34. Desc string
  35. CreatedTime time.Time
  36. UpdatedTime time.Time
  37. SgVersion string
  38. Rules []SSecurityGroupRule
  39. }
  40. func (self *SSecurityGroup) GetVpcId() string {
  41. return self.VpcId
  42. }
  43. func (self *SSecurityGroup) GetId() string {
  44. return self.Id
  45. }
  46. func (self *SSecurityGroup) GetGlobalId() string {
  47. return self.Id
  48. }
  49. func (self *SSecurityGroup) GetDescription() string {
  50. return self.Desc
  51. }
  52. func (self *SSecurityGroup) GetName() string {
  53. if len(self.Name) > 0 {
  54. return self.Name
  55. }
  56. return self.Name
  57. }
  58. func (self *SSecurityGroup) GetStatus() string {
  59. return api.SECGROUP_STATUS_READY
  60. }
  61. func (self *SSecurityGroup) Refresh() error {
  62. group, err := self.region.GetSecurityGroup(self.Id)
  63. if err != nil {
  64. return err
  65. }
  66. return jsonutils.Update(self, group)
  67. }
  68. func (self *SSecurityGroup) Delete() error {
  69. return self.region.DeleteSecurityGroup(self.Id)
  70. }
  71. func (self *SSecurityGroup) GetRules() ([]cloudprovider.ISecurityGroupRule, error) {
  72. ret := make([]cloudprovider.ISecurityGroupRule, 0)
  73. for i := range self.Rules {
  74. self.Rules[i].region = self.region
  75. ret = append(ret, &self.Rules[i])
  76. }
  77. return ret, nil
  78. }
  79. func (self *SSecurityGroup) CreateRule(opts *cloudprovider.SecurityGroupRuleCreateOptions) (cloudprovider.ISecurityGroupRule, error) {
  80. ruleIds := []string{}
  81. for _, rule := range self.Rules {
  82. ruleIds = append(ruleIds, rule.GetGlobalId())
  83. }
  84. err := self.region.CreateSecurityGroupRule(self.Id, opts)
  85. if err != nil {
  86. return nil, err
  87. }
  88. err = self.Refresh()
  89. if err != nil {
  90. return nil, err
  91. }
  92. for i := range self.Rules {
  93. if !utils.IsInStringArray(self.Rules[i].GetGlobalId(), ruleIds) {
  94. self.Rules[i].region = self.region
  95. return &self.Rules[i], nil
  96. }
  97. }
  98. return nil, errors.Wrapf(cloudprovider.ErrNotFound, "After created")
  99. }
  100. func (region *SRegion) CreateSecurityGroupRule(groupId string, opts *cloudprovider.SecurityGroupRuleCreateOptions) error {
  101. params := url.Values{}
  102. params.Set("clientToken", utils.GenRequestId(20))
  103. params.Set("authorizeRule", "")
  104. rule := map[string]interface{}{
  105. "remark": opts.Desc,
  106. "protocol": opts.Protocol,
  107. "portRange": opts.Ports,
  108. }
  109. switch opts.Direction {
  110. case secrules.DIR_OUT:
  111. rule["direction"] = "egress"
  112. rule["destIp"] = opts.CIDR
  113. case secrules.DIR_IN:
  114. rule["direction"] = "ingress"
  115. rule["sourceIp"] = opts.CIDR
  116. }
  117. if opts.Protocol == secrules.PROTO_ANY {
  118. rule["protocol"] = "all"
  119. }
  120. body := map[string]interface{}{
  121. "rule": rule,
  122. }
  123. _, err := region.bccUpdate(fmt.Sprintf("v2/securityGroup/%s", groupId), params, body)
  124. return err
  125. }
  126. func (region *SRegion) GetSecurityGroups(vpcId string) ([]SSecurityGroup, error) {
  127. params := url.Values{}
  128. if len(vpcId) > 0 {
  129. params.Set("vpcId", vpcId)
  130. }
  131. ret := []SSecurityGroup{}
  132. for {
  133. resp, err := region.bccList("v2/securityGroup", params)
  134. if err != nil {
  135. return nil, err
  136. }
  137. part := struct {
  138. NextMarker string
  139. SecurityGroups []SSecurityGroup
  140. }{}
  141. err = resp.Unmarshal(&part)
  142. if err != nil {
  143. return nil, err
  144. }
  145. ret = append(ret, part.SecurityGroups...)
  146. if len(part.NextMarker) == 0 {
  147. break
  148. }
  149. params.Set("marker", part.NextMarker)
  150. }
  151. return ret, nil
  152. }
  153. func (region *SRegion) DeleteSecurityGroup(id string) error {
  154. _, err := region.bccDelete(fmt.Sprintf("v2/securityGroup/%s", id), nil)
  155. return err
  156. }
  157. func (region *SRegion) GetSecurityGroup(id string) (*SSecurityGroup, error) {
  158. resp, err := region.bccList(fmt.Sprintf("v2/securityGroup/%s", id), nil)
  159. if err != nil {
  160. return nil, err
  161. }
  162. ret := &SSecurityGroup{region: region}
  163. err = resp.Unmarshal(ret)
  164. if err != nil {
  165. return nil, err
  166. }
  167. return ret, nil
  168. }
  169. func (region *SRegion) CreateSecurityGroup(opts *cloudprovider.SecurityGroupCreateInput) (*SSecurityGroup, error) {
  170. params := url.Values{}
  171. params.Set("clientToken", utils.GenRequestId(20))
  172. tags := []BaiduTag{}
  173. for k, v := range opts.Tags {
  174. tags = append(tags, BaiduTag{
  175. TagKey: k,
  176. TagValue: v,
  177. })
  178. }
  179. body := map[string]interface{}{
  180. "name": opts.Name,
  181. "vpcId": opts.VpcId,
  182. "desc": opts.Desc,
  183. "tags": tags,
  184. }
  185. resp, err := region.bccPost("v2/securityGroup", params, body)
  186. if err != nil {
  187. return nil, err
  188. }
  189. groupId, err := resp.GetString("securityGroupId")
  190. if err != nil {
  191. return nil, err
  192. }
  193. return region.GetSecurityGroup(groupId)
  194. }