| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217 |
- // Copyright 2019 Yunion
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- package ksyun
- import (
- "fmt"
- "yunion.io/x/jsonutils"
- "yunion.io/x/pkg/errors"
- api "yunion.io/x/cloudmux/pkg/apis/compute"
- "yunion.io/x/cloudmux/pkg/cloudprovider"
- "yunion.io/x/cloudmux/pkg/multicloud"
- )
- type SecurityGroupPermissionNicType string
- const (
- IntranetNicType SecurityGroupPermissionNicType = "intranet"
- InternetNicType SecurityGroupPermissionNicType = "internet"
- )
- type SSecurityGroup struct {
- multicloud.SSecurityGroup
- SKsyunTags
- region *SRegion
- CreateTime string `json:"CreateTime"`
- ProductTag string `json:"ProductTag"`
- SecurityGroupEntrySet []SPermission `json:"SecurityGroupEntrySet"`
- SecurityGroupId string `json:"SecurityGroupId"`
- SecurityGroupName string `json:"SecurityGroupName"`
- SecurityGroupType string `json:"SecurityGroupType"`
- UserTag string `json:"UserTag"`
- VpcId string `json:"VpcId"`
- }
- type SecurityGroupEntrySet struct {
- CidrBlock string `json:"CidrBlock"`
- CreateTime string `json:"CreateTime"`
- Direction string `json:"Direction"`
- IcmpCode int `json:"IcmpCode,omitempty"`
- IcmpType int `json:"IcmpType,omitempty"`
- Policy string `json:"Policy"`
- Priority int `json:"Priority"`
- ProductTag string `json:"ProductTag"`
- Protocol string `json:"Protocol"`
- RuleTag string `json:"RuleTag,omitempty"`
- SecurityGroupEntryId string `json:"SecurityGroupEntryId"`
- UserTag string `json:"UserTag"`
- PortRangeFrom int `json:"PortRangeFrom,omitempty"`
- PortRangeTo int `json:"PortRangeTo,omitempty"`
- }
- func (secgroup *SSecurityGroup) GetVpcId() string {
- return secgroup.VpcId
- }
- func (secgroup *SSecurityGroup) GetId() string {
- return secgroup.SecurityGroupId
- }
- func (secgroup *SSecurityGroup) GetGlobalId() string {
- return secgroup.SecurityGroupId
- }
- func (secgroup *SSecurityGroup) GetRules() ([]cloudprovider.ISecurityGroupRule, error) {
- ret := make([]cloudprovider.ISecurityGroupRule, 0)
- for i := range secgroup.SecurityGroupEntrySet {
- secgroup.SecurityGroupEntrySet[i].region = secgroup.region
- secgroup.SecurityGroupEntrySet[i].SecurityGroupId = secgroup.SecurityGroupId
- ret = append(ret, &secgroup.SecurityGroupEntrySet[i])
- }
- return ret, nil
- }
- func (secgroup *SSecurityGroup) GetName() string {
- if len(secgroup.SecurityGroupName) > 0 {
- return secgroup.SecurityGroupName
- }
- return secgroup.SecurityGroupId
- }
- func (secgroup *SSecurityGroup) GetStatus() string {
- return api.SECGROUP_STATUS_READY
- }
- func (secgroup *SSecurityGroup) Refresh() error {
- group, err := secgroup.region.GetSecurityGroup(secgroup.SecurityGroupId)
- if err != nil {
- return err
- }
- return jsonutils.Update(secgroup, group)
- }
- func (secgroup *SSecurityGroup) GetTags() (map[string]string, error) {
- tags, err := secgroup.region.ListTags("security-group", secgroup.SecurityGroupId)
- if err != nil {
- return nil, err
- }
- return tags.GetTags(), nil
- }
- func (secgroup *SSecurityGroup) GetReferences() ([]cloudprovider.SecurityGroupReference, error) {
- return nil, errors.ErrNotSupported
- }
- func (region *SRegion) GetSecurityGroups(vpcId string, securityGroupIds []string) ([]SSecurityGroup, error) {
- ret := []SSecurityGroup{}
- params := map[string]interface{}{
- "MaxResults": "1000",
- }
- if len(vpcId) > 0 {
- params["Filter.1.Name"] = "vpc-id"
- params["Filter.1.Value.1"] = vpcId
- }
- for i, secgroupId := range securityGroupIds {
- params[fmt.Sprintf("SecurityGroupId.%d", i+1)] = secgroupId
- }
- for {
- resp, err := region.vpcRequest("DescribeSecurityGroups", params)
- if err != nil {
- return nil, errors.Wrap(err, "DescribeSecurityGroups")
- }
- part := struct {
- SecurityGroupSet []SSecurityGroup `json:"SecurityGroupSet"`
- NextToken string `json:"NextToken"`
- }{}
- err = resp.Unmarshal(&part)
- if err != nil {
- return nil, errors.Wrap(err, "unmarshal secgroups")
- }
- ret = append(ret, part.SecurityGroupSet...)
- if len(part.NextToken) == 0 {
- break
- }
- params["NextToken"] = part.NextToken
- }
- return ret, nil
- }
- func (region *SRegion) GetSecurityGroup(id string) (*SSecurityGroup, error) {
- groups, err := region.GetSecurityGroups("", []string{id})
- if err != nil {
- return nil, err
- }
- for _, group := range groups {
- return &group, nil
- }
- return nil, errors.Wrapf(cloudprovider.ErrNotFound, "security_group id:%s", id)
- }
- func (region *SRegion) CreateSecurityGroup(opts *cloudprovider.SecurityGroupCreateInput) (*SSecurityGroup, error) {
- params := map[string]interface{}{
- "VpcId": opts.VpcId,
- "SecurityGroupName": opts.Name,
- }
- if len(opts.Desc) > 0 {
- params["Description"] = opts.Desc
- }
- resp, err := region.vpcRequest("CreateSecurityGroup", params)
- if err != nil {
- return nil, err
- }
- ret := &SSecurityGroup{region: region}
- err = resp.Unmarshal(ret, "SecurityGroup")
- if err != nil {
- return nil, err
- }
- return ret, nil
- }
- func (region *SRegion) SetSecurityGroups(secgroupIds []string, instanceId, nicId, subnetId string) error {
- params := map[string]interface{}{
- "InstanceId": instanceId,
- "NetworkInterfaceId": nicId,
- "SubnetId": subnetId,
- }
- for i, secgroupId := range secgroupIds {
- params[fmt.Sprintf("SecurityGroupId.%d", i+1)] = secgroupId
- }
- _, err := region.ecsRequest("ModifyNetworkInterfaceAttribute", params)
- if err != nil {
- return err
- }
- return nil
- }
- func (sg *SSecurityGroup) GetProjectId() string {
- return ""
- }
- func (sg *SSecurityGroup) Delete() error {
- return sg.region.DeleteSecurityGroup(sg.SecurityGroupId)
- }
- func (region *SRegion) DeleteSecurityGroup(secGrpId string) error {
- params := map[string]interface{}{
- "SecurityGroupId": secGrpId,
- }
- _, err := region.vpcRequest("DeleteSecurityGroup", params)
- return err
- }
|