using ServiceStack.Web;
using System;
using System.Linq;
namespace MediaBrowser.Controller.Net
{
public class AuthenticatedAttribute : Attribute, IHasRequestFilter
{
public IAuthService AuthService { get; set; }
///
/// Gets or sets a value indicating whether or not to allow local unauthenticated access.
///
/// true if [allow local]; otherwise, false.
public bool AllowLocal { get; set; }
public string Roles { get; set; }
///
/// The request filter is executed before the service.
///
/// The http request wrapper
/// The http response wrapper
/// The request DTO
public void RequestFilter(IRequest request, IResponse response, object requestDto)
{
var roles = (Roles ?? string.Empty).Split(',')
.Where(i => !string.IsNullOrWhiteSpace(i))
.ToArray();
AuthService.Authenticate(request, response, requestDto, AllowLocal, roles);
}
///
/// A new shallow copy of this filter is used on every request.
///
/// IHasRequestFilter.
public IHasRequestFilter Copy()
{
return this;
}
///
/// Order in which Request Filters are executed.
/// <0 Executed before global request filters
/// >0 Executed after global request filters
///
/// The priority.
public int Priority
{
get { return 0; }
}
}
}