mirror of
https://github.com/jellyfin/jellyfin.git
synced 2024-07-27 07:58:43 +02:00
Merge pull request #6837 from crobibero/auth-exception
This commit is contained in:
commit
761a4e8415
|
@ -24,7 +24,7 @@ namespace Emby.Server.Implementations.HttpServer.Security
|
||||||
|
|
||||||
if (!auth.HasToken)
|
if (!auth.HasToken)
|
||||||
{
|
{
|
||||||
throw new AuthenticationException("Request does not contain a token.");
|
return auth;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!auth.IsAuthenticated)
|
if (!auth.IsAuthenticated)
|
||||||
|
|
|
@ -35,7 +35,12 @@ namespace Emby.Server.Implementations.HttpServer
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
public async Task WebSocketRequestHandler(HttpContext context)
|
public async Task WebSocketRequestHandler(HttpContext context)
|
||||||
{
|
{
|
||||||
_ = await _authService.Authenticate(context.Request).ConfigureAwait(false);
|
var authorizationInfo = await _authService.Authenticate(context.Request).ConfigureAwait(false);
|
||||||
|
if (!authorizationInfo.IsAuthenticated)
|
||||||
|
{
|
||||||
|
throw new SecurityException("Token is required");
|
||||||
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_logger.LogInformation("WS {IP} request", context.Connection.RemoteIpAddress);
|
_logger.LogInformation("WS {IP} request", context.Connection.RemoteIpAddress);
|
||||||
|
|
|
@ -45,6 +45,11 @@ namespace Jellyfin.Api.Auth
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var authorizationInfo = await _authService.Authenticate(Request).ConfigureAwait(false);
|
var authorizationInfo = await _authService.Authenticate(Request).ConfigureAwait(false);
|
||||||
|
if (!authorizationInfo.HasToken)
|
||||||
|
{
|
||||||
|
return AuthenticateResult.NoResult();
|
||||||
|
}
|
||||||
|
|
||||||
var role = UserRoles.User;
|
var role = UserRoles.User;
|
||||||
if (authorizationInfo.IsApiKey || authorizationInfo.User.HasPermission(PermissionKind.IsAdministrator))
|
if (authorizationInfo.IsApiKey || authorizationInfo.User.HasPermission(PermissionKind.IsAdministrator))
|
||||||
{
|
{
|
||||||
|
|
|
@ -132,6 +132,8 @@ namespace Jellyfin.Api.Tests.Auth
|
||||||
authorizationInfo.User.AddDefaultPreferences();
|
authorizationInfo.User.AddDefaultPreferences();
|
||||||
authorizationInfo.User.SetPermission(PermissionKind.IsAdministrator, isAdmin);
|
authorizationInfo.User.SetPermission(PermissionKind.IsAdministrator, isAdmin);
|
||||||
authorizationInfo.IsApiKey = false;
|
authorizationInfo.IsApiKey = false;
|
||||||
|
authorizationInfo.HasToken = true;
|
||||||
|
authorizationInfo.Token = "fake-token";
|
||||||
|
|
||||||
_jellyfinAuthServiceMock.Setup(
|
_jellyfinAuthServiceMock.Setup(
|
||||||
a => a.Authenticate(
|
a => a.Authenticate(
|
||||||
|
|
Loading…
Reference in a new issue