2014-07-16 08:25:31 -04:00
|
|
|
<?php
|
2023-05-23 13:00:38 -04:00
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2014-07-16 08:25:31 -04:00
|
|
|
/**
|
2024-05-23 03:26:56 -04:00
|
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
|
|
|
|
namespace OCP;
|
|
|
|
|
|
2015-04-16 11:00:08 -04:00
|
|
|
/**
|
|
|
|
|
* Interface IGroup
|
|
|
|
|
*
|
|
|
|
|
* @since 8.0.0
|
|
|
|
|
*/
|
2014-07-16 08:25:31 -04:00
|
|
|
interface IGroup {
|
|
|
|
|
/**
|
|
|
|
|
* @return string
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function getGID(): string;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
2016-11-30 14:21:44 -05:00
|
|
|
/**
|
|
|
|
|
* Returns the group display name
|
|
|
|
|
*
|
|
|
|
|
* @return string
|
2017-05-04 06:06:03 -04:00
|
|
|
* @since 12.0.0
|
2016-11-30 14:21:44 -05:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function getDisplayName(): string;
|
2016-11-30 14:21:44 -05:00
|
|
|
|
2019-09-20 05:33:02 -04:00
|
|
|
/**
|
|
|
|
|
* Set the group display name
|
|
|
|
|
*
|
|
|
|
|
* @param string $displayName
|
|
|
|
|
* @return bool
|
|
|
|
|
* @since 18.0.0
|
|
|
|
|
*/
|
|
|
|
|
public function setDisplayName(string $displayName): bool;
|
|
|
|
|
|
2014-07-16 08:25:31 -04:00
|
|
|
/**
|
|
|
|
|
* get all users in the group
|
|
|
|
|
*
|
2023-05-23 13:00:38 -04:00
|
|
|
* @return IUser[]
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function getUsers(): array;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* check if a user is in the group
|
|
|
|
|
*
|
2023-05-23 13:00:38 -04:00
|
|
|
* @param IUser $user
|
|
|
|
|
*
|
2014-07-16 08:25:31 -04:00
|
|
|
* @return bool
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function inGroup(IUser $user): bool;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* add a user to the group
|
|
|
|
|
*
|
2023-05-23 13:00:38 -04:00
|
|
|
* @param IUser $user
|
|
|
|
|
*
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function addUser(IUser $user): void;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
|
|
|
|
/**
|
2023-05-23 13:00:38 -04:00
|
|
|
* Remove a user from the group
|
|
|
|
|
*
|
|
|
|
|
* @param IUser $user
|
2014-07-16 08:25:31 -04:00
|
|
|
*
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function removeUser(IUser $user): void;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* search for users in the group by userid
|
|
|
|
|
*
|
|
|
|
|
* @param string $search
|
2023-05-23 13:00:38 -04:00
|
|
|
* @param int|null $limit
|
|
|
|
|
* @param int|null $offset
|
|
|
|
|
*
|
|
|
|
|
* @return IUser[]
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2022-06-13 12:48:49 -04:00
|
|
|
public function searchUsers(string $search, ?int $limit = null, ?int $offset = null): array;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* returns the number of users matching the search string
|
|
|
|
|
*
|
|
|
|
|
* @param string $search
|
|
|
|
|
* @return int|bool
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function count(string $search = ''): int|bool;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
2018-05-17 06:48:26 -04:00
|
|
|
/**
|
|
|
|
|
* returns the number of disabled users
|
|
|
|
|
*
|
|
|
|
|
* @return int|bool
|
2018-05-17 08:40:26 -04:00
|
|
|
* @since 14.0.0
|
2018-05-17 06:48:26 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function countDisabled(): int|bool;
|
2018-05-17 06:48:26 -04:00
|
|
|
|
2014-07-16 08:25:31 -04:00
|
|
|
/**
|
2023-05-23 13:00:38 -04:00
|
|
|
* Search for users in the group by displayname
|
2014-07-16 08:25:31 -04:00
|
|
|
*
|
|
|
|
|
* @param string $search
|
2023-05-23 13:00:38 -04:00
|
|
|
* @param int|null $limit
|
|
|
|
|
* @param int|null $offset
|
|
|
|
|
*
|
|
|
|
|
* @return IUser[]
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2024-03-28 11:13:19 -04:00
|
|
|
public function searchDisplayName(string $search, ?int $limit = null, ?int $offset = null): array;
|
2014-07-16 08:25:31 -04:00
|
|
|
|
2021-02-09 08:50:38 -05:00
|
|
|
/**
|
|
|
|
|
* Get the names of the backends the group is connected to
|
|
|
|
|
*
|
|
|
|
|
* @return string[]
|
|
|
|
|
* @since 22.0.0
|
|
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function getBackendNames(): array;
|
2021-02-09 08:50:38 -05:00
|
|
|
|
2014-07-16 08:25:31 -04:00
|
|
|
/**
|
2023-05-23 13:00:38 -04:00
|
|
|
* Delete the group
|
2014-07-16 08:25:31 -04:00
|
|
|
*
|
|
|
|
|
* @return bool
|
2015-04-16 11:00:08 -04:00
|
|
|
* @since 8.0.0
|
2014-07-16 08:25:31 -04:00
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function delete(): bool;
|
2018-06-19 10:23:02 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return bool
|
|
|
|
|
* @since 14.0.0
|
|
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function canRemoveUser(): bool;
|
2018-06-19 10:23:02 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return bool
|
|
|
|
|
* @since 14.0.0
|
|
|
|
|
*/
|
2023-05-23 13:00:38 -04:00
|
|
|
public function canAddUser(): bool;
|
2019-02-22 10:36:25 -05:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return bool
|
|
|
|
|
* @since 16.0.0
|
|
|
|
|
*/
|
|
|
|
|
public function hideFromCollaboration(): bool;
|
2014-07-16 08:25:31 -04:00
|
|
|
}
|