// // Copyright 2018, Sander van Harmelen // // 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 cloudstack import ( "encoding/json" "fmt" "net/url" "strconv" "strings" ) // Helper function for maintaining backwards compatibility func convertAuthorizeSecurityGroupIngressResponse(b []byte) ([]byte, error) { var raw struct { Ingressrule []interface{} `json:"ingressrule"` } if err := json.Unmarshal(b, &raw); err != nil { return nil, err } if len(raw.Ingressrule) != 1 { return b, nil } return json.Marshal(raw.Ingressrule[0]) } // Helper function for maintaining backwards compatibility func convertAuthorizeSecurityGroupEgressResponse(b []byte) ([]byte, error) { var raw struct { Egressrule []interface{} `json:"egressrule"` } if err := json.Unmarshal(b, &raw); err != nil { return nil, err } if len(raw.Egressrule) != 1 { return b, nil } return json.Marshal(raw.Egressrule[0]) } type AuthorizeSecurityGroupEgressParams struct { p map[string]interface{} } func (p *AuthorizeSecurityGroupEgressParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["cidrlist"]; found { vv := strings.Join(v.([]string), ",") u.Set("cidrlist", vv) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["endport"]; found { vv := strconv.Itoa(v.(int)) u.Set("endport", vv) } if v, found := p.p["icmpcode"]; found { vv := strconv.Itoa(v.(int)) u.Set("icmpcode", vv) } if v, found := p.p["icmptype"]; found { vv := strconv.Itoa(v.(int)) u.Set("icmptype", vv) } if v, found := p.p["projectid"]; found { u.Set("projectid", v.(string)) } if v, found := p.p["protocol"]; found { u.Set("protocol", v.(string)) } if v, found := p.p["securitygroupid"]; found { u.Set("securitygroupid", v.(string)) } if v, found := p.p["securitygroupname"]; found { u.Set("securitygroupname", v.(string)) } if v, found := p.p["startport"]; found { vv := strconv.Itoa(v.(int)) u.Set("startport", vv) } if v, found := p.p["usersecuritygrouplist"]; found { i := 0 for k, vv := range v.(map[string]string) { u.Set(fmt.Sprintf("usersecuritygrouplist[%d].account", i), k) u.Set(fmt.Sprintf("usersecuritygrouplist[%d].group", i), vv) i++ } } return u } func (p *AuthorizeSecurityGroupEgressParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetCidrlist(v []string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["cidrlist"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetEndport(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["endport"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetIcmpcode(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["icmpcode"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetIcmptype(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["icmptype"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetProjectid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["projectid"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetProtocol(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["protocol"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetSecuritygroupid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["securitygroupid"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetSecuritygroupname(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["securitygroupname"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetStartport(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["startport"] = v return } func (p *AuthorizeSecurityGroupEgressParams) SetUsersecuritygrouplist(v map[string]string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["usersecuritygrouplist"] = v return } // You should always use this function to get a new AuthorizeSecurityGroupEgressParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewAuthorizeSecurityGroupEgressParams() *AuthorizeSecurityGroupEgressParams { p := &AuthorizeSecurityGroupEgressParams{} p.p = make(map[string]interface{}) return p } // Authorizes a particular egress rule for this security group func (s *SecurityGroupService) AuthorizeSecurityGroupEgress(p *AuthorizeSecurityGroupEgressParams) (*AuthorizeSecurityGroupEgressResponse, error) { resp, err := s.cs.newRequest("authorizeSecurityGroupEgress", p.toURLValues()) if err != nil { return nil, err } var r AuthorizeSecurityGroupEgressResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } // If we have a async client, we need to wait for the async result if s.cs.async { b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout) if err != nil { if err == AsyncTimeoutErr { return &r, err } return nil, err } b, err = getRawValue(b) if err != nil { return nil, err } b, err = convertAuthorizeSecurityGroupEgressResponse(b) if err != nil { return nil, err } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type AuthorizeSecurityGroupEgressResponse struct { JobID string `json:"jobid"` Account string `json:"account"` Cidr string `json:"cidr"` Endport int `json:"endport"` Icmpcode int `json:"icmpcode"` Icmptype int `json:"icmptype"` Protocol string `json:"protocol"` Ruleid string `json:"ruleid"` Securitygroupname string `json:"securitygroupname"` Startport int `json:"startport"` Tags []Tags `json:"tags"` } type AuthorizeSecurityGroupIngressParams struct { p map[string]interface{} } func (p *AuthorizeSecurityGroupIngressParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["cidrlist"]; found { vv := strings.Join(v.([]string), ",") u.Set("cidrlist", vv) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["endport"]; found { vv := strconv.Itoa(v.(int)) u.Set("endport", vv) } if v, found := p.p["icmpcode"]; found { vv := strconv.Itoa(v.(int)) u.Set("icmpcode", vv) } if v, found := p.p["icmptype"]; found { vv := strconv.Itoa(v.(int)) u.Set("icmptype", vv) } if v, found := p.p["projectid"]; found { u.Set("projectid", v.(string)) } if v, found := p.p["protocol"]; found { u.Set("protocol", v.(string)) } if v, found := p.p["securitygroupid"]; found { u.Set("securitygroupid", v.(string)) } if v, found := p.p["securitygroupname"]; found { u.Set("securitygroupname", v.(string)) } if v, found := p.p["startport"]; found { vv := strconv.Itoa(v.(int)) u.Set("startport", vv) } if v, found := p.p["usersecuritygrouplist"]; found { i := 0 for k, vv := range v.(map[string]string) { u.Set(fmt.Sprintf("usersecuritygrouplist[%d].account", i), k) u.Set(fmt.Sprintf("usersecuritygrouplist[%d].group", i), vv) i++ } } return u } func (p *AuthorizeSecurityGroupIngressParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetCidrlist(v []string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["cidrlist"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetEndport(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["endport"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetIcmpcode(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["icmpcode"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetIcmptype(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["icmptype"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetProjectid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["projectid"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetProtocol(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["protocol"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetSecuritygroupid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["securitygroupid"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetSecuritygroupname(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["securitygroupname"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetStartport(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["startport"] = v return } func (p *AuthorizeSecurityGroupIngressParams) SetUsersecuritygrouplist(v map[string]string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["usersecuritygrouplist"] = v return } // You should always use this function to get a new AuthorizeSecurityGroupIngressParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewAuthorizeSecurityGroupIngressParams() *AuthorizeSecurityGroupIngressParams { p := &AuthorizeSecurityGroupIngressParams{} p.p = make(map[string]interface{}) return p } // Authorizes a particular ingress rule for this security group func (s *SecurityGroupService) AuthorizeSecurityGroupIngress(p *AuthorizeSecurityGroupIngressParams) (*AuthorizeSecurityGroupIngressResponse, error) { resp, err := s.cs.newRequest("authorizeSecurityGroupIngress", p.toURLValues()) if err != nil { return nil, err } var r AuthorizeSecurityGroupIngressResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } // If we have a async client, we need to wait for the async result if s.cs.async { b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout) if err != nil { if err == AsyncTimeoutErr { return &r, err } return nil, err } b, err = getRawValue(b) if err != nil { return nil, err } b, err = convertAuthorizeSecurityGroupIngressResponse(b) if err != nil { return nil, err } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type AuthorizeSecurityGroupIngressResponse struct { JobID string `json:"jobid"` Account string `json:"account"` Cidr string `json:"cidr"` Endport int `json:"endport"` Icmpcode int `json:"icmpcode"` Icmptype int `json:"icmptype"` Protocol string `json:"protocol"` Ruleid string `json:"ruleid"` Securitygroupname string `json:"securitygroupname"` Startport int `json:"startport"` Tags []Tags `json:"tags"` } type CreateSecurityGroupParams struct { p map[string]interface{} } func (p *CreateSecurityGroupParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["description"]; found { u.Set("description", v.(string)) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["name"]; found { u.Set("name", v.(string)) } if v, found := p.p["projectid"]; found { u.Set("projectid", v.(string)) } return u } func (p *CreateSecurityGroupParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *CreateSecurityGroupParams) SetDescription(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["description"] = v return } func (p *CreateSecurityGroupParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *CreateSecurityGroupParams) SetName(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["name"] = v return } func (p *CreateSecurityGroupParams) SetProjectid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["projectid"] = v return } // You should always use this function to get a new CreateSecurityGroupParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewCreateSecurityGroupParams(name string) *CreateSecurityGroupParams { p := &CreateSecurityGroupParams{} p.p = make(map[string]interface{}) p.p["name"] = name return p } // Creates a security group func (s *SecurityGroupService) CreateSecurityGroup(p *CreateSecurityGroupParams) (*CreateSecurityGroupResponse, error) { resp, err := s.cs.newRequest("createSecurityGroup", p.toURLValues()) if err != nil { return nil, err } if resp, err = getRawValue(resp); err != nil { return nil, err } var r CreateSecurityGroupResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type CreateSecurityGroupResponse struct { Account string `json:"account"` Description string `json:"description"` Domain string `json:"domain"` Domainid string `json:"domainid"` Egressrule []CreateSecurityGroupResponseRule `json:"egressrule"` Id string `json:"id"` Ingressrule []CreateSecurityGroupResponseRule `json:"ingressrule"` Name string `json:"name"` Project string `json:"project"` Projectid string `json:"projectid"` Tags []Tags `json:"tags"` Virtualmachinecount int `json:"virtualmachinecount"` Virtualmachineids []interface{} `json:"virtualmachineids"` } type CreateSecurityGroupResponseRule struct { Account string `json:"account"` Cidr string `json:"cidr"` Endport int `json:"endport"` Icmpcode int `json:"icmpcode"` Icmptype int `json:"icmptype"` Protocol string `json:"protocol"` Ruleid string `json:"ruleid"` Securitygroupname string `json:"securitygroupname"` Startport int `json:"startport"` Tags []Tags `json:"tags"` } type DeleteSecurityGroupParams struct { p map[string]interface{} } func (p *DeleteSecurityGroupParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } if v, found := p.p["name"]; found { u.Set("name", v.(string)) } if v, found := p.p["projectid"]; found { u.Set("projectid", v.(string)) } return u } func (p *DeleteSecurityGroupParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *DeleteSecurityGroupParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *DeleteSecurityGroupParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v return } func (p *DeleteSecurityGroupParams) SetName(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["name"] = v return } func (p *DeleteSecurityGroupParams) SetProjectid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["projectid"] = v return } // You should always use this function to get a new DeleteSecurityGroupParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewDeleteSecurityGroupParams() *DeleteSecurityGroupParams { p := &DeleteSecurityGroupParams{} p.p = make(map[string]interface{}) return p } // Deletes security group func (s *SecurityGroupService) DeleteSecurityGroup(p *DeleteSecurityGroupParams) (*DeleteSecurityGroupResponse, error) { resp, err := s.cs.newRequest("deleteSecurityGroup", p.toURLValues()) if err != nil { return nil, err } var r DeleteSecurityGroupResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type DeleteSecurityGroupResponse struct { Displaytext string `json:"displaytext"` Success bool `json:"success"` } func (r *DeleteSecurityGroupResponse) UnmarshalJSON(b []byte) error { var m map[string]interface{} err := json.Unmarshal(b, &m) if err != nil { return err } if success, ok := m["success"].(string); ok { m["success"] = success == "true" b, err = json.Marshal(m) if err != nil { return err } } type alias DeleteSecurityGroupResponse return json.Unmarshal(b, (*alias)(r)) } type ListSecurityGroupsParams struct { p map[string]interface{} } func (p *ListSecurityGroupsParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } if v, found := p.p["isrecursive"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("isrecursive", vv) } if v, found := p.p["keyword"]; found { u.Set("keyword", v.(string)) } if v, found := p.p["listall"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("listall", vv) } if v, found := p.p["page"]; found { vv := strconv.Itoa(v.(int)) u.Set("page", vv) } if v, found := p.p["pagesize"]; found { vv := strconv.Itoa(v.(int)) u.Set("pagesize", vv) } if v, found := p.p["projectid"]; found { u.Set("projectid", v.(string)) } if v, found := p.p["securitygroupname"]; found { u.Set("securitygroupname", v.(string)) } if v, found := p.p["tags"]; found { i := 0 for k, vv := range v.(map[string]string) { u.Set(fmt.Sprintf("tags[%d].key", i), k) u.Set(fmt.Sprintf("tags[%d].value", i), vv) i++ } } if v, found := p.p["virtualmachineid"]; found { u.Set("virtualmachineid", v.(string)) } return u } func (p *ListSecurityGroupsParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *ListSecurityGroupsParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *ListSecurityGroupsParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v return } func (p *ListSecurityGroupsParams) SetIsrecursive(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["isrecursive"] = v return } func (p *ListSecurityGroupsParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v return } func (p *ListSecurityGroupsParams) SetListall(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["listall"] = v return } func (p *ListSecurityGroupsParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v return } func (p *ListSecurityGroupsParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v return } func (p *ListSecurityGroupsParams) SetProjectid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["projectid"] = v return } func (p *ListSecurityGroupsParams) SetSecuritygroupname(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["securitygroupname"] = v return } func (p *ListSecurityGroupsParams) SetTags(v map[string]string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["tags"] = v return } func (p *ListSecurityGroupsParams) SetVirtualmachineid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["virtualmachineid"] = v return } // You should always use this function to get a new ListSecurityGroupsParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewListSecurityGroupsParams() *ListSecurityGroupsParams { p := &ListSecurityGroupsParams{} p.p = make(map[string]interface{}) return p } // This is a courtesy helper function, which in some cases may not work as expected! func (s *SecurityGroupService) GetSecurityGroupID(keyword string, opts ...OptionFunc) (string, int, error) { p := &ListSecurityGroupsParams{} p.p = make(map[string]interface{}) p.p["keyword"] = keyword for _, fn := range append(s.cs.options, opts...) { if err := fn(s.cs, p); err != nil { return "", -1, err } } l, err := s.ListSecurityGroups(p) if err != nil { return "", -1, err } if l.Count == 0 { return "", l.Count, fmt.Errorf("No match found for %s: %+v", keyword, l) } if l.Count == 1 { return l.SecurityGroups[0].Id, l.Count, nil } if l.Count > 1 { for _, v := range l.SecurityGroups { if v.Name == keyword { return v.Id, l.Count, nil } } } return "", l.Count, fmt.Errorf("Could not find an exact match for %s: %+v", keyword, l) } // This is a courtesy helper function, which in some cases may not work as expected! func (s *SecurityGroupService) GetSecurityGroupByName(name string, opts ...OptionFunc) (*SecurityGroup, int, error) { id, count, err := s.GetSecurityGroupID(name, opts...) if err != nil { return nil, count, err } r, count, err := s.GetSecurityGroupByID(id, opts...) if err != nil { return nil, count, err } return r, count, nil } // This is a courtesy helper function, which in some cases may not work as expected! func (s *SecurityGroupService) GetSecurityGroupByID(id string, opts ...OptionFunc) (*SecurityGroup, int, error) { p := &ListSecurityGroupsParams{} p.p = make(map[string]interface{}) p.p["id"] = id for _, fn := range append(s.cs.options, opts...) { if err := fn(s.cs, p); err != nil { return nil, -1, err } } l, err := s.ListSecurityGroups(p) if err != nil { if strings.Contains(err.Error(), fmt.Sprintf( "Invalid parameter id value=%s due to incorrect long value format, "+ "or entity does not exist", id)) { return nil, 0, fmt.Errorf("No match found for %s: %+v", id, l) } return nil, -1, err } if l.Count == 0 { return nil, l.Count, fmt.Errorf("No match found for %s: %+v", id, l) } if l.Count == 1 { return l.SecurityGroups[0], l.Count, nil } return nil, l.Count, fmt.Errorf("There is more then one result for SecurityGroup UUID: %s!", id) } // Lists security groups func (s *SecurityGroupService) ListSecurityGroups(p *ListSecurityGroupsParams) (*ListSecurityGroupsResponse, error) { resp, err := s.cs.newRequest("listSecurityGroups", p.toURLValues()) if err != nil { return nil, err } var r ListSecurityGroupsResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type ListSecurityGroupsResponse struct { Count int `json:"count"` SecurityGroups []*SecurityGroup `json:"securitygroup"` } type SecurityGroup struct { Account string `json:"account"` Description string `json:"description"` Domain string `json:"domain"` Domainid string `json:"domainid"` Egressrule []SecurityGroupRule `json:"egressrule"` Id string `json:"id"` Ingressrule []SecurityGroupRule `json:"ingressrule"` Name string `json:"name"` Project string `json:"project"` Projectid string `json:"projectid"` Tags []Tags `json:"tags"` Virtualmachinecount int `json:"virtualmachinecount"` Virtualmachineids []interface{} `json:"virtualmachineids"` } type SecurityGroupRule struct { Account string `json:"account"` Cidr string `json:"cidr"` Endport int `json:"endport"` Icmpcode int `json:"icmpcode"` Icmptype int `json:"icmptype"` Protocol string `json:"protocol"` Ruleid string `json:"ruleid"` Securitygroupname string `json:"securitygroupname"` Startport int `json:"startport"` Tags []Tags `json:"tags"` } type RevokeSecurityGroupEgressParams struct { p map[string]interface{} } func (p *RevokeSecurityGroupEgressParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } return u } func (p *RevokeSecurityGroupEgressParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v return } // You should always use this function to get a new RevokeSecurityGroupEgressParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewRevokeSecurityGroupEgressParams(id string) *RevokeSecurityGroupEgressParams { p := &RevokeSecurityGroupEgressParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Deletes a particular egress rule from this security group func (s *SecurityGroupService) RevokeSecurityGroupEgress(p *RevokeSecurityGroupEgressParams) (*RevokeSecurityGroupEgressResponse, error) { resp, err := s.cs.newRequest("revokeSecurityGroupEgress", p.toURLValues()) if err != nil { return nil, err } var r RevokeSecurityGroupEgressResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } // If we have a async client, we need to wait for the async result if s.cs.async { b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout) if err != nil { if err == AsyncTimeoutErr { return &r, err } return nil, err } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type RevokeSecurityGroupEgressResponse struct { JobID string `json:"jobid"` Displaytext string `json:"displaytext"` Success bool `json:"success"` } type RevokeSecurityGroupIngressParams struct { p map[string]interface{} } func (p *RevokeSecurityGroupIngressParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } return u } func (p *RevokeSecurityGroupIngressParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v return } // You should always use this function to get a new RevokeSecurityGroupIngressParams instance, // as then you are sure you have configured all required params func (s *SecurityGroupService) NewRevokeSecurityGroupIngressParams(id string) *RevokeSecurityGroupIngressParams { p := &RevokeSecurityGroupIngressParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Deletes a particular ingress rule from this security group func (s *SecurityGroupService) RevokeSecurityGroupIngress(p *RevokeSecurityGroupIngressParams) (*RevokeSecurityGroupIngressResponse, error) { resp, err := s.cs.newRequest("revokeSecurityGroupIngress", p.toURLValues()) if err != nil { return nil, err } var r RevokeSecurityGroupIngressResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } // If we have a async client, we need to wait for the async result if s.cs.async { b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout) if err != nil { if err == AsyncTimeoutErr { return &r, err } return nil, err } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type RevokeSecurityGroupIngressResponse struct { JobID string `json:"jobid"` Displaytext string `json:"displaytext"` Success bool `json:"success"` }