本文整理汇总了Golang中github.com/solher/zest/interfaces.FilterIfOwnerRelations函数的典型用法代码示例。如果您正苦于以下问题:Golang FilterIfOwnerRelations函数的具体用法?Golang FilterIfOwnerRelations怎么用?Golang FilterIfOwnerRelations使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了FilterIfOwnerRelations函数的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: UpdateByID
func (c *AclCtrl) UpdateByID(w http.ResponseWriter, r *http.Request, params map[string]string) {
id, err := strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
acl := &domain.Acl{}
err = json.NewDecoder(r.Body).Decode(acl)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.BodyDecodingError, err)
return
}
lastRessource := interfaces.GetLastRessource(r)
filter := interfaces.FilterIfOwnerRelations(r, nil)
relations := interfaces.GetOwnerRelations(r)
acl.SetRelatedID(lastRessource.IDKey, lastRessource.ID)
acl, err = c.interactor.UpdateByID(id, acl, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
acl.BeforeRender()
c.render.JSON(w, http.StatusCreated, acl)
}
开发者ID:optimuse,项目名称:zest,代码行数:35,代码来源:acl_controller.go
示例2: FindByID
func (c *AclCtrl) FindByID(w http.ResponseWriter, r *http.Request, params map[string]string) {
id, err := strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
filter, err := interfaces.GetQueryFilter(r)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.FilterDecodingError, err)
return
}
filter = interfaces.FilterIfOwnerRelations(r, filter)
relations := interfaces.GetOwnerRelations(r)
acl, err := c.interactor.FindByID(id, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
acl.BeforeRender()
c.render.JSON(w, http.StatusOK, acl)
}
开发者ID:optimuse,项目名称:zest,代码行数:30,代码来源:acl_controller.go
示例3: UpdatePassword
// @Title UpdatePassword
// @Description Update the user password
// @Accept json
// @Param id path int true "User id"
// @Param PasswordForm body PasswordForm true "The old and the new password"
// @Success 200 {object} domain.User "Request was successful"
// @Router /users/{id}/updatePassword [post]
func (c *UserCtrl) UpdatePassword(w http.ResponseWriter, r *http.Request, params map[string]string) {
id, err := strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
form := &PasswordForm{}
err = json.NewDecoder(r.Body).Decode(form)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.BodyDecodingError, err)
return
}
filter := interfaces.FilterIfOwnerRelations(r, nil)
relations := interfaces.GetOwnerRelations(r)
user, err := c.guestInter.UpdatePassword(id, usecases.QueryContext{Filter: filter, OwnerRelations: relations}, form.OldPassword, form.NewPassword)
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
case internalerrors.InvalidCredentials:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.InvalidCredentials, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
user.BeforeRender()
c.render.JSON(w, http.StatusOK, user)
}
开发者ID:wid-la,项目名称:wus,代码行数:42,代码来源:user_controller.go
示例4: DeleteByID
// @Title DeleteByID
// @Description Delete a Account instance
// @Accept json
// @Param id path int true "Account id"
// @Success 204 {object} error "Request was successful"
// @Router /accounts/{id} [delete]
func (c *AccountCtrl) DeleteByID(w http.ResponseWriter, r *http.Request, params map[string]string) {
var (
id int
err error
)
id, err = strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
filter := interfaces.FilterIfOwnerRelations(r, nil)
relations := interfaces.GetOwnerRelations(r)
err = c.interactor.DeleteByID(id, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
c.render.JSON(w, http.StatusNoContent, nil)
}
开发者ID:wid-la,项目名称:wus,代码行数:34,代码来源:account_controller.go
示例5: Upsert
func (c *AclCtrl) Upsert(w http.ResponseWriter, r *http.Request, _ map[string]string) {
acl := &domain.Acl{}
var acls []domain.Acl
buffer, _ := ioutil.ReadAll(r.Body)
err := json.Unmarshal(buffer, acl)
if err != nil {
err := json.Unmarshal(buffer, &acls)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.BodyDecodingError, err)
return
}
}
lastRessource := interfaces.GetLastRessource(r)
filter := interfaces.FilterIfOwnerRelations(r, nil)
relations := interfaces.GetOwnerRelations(r)
if acls == nil {
acl.SetRelatedID(lastRessource.IDKey, lastRessource.ID)
acl, err = c.interactor.UpsertOne(acl, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
} else {
for i := range acls {
(&acls[i]).SetRelatedID(lastRessource.IDKey, lastRessource.ID)
}
acls, err = c.interactor.Upsert(acls, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
}
if err != nil {
switch err.(type) {
case *internalerrors.ViolatedConstraint:
c.render.JSONError(w, 422, apierrors.ViolatedConstraint, err)
}
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
if acls == nil {
acl.BeforeRender()
c.render.JSON(w, http.StatusCreated, acl)
} else {
for i := range acls {
(&acls[i]).BeforeRender()
}
c.render.JSON(w, http.StatusCreated, acls)
}
}
开发者ID:optimuse,项目名称:zest,代码行数:55,代码来源:acl_controller.go
示例6: UpdateByID
func (c *AccountCtrl) UpdateByID(w http.ResponseWriter, r *http.Request, params map[string]string) {
var (
id int
err error
)
if params["id"] == "me" {
sessionCtx := context.Get(r, "currentSession")
if sessionCtx == nil {
c.render.JSONError(w, http.StatusUnauthorized, apierrors.SessionNotFound, nil)
return
}
id = sessionCtx.(domain.Session).AccountID
} else {
id, err = strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
}
account := &domain.Account{}
err = json.NewDecoder(r.Body).Decode(account)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.BodyDecodingError, err)
return
}
lastRessource := interfaces.GetLastRessource(r)
filter := interfaces.FilterIfOwnerRelations(r, nil)
relations := interfaces.GetOwnerRelations(r)
account.SetRelatedID(lastRessource.IDKey, lastRessource.ID)
account, err = c.interactor.UpdateByID(id, account, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
account.BeforeRender()
c.render.JSON(w, http.StatusCreated, account)
}
开发者ID:optimuse,项目名称:zest,代码行数:50,代码来源:account_controller.go
示例7: FindByID
func (c *AccountCtrl) FindByID(w http.ResponseWriter, r *http.Request, params map[string]string) {
var (
id int
err error
)
if params["id"] == "me" {
sessionCtx := context.Get(r, "currentSession")
if sessionCtx == nil {
c.render.JSONError(w, http.StatusUnauthorized, apierrors.SessionNotFound, nil)
return
}
id = sessionCtx.(domain.Session).AccountID
} else {
id, err = strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
}
filter, err := interfaces.GetQueryFilter(r)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.FilterDecodingError, err)
return
}
filter = interfaces.FilterIfOwnerRelations(r, filter)
relations := interfaces.GetOwnerRelations(r)
account, err := c.interactor.FindByID(id, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
account.BeforeRender()
c.render.JSON(w, http.StatusOK, account)
}
开发者ID:optimuse,项目名称:zest,代码行数:45,代码来源:account_controller.go
示例8: DeleteAll
func (c *AclCtrl) DeleteAll(w http.ResponseWriter, r *http.Request, _ map[string]string) {
filter, err := interfaces.GetQueryFilter(r)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.FilterDecodingError, err)
return
}
filter = interfaces.FilterIfLastRessource(r, filter)
filter = interfaces.FilterIfOwnerRelations(r, filter)
relations := interfaces.GetOwnerRelations(r)
err = c.interactor.DeleteAll(usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
return
}
c.render.JSON(w, http.StatusNoContent, nil)
}
开发者ID:optimuse,项目名称:zest,代码行数:19,代码来源:acl_controller.go
示例9: UpdateByID
// @Title UpdateByID
// @Description Update attributes of a User instance
// @Accept json
// @Param id path int true "User id"
// @Param User body domain.User true "User instance data"
// @Success 200 {object} domain.User
// @Router /users/{id} [put]
func (c *UserCtrl) UpdateByID(w http.ResponseWriter, r *http.Request, params map[string]string) {
id, err := strconv.Atoi(params["id"])
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.InvalidPathParams, err)
return
}
user := &domain.User{}
err = json.NewDecoder(r.Body).Decode(user)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.BodyDecodingError, err)
return
}
lastResource := interfaces.GetLastResource(r)
filter := interfaces.FilterIfOwnerRelations(r, nil)
relations := interfaces.GetOwnerRelations(r)
user.SetRelatedID(lastResource.IDKey, lastResource.ID)
if roles := context.Get(r, "roles"); roles != nil && utils.ContainsStr(roles.([]string), "Admin") {
user, err = c.interactor.UpdateByID(id, user, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
} else {
user, err = c.guestInter.UpdateByID(id, user, usecases.QueryContext{Filter: filter, OwnerRelations: relations})
}
if err != nil {
switch err {
case internalerrors.NotFound:
c.render.JSONError(w, http.StatusUnauthorized, apierrors.Unauthorized, err)
default:
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
}
return
}
user.BeforeRender()
c.render.JSON(w, http.StatusOK, user)
}
开发者ID:wid-la,项目名称:wus,代码行数:47,代码来源:user_controller.go
示例10: Find
func (c *AclCtrl) Find(w http.ResponseWriter, r *http.Request, _ map[string]string) {
filter, err := interfaces.GetQueryFilter(r)
if err != nil {
c.render.JSONError(w, http.StatusBadRequest, apierrors.FilterDecodingError, err)
return
}
filter = interfaces.FilterIfLastRessource(r, filter)
filter = interfaces.FilterIfOwnerRelations(r, filter)
relations := interfaces.GetOwnerRelations(r)
acls, err := c.interactor.Find(usecases.QueryContext{Filter: filter, OwnerRelations: relations})
if err != nil {
c.render.JSONError(w, http.StatusInternalServerError, apierrors.InternalServerError, err)
return
}
for i := range acls {
(&acls[i]).BeforeRender()
}
c.render.JSON(w, http.StatusOK, acls)
}
开发者ID:optimuse,项目名称:zest,代码行数:22,代码来源:acl_controller.go
注:本文中的github.com/solher/zest/interfaces.FilterIfOwnerRelations函数示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论