// PublicAddress returns the public address for each given unit, if set. func (u *UniterAPI) PublicAddress(args params.Entities) (params.StringResults, error) { result := params.StringResults{ Results: make([]params.StringResult, len(args.Entities)), } canAccess, err := u.accessUnit() if err != nil { return params.StringResults{}, err } for i, entity := range args.Entities { err := common.ErrPerm if canAccess(entity.Tag) { var unit *state.Unit unit, err = u.getUnit(entity.Tag) if err == nil { address, ok := unit.PublicAddress() if ok { result.Results[i].Result = address } else { err = common.NoAddressSetError(entity.Tag, "public") } } } result.Results[i].Error = common.ServerError(err) } return result, nil }
code: params.CodeCannotEnterScope, helperFunc: params.IsCodeCannotEnterScope, }, { err: state.ErrExcessiveContention, code: params.CodeExcessiveContention, helperFunc: params.IsCodeExcessiveContention, }, { err: state.ErrUnitHasSubordinates, code: params.CodeUnitHasSubordinates, helperFunc: params.IsCodeUnitHasSubordinates, }, { err: common.ErrBadId, code: params.CodeNotFound, helperFunc: params.IsCodeNotFound, }, { err: common.NoAddressSetError("unit-mysql-0", "public"), code: params.CodeNoAddressSet, helperFunc: params.IsCodeNoAddressSet, }, { err: common.ErrBadCreds, code: params.CodeUnauthorized, helperFunc: params.IsCodeUnauthorized, }, { err: common.ErrPerm, code: params.CodeUnauthorized, helperFunc: params.IsCodeUnauthorized, }, { err: common.ErrNotLoggedIn, code: params.CodeUnauthorized, helperFunc: params.IsCodeUnauthorized, }, {