diff --git a/src/Core/AdminConsole/OrganizationFeatures/OrganizationUsers/RestoreOrganizationUser/IRestoreOrganizationUserCommand.cs b/src/Core/AdminConsole/OrganizationFeatures/OrganizationUsers/RestoreOrganizationUser/IRestoreOrganizationUserCommand.cs
index 1347dfdb77..81569b6e2e 100644
--- a/src/Core/AdminConsole/OrganizationFeatures/OrganizationUsers/RestoreOrganizationUser/IRestoreOrganizationUserCommand.cs
+++ b/src/Core/AdminConsole/OrganizationFeatures/OrganizationUsers/RestoreOrganizationUser/IRestoreOrganizationUserCommand.cs
@@ -4,9 +4,51 @@ using Bit.Core.Services;
namespace Bit.Core.AdminConsole.OrganizationFeatures.OrganizationUsers.RestoreOrganizationUser;
+///
+/// Restores a user back to their previous status.
+///
public interface IRestoreOrganizationUserCommand
{
+ ///
+ /// Validates that the requesting user can perform the action. There is also a check done to ensure the organization
+ /// can re-add this user based on their current occupied seats.
+ ///
+ /// Checks are performed to make sure the user is conforming to all policies enforced by the organization as well as
+ /// other organizations the user may belong to.
+ ///
+ /// Reference Events and Push Notifications are fired off for this as well.
+ ///
+ /// Revoked user to be restored.
+ /// UserId of the user performing the action.
Task RestoreUserAsync(OrganizationUser organizationUser, Guid? restoringUserId);
+
+ ///
+ /// Validates that the requesting user can perform the action. There is also a check done to ensure the organization
+ /// can re-add this user based on their current occupied seats.
+ ///
+ /// Checks are performed to make sure the user is conforming to all policies enforced by the organization as well as
+ /// other organizations the user may belong to.
+ ///
+ /// Reference Events and Push Notifications are fired off for this as well.
+ ///
+ /// Revoked user to be restored.
+ /// System that is performing the action on behalf of the organization (Public API, SCIM, etc.)
Task RestoreUserAsync(OrganizationUser organizationUser, EventSystemUser systemUser);
+
+ ///
+ /// Validates that the requesting user can perform the action. There is also a check done to ensure the organization
+ /// can re-add this user based on their current occupied seats.
+ ///
+ /// Checks are performed to make sure the user is conforming to all policies enforced by the organization as well as
+ /// other organizations the user may belong to.
+ ///
+ /// Reference Events and Push Notifications are fired off for this as well.
+ ///
+ /// Organization the users should be restored to.
+ /// List of organization user ids to restore to previous status.
+ /// UserId of the user performing the action.
+ /// Passed in from caller to avoid circular dependency
+ /// List of organization user Ids and strings. A successful restoration will have an empty string.
+ /// If an error occurs, the error message will be provided.
Task>> RestoreUsersAsync(Guid organizationId, IEnumerable organizationUserIds, Guid? restoringUserId, IUserService userService);
}