本文整理匯總了Golang中github.com/rhinoman/wikifeat/common/util.HasRole函數的典型用法代碼示例。如果您正苦於以下問題:Golang HasRole函數的具體用法?Golang HasRole怎麽用?Golang HasRole使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了HasRole函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: genCommentIndexResponse
func (pc PagesController) genCommentIndexResponse(curUser *CurrentUserInfo,
wikiId string, pageId string, commentList *wikit.CommentIndexViewResponse) CommentIndexResponse {
commentsUri := pc.genPageUri(wikiId, pageId) + "/comments"
userRoles := curUser.User.Roles
dbName := "wiki_" + wikiId
admin := util.HasRole(userRoles, AdminRole(dbName)) ||
util.HasRole(userRoles, AdminRole(MainDbName())) ||
util.HasRole(userRoles, MasterRole())
write := util.HasRole(userRoles, WriteRole(dbName))
indexLinks := HatLinks{}
indexLinks.Self = &HatLink{Href: commentsUri, Method: "GET"}
if admin || write {
indexLinks.Create = &HatLink{Href: commentsUri, Method: "POST"}
}
var entries []CommentResponse
for _, com := range commentList.Rows {
entries = append(entries,
pc.genCommentRecordResponse(curUser, wikiId, pageId, com.Id, &com.Value))
}
return CommentIndexResponse{
Links: indexLinks,
TotalRows: commentList.TotalRows,
Offset: commentList.Offset,
Entries: CommentIndexList{
List: entries,
},
}
}
示例2: genWikiLinks
func (wc WikisController) genWikiLinks(userRoles []string,
wikiId string, dbName string, uri string) wikiLinks {
//First, add links for wikiRecord in main db
links := wikiLinks{}
//Now check admin rights for wiki db and add links
wikiDb := "wiki_" + wikiId
admin := util.HasRole(userRoles, AdminRole(wikiDb)) ||
util.HasRole(userRoles, AdminRole(MainDbName())) ||
util.HasRole(userRoles, MasterRole())
read := util.HasRole(userRoles, ReadRole(wikiDb))
write := util.HasRole(userRoles, WriteRole(wikiDb))
pageUri := uri + "/pages"
links.Self = &HatLink{Href: uri, Method: "GET"}
if admin || read || write {
links.PageIndex = &HatLink{Href: pageUri, Method: "GET"}
}
if admin || write {
links.Update = &HatLink{Href: uri, Method: "PUT"}
links.CreatePage = &HatLink{Href: pageUri, Method: "POST"}
}
if admin {
links.Delete = &HatLink{Href: uri, Method: "DELETE"}
}
return links
}
示例3: RevokeRole
//Revoke user access
func (um *UserManager) RevokeRole(id string,
revokeRequest *RoleRequest,
curUser *CurrentUserInfo) (string, error) {
theUser := curUser.User
//Make sure user is an admin of the resource being requested
resourceDbName := resourceDbName(revokeRequest)
if !util.HasRole(theUser.Roles, AdminRole(MainDbName())) &&
!util.HasRole(theUser.Roles, AdminRole(resourceDbName)) {
//Not an admin
return "", NotAdminError()
}
//Fetch the user
userDb := Connection.SelectDB(UserDbName, AdminAuth)
readUser := new(User)
rev, err := userDb.Read(UserPrefix+id, readUser, nil)
if err != nil {
return "", err
}
//validate the role request
if revokeRequest.validate() == false {
return "", BadRequestError()
}
//ok, revoke the role
revokeRole := revokeRequest.roleString()
rev, err = Connection.RevokeRole(id, revokeRole, AdminAuth)
if err != nil {
return "", err
}
return rev, nil
}
示例4: list
//Get user list
func (uc UsersController) list(request *restful.Request,
response *restful.Response) {
curUser := GetCurrentUser(request, response)
if curUser == nil {
Unauthenticated(request, response)
return
}
var limit int
var pageNum int
limitString := request.QueryParameter("numPerPage")
if limitString == "" {
limit = 0
} else {
ln, err := strconv.Atoi(limitString)
if err != nil {
log.Printf("Error: %v", err)
WriteIllegalRequestError(response)
return
}
limit = ln
}
pageNumString := request.QueryParameter("pageNum")
if pageNumString == "" {
pageNum = 1
} else {
if ln, err := strconv.Atoi(pageNumString); err != nil {
log.Printf("Error: %v", err)
WriteIllegalRequestError(response)
} else {
pageNum = ln
}
}
ulr := UserListQueryResponse{}
forResource := request.QueryParameter("forResource")
searchText := request.QueryParameter("searchText")
var err error
if forResource != "" {
//Make sure the user is an admin for the given resource
if !util.HasRole(curUser.User.Roles, AdminRole(forResource)) &&
!util.HasRole(curUser.User.Roles, AdminRole(MainDbName())) {
WriteError(NotAdminError(), response)
return
}
rolesArray := []string{AdminRole(forResource),
WriteRole(forResource), ReadRole(forResource)}
err = new(UserManager).GetUserListForRole(
pageNum, limit, rolesArray, &ulr, curUser)
} else if searchText != "" {
err = new(UserManager).SearchForUsersByName(pageNum, limit, searchText, &ulr, curUser)
} else {
err = new(UserManager).GetUserList(pageNum, limit, &ulr, curUser)
}
if err != nil {
WriteError(err, response)
return
}
uir := uc.genUserListResponse(curUser, &ulr)
SetAuth(response, curUser.Auth)
response.WriteEntity(uir)
}
示例5: Create
//Create a normal user
func (um *UserManager) Create(newUser *User,
curUser *CurrentUserInfo) (string, error) {
//Who am I?
theUser := curUser.User
//check for admin
if !util.HasRole(theUser.Roles, AdminRole(MainDbName())) &&
!util.HasRole(theUser.Roles, MasterRole()) {
return "", NotAdminError()
}
//ok, now create the user
err := um.validateUser(newUser)
if err != nil {
return "", err
}
newUser.Roles = []string{ReadRole(MainDbName()), AllUsersRole()}
newUser.Type = "user"
namestring := UserPrefix + newUser.UserName
nowTime := time.Now().UTC()
newUser.CreatedAt = nowTime
newUser.ModifiedAt = nowTime
userDb := Connection.SelectDB(UserDbName, AdminAuth)
log.Printf("Creating new user account for: %v", newUser.UserName)
return userDb.Save(newUser, namestring, "")
}
示例6: GenIndexLinks
//Create usual links for an index
func GenIndexLinks(userRoles []string, dbName string, uri string) HatLinks {
links := HatLinks{}
admin := util.HasRole(userRoles, AdminRole(dbName))
write := util.HasRole(userRoles, WriteRole(dbName))
//Generate the self link
links.Self = &HatLink{Href: uri, Method: "GET"}
if admin || write {
links.Create = &HatLink{Href: uri, Method: "POST"}
}
return links
}
示例7: genFileRecordLinks
func (fc FileController) genFileRecordLinks(userRoles []string,
wikiDb string, uri string) fileLinks {
links := fileLinks{}
admin := util.HasRole(userRoles, AdminRole(wikiDb))
write := util.HasRole(userRoles, WriteRole(wikiDb))
links.Self = &HatLink{Href: uri, Method: "GET"}
links.GetAttachment = &HatLink{Href: uri + "/content", Method: "GET"}
if admin || write {
links.Update = &HatLink{Href: uri, Method: "PUT"}
links.Delete = &HatLink{Href: uri, Method: "DELETE"}
links.SaveAttachment = &HatLink{Href: uri + "/content", Method: "PUT"}
}
return links
}
示例8: GenRecordLinks
//Create the basic CRUD links for a resource record
func GenRecordLinks(userRoles []string, dbName string, uri string) HatLinks {
links := HatLinks{}
//Admin can be a resource admin OR a site admin/master
admin := util.HasRole(userRoles, AdminRole(dbName)) ||
util.HasRole(userRoles, AdminRole(MainDbName())) ||
util.HasRole(userRoles, MasterRole())
write := util.HasRole(userRoles, WriteRole(dbName))
//Generate the self link
links.Self = &HatLink{Href: uri, Method: "GET"}
if admin || write {
links.Update = &HatLink{Href: uri, Method: "PUT"}
links.Delete = &HatLink{Href: uri, Method: "DELETE"}
}
return links
}
示例9: Update
//Update a user
func (um *UserManager) Update(id string, rev string, updatedUser *User,
curUser *CurrentUserInfo) (string, error) {
//Who am I?
theUser := curUser.User
var auth couchdb.Auth
//make sure Id matches the user object
if id != updatedUser.UserName {
return "", BadRequestError()
}
//check for admin
if util.HasRole(theUser.Roles, AdminRole(MainDbName())) ||
util.HasRole(theUser.Roles, MasterRole()) {
auth = AdminAuth
} else {
auth = curUser.Auth
}
if err := um.validateUser(updatedUser); err != nil {
return "", err
}
userDb := Connection.SelectDB(UserDbName, auth)
//pull the user record
namestring := UserPrefix + id
//readUser := FullUserRecord{}
var userData interface{}
_, err := userDb.Read(namestring, &userData, nil)
if err != nil {
return "", err
}
readUser := userData.(map[string]interface{})
//Update the user parameters of the read user
//We do this instead of just pushing the updated user to CouchDB,
//because the updated user doesn't contain password information,
//and we don't want to wipe away the password.
nowTime := time.Now().UTC()
readUser["modifiedAt"] = nowTime
readUser["userPublic"] = updatedUser.Public
readUser["userName"] = updatedUser.UserName
readUser["passwordReset"] = updatedUser.PassResetToken
//And save the updated user
uRev, err := userDb.Save(&readUser, namestring, rev)
if err != nil {
return "", err
}
//Censor the password
//updatedUser.Password = ""
return uRev, nil
}
示例10: Read
//Get a user
func (um *UserManager) Read(id string, user *User,
curUser *CurrentUserInfo) (string, error) {
//Who am I?
theUser := curUser.User
readUser := User{}
if util.HasRole(theUser.Roles, AdminRole(MainDbName())) {
//This is an admin
userDb := Connection.SelectDB(UserDbName, AdminAuth)
rev, err := userDb.Read(UserPrefix+id, &readUser, nil)
if err != nil {
return "", err
} else {
*user = readUser
return rev, nil
}
} else {
userDb := Connection.SelectDB(UserDbName, curUser.Auth)
if rev, err := userDb.Read(UserPrefix+id, &readUser, nil); err != nil {
return "", err
} else {
*user = readUser
return rev, nil
}
}
}
示例11: Create
//Create a new wiki
func (wm *WikiManager) Create(id string, wr *WikiRecord,
curUser *CurrentUserInfo) (string, error) {
auth := curUser.Auth
theUser := curUser.User
//Verify user is authorized to create wikis
mainDb := MainDbName()
if !util.HasRole(theUser.Roles, AdminRole(mainDb)) &&
!util.HasRole(theUser.Roles, WriteRole(mainDb)) {
return "", NotAdminError()
}
owner := theUser.UserName
//Add an entry for this wiki to the Main db
wr.Id = id
wr.Slug = slugification.Slugify(wr.Name)
wr.CreatedAt = time.Now().UTC()
wr.ModifiedAt = time.Now().UTC()
wr.Type = "wiki_record"
if err := wr.Validate(); err != nil {
return "", err
}
cDb := Connection.SelectDB(mainDb, auth)
log.Printf("Adding wiki entry %v to db %v", id, mainDb)
rev, err := cDb.Save(&wr, id, "")
//Check for duplicate slugs
err = wm.checkForDuplicateSlug(wr.Slug)
if err != nil {
//Delete the wiki record we just created
cDb.Delete(id, rev)
return "", err
}
//Create the Wiki
log.Printf("Creating Wiki: %v", id)
err = wikit.CreateWiki(Connection, AdminAuth, owner, WikiDbName(id))
if err != nil {
//Delete the wiki record from maindb
cDb.Delete(id, rev)
return "", err
}
//Set Guest Acess
if err := wm.setGuestAccess(id, wr, auth); err != nil {
return rev, err
}
//wr.Id = id
return rev, nil
}
示例12: genAvatarRecordLinks
//Generates the Links for a UserAvatar Record Response
func (ac AvatarController) genAvatarRecordLinks(user *User,
userId string, uri string) avatarLinks {
links := avatarLinks{}
userRoles := user.Roles
admin := util.HasRole(userRoles, AdminRole(MainDbName())) ||
util.HasRole(userRoles, MasterRole())
write := user.UserName == userId
links.Self = &HatLink{Href: uri, Method: "GET"}
links.GetLargeAvatar = &HatLink{Href: uri + "/image", Method: "GET"}
links.GetThumbnailAvatar = &HatLink{Href: uri + "/thumbnail", Method: "GET"}
if admin || write {
links.Update = &HatLink{Href: uri, Method: "PUT"}
links.Delete = &HatLink{Href: uri, Method: "DELETE"}
links.SaveImage = &HatLink{Href: uri + "/image", Method: "PUT"}
}
return links
}
示例13: genCommentRecordLinks
// Permissions are a bit different for comments, so we need a custom function
func (pc PagesController) genCommentRecordLinks(curUser *CurrentUserInfo,
dbName string, commentUri string, commentAuthor string) HatLinks {
links := HatLinks{}
userRoles := curUser.User.Roles
admin := util.HasRole(userRoles, AdminRole(dbName)) ||
util.HasRole(userRoles, AdminRole(MainDbName())) ||
util.HasRole(userRoles, MasterRole())
ownComment := commentAuthor == curUser.User.UserName
//Generate the self link
links.Self = &HatLink{Href: commentUri, Method: "GET"}
//Update links
if admin || ownComment {
links.Update = &HatLink{Href: commentUri, Method: "PUT"}
links.Delete = &HatLink{Href: commentUri, Method: "DELETE"}
}
return links
}
示例14: Delete
//Delete a User Avatar Record
func (uam *UserAvatarManager) Delete(id string, curUser *CurrentUserInfo) (string, error) {
theUser := curUser.User
var auth couchdb.Auth
if util.HasRole(theUser.Roles, AdminRole(MainDbName())) ||
util.HasRole(theUser.Roles, MasterRole()) {
auth = AdminAuth
} else {
auth = curUser.Auth
}
avatarDb := Connection.SelectDB(AvatarDbName(), auth)
//Fetch the record
avatarRecord := new(UserAvatar)
rev, err := avatarDb.Read(id, avatarRecord, nil)
if err != nil {
return "", err
}
return avatarDb.Delete(id, rev)
}
示例15: Save
//Save User Avatar Record
func (uam *UserAvatarManager) Save(id string, rev string,
avatar *UserAvatar, curUser *CurrentUserInfo) (string, error) {
nowTime := time.Now().UTC()
if rev == "" {
avatar.CreatedAt = nowTime
}
avatar.ModifiedAt = nowTime
var auth couchdb.Auth
//check for admin
if util.HasRole(curUser.Roles, AdminRole(MainDbName())) ||
util.HasRole(curUser.Roles, MasterRole()) {
auth = AdminAuth
} else {
auth = curUser.Auth
}
avatarDb := Connection.SelectDB(AvatarDbName(), auth)
return avatarDb.Save(avatar, id, rev)
}