2016-01-29 20:53:56 +01:00
|
|
|
//
|
2016-04-21 16:57:02 +02:00
|
|
|
// Copyright 2016, Sander van Harmelen
|
2016-01-29 20:53:56 +01:00
|
|
|
//
|
|
|
|
// 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"
|
|
|
|
"net/url"
|
|
|
|
"strconv"
|
|
|
|
)
|
|
|
|
|
|
|
|
type ResetSSHKeyForVirtualMachineParams struct {
|
|
|
|
p map[string]interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ResetSSHKeyForVirtualMachineParams) 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["keypair"]; found {
|
|
|
|
u.Set("keypair", v.(string))
|
|
|
|
}
|
|
|
|
if v, found := p.p["projectid"]; found {
|
|
|
|
u.Set("projectid", v.(string))
|
|
|
|
}
|
|
|
|
return u
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ResetSSHKeyForVirtualMachineParams) SetAccount(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["account"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ResetSSHKeyForVirtualMachineParams) SetDomainid(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["domainid"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ResetSSHKeyForVirtualMachineParams) SetId(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["id"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ResetSSHKeyForVirtualMachineParams) SetKeypair(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["keypair"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ResetSSHKeyForVirtualMachineParams) 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 ResetSSHKeyForVirtualMachineParams instance,
|
|
|
|
// as then you are sure you have configured all required params
|
|
|
|
func (s *SSHService) NewResetSSHKeyForVirtualMachineParams(id string, keypair string) *ResetSSHKeyForVirtualMachineParams {
|
|
|
|
p := &ResetSSHKeyForVirtualMachineParams{}
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
p.p["id"] = id
|
|
|
|
p.p["keypair"] = keypair
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// Resets the SSH Key for virtual machine. The virtual machine must be in a "Stopped" state. [async]
|
|
|
|
func (s *SSHService) ResetSSHKeyForVirtualMachine(p *ResetSSHKeyForVirtualMachineParams) (*ResetSSHKeyForVirtualMachineResponse, error) {
|
|
|
|
resp, err := s.cs.newRequest("resetSSHKeyForVirtualMachine", p.toURLValues())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var r ResetSSHKeyForVirtualMachineResponse
|
|
|
|
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 ResetSSHKeyForVirtualMachineResponse struct {
|
|
|
|
JobID string `json:"jobid,omitempty"`
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Affinitygroup []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Description string `json:"description,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Id string `json:"id,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
2016-04-19 22:48:57 +02:00
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
2016-01-29 20:53:56 +01:00
|
|
|
Type string `json:"type,omitempty"`
|
|
|
|
VirtualmachineIds []string `json:"virtualmachineIds,omitempty"`
|
|
|
|
} `json:"affinitygroup,omitempty"`
|
|
|
|
Cpunumber int `json:"cpunumber,omitempty"`
|
|
|
|
Cpuspeed int `json:"cpuspeed,omitempty"`
|
|
|
|
Cpuused string `json:"cpuused,omitempty"`
|
|
|
|
Created string `json:"created,omitempty"`
|
|
|
|
Details map[string]string `json:"details,omitempty"`
|
|
|
|
Diskioread int64 `json:"diskioread,omitempty"`
|
|
|
|
Diskiowrite int64 `json:"diskiowrite,omitempty"`
|
|
|
|
Diskkbsread int64 `json:"diskkbsread,omitempty"`
|
|
|
|
Diskkbswrite int64 `json:"diskkbswrite,omitempty"`
|
|
|
|
Diskofferingid string `json:"diskofferingid,omitempty"`
|
|
|
|
Diskofferingname string `json:"diskofferingname,omitempty"`
|
|
|
|
Displayname string `json:"displayname,omitempty"`
|
|
|
|
Displayvm bool `json:"displayvm,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Forvirtualnetwork bool `json:"forvirtualnetwork,omitempty"`
|
|
|
|
Group string `json:"group,omitempty"`
|
|
|
|
Groupid string `json:"groupid,omitempty"`
|
|
|
|
Guestosid string `json:"guestosid,omitempty"`
|
|
|
|
Haenable bool `json:"haenable,omitempty"`
|
|
|
|
Hostid string `json:"hostid,omitempty"`
|
|
|
|
Hostname string `json:"hostname,omitempty"`
|
|
|
|
Hypervisor string `json:"hypervisor,omitempty"`
|
|
|
|
Id string `json:"id,omitempty"`
|
|
|
|
Instancename string `json:"instancename,omitempty"`
|
|
|
|
Isdynamicallyscalable bool `json:"isdynamicallyscalable,omitempty"`
|
|
|
|
Isodisplaytext string `json:"isodisplaytext,omitempty"`
|
|
|
|
Isoid string `json:"isoid,omitempty"`
|
|
|
|
Isoname string `json:"isoname,omitempty"`
|
|
|
|
Keypair string `json:"keypair,omitempty"`
|
|
|
|
Memory int `json:"memory,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
Networkkbsread int64 `json:"networkkbsread,omitempty"`
|
|
|
|
Networkkbswrite int64 `json:"networkkbswrite,omitempty"`
|
|
|
|
Nic []struct {
|
|
|
|
Broadcasturi string `json:"broadcasturi,omitempty"`
|
|
|
|
Deviceid string `json:"deviceid,omitempty"`
|
|
|
|
Gateway string `json:"gateway,omitempty"`
|
|
|
|
Id string `json:"id,omitempty"`
|
|
|
|
Ip6address string `json:"ip6address,omitempty"`
|
|
|
|
Ip6cidr string `json:"ip6cidr,omitempty"`
|
|
|
|
Ip6gateway string `json:"ip6gateway,omitempty"`
|
|
|
|
Ipaddress string `json:"ipaddress,omitempty"`
|
|
|
|
Isdefault bool `json:"isdefault,omitempty"`
|
|
|
|
Isolationuri string `json:"isolationuri,omitempty"`
|
|
|
|
Macaddress string `json:"macaddress,omitempty"`
|
|
|
|
Netmask string `json:"netmask,omitempty"`
|
|
|
|
Networkid string `json:"networkid,omitempty"`
|
|
|
|
Networkname string `json:"networkname,omitempty"`
|
|
|
|
Secondaryip []struct {
|
|
|
|
Id string `json:"id,omitempty"`
|
|
|
|
Ipaddress string `json:"ipaddress,omitempty"`
|
|
|
|
} `json:"secondaryip,omitempty"`
|
|
|
|
Traffictype string `json:"traffictype,omitempty"`
|
|
|
|
Type string `json:"type,omitempty"`
|
|
|
|
Virtualmachineid string `json:"virtualmachineid,omitempty"`
|
|
|
|
} `json:"nic,omitempty"`
|
|
|
|
Ostypeid int64 `json:"ostypeid,omitempty"`
|
|
|
|
Password string `json:"password,omitempty"`
|
|
|
|
Passwordenabled bool `json:"passwordenabled,omitempty"`
|
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
|
|
|
Publicip string `json:"publicip,omitempty"`
|
|
|
|
Publicipid string `json:"publicipid,omitempty"`
|
|
|
|
Rootdeviceid int64 `json:"rootdeviceid,omitempty"`
|
|
|
|
Rootdevicetype string `json:"rootdevicetype,omitempty"`
|
|
|
|
Securitygroup []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Description string `json:"description,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Egressrule []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Cidr string `json:"cidr,omitempty"`
|
|
|
|
Endport int `json:"endport,omitempty"`
|
|
|
|
Icmpcode int `json:"icmpcode,omitempty"`
|
|
|
|
Icmptype int `json:"icmptype,omitempty"`
|
|
|
|
Protocol string `json:"protocol,omitempty"`
|
|
|
|
Ruleid string `json:"ruleid,omitempty"`
|
|
|
|
Securitygroupname string `json:"securitygroupname,omitempty"`
|
|
|
|
Startport int `json:"startport,omitempty"`
|
|
|
|
Tags []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Customer string `json:"customer,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Key string `json:"key,omitempty"`
|
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
|
|
|
Resourceid string `json:"resourceid,omitempty"`
|
|
|
|
Resourcetype string `json:"resourcetype,omitempty"`
|
|
|
|
Value string `json:"value,omitempty"`
|
|
|
|
} `json:"tags,omitempty"`
|
|
|
|
} `json:"egressrule,omitempty"`
|
|
|
|
Id string `json:"id,omitempty"`
|
|
|
|
Ingressrule []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Cidr string `json:"cidr,omitempty"`
|
|
|
|
Endport int `json:"endport,omitempty"`
|
|
|
|
Icmpcode int `json:"icmpcode,omitempty"`
|
|
|
|
Icmptype int `json:"icmptype,omitempty"`
|
|
|
|
Protocol string `json:"protocol,omitempty"`
|
|
|
|
Ruleid string `json:"ruleid,omitempty"`
|
|
|
|
Securitygroupname string `json:"securitygroupname,omitempty"`
|
|
|
|
Startport int `json:"startport,omitempty"`
|
|
|
|
Tags []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Customer string `json:"customer,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Key string `json:"key,omitempty"`
|
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
|
|
|
Resourceid string `json:"resourceid,omitempty"`
|
|
|
|
Resourcetype string `json:"resourcetype,omitempty"`
|
|
|
|
Value string `json:"value,omitempty"`
|
|
|
|
} `json:"tags,omitempty"`
|
|
|
|
} `json:"ingressrule,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
|
|
|
Tags []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Customer string `json:"customer,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Key string `json:"key,omitempty"`
|
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
|
|
|
Resourceid string `json:"resourceid,omitempty"`
|
|
|
|
Resourcetype string `json:"resourcetype,omitempty"`
|
|
|
|
Value string `json:"value,omitempty"`
|
|
|
|
} `json:"tags,omitempty"`
|
2016-04-19 22:48:57 +02:00
|
|
|
Virtualmachinecount int `json:"virtualmachinecount,omitempty"`
|
|
|
|
Virtualmachineids []string `json:"virtualmachineids,omitempty"`
|
2016-01-29 20:53:56 +01:00
|
|
|
} `json:"securitygroup,omitempty"`
|
|
|
|
Serviceofferingid string `json:"serviceofferingid,omitempty"`
|
|
|
|
Serviceofferingname string `json:"serviceofferingname,omitempty"`
|
|
|
|
Servicestate string `json:"servicestate,omitempty"`
|
|
|
|
State string `json:"state,omitempty"`
|
|
|
|
Tags []struct {
|
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Customer string `json:"customer,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
|
|
|
Key string `json:"key,omitempty"`
|
|
|
|
Project string `json:"project,omitempty"`
|
|
|
|
Projectid string `json:"projectid,omitempty"`
|
|
|
|
Resourceid string `json:"resourceid,omitempty"`
|
|
|
|
Resourcetype string `json:"resourcetype,omitempty"`
|
|
|
|
Value string `json:"value,omitempty"`
|
|
|
|
} `json:"tags,omitempty"`
|
|
|
|
Templatedisplaytext string `json:"templatedisplaytext,omitempty"`
|
|
|
|
Templateid string `json:"templateid,omitempty"`
|
|
|
|
Templatename string `json:"templatename,omitempty"`
|
2016-04-19 22:48:57 +02:00
|
|
|
Userid string `json:"userid,omitempty"`
|
|
|
|
Username string `json:"username,omitempty"`
|
2016-01-29 20:53:56 +01:00
|
|
|
Vgpu string `json:"vgpu,omitempty"`
|
|
|
|
Zoneid string `json:"zoneid,omitempty"`
|
|
|
|
Zonename string `json:"zonename,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type RegisterSSHKeyPairParams struct {
|
|
|
|
p map[string]interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *RegisterSSHKeyPairParams) 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["name"]; found {
|
|
|
|
u.Set("name", v.(string))
|
|
|
|
}
|
|
|
|
if v, found := p.p["projectid"]; found {
|
|
|
|
u.Set("projectid", v.(string))
|
|
|
|
}
|
|
|
|
if v, found := p.p["publickey"]; found {
|
|
|
|
u.Set("publickey", v.(string))
|
|
|
|
}
|
|
|
|
return u
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *RegisterSSHKeyPairParams) SetAccount(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["account"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *RegisterSSHKeyPairParams) SetDomainid(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["domainid"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *RegisterSSHKeyPairParams) SetName(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["name"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *RegisterSSHKeyPairParams) SetProjectid(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["projectid"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *RegisterSSHKeyPairParams) SetPublickey(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["publickey"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// You should always use this function to get a new RegisterSSHKeyPairParams instance,
|
|
|
|
// as then you are sure you have configured all required params
|
|
|
|
func (s *SSHService) NewRegisterSSHKeyPairParams(name string, publickey string) *RegisterSSHKeyPairParams {
|
|
|
|
p := &RegisterSSHKeyPairParams{}
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
p.p["name"] = name
|
|
|
|
p.p["publickey"] = publickey
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// Register a public key in a keypair under a certain name
|
|
|
|
func (s *SSHService) RegisterSSHKeyPair(p *RegisterSSHKeyPairParams) (*RegisterSSHKeyPairResponse, error) {
|
|
|
|
resp, err := s.cs.newRequest("registerSSHKeyPair", p.toURLValues())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp, err = getRawValue(resp); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var r RegisterSSHKeyPairResponse
|
|
|
|
if err := json.Unmarshal(resp, &r); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &r, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type RegisterSSHKeyPairResponse struct {
|
2016-04-19 22:48:57 +02:00
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
2016-01-29 20:53:56 +01:00
|
|
|
Fingerprint string `json:"fingerprint,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type CreateSSHKeyPairParams struct {
|
|
|
|
p map[string]interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *CreateSSHKeyPairParams) 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["name"]; found {
|
|
|
|
u.Set("name", v.(string))
|
|
|
|
}
|
|
|
|
if v, found := p.p["projectid"]; found {
|
|
|
|
u.Set("projectid", v.(string))
|
|
|
|
}
|
|
|
|
return u
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *CreateSSHKeyPairParams) SetAccount(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["account"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *CreateSSHKeyPairParams) SetDomainid(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["domainid"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *CreateSSHKeyPairParams) SetName(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["name"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *CreateSSHKeyPairParams) 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 CreateSSHKeyPairParams instance,
|
|
|
|
// as then you are sure you have configured all required params
|
|
|
|
func (s *SSHService) NewCreateSSHKeyPairParams(name string) *CreateSSHKeyPairParams {
|
|
|
|
p := &CreateSSHKeyPairParams{}
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
p.p["name"] = name
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create a new keypair and returns the private key
|
|
|
|
func (s *SSHService) CreateSSHKeyPair(p *CreateSSHKeyPairParams) (*CreateSSHKeyPairResponse, error) {
|
|
|
|
resp, err := s.cs.newRequest("createSSHKeyPair", p.toURLValues())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp, err = getRawValue(resp); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var r CreateSSHKeyPairResponse
|
|
|
|
if err := json.Unmarshal(resp, &r); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &r, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type CreateSSHKeyPairResponse struct {
|
|
|
|
Privatekey string `json:"privatekey,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type DeleteSSHKeyPairParams struct {
|
|
|
|
p map[string]interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *DeleteSSHKeyPairParams) 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["name"]; found {
|
|
|
|
u.Set("name", v.(string))
|
|
|
|
}
|
|
|
|
if v, found := p.p["projectid"]; found {
|
|
|
|
u.Set("projectid", v.(string))
|
|
|
|
}
|
|
|
|
return u
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *DeleteSSHKeyPairParams) SetAccount(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["account"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *DeleteSSHKeyPairParams) SetDomainid(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["domainid"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *DeleteSSHKeyPairParams) SetName(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["name"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *DeleteSSHKeyPairParams) 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 DeleteSSHKeyPairParams instance,
|
|
|
|
// as then you are sure you have configured all required params
|
|
|
|
func (s *SSHService) NewDeleteSSHKeyPairParams(name string) *DeleteSSHKeyPairParams {
|
|
|
|
p := &DeleteSSHKeyPairParams{}
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
p.p["name"] = name
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// Deletes a keypair by name
|
|
|
|
func (s *SSHService) DeleteSSHKeyPair(p *DeleteSSHKeyPairParams) (*DeleteSSHKeyPairResponse, error) {
|
|
|
|
resp, err := s.cs.newRequest("deleteSSHKeyPair", p.toURLValues())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var r DeleteSSHKeyPairResponse
|
|
|
|
if err := json.Unmarshal(resp, &r); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &r, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type DeleteSSHKeyPairResponse struct {
|
|
|
|
Displaytext string `json:"displaytext,omitempty"`
|
|
|
|
Success string `json:"success,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ListSSHKeyPairsParams struct {
|
|
|
|
p map[string]interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) 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["fingerprint"]; found {
|
|
|
|
u.Set("fingerprint", 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["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))
|
|
|
|
}
|
|
|
|
return u
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetAccount(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["account"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetDomainid(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["domainid"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetFingerprint(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["fingerprint"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetIsrecursive(v bool) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["isrecursive"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetKeyword(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["keyword"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetListall(v bool) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["listall"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetName(v string) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["name"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetPage(v int) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["page"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) SetPagesize(v int) {
|
|
|
|
if p.p == nil {
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
}
|
|
|
|
p.p["pagesize"] = v
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *ListSSHKeyPairsParams) 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 ListSSHKeyPairsParams instance,
|
|
|
|
// as then you are sure you have configured all required params
|
|
|
|
func (s *SSHService) NewListSSHKeyPairsParams() *ListSSHKeyPairsParams {
|
|
|
|
p := &ListSSHKeyPairsParams{}
|
|
|
|
p.p = make(map[string]interface{})
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// List registered keypairs
|
|
|
|
func (s *SSHService) ListSSHKeyPairs(p *ListSSHKeyPairsParams) (*ListSSHKeyPairsResponse, error) {
|
|
|
|
resp, err := s.cs.newRequest("listSSHKeyPairs", p.toURLValues())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var r ListSSHKeyPairsResponse
|
|
|
|
if err := json.Unmarshal(resp, &r); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &r, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type ListSSHKeyPairsResponse struct {
|
|
|
|
Count int `json:"count"`
|
|
|
|
SSHKeyPairs []*SSHKeyPair `json:"sshkeypair"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type SSHKeyPair struct {
|
2016-04-19 22:48:57 +02:00
|
|
|
Account string `json:"account,omitempty"`
|
|
|
|
Domain string `json:"domain,omitempty"`
|
|
|
|
Domainid string `json:"domainid,omitempty"`
|
2016-01-29 20:53:56 +01:00
|
|
|
Fingerprint string `json:"fingerprint,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
}
|