cloudstack/InternalLBService.go (1,207 lines of code) (raw):

// // Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you 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" ) type InternalLBServiceIface interface { ConfigureInternalLoadBalancerElement(p *ConfigureInternalLoadBalancerElementParams) (*InternalLoadBalancerElementResponse, error) NewConfigureInternalLoadBalancerElementParams(enabled bool, id string) *ConfigureInternalLoadBalancerElementParams CreateInternalLoadBalancerElement(p *CreateInternalLoadBalancerElementParams) (*CreateInternalLoadBalancerElementResponse, error) NewCreateInternalLoadBalancerElementParams(nspid string) *CreateInternalLoadBalancerElementParams ListInternalLoadBalancerElements(p *ListInternalLoadBalancerElementsParams) (*ListInternalLoadBalancerElementsResponse, error) NewListInternalLoadBalancerElementsParams() *ListInternalLoadBalancerElementsParams GetInternalLoadBalancerElementByID(id string, opts ...OptionFunc) (*InternalLoadBalancerElement, int, error) ListInternalLoadBalancerVMs(p *ListInternalLoadBalancerVMsParams) (*ListInternalLoadBalancerVMsResponse, error) NewListInternalLoadBalancerVMsParams() *ListInternalLoadBalancerVMsParams GetInternalLoadBalancerVMID(name string, opts ...OptionFunc) (string, int, error) GetInternalLoadBalancerVMByName(name string, opts ...OptionFunc) (*InternalLoadBalancerVM, int, error) GetInternalLoadBalancerVMByID(id string, opts ...OptionFunc) (*InternalLoadBalancerVM, int, error) StartInternalLoadBalancerVM(p *StartInternalLoadBalancerVMParams) (*StartInternalLoadBalancerVMResponse, error) NewStartInternalLoadBalancerVMParams(id string) *StartInternalLoadBalancerVMParams StopInternalLoadBalancerVM(p *StopInternalLoadBalancerVMParams) (*StopInternalLoadBalancerVMResponse, error) NewStopInternalLoadBalancerVMParams(id string) *StopInternalLoadBalancerVMParams } type ConfigureInternalLoadBalancerElementParams struct { p map[string]interface{} } func (p *ConfigureInternalLoadBalancerElementParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["enabled"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("enabled", vv) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } return u } func (p *ConfigureInternalLoadBalancerElementParams) SetEnabled(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["enabled"] = v } func (p *ConfigureInternalLoadBalancerElementParams) ResetEnabled() { if p.p != nil && p.p["enabled"] != nil { delete(p.p, "enabled") } } func (p *ConfigureInternalLoadBalancerElementParams) GetEnabled() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["enabled"].(bool) return value, ok } func (p *ConfigureInternalLoadBalancerElementParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v } func (p *ConfigureInternalLoadBalancerElementParams) ResetId() { if p.p != nil && p.p["id"] != nil { delete(p.p, "id") } } func (p *ConfigureInternalLoadBalancerElementParams) GetId() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["id"].(string) return value, ok } // You should always use this function to get a new ConfigureInternalLoadBalancerElementParams instance, // as then you are sure you have configured all required params func (s *InternalLBService) NewConfigureInternalLoadBalancerElementParams(enabled bool, id string) *ConfigureInternalLoadBalancerElementParams { p := &ConfigureInternalLoadBalancerElementParams{} p.p = make(map[string]interface{}) p.p["enabled"] = enabled p.p["id"] = id return p } // Configures an Internal Load Balancer element. func (s *InternalLBService) ConfigureInternalLoadBalancerElement(p *ConfigureInternalLoadBalancerElementParams) (*InternalLoadBalancerElementResponse, error) { resp, err := s.cs.newRequest("configureInternalLoadBalancerElement", p.toURLValues()) if err != nil { return nil, err } var r InternalLoadBalancerElementResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type InternalLoadBalancerElementResponse struct { Enabled bool `json:"enabled"` Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Nspid string `json:"nspid"` } type CreateInternalLoadBalancerElementParams struct { p map[string]interface{} } func (p *CreateInternalLoadBalancerElementParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["nspid"]; found { u.Set("nspid", v.(string)) } return u } func (p *CreateInternalLoadBalancerElementParams) SetNspid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["nspid"] = v } func (p *CreateInternalLoadBalancerElementParams) ResetNspid() { if p.p != nil && p.p["nspid"] != nil { delete(p.p, "nspid") } } func (p *CreateInternalLoadBalancerElementParams) GetNspid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["nspid"].(string) return value, ok } // You should always use this function to get a new CreateInternalLoadBalancerElementParams instance, // as then you are sure you have configured all required params func (s *InternalLBService) NewCreateInternalLoadBalancerElementParams(nspid string) *CreateInternalLoadBalancerElementParams { p := &CreateInternalLoadBalancerElementParams{} p.p = make(map[string]interface{}) p.p["nspid"] = nspid return p } // Create an Internal Load Balancer element. func (s *InternalLBService) CreateInternalLoadBalancerElement(p *CreateInternalLoadBalancerElementParams) (*CreateInternalLoadBalancerElementResponse, error) { resp, err := s.cs.newRequest("createInternalLoadBalancerElement", p.toURLValues()) if err != nil { return nil, err } var r CreateInternalLoadBalancerElementResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type CreateInternalLoadBalancerElementResponse struct { Enabled bool `json:"enabled"` Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Nspid string `json:"nspid"` } type ListInternalLoadBalancerElementsParams struct { p map[string]interface{} } func (p *ListInternalLoadBalancerElementsParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["enabled"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("enabled", vv) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } if v, found := p.p["keyword"]; found { u.Set("keyword", v.(string)) } if v, found := p.p["nspid"]; found { u.Set("nspid", v.(string)) } 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) } return u } func (p *ListInternalLoadBalancerElementsParams) SetEnabled(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["enabled"] = v } func (p *ListInternalLoadBalancerElementsParams) ResetEnabled() { if p.p != nil && p.p["enabled"] != nil { delete(p.p, "enabled") } } func (p *ListInternalLoadBalancerElementsParams) GetEnabled() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["enabled"].(bool) return value, ok } func (p *ListInternalLoadBalancerElementsParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v } func (p *ListInternalLoadBalancerElementsParams) ResetId() { if p.p != nil && p.p["id"] != nil { delete(p.p, "id") } } func (p *ListInternalLoadBalancerElementsParams) GetId() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["id"].(string) return value, ok } func (p *ListInternalLoadBalancerElementsParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v } func (p *ListInternalLoadBalancerElementsParams) ResetKeyword() { if p.p != nil && p.p["keyword"] != nil { delete(p.p, "keyword") } } func (p *ListInternalLoadBalancerElementsParams) GetKeyword() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["keyword"].(string) return value, ok } func (p *ListInternalLoadBalancerElementsParams) SetNspid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["nspid"] = v } func (p *ListInternalLoadBalancerElementsParams) ResetNspid() { if p.p != nil && p.p["nspid"] != nil { delete(p.p, "nspid") } } func (p *ListInternalLoadBalancerElementsParams) GetNspid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["nspid"].(string) return value, ok } func (p *ListInternalLoadBalancerElementsParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v } func (p *ListInternalLoadBalancerElementsParams) ResetPage() { if p.p != nil && p.p["page"] != nil { delete(p.p, "page") } } func (p *ListInternalLoadBalancerElementsParams) GetPage() (int, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["page"].(int) return value, ok } func (p *ListInternalLoadBalancerElementsParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v } func (p *ListInternalLoadBalancerElementsParams) ResetPagesize() { if p.p != nil && p.p["pagesize"] != nil { delete(p.p, "pagesize") } } func (p *ListInternalLoadBalancerElementsParams) GetPagesize() (int, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["pagesize"].(int) return value, ok } // You should always use this function to get a new ListInternalLoadBalancerElementsParams instance, // as then you are sure you have configured all required params func (s *InternalLBService) NewListInternalLoadBalancerElementsParams() *ListInternalLoadBalancerElementsParams { p := &ListInternalLoadBalancerElementsParams{} 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 *InternalLBService) GetInternalLoadBalancerElementByID(id string, opts ...OptionFunc) (*InternalLoadBalancerElement, int, error) { p := &ListInternalLoadBalancerElementsParams{} 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.ListInternalLoadBalancerElements(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.InternalLoadBalancerElements[0], l.Count, nil } return nil, l.Count, fmt.Errorf("There is more then one result for InternalLoadBalancerElement UUID: %s!", id) } // Lists all available Internal Load Balancer elements. func (s *InternalLBService) ListInternalLoadBalancerElements(p *ListInternalLoadBalancerElementsParams) (*ListInternalLoadBalancerElementsResponse, error) { resp, err := s.cs.newRequest("listInternalLoadBalancerElements", p.toURLValues()) if err != nil { return nil, err } var r ListInternalLoadBalancerElementsResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type ListInternalLoadBalancerElementsResponse struct { Count int `json:"count"` InternalLoadBalancerElements []*InternalLoadBalancerElement `json:"internalloadbalancerelement"` } type InternalLoadBalancerElement struct { Enabled bool `json:"enabled"` Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Nspid string `json:"nspid"` } type ListInternalLoadBalancerVMsParams struct { p map[string]interface{} } func (p *ListInternalLoadBalancerVMsParams) 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["fetchhealthcheckresults"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("fetchhealthcheckresults", vv) } if v, found := p.p["forvpc"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("forvpc", vv) } if v, found := p.p["hostid"]; found { u.Set("hostid", 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["name"]; found { u.Set("name", v.(string)) } if v, found := p.p["networkid"]; found { u.Set("networkid", v.(string)) } 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["podid"]; found { u.Set("podid", v.(string)) } if v, found := p.p["projectid"]; found { u.Set("projectid", v.(string)) } if v, found := p.p["state"]; found { u.Set("state", v.(string)) } if v, found := p.p["vpcid"]; found { u.Set("vpcid", v.(string)) } if v, found := p.p["zoneid"]; found { u.Set("zoneid", v.(string)) } return u } func (p *ListInternalLoadBalancerVMsParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetAccount() { if p.p != nil && p.p["account"] != nil { delete(p.p, "account") } } func (p *ListInternalLoadBalancerVMsParams) GetAccount() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["account"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetDomainid() { if p.p != nil && p.p["domainid"] != nil { delete(p.p, "domainid") } } func (p *ListInternalLoadBalancerVMsParams) GetDomainid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["domainid"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetFetchhealthcheckresults(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["fetchhealthcheckresults"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetFetchhealthcheckresults() { if p.p != nil && p.p["fetchhealthcheckresults"] != nil { delete(p.p, "fetchhealthcheckresults") } } func (p *ListInternalLoadBalancerVMsParams) GetFetchhealthcheckresults() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["fetchhealthcheckresults"].(bool) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetForvpc(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["forvpc"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetForvpc() { if p.p != nil && p.p["forvpc"] != nil { delete(p.p, "forvpc") } } func (p *ListInternalLoadBalancerVMsParams) GetForvpc() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["forvpc"].(bool) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetHostid() { if p.p != nil && p.p["hostid"] != nil { delete(p.p, "hostid") } } func (p *ListInternalLoadBalancerVMsParams) GetHostid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["hostid"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetId() { if p.p != nil && p.p["id"] != nil { delete(p.p, "id") } } func (p *ListInternalLoadBalancerVMsParams) GetId() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["id"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetIsrecursive(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["isrecursive"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetIsrecursive() { if p.p != nil && p.p["isrecursive"] != nil { delete(p.p, "isrecursive") } } func (p *ListInternalLoadBalancerVMsParams) GetIsrecursive() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["isrecursive"].(bool) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetKeyword() { if p.p != nil && p.p["keyword"] != nil { delete(p.p, "keyword") } } func (p *ListInternalLoadBalancerVMsParams) GetKeyword() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["keyword"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetListall(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["listall"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetListall() { if p.p != nil && p.p["listall"] != nil { delete(p.p, "listall") } } func (p *ListInternalLoadBalancerVMsParams) GetListall() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["listall"].(bool) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetName(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["name"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetName() { if p.p != nil && p.p["name"] != nil { delete(p.p, "name") } } func (p *ListInternalLoadBalancerVMsParams) GetName() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["name"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetNetworkid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["networkid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetNetworkid() { if p.p != nil && p.p["networkid"] != nil { delete(p.p, "networkid") } } func (p *ListInternalLoadBalancerVMsParams) GetNetworkid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["networkid"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetPage() { if p.p != nil && p.p["page"] != nil { delete(p.p, "page") } } func (p *ListInternalLoadBalancerVMsParams) GetPage() (int, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["page"].(int) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetPagesize() { if p.p != nil && p.p["pagesize"] != nil { delete(p.p, "pagesize") } } func (p *ListInternalLoadBalancerVMsParams) GetPagesize() (int, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["pagesize"].(int) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetPodid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["podid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetPodid() { if p.p != nil && p.p["podid"] != nil { delete(p.p, "podid") } } func (p *ListInternalLoadBalancerVMsParams) GetPodid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["podid"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetProjectid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["projectid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetProjectid() { if p.p != nil && p.p["projectid"] != nil { delete(p.p, "projectid") } } func (p *ListInternalLoadBalancerVMsParams) GetProjectid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["projectid"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetState(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["state"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetState() { if p.p != nil && p.p["state"] != nil { delete(p.p, "state") } } func (p *ListInternalLoadBalancerVMsParams) GetState() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["state"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetVpcid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["vpcid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetVpcid() { if p.p != nil && p.p["vpcid"] != nil { delete(p.p, "vpcid") } } func (p *ListInternalLoadBalancerVMsParams) GetVpcid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["vpcid"].(string) return value, ok } func (p *ListInternalLoadBalancerVMsParams) SetZoneid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["zoneid"] = v } func (p *ListInternalLoadBalancerVMsParams) ResetZoneid() { if p.p != nil && p.p["zoneid"] != nil { delete(p.p, "zoneid") } } func (p *ListInternalLoadBalancerVMsParams) GetZoneid() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["zoneid"].(string) return value, ok } // You should always use this function to get a new ListInternalLoadBalancerVMsParams instance, // as then you are sure you have configured all required params func (s *InternalLBService) NewListInternalLoadBalancerVMsParams() *ListInternalLoadBalancerVMsParams { p := &ListInternalLoadBalancerVMsParams{} 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 *InternalLBService) GetInternalLoadBalancerVMID(name string, opts ...OptionFunc) (string, int, error) { p := &ListInternalLoadBalancerVMsParams{} p.p = make(map[string]interface{}) p.p["name"] = name for _, fn := range append(s.cs.options, opts...) { if err := fn(s.cs, p); err != nil { return "", -1, err } } l, err := s.ListInternalLoadBalancerVMs(p) if err != nil { return "", -1, err } if l.Count == 0 { return "", l.Count, fmt.Errorf("No match found for %s: %+v", name, l) } if l.Count == 1 { return l.InternalLoadBalancerVMs[0].Id, l.Count, nil } if l.Count > 1 { for _, v := range l.InternalLoadBalancerVMs { if v.Name == name { return v.Id, l.Count, nil } } } return "", l.Count, fmt.Errorf("Could not find an exact match for %s: %+v", name, l) } // This is a courtesy helper function, which in some cases may not work as expected! func (s *InternalLBService) GetInternalLoadBalancerVMByName(name string, opts ...OptionFunc) (*InternalLoadBalancerVM, int, error) { id, count, err := s.GetInternalLoadBalancerVMID(name, opts...) if err != nil { return nil, count, err } r, count, err := s.GetInternalLoadBalancerVMByID(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 *InternalLBService) GetInternalLoadBalancerVMByID(id string, opts ...OptionFunc) (*InternalLoadBalancerVM, int, error) { p := &ListInternalLoadBalancerVMsParams{} 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.ListInternalLoadBalancerVMs(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.InternalLoadBalancerVMs[0], l.Count, nil } return nil, l.Count, fmt.Errorf("There is more then one result for InternalLoadBalancerVM UUID: %s!", id) } // List internal LB VMs. func (s *InternalLBService) ListInternalLoadBalancerVMs(p *ListInternalLoadBalancerVMsParams) (*ListInternalLoadBalancerVMsResponse, error) { resp, err := s.cs.newRequest("listInternalLoadBalancerVMs", p.toURLValues()) if err != nil { return nil, err } var r ListInternalLoadBalancerVMsResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type ListInternalLoadBalancerVMsResponse struct { Count int `json:"count"` InternalLoadBalancerVMs []*InternalLoadBalancerVM `json:"internalloadbalancervm"` } type InternalLoadBalancerVM struct { Account string `json:"account"` Created string `json:"created"` Dns1 string `json:"dns1"` Dns2 string `json:"dns2"` Domain string `json:"domain"` Domainid string `json:"domainid"` Domainpath string `json:"domainpath"` Gateway string `json:"gateway"` Guestipaddress string `json:"guestipaddress"` Guestmacaddress string `json:"guestmacaddress"` Guestnetmask string `json:"guestnetmask"` Guestnetworkid string `json:"guestnetworkid"` Guestnetworkname string `json:"guestnetworkname"` Hasannotations bool `json:"hasannotations"` Healthcheckresults []InternalLoadBalancerVMHealthcheckresults `json:"healthcheckresults"` Healthchecksfailed bool `json:"healthchecksfailed"` Hostcontrolstate string `json:"hostcontrolstate"` Hostid string `json:"hostid"` Hostname string `json:"hostname"` Hypervisor string `json:"hypervisor"` Id string `json:"id"` Ip6dns1 string `json:"ip6dns1"` Ip6dns2 string `json:"ip6dns2"` Isredundantrouter bool `json:"isredundantrouter"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Linklocalip string `json:"linklocalip"` Linklocalmacaddress string `json:"linklocalmacaddress"` Linklocalnetmask string `json:"linklocalnetmask"` Linklocalnetworkid string `json:"linklocalnetworkid"` Name string `json:"name"` Networkdomain string `json:"networkdomain"` Nic []Nic `json:"nic"` Podid string `json:"podid"` Podname string `json:"podname"` Project string `json:"project"` Projectid string `json:"projectid"` Publicip string `json:"publicip"` Publicmacaddress string `json:"publicmacaddress"` Publicnetmask string `json:"publicnetmask"` Publicnetworkid string `json:"publicnetworkid"` Redundantstate string `json:"redundantstate"` Requiresupgrade bool `json:"requiresupgrade"` Role string `json:"role"` Scriptsversion string `json:"scriptsversion"` Serviceofferingid string `json:"serviceofferingid"` Serviceofferingname string `json:"serviceofferingname"` Softwareversion string `json:"softwareversion"` State string `json:"state"` Templateid string `json:"templateid"` Templatename string `json:"templatename"` Version string `json:"version"` Vpcid string `json:"vpcid"` Vpcname string `json:"vpcname"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type InternalLoadBalancerVMHealthcheckresults struct { Checkname string `json:"checkname"` Checktype string `json:"checktype"` Details string `json:"details"` Lastupdated string `json:"lastupdated"` Success bool `json:"success"` } type StartInternalLoadBalancerVMParams struct { p map[string]interface{} } func (p *StartInternalLoadBalancerVMParams) 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 *StartInternalLoadBalancerVMParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v } func (p *StartInternalLoadBalancerVMParams) ResetId() { if p.p != nil && p.p["id"] != nil { delete(p.p, "id") } } func (p *StartInternalLoadBalancerVMParams) GetId() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["id"].(string) return value, ok } // You should always use this function to get a new StartInternalLoadBalancerVMParams instance, // as then you are sure you have configured all required params func (s *InternalLBService) NewStartInternalLoadBalancerVMParams(id string) *StartInternalLoadBalancerVMParams { p := &StartInternalLoadBalancerVMParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Starts an existing internal lb vm. func (s *InternalLBService) StartInternalLoadBalancerVM(p *StartInternalLoadBalancerVMParams) (*StartInternalLoadBalancerVMResponse, error) { resp, err := s.cs.newRequest("startInternalLoadBalancerVM", p.toURLValues()) if err != nil { return nil, err } var r StartInternalLoadBalancerVMResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type StartInternalLoadBalancerVMResponse struct { Account string `json:"account"` Created string `json:"created"` Dns1 string `json:"dns1"` Dns2 string `json:"dns2"` Domain string `json:"domain"` Domainid string `json:"domainid"` Domainpath string `json:"domainpath"` Gateway string `json:"gateway"` Guestipaddress string `json:"guestipaddress"` Guestmacaddress string `json:"guestmacaddress"` Guestnetmask string `json:"guestnetmask"` Guestnetworkid string `json:"guestnetworkid"` Guestnetworkname string `json:"guestnetworkname"` Hasannotations bool `json:"hasannotations"` Healthcheckresults []StartInternalLoadBalancerVMResponseHealthcheckresults `json:"healthcheckresults"` Healthchecksfailed bool `json:"healthchecksfailed"` Hostcontrolstate string `json:"hostcontrolstate"` Hostid string `json:"hostid"` Hostname string `json:"hostname"` Hypervisor string `json:"hypervisor"` Id string `json:"id"` Ip6dns1 string `json:"ip6dns1"` Ip6dns2 string `json:"ip6dns2"` Isredundantrouter bool `json:"isredundantrouter"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Linklocalip string `json:"linklocalip"` Linklocalmacaddress string `json:"linklocalmacaddress"` Linklocalnetmask string `json:"linklocalnetmask"` Linklocalnetworkid string `json:"linklocalnetworkid"` Name string `json:"name"` Networkdomain string `json:"networkdomain"` Nic []Nic `json:"nic"` Podid string `json:"podid"` Podname string `json:"podname"` Project string `json:"project"` Projectid string `json:"projectid"` Publicip string `json:"publicip"` Publicmacaddress string `json:"publicmacaddress"` Publicnetmask string `json:"publicnetmask"` Publicnetworkid string `json:"publicnetworkid"` Redundantstate string `json:"redundantstate"` Requiresupgrade bool `json:"requiresupgrade"` Role string `json:"role"` Scriptsversion string `json:"scriptsversion"` Serviceofferingid string `json:"serviceofferingid"` Serviceofferingname string `json:"serviceofferingname"` Softwareversion string `json:"softwareversion"` State string `json:"state"` Templateid string `json:"templateid"` Templatename string `json:"templatename"` Version string `json:"version"` Vpcid string `json:"vpcid"` Vpcname string `json:"vpcname"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type StartInternalLoadBalancerVMResponseHealthcheckresults struct { Checkname string `json:"checkname"` Checktype string `json:"checktype"` Details string `json:"details"` Lastupdated string `json:"lastupdated"` Success bool `json:"success"` } type StopInternalLoadBalancerVMParams struct { p map[string]interface{} } func (p *StopInternalLoadBalancerVMParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["forced"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("forced", vv) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } return u } func (p *StopInternalLoadBalancerVMParams) SetForced(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["forced"] = v } func (p *StopInternalLoadBalancerVMParams) ResetForced() { if p.p != nil && p.p["forced"] != nil { delete(p.p, "forced") } } func (p *StopInternalLoadBalancerVMParams) GetForced() (bool, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["forced"].(bool) return value, ok } func (p *StopInternalLoadBalancerVMParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v } func (p *StopInternalLoadBalancerVMParams) ResetId() { if p.p != nil && p.p["id"] != nil { delete(p.p, "id") } } func (p *StopInternalLoadBalancerVMParams) GetId() (string, bool) { if p.p == nil { p.p = make(map[string]interface{}) } value, ok := p.p["id"].(string) return value, ok } // You should always use this function to get a new StopInternalLoadBalancerVMParams instance, // as then you are sure you have configured all required params func (s *InternalLBService) NewStopInternalLoadBalancerVMParams(id string) *StopInternalLoadBalancerVMParams { p := &StopInternalLoadBalancerVMParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Stops an Internal LB vm. func (s *InternalLBService) StopInternalLoadBalancerVM(p *StopInternalLoadBalancerVMParams) (*StopInternalLoadBalancerVMResponse, error) { resp, err := s.cs.newRequest("stopInternalLoadBalancerVM", p.toURLValues()) if err != nil { return nil, err } var r StopInternalLoadBalancerVMResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type StopInternalLoadBalancerVMResponse struct { Account string `json:"account"` Created string `json:"created"` Dns1 string `json:"dns1"` Dns2 string `json:"dns2"` Domain string `json:"domain"` Domainid string `json:"domainid"` Domainpath string `json:"domainpath"` Gateway string `json:"gateway"` Guestipaddress string `json:"guestipaddress"` Guestmacaddress string `json:"guestmacaddress"` Guestnetmask string `json:"guestnetmask"` Guestnetworkid string `json:"guestnetworkid"` Guestnetworkname string `json:"guestnetworkname"` Hasannotations bool `json:"hasannotations"` Healthcheckresults []StopInternalLoadBalancerVMResponseHealthcheckresults `json:"healthcheckresults"` Healthchecksfailed bool `json:"healthchecksfailed"` Hostcontrolstate string `json:"hostcontrolstate"` Hostid string `json:"hostid"` Hostname string `json:"hostname"` Hypervisor string `json:"hypervisor"` Id string `json:"id"` Ip6dns1 string `json:"ip6dns1"` Ip6dns2 string `json:"ip6dns2"` Isredundantrouter bool `json:"isredundantrouter"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Linklocalip string `json:"linklocalip"` Linklocalmacaddress string `json:"linklocalmacaddress"` Linklocalnetmask string `json:"linklocalnetmask"` Linklocalnetworkid string `json:"linklocalnetworkid"` Name string `json:"name"` Networkdomain string `json:"networkdomain"` Nic []Nic `json:"nic"` Podid string `json:"podid"` Podname string `json:"podname"` Project string `json:"project"` Projectid string `json:"projectid"` Publicip string `json:"publicip"` Publicmacaddress string `json:"publicmacaddress"` Publicnetmask string `json:"publicnetmask"` Publicnetworkid string `json:"publicnetworkid"` Redundantstate string `json:"redundantstate"` Requiresupgrade bool `json:"requiresupgrade"` Role string `json:"role"` Scriptsversion string `json:"scriptsversion"` Serviceofferingid string `json:"serviceofferingid"` Serviceofferingname string `json:"serviceofferingname"` Softwareversion string `json:"softwareversion"` State string `json:"state"` Templateid string `json:"templateid"` Templatename string `json:"templatename"` Version string `json:"version"` Vpcid string `json:"vpcid"` Vpcname string `json:"vpcname"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type StopInternalLoadBalancerVMResponseHealthcheckresults struct { Checkname string `json:"checkname"` Checktype string `json:"checktype"` Details string `json:"details"` Lastupdated string `json:"lastupdated"` Success bool `json:"success"` }