Contextual serialization from WebApi endpoint based on permissions

后端 未结 2 852
抹茶落季
抹茶落季 2020-12-31 19:33

I am using the Asp.Net Web Api. I would like to be able to filter out certain fields on the response objects based on the connected clients access rights.

Example:

相关标签:
2条回答
  • 2020-12-31 20:18

    It was actually a lot simpler than I first thought. What I did not realise is that the DelegatingHandler can be used to manipulate the response as well as the request in the Web Api Pipeline.

    Lifecycle of an ASP.NET Web API Message

    Delegating Handler


    Delegating handlers are an extensibility point in the message pipeline allowing you to massage the Request before passing it on to the rest of the pipeline. The response message on its way back has to pass through the Delegating Handler as well, so any response can also be monitored/filtered/updated at this extensibility point.

    Delegating Handlers if required, can bypass the rest of the pipeline too and send back and Http Response themselves.

    Example

    Here is an example implementation of a DelegatingHandler that can either manipulate the response object or replace it altogether.

    public class ResponseDataFilterHandler : DelegatingHandler
    {
        protected override System.Threading.Tasks.Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
        {
            return base.SendAsync(request, cancellationToken)
                .ContinueWith(task =>
                {
                    var response = task.Result;
    
                    //Manipulate content here
                    var content = response.Content as ObjectContent;
                    if (content != null && content.Value != null)
                    {
                        ((SomeObject)content.Value).SomeProperty = null;
                    }
    
                    //Or replace the content
                    response.Content = new ObjectContent(typeof(object), new object(), new JsonMediaTypeFormatter());
    
                    return response;
                });
        }
    }
    

    Microsoft article on how to implement a delegating handler and add it to the pipeline.HTTP Message Handlers in ASP.NET Web API

    0 讨论(0)
  • 2020-12-31 20:27

    I have a similar question in the works over here: ASP.NET WebAPI Conditional Serialization based on User Role

    A proposed solution that I came up with is to have my ApiController inherit from a BaseApiController which overrides the Initalize function to set the appropriate formatter based on the user's role. I haven't decided if I will go this way yet, but perhaps it will work for you.

    protected override void Initialize(System.Web.Http.Controllers.HttpControllerContext controllerContext)
    {
        base.Initialize(controllerContext);
        // If the user is in a sensitive-data access role
        controllerContext.Configuration.Formatters.Add(/*My Formatter*/);
        // Otherwise use the default ones added in global app_start that defaults to remove sensitive data
    }
    
    0 讨论(0)
提交回复
热议问题