本文整理匯總了Golang中github.com/wallyworld/core/state/api/params.ErrorResults類的典型用法代碼示例。如果您正苦於以下問題:Golang ErrorResults類的具體用法?Golang ErrorResults怎麽用?Golang ErrorResults使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了ErrorResults類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: RemoveUser
func (c *Client) RemoveUser(tag string) error {
u := params.Entity{Tag: tag}
p := params.Entities{Entities: []params.Entity{u}}
results := new(params.ErrorResults)
err := c.call("RemoveUser", p, results)
if err != nil {
return err
}
return results.OneError()
}
示例2: AddUser
func (c *Client) AddUser(tag, password string) error {
u := params.EntityPassword{Tag: tag, Password: password}
p := params.EntityPasswords{Changes: []params.EntityPassword{u}}
results := new(params.ErrorResults)
err := c.call("AddUser", p, results)
if err != nil {
return err
}
return results.OneError()
}
示例3: Remove
// Remove removes the machine from state. It will fail if the machine
// is not Dead.
func (m *Machine) Remove() error {
var result params.ErrorResults
args := params.Entities{
Entities: []params.Entity{{Tag: m.tag}},
}
err := m.st.call("Remove", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例4: EnsureDead
// EnsureDead sets the unit lifecycle to Dead if it is Alive or
// Dying. It does nothing otherwise.
func (u *Unit) EnsureDead() error {
var result params.ErrorResults
args := params.Entities{
Entities: []params.Entity{{Tag: u.tag}},
}
err := u.st.call("EnsureDead", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例5: DestroyAllSubordinates
// DestroyAllSubordinates destroys all subordinates of the unit.
func (u *Unit) DestroyAllSubordinates() error {
var result params.ErrorResults
args := params.Entities{
Entities: []params.Entity{{Tag: u.tag}},
}
err := u.st.call("DestroyAllSubordinates", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例6: SetStatus
// SetStatus sets the status of the machine.
func (m *Machine) SetStatus(status params.Status, info string, data params.StatusData) error {
var result params.ErrorResults
args := params.SetStatus{
Entities: []params.EntityStatus{
{Tag: m.tag, Status: status, Info: info, Data: data},
},
}
err := m.st.call("SetStatus", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例7: SetPassword
// SetPassword sets the machine's password.
func (m *Machine) SetPassword(password string) error {
var result params.ErrorResults
args := params.EntityPasswords{
Changes: []params.EntityPassword{
{Tag: m.tag, Password: password},
},
}
err := m.st.call("SetPasswords", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例8: ClosePort
// ClosePort sets the policy of the port with protocol and number to
// be closed.
//
// TODO: We should really be opening and closing ports on machines,
// rather than units.
func (u *Unit) ClosePort(protocol string, number int) error {
var result params.ErrorResults
args := params.EntitiesPorts{
Entities: []params.EntityPort{
{Tag: u.tag, Protocol: protocol, Port: number},
},
}
err := u.st.call("ClosePort", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例9: SetMachineAddresses
// SetMachineAddresses sets the machine determined addresses of the machine.
func (m *Machine) SetMachineAddresses(addresses []instance.Address) error {
var result params.ErrorResults
args := params.SetMachinesAddresses{
MachineAddresses: []params.MachineAddresses{
{Tag: m.Tag(), Addresses: addresses},
},
}
err := m.st.call("SetMachineAddresses", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例10: LeaveScope
// LeaveScope signals that the unit has left its scope in the relation.
// After the unit has left its relation scope, it is no longer a member
// of the relation; if the relation is dying when its last member unit
// leaves, it is removed immediately. It is not an error to leave a scope
// that the unit is not, or never was, a member of.
func (ru *RelationUnit) LeaveScope() error {
var result params.ErrorResults
args := params.RelationUnits{
RelationUnits: []params.RelationUnit{{
Relation: ru.relation.tag,
Unit: ru.unit.tag,
}},
}
err := ru.st.call("LeaveScope", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例11: SetPassword
// SetPassword sets the password associated with the agent's entity.
func (m *Entity) SetPassword(password string) error {
var results params.ErrorResults
args := params.EntityPasswords{
Changes: []params.EntityPassword{{
Tag: m.tag,
Password: password,
}},
}
err := m.st.caller.Call("Agent", "", "SetPasswords", args, &results)
if err != nil {
return err
}
return results.OneError()
}
示例12: SetVersion
// SetVersion sets the tools version associated with the entity with
// the given tag, which must be the tag of the entity that the
// upgrader is running on behalf of.
func (st *State) SetVersion(tag string, v version.Binary) error {
var results params.ErrorResults
args := params.EntitiesVersion{
AgentTools: []params.EntityVersion{{
Tag: tag,
Tools: ¶ms.Version{v},
}},
}
err := st.call("SetTools", args, &results)
if err != nil {
// TODO: Not directly tested
return err
}
return results.OneError()
}
示例13: SetCharmURL
// SetCharmURL marks the unit as currently using the supplied charm URL.
// An error will be returned if the unit is dead, or the charm URL not known.
func (u *Unit) SetCharmURL(curl *charm.URL) error {
if curl == nil {
return fmt.Errorf("charm URL cannot be nil")
}
var result params.ErrorResults
args := params.EntitiesCharmURL{
Entities: []params.EntityCharmURL{
{Tag: u.tag, CharmURL: curl.String()},
},
}
err := u.st.call("SetCharmURL", args, &result)
if err != nil {
return err
}
return result.OneError()
}
示例14: ImportKeys
// ImportKeys imports new authorised ssh keys from the specified key ids for the specified user.
func (api *KeyManagerAPI) ImportKeys(arg params.ModifyUserSSHKeys) (params.ErrorResults, error) {
result := params.ErrorResults{
Results: make([]params.ErrorResult, len(arg.Keys)),
}
if len(arg.Keys) == 0 {
return result, nil
}
canWrite, err := api.getCanWrite()
if err != nil {
return params.ErrorResults{}, common.ServerError(err)
}
if !canWrite(arg.User) {
return params.ErrorResults{}, common.ServerError(common.ErrPerm)
}
// For now, authorised keys are global, common to all users.
sshKeys, currentFingerprints, err := api.currentKeyDataForAdd()
if err != nil {
return params.ErrorResults{}, common.ServerError(fmt.Errorf("reading current key data: %v", err))
}
importedKeyInfo := runSSHKeyImport(arg.Keys)
// Ensure we are not going to add invalid or duplicate keys.
result.Results = make([]params.ErrorResult, len(importedKeyInfo))
for i, keyInfo := range importedKeyInfo {
if keyInfo.err != nil {
result.Results[i].Error = common.ServerError(keyInfo.err)
continue
}
if currentFingerprints.Contains(keyInfo.fingerprint) {
result.Results[i].Error = common.ServerError(fmt.Errorf("duplicate ssh key: %s", keyInfo.key))
continue
}
sshKeys = append(sshKeys, keyInfo.key)
}
err = api.writeSSHKeys(sshKeys)
if err != nil {
return params.ErrorResults{}, common.ServerError(err)
}
return result, nil
}
示例15: SetInstanceInfo
// SetInstanceInfo sets the provider specific instance id, nonce,
// metadata, networks and interfaces for this machine. Once set, the
// instance id cannot be changed.
func (m *Machine) SetInstanceInfo(
id instance.Id, nonce string, characteristics *instance.HardwareCharacteristics,
networks []params.Network, interfaces []params.NetworkInterface,
) error {
var result params.ErrorResults
args := params.InstancesInfo{
Machines: []params.InstanceInfo{{
Tag: m.tag,
InstanceId: id,
Nonce: nonce,
Characteristics: characteristics,
Networks: networks,
Interfaces: interfaces,
}},
}
err := m.st.call("SetInstanceInfo", args, &result)
if err != nil {
return err
}
return result.OneError()
}