mirror of
https://github.com/bitwarden/server.git
synced 2025-04-04 20:50:21 -05:00
Auth/PM-16947 - Device Management - Adjust Device + pending auth request get query (#5250)
* Added userId check on query * Added required field to inner select * PM-16947 - Update to filter inner subquery on user id per discussion with Robert * Updated to use new query with ROW_NUMBER * More query optimizations to eliminate returning old requests for a device * Fixed approval condition to be NULL as 0 means denied. * Added negation of @ExpirationMinutes --------- Co-authored-by: Todd Martin <tmartin@bitwarden.com>
This commit is contained in:
parent
aa0b35a345
commit
72bb06a9d7
@ -10,18 +10,21 @@ BEGIN
|
|||||||
AR.Id as AuthRequestId,
|
AR.Id as AuthRequestId,
|
||||||
AR.CreationDate as AuthRequestCreationDate
|
AR.CreationDate as AuthRequestCreationDate
|
||||||
FROM dbo.DeviceView D
|
FROM dbo.DeviceView D
|
||||||
LEFT JOIN (
|
LEFT JOIN (
|
||||||
SELECT TOP 1 -- Take only the top record sorted by auth request creation date
|
SELECT
|
||||||
Id,
|
Id,
|
||||||
CreationDate,
|
CreationDate,
|
||||||
RequestDeviceIdentifier
|
RequestDeviceIdentifier,
|
||||||
|
Approved,
|
||||||
|
ROW_NUMBER() OVER (PARTITION BY RequestDeviceIdentifier ORDER BY CreationDate DESC) as rn
|
||||||
FROM dbo.AuthRequestView
|
FROM dbo.AuthRequestView
|
||||||
WHERE Type IN (0, 1) -- Include only AuthenticateAndUnlock and Unlock types, excluding Admin Approval (type 2)
|
WHERE Type IN (0, 1) -- AuthenticateAndUnlock and Unlock types only
|
||||||
AND CreationDate >= DATEADD(MINUTE, -@ExpirationMinutes, GETUTCDATE()) -- Ensure the request hasn't expired
|
AND CreationDate >= DATEADD(MINUTE, -@ExpirationMinutes, GETUTCDATE()) -- Ensure the request hasn't expired
|
||||||
AND Approved IS NULL -- Include only requests that haven't been acknowledged or approved
|
AND UserId = @UserId -- Requests for this user only
|
||||||
ORDER BY CreationDate DESC
|
) AR -- This join will get the most recent request per device, regardless of approval status
|
||||||
) AR ON D.Identifier = AR.RequestDeviceIdentifier
|
ON D.Identifier = AR.RequestDeviceIdentifier AND AR.rn = 1 AND AR.Approved IS NULL -- Get only the most recent unapproved request per device
|
||||||
WHERE
|
WHERE
|
||||||
D.UserId = @UserId
|
D.UserId = @UserId -- Include only devices for this user
|
||||||
AND D.Active = 1; -- Include only active devices
|
AND D.Active = 1; -- Include only active devices
|
||||||
END;
|
END;
|
||||||
|
|
||||||
|
@ -0,0 +1,29 @@
|
|||||||
|
CREATE OR ALTER PROCEDURE [dbo].[Device_ReadActiveWithPendingAuthRequestsByUserId]
|
||||||
|
@UserId UNIQUEIDENTIFIER,
|
||||||
|
@ExpirationMinutes INT
|
||||||
|
AS
|
||||||
|
BEGIN
|
||||||
|
SET NOCOUNT ON;
|
||||||
|
|
||||||
|
SELECT
|
||||||
|
D.*,
|
||||||
|
AR.Id as AuthRequestId,
|
||||||
|
AR.CreationDate as AuthRequestCreationDate
|
||||||
|
FROM dbo.DeviceView D
|
||||||
|
LEFT JOIN (
|
||||||
|
SELECT
|
||||||
|
Id,
|
||||||
|
CreationDate,
|
||||||
|
RequestDeviceIdentifier,
|
||||||
|
Approved,
|
||||||
|
ROW_NUMBER() OVER (PARTITION BY RequestDeviceIdentifier ORDER BY CreationDate DESC) as rn
|
||||||
|
FROM dbo.AuthRequestView
|
||||||
|
WHERE Type IN (0, 1) -- AuthenticateAndUnlock and Unlock types only
|
||||||
|
AND CreationDate >= DATEADD(MINUTE, -@ExpirationMinutes, GETUTCDATE()) -- Ensure the request hasn't expired
|
||||||
|
AND UserId = @UserId -- Requests for this user only
|
||||||
|
) AR -- This join will get the most recent request per device, regardless of approval status
|
||||||
|
ON D.Identifier = AR.RequestDeviceIdentifier AND AR.rn = 1 AND AR.Approved IS NULL -- Get only the most recent unapproved request per device
|
||||||
|
WHERE
|
||||||
|
D.UserId = @UserId -- Include only devices for this user
|
||||||
|
AND D.Active = 1; -- Include only active devices
|
||||||
|
END;
|
Loading…
x
Reference in New Issue
Block a user