aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/HttpServer/Security/SessionContext.cs
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2016-11-03 21:18:51 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2016-11-03 21:18:51 -0400
commit46efa464d851d3f78b74ac02d061388115cf6d66 (patch)
tree56b95c1ff2dd71e2b75b27e059da9173b7d915b5 /Emby.Server.Implementations/HttpServer/Security/SessionContext.cs
parent70e146a0b2b96129da80476a01bb794936419242 (diff)
move classes
Diffstat (limited to 'Emby.Server.Implementations/HttpServer/Security/SessionContext.cs')
-rw-r--r--Emby.Server.Implementations/HttpServer/Security/SessionContext.cs67
1 files changed, 67 insertions, 0 deletions
diff --git a/Emby.Server.Implementations/HttpServer/Security/SessionContext.cs b/Emby.Server.Implementations/HttpServer/Security/SessionContext.cs
new file mode 100644
index 000000000..33dd4e2d7
--- /dev/null
+++ b/Emby.Server.Implementations/HttpServer/Security/SessionContext.cs
@@ -0,0 +1,67 @@
+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(IServiceRequest requestContext)
+ {
+ var authorization = _authContext.GetAuthorizationInfo(requestContext);
+
+ //if (!string.IsNullOrWhiteSpace(authorization.Token))
+ //{
+ // var auth = GetTokenInfo(requestContext);
+ // if (auth != null)
+ // {
+ // return _sessionManager.GetSessionByAuthenticationToken(auth, authorization.DeviceId, requestContext.RemoteIp, authorization.Version);
+ // }
+ //}
+
+ 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(IServiceRequest request)
+ {
+ object info;
+ request.Items.TryGetValue("OriginalAuthenticationInfo", out info);
+ return info as AuthenticationInfo;
+ }
+
+ public Task<SessionInfo> GetSession(object requestContext)
+ {
+ var req = new ServiceRequest((IRequest)requestContext);
+ return GetSession(req);
+ }
+
+ public async Task<User> GetUser(IServiceRequest 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)
+ {
+ var req = new ServiceRequest((IRequest)requestContext);
+ return GetUser(req);
+ }
+ }
+}