本文整理匯總了Golang中github.com/juju/juju/apiserver/params.UserInfoResults.Results方法的典型用法代碼示例。如果您正苦於以下問題:Golang UserInfoResults.Results方法的具體用法?Golang UserInfoResults.Results怎麽用?Golang UserInfoResults.Results使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/juju/juju/apiserver/params.UserInfoResults
的用法示例。
在下文中一共展示了UserInfoResults.Results方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestUserInfoAll
func (s *userManagerSuite) TestUserInfoAll(c *gc.C) {
admin, err := s.State.User(s.AdminUserTag(c))
c.Assert(err, jc.ErrorIsNil)
userFoo := s.Factory.MakeUser(c, &factory.UserParams{Name: "foobar", DisplayName: "Foo Bar"})
userAardvark := s.Factory.MakeUser(c, &factory.UserParams{Name: "aardvark", DisplayName: "Aard Vark", Disabled: true})
args := params.UserInfoRequest{IncludeDisabled: true}
results, err := s.usermanager.UserInfo(args)
c.Assert(err, jc.ErrorIsNil)
var expected params.UserInfoResults
for _, r := range []struct {
user *state.User
info *params.UserInfo
}{{
user: userAardvark,
info: ¶ms.UserInfo{
Username: "aardvark",
DisplayName: "Aard Vark",
Access: "login",
Disabled: true,
},
}, {
user: admin,
info: ¶ms.UserInfo{
Username: s.adminName,
DisplayName: admin.DisplayName(),
Access: "superuser",
},
}, {
user: userFoo,
info: ¶ms.UserInfo{
Username: "foobar",
DisplayName: "Foo Bar",
Access: "login",
},
}} {
r.info.CreatedBy = s.adminName
r.info.DateCreated = r.user.DateCreated()
r.info.LastConnection = lastLoginPointer(c, r.user)
expected.Results = append(expected.Results, params.UserInfoResult{Result: r.info})
}
c.Assert(results, jc.DeepEquals, expected)
results, err = s.usermanager.UserInfo(params.UserInfoRequest{})
c.Assert(err, jc.ErrorIsNil)
// Same results as before, but without the deactivated user
expected.Results = expected.Results[1:]
c.Assert(results, jc.DeepEquals, expected)
}
示例2: UserInfo
// UserInfo returns information on a user.
func (api *UserManagerAPI) UserInfo(request params.UserInfoRequest) (params.UserInfoResults, error) {
var results params.UserInfoResults
var infoForUser = func(user *state.User) params.UserInfoResult {
var lastLogin *time.Time
userLastLogin, err := user.LastLogin()
if err != nil {
if !state.IsNeverLoggedInError(err) {
logger.Debugf("error getting last login: %v", err)
}
} else {
lastLogin = &userLastLogin
}
return params.UserInfoResult{
Result: ¶ms.UserInfo{
Username: user.Name(),
DisplayName: user.DisplayName(),
CreatedBy: user.CreatedBy(),
DateCreated: user.DateCreated(),
LastConnection: lastLogin,
Disabled: user.IsDisabled(),
},
}
}
argCount := len(request.Entities)
if argCount == 0 {
users, err := api.state.AllUsers(request.IncludeDisabled)
if err != nil {
return results, errors.Trace(err)
}
for _, user := range users {
results.Results = append(results.Results, infoForUser(user))
}
return results, nil
}
results.Results = make([]params.UserInfoResult, argCount)
for i, arg := range request.Entities {
user, err := api.getUser(arg.Tag)
if err != nil {
results.Results[i].Error = common.ServerError(err)
continue
}
results.Results[i] = infoForUser(user)
}
return results, nil
}
示例3: TestUserInfoAll
func (s *userManagerSuite) TestUserInfoAll(c *gc.C) {
admin, err := s.State.User(s.AdminUserTag(c))
c.Assert(err, jc.ErrorIsNil)
userFoo := s.Factory.MakeUser(c, &factory.UserParams{Name: "foobar", DisplayName: "Foo Bar"})
userBar := s.Factory.MakeUser(c, &factory.UserParams{Name: "barfoo", DisplayName: "Bar Foo", Disabled: true})
args := params.UserInfoRequest{IncludeDisabled: true}
results, err := s.usermanager.UserInfo(args)
c.Assert(err, jc.ErrorIsNil)
expected := params.UserInfoResults{
Results: []params.UserInfoResult{
{
Result: ¶ms.UserInfo{
Username: "barfoo",
DisplayName: "Bar Foo",
CreatedBy: s.adminName,
DateCreated: userBar.DateCreated(),
LastConnection: userBar.LastLogin(),
Disabled: true,
},
}, {
Result: ¶ms.UserInfo{
Username: s.adminName,
DisplayName: admin.DisplayName(),
CreatedBy: s.adminName,
DateCreated: admin.DateCreated(),
LastConnection: admin.LastLogin(),
},
}, {
Result: ¶ms.UserInfo{
Username: "foobar",
DisplayName: "Foo Bar",
CreatedBy: s.adminName,
DateCreated: userFoo.DateCreated(),
LastConnection: userFoo.LastLogin(),
},
}},
}
c.Assert(results, jc.DeepEquals, expected)
results, err = s.usermanager.UserInfo(params.UserInfoRequest{})
c.Assert(err, jc.ErrorIsNil)
// Same results as before, but without the deactivated barfoo user
expected.Results = expected.Results[1:]
c.Assert(results, jc.DeepEquals, expected)
}
示例4: TestUserInfo
func (s *userManagerSuite) TestUserInfo(c *gc.C) {
userFoo := s.Factory.MakeUser(c, &factory.UserParams{Name: "foobar", DisplayName: "Foo Bar"})
userBar := s.Factory.MakeUser(c, &factory.UserParams{Name: "barfoo", DisplayName: "Bar Foo", Disabled: true})
args := params.UserInfoRequest{
Entities: []params.Entity{
{
Tag: userFoo.Tag().String(),
}, {
Tag: userBar.Tag().String(),
}, {
Tag: names.NewLocalUserTag("ellie").String(),
}, {
Tag: names.NewUserTag("[email protected]").String(),
}, {
Tag: "not-a-tag",
},
}}
results, err := s.usermanager.UserInfo(args)
c.Assert(err, jc.ErrorIsNil)
var expected params.UserInfoResults
for _, r := range []struct {
user *state.User
info *params.UserInfo
err *params.Error
}{
{
user: userFoo,
info: ¶ms.UserInfo{
Username: "foobar",
DisplayName: "Foo Bar",
},
}, {
user: userBar,
info: ¶ms.UserInfo{
Username: "barfoo",
DisplayName: "Bar Foo",
Disabled: true,
},
}, {
err: ¶ms.Error{
Message: "permission denied",
Code: params.CodeUnauthorized,
},
}, {
err: ¶ms.Error{
Message: "permission denied",
Code: params.CodeUnauthorized,
},
}, {
err: ¶ms.Error{
Message: `"not-a-tag" is not a valid tag`,
},
},
} {
if r.info != nil {
r.info.DateCreated = r.user.DateCreated()
r.info.LastConnection = lastLoginPointer(c, r.user)
r.info.CreatedBy = s.adminName
}
expected.Results = append(expected.Results, params.UserInfoResult{Result: r.info, Error: r.err})
}
c.Assert(results, jc.DeepEquals, expected)
}
示例5: UserInfo
// UserInfo returns information on a user.
func (api *UserManagerAPI) UserInfo(request params.UserInfoRequest) (params.UserInfoResults, error) {
var results params.UserInfoResults
isAdmin, err := api.hasControllerAdminAccess()
if err != nil {
return results, errors.Trace(err)
}
var accessForUser = func(userTag names.UserTag, result *params.UserInfoResult) {
// Lookup the access the specified user has to the controller.
_, controllerUserAccess, err := common.UserAccess(api.state, userTag)
if err == nil {
result.Result.Access = string(controllerUserAccess.Access)
} else if err != nil && !errors.IsNotFound(err) {
result.Result = nil
result.Error = common.ServerError(err)
}
}
var infoForUser = func(user *state.User) params.UserInfoResult {
var lastLogin *time.Time
userLastLogin, err := user.LastLogin()
if err != nil {
if !state.IsNeverLoggedInError(err) {
logger.Debugf("error getting last login: %v", err)
}
} else {
lastLogin = &userLastLogin
}
result := params.UserInfoResult{
Result: ¶ms.UserInfo{
Username: user.Name(),
DisplayName: user.DisplayName(),
CreatedBy: user.CreatedBy(),
DateCreated: user.DateCreated(),
LastConnection: lastLogin,
Disabled: user.IsDisabled(),
},
}
accessForUser(user.UserTag(), &result)
return result
}
argCount := len(request.Entities)
if argCount == 0 {
users, err := api.state.AllUsers(request.IncludeDisabled)
if err != nil {
return results, errors.Trace(err)
}
for _, user := range users {
if !isAdmin && !api.authorizer.AuthOwner(user.Tag()) {
continue
}
results.Results = append(results.Results, infoForUser(user))
}
return results, nil
}
// Create the results list to populate.
for _, arg := range request.Entities {
userTag, err := names.ParseUserTag(arg.Tag)
if err != nil {
results.Results = append(results.Results, params.UserInfoResult{Error: common.ServerError(err)})
continue
}
if !isAdmin && !api.authorizer.AuthOwner(userTag) {
results.Results = append(results.Results, params.UserInfoResult{Error: common.ServerError(common.ErrPerm)})
continue
}
if !userTag.IsLocal() {
// TODO(wallyworld) record login information about external users.
result := params.UserInfoResult{
Result: ¶ms.UserInfo{
Username: userTag.Id(),
},
}
accessForUser(userTag, &result)
results.Results = append(results.Results, result)
continue
}
user, err := api.getUser(arg.Tag)
if err != nil {
results.Results = append(results.Results, params.UserInfoResult{Error: common.ServerError(err)})
continue
}
results.Results = append(results.Results, infoForUser(user))
}
return results, nil
}