请求上下文中的ServiceStack HasPermission

时间:2013-09-21 08:55:20

标签: c# servicestack

我正在尝试利用servicestack的身份验证和授权功能,这样我就不需要用这个来污染我的服务代码了,这样可以带来更干净的测试等。

在我的应用程序中,用户有权在特定环境中执行某些操作。

即用户只能查看其产品集中的产品。

为了实现这一点,我考虑使用名为canView的权限属性来装饰我的productViewRequest dto,然后创建我自己的IAuthSession实现,以检查用户是否在其允许的集合中请求产品。

这会是一个不错的方法还是我咆哮错误的树?

假设这是一种正确的方法,我如何在会话实现中获取上下文,即HasPermission调用中的productViewRequest对象?

感谢您的帮助

1 个答案:

答案 0 :(得分:1)

首先,我会检查ServiceStack内置的auth选项https://github.com/ServiceStack/ServiceStack/wiki/Authentication-and-authorization

如果这不符合您的要求,请求过滤器属性将允许您访问请求上下文。

public class CanViewAttribute : RequestFilterAttribute {
    private readonly string permission;

    public CanViewAttribute(string permission) {
        this.permission = permission;
    }

    public override void Execute(IHttpRequest req, IHttpResponse res, object responseDto) {
        // todo: check permission

        if (!hasPermission) {
          res.StatusCode = (int)HttpStatusCode.Forbidden;
          res.EndRequest();
        }
    }
}