123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- <?php
- namespace OCA\User_LDAP\User;
- use OCA\User_LDAP\Mapping\UserMapping;
- use OCP\IConfig;
- use OCP\Share\IManager;
- class DeletedUsersIndex {
- protected IConfig $config;
- protected UserMapping $mapping;
- protected ?array $deletedUsers = null;
- private IManager $shareManager;
- public function __construct(
- IConfig $config,
- UserMapping $mapping,
- IManager $shareManager
- ) {
- $this->config = $config;
- $this->mapping = $mapping;
- $this->shareManager = $shareManager;
- }
-
- private function fetchDeletedUsers(): array {
- $deletedUsers = $this->config->getUsersForUserValue('user_ldap', 'isDeleted', '1');
- $userObjects = [];
- foreach ($deletedUsers as $user) {
- $userObject = new OfflineUser($user, $this->config, $this->mapping, $this->shareManager);
- if ($userObject->getLastLogin() > $userObject->getDetectedOn()) {
- $userObject->unmark();
- } else {
- $userObjects[] = $userObject;
- }
- }
- $this->deletedUsers = $userObjects;
- return $this->deletedUsers;
- }
-
- public function getUsers(): array {
- if (is_array($this->deletedUsers)) {
- return $this->deletedUsers;
- }
- return $this->fetchDeletedUsers();
- }
-
- public function hasUsers(): bool {
- if (!is_array($this->deletedUsers)) {
- $this->fetchDeletedUsers();
- }
- return is_array($this->deletedUsers) && (count($this->deletedUsers) > 0);
- }
-
- public function markUser(string $ocName): void {
- if ($this->isUserMarked($ocName)) {
-
- return;
- }
- $this->config->setUserValue($ocName, 'user_ldap', 'isDeleted', '1');
- $this->config->setUserValue($ocName, 'user_ldap', 'foundDeleted', (string)time());
- $this->deletedUsers = null;
- }
- public function isUserMarked(string $ocName): bool {
- return ($this->config->getUserValue($ocName, 'user_ldap', 'isDeleted', '0') === '1');
- }
- }
|