securitygroup.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  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 ksyun
  15. import (
  16. "fmt"
  17. "yunion.io/x/jsonutils"
  18. "yunion.io/x/pkg/errors"
  19. api "yunion.io/x/cloudmux/pkg/apis/compute"
  20. "yunion.io/x/cloudmux/pkg/cloudprovider"
  21. "yunion.io/x/cloudmux/pkg/multicloud"
  22. )
  23. type SecurityGroupPermissionNicType string
  24. const (
  25. IntranetNicType SecurityGroupPermissionNicType = "intranet"
  26. InternetNicType SecurityGroupPermissionNicType = "internet"
  27. )
  28. type SSecurityGroup struct {
  29. multicloud.SSecurityGroup
  30. SKsyunTags
  31. region *SRegion
  32. CreateTime string `json:"CreateTime"`
  33. ProductTag string `json:"ProductTag"`
  34. SecurityGroupEntrySet []SPermission `json:"SecurityGroupEntrySet"`
  35. SecurityGroupId string `json:"SecurityGroupId"`
  36. SecurityGroupName string `json:"SecurityGroupName"`
  37. SecurityGroupType string `json:"SecurityGroupType"`
  38. UserTag string `json:"UserTag"`
  39. VpcId string `json:"VpcId"`
  40. }
  41. type SecurityGroupEntrySet struct {
  42. CidrBlock string `json:"CidrBlock"`
  43. CreateTime string `json:"CreateTime"`
  44. Direction string `json:"Direction"`
  45. IcmpCode int `json:"IcmpCode,omitempty"`
  46. IcmpType int `json:"IcmpType,omitempty"`
  47. Policy string `json:"Policy"`
  48. Priority int `json:"Priority"`
  49. ProductTag string `json:"ProductTag"`
  50. Protocol string `json:"Protocol"`
  51. RuleTag string `json:"RuleTag,omitempty"`
  52. SecurityGroupEntryId string `json:"SecurityGroupEntryId"`
  53. UserTag string `json:"UserTag"`
  54. PortRangeFrom int `json:"PortRangeFrom,omitempty"`
  55. PortRangeTo int `json:"PortRangeTo,omitempty"`
  56. }
  57. func (secgroup *SSecurityGroup) GetVpcId() string {
  58. return secgroup.VpcId
  59. }
  60. func (secgroup *SSecurityGroup) GetId() string {
  61. return secgroup.SecurityGroupId
  62. }
  63. func (secgroup *SSecurityGroup) GetGlobalId() string {
  64. return secgroup.SecurityGroupId
  65. }
  66. func (secgroup *SSecurityGroup) GetRules() ([]cloudprovider.ISecurityGroupRule, error) {
  67. ret := make([]cloudprovider.ISecurityGroupRule, 0)
  68. for i := range secgroup.SecurityGroupEntrySet {
  69. secgroup.SecurityGroupEntrySet[i].region = secgroup.region
  70. secgroup.SecurityGroupEntrySet[i].SecurityGroupId = secgroup.SecurityGroupId
  71. ret = append(ret, &secgroup.SecurityGroupEntrySet[i])
  72. }
  73. return ret, nil
  74. }
  75. func (secgroup *SSecurityGroup) GetName() string {
  76. if len(secgroup.SecurityGroupName) > 0 {
  77. return secgroup.SecurityGroupName
  78. }
  79. return secgroup.SecurityGroupId
  80. }
  81. func (secgroup *SSecurityGroup) GetStatus() string {
  82. return api.SECGROUP_STATUS_READY
  83. }
  84. func (secgroup *SSecurityGroup) Refresh() error {
  85. group, err := secgroup.region.GetSecurityGroup(secgroup.SecurityGroupId)
  86. if err != nil {
  87. return err
  88. }
  89. return jsonutils.Update(secgroup, group)
  90. }
  91. func (secgroup *SSecurityGroup) GetTags() (map[string]string, error) {
  92. tags, err := secgroup.region.ListTags("security-group", secgroup.SecurityGroupId)
  93. if err != nil {
  94. return nil, err
  95. }
  96. return tags.GetTags(), nil
  97. }
  98. func (secgroup *SSecurityGroup) GetReferences() ([]cloudprovider.SecurityGroupReference, error) {
  99. return nil, errors.ErrNotSupported
  100. }
  101. func (region *SRegion) GetSecurityGroups(vpcId string, securityGroupIds []string) ([]SSecurityGroup, error) {
  102. ret := []SSecurityGroup{}
  103. params := map[string]interface{}{
  104. "MaxResults": "1000",
  105. }
  106. if len(vpcId) > 0 {
  107. params["Filter.1.Name"] = "vpc-id"
  108. params["Filter.1.Value.1"] = vpcId
  109. }
  110. for i, secgroupId := range securityGroupIds {
  111. params[fmt.Sprintf("SecurityGroupId.%d", i+1)] = secgroupId
  112. }
  113. for {
  114. resp, err := region.vpcRequest("DescribeSecurityGroups", params)
  115. if err != nil {
  116. return nil, errors.Wrap(err, "DescribeSecurityGroups")
  117. }
  118. part := struct {
  119. SecurityGroupSet []SSecurityGroup `json:"SecurityGroupSet"`
  120. NextToken string `json:"NextToken"`
  121. }{}
  122. err = resp.Unmarshal(&part)
  123. if err != nil {
  124. return nil, errors.Wrap(err, "unmarshal secgroups")
  125. }
  126. ret = append(ret, part.SecurityGroupSet...)
  127. if len(part.NextToken) == 0 {
  128. break
  129. }
  130. params["NextToken"] = part.NextToken
  131. }
  132. return ret, nil
  133. }
  134. func (region *SRegion) GetSecurityGroup(id string) (*SSecurityGroup, error) {
  135. groups, err := region.GetSecurityGroups("", []string{id})
  136. if err != nil {
  137. return nil, err
  138. }
  139. for _, group := range groups {
  140. return &group, nil
  141. }
  142. return nil, errors.Wrapf(cloudprovider.ErrNotFound, "security_group id:%s", id)
  143. }
  144. func (region *SRegion) CreateSecurityGroup(opts *cloudprovider.SecurityGroupCreateInput) (*SSecurityGroup, error) {
  145. params := map[string]interface{}{
  146. "VpcId": opts.VpcId,
  147. "SecurityGroupName": opts.Name,
  148. }
  149. if len(opts.Desc) > 0 {
  150. params["Description"] = opts.Desc
  151. }
  152. resp, err := region.vpcRequest("CreateSecurityGroup", params)
  153. if err != nil {
  154. return nil, err
  155. }
  156. ret := &SSecurityGroup{region: region}
  157. err = resp.Unmarshal(ret, "SecurityGroup")
  158. if err != nil {
  159. return nil, err
  160. }
  161. return ret, nil
  162. }
  163. func (region *SRegion) SetSecurityGroups(secgroupIds []string, instanceId, nicId, subnetId string) error {
  164. params := map[string]interface{}{
  165. "InstanceId": instanceId,
  166. "NetworkInterfaceId": nicId,
  167. "SubnetId": subnetId,
  168. }
  169. for i, secgroupId := range secgroupIds {
  170. params[fmt.Sprintf("SecurityGroupId.%d", i+1)] = secgroupId
  171. }
  172. _, err := region.ecsRequest("ModifyNetworkInterfaceAttribute", params)
  173. if err != nil {
  174. return err
  175. }
  176. return nil
  177. }
  178. func (sg *SSecurityGroup) GetProjectId() string {
  179. return ""
  180. }
  181. func (sg *SSecurityGroup) Delete() error {
  182. return sg.region.DeleteSecurityGroup(sg.SecurityGroupId)
  183. }
  184. func (region *SRegion) DeleteSecurityGroup(secGrpId string) error {
  185. params := map[string]interface{}{
  186. "SecurityGroupId": secGrpId,
  187. }
  188. _, err := region.vpcRequest("DeleteSecurityGroup", params)
  189. return err
  190. }