1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- using MediaBrowser.Controller.Entities;
- using MediaBrowser.Controller.Library;
- using MediaBrowser.Controller.Net;
- using MediaBrowser.Controller.Security;
- using MediaBrowser.Controller.Session;
- using System.Threading.Tasks;
- using MediaBrowser.Model.Services;
- namespace Emby.Server.Implementations.HttpServer.Security
- {
- public class SessionContext : ISessionContext
- {
- private readonly IUserManager _userManager;
- private readonly ISessionManager _sessionManager;
- private readonly IAuthorizationContext _authContext;
- public SessionContext(IUserManager userManager, IAuthorizationContext authContext, ISessionManager sessionManager)
- {
- _userManager = userManager;
- _authContext = authContext;
- _sessionManager = sessionManager;
- }
- public Task<SessionInfo> GetSession(IRequest requestContext)
- {
- var authorization = _authContext.GetAuthorizationInfo(requestContext);
- var user = string.IsNullOrWhiteSpace(authorization.UserId) ? null : _userManager.GetUserById(authorization.UserId);
- return _sessionManager.LogSessionActivity(authorization.Client, authorization.Version, authorization.DeviceId, authorization.Device, requestContext.RemoteIp, user);
- }
- private AuthenticationInfo GetTokenInfo(IRequest request)
- {
- object info;
- request.Items.TryGetValue("OriginalAuthenticationInfo", out info);
- return info as AuthenticationInfo;
- }
- public Task<SessionInfo> GetSession(object requestContext)
- {
- return GetSession((IRequest)requestContext);
- }
- public async Task<User> GetUser(IRequest requestContext)
- {
- var session = await GetSession(requestContext).ConfigureAwait(false);
- return session == null || !session.UserId.HasValue ? null : _userManager.GetUserById(session.UserId.Value);
- }
- public Task<User> GetUser(object requestContext)
- {
- return GetUser((IRequest)requestContext);
- }
- }
- }
|