session-ios/SessionMessagingKit/Open Groups/Models/UserModeratorRequest.swift

70 lines
4.9 KiB
Swift

// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
import Foundation
extension OpenGroupAPIV2 {
struct UserModeratorRequest: Codable {
/// List of room tokens to which the moderator status should be applied. The invoking user must be an admin of all of the given rooms.
///
/// This may be set to the single-element list ['*'] to add or remove the moderator from all rooms in which the current user has admin
/// permissions (the call will succeed if the calling user is an admin in at least one channel).
///
/// Exclusive of `global`. (If you want to apply both at once use two calls, e.g. bundled in a batch request).
let rooms: [String]?
/// If true then appoint this user as a global moderator or admin of the server. The user will receive moderator/admin ability in all rooms
/// on the server (both current and future).
///
/// The caller must be a global admin to add/remove a global moderator or admin.
let global: Bool?
/// If `true` then this user will be granted moderator permission to either the listed room(s) or the server globally.
///
/// If `false` then this user will have their moderator *and admin* permissions removed from the given rooms (or server). Note
/// that removing a global moderator only removes the global permission but does not remove individual room moderator permissions
/// that may also be present.
///
/// See the `admin` parameter description for information on how `admin` and `moderator` parameters interact.
let moderator: Bool
/// If `true` then this user will be granted moderator and admin permissions to the given rooms or server. Admin permissions are
/// required to appoint new moderators or administrators and to alter room info such as the image, adding/removing pinned messages,
/// and changing the name/description of the room.
///
/// If false then this user will have their admin permission removed, but will keep moderator permissions. To remove both moderator and
/// admin permissions specify `moderator: false` (which implies clearing admin permissions as well).
///
/// Note that removing a global admin only removes the global permission but does not remove individual room admin permissions that
/// may also be present.
///
/// The `admin`/`moderator` paramters interact as follows:
/// - `admin=true`, `moderator` omitted: this adds admin permissions, which automatically also implies moderator permissions.
/// - `admin=true, moderator=true`: exactly the same as above.
/// - `admin=false, moderator=true`: removes any existing admin permissions from the rooms (or globally), if present, and adds
/// moderator permissions to the rooms/globally (if not already present).
/// - `admin=false`, `moderator` omitted: this removes admin permissions but leaves moderator permissions, if present. (This
/// effectively "downgrades" an admin to a moderator). Unlike the above this does *not* add moderator permissions to matching rooms
/// if not already present.
/// - `moderator=true`, `admin` omitted: adds moderator permissions to the given rooms (or globally), if not already present. If
/// the user already has admin permissions this does nothing (that is, admin permission is *not* removed, unlike the above).
/// - `moderator=false`, `admin` omitted: this removes moderator *and* admin permissions from all given rooms (or globally).
/// - `moderator=false, admin=false`: exactly the same as above.
/// - `moderator=false, admin=true`: this combination is *not* *permitted* (because admin permissions imply moderator
/// permissions) and will result in Bad Request error if given.
let admin: Bool
/// Whether this user should be a "visible" moderator or admin in the specified rooms (or globally). Visible moderators are identified to all
/// room users (e.g. via a special status badge in Session clients).
///
/// Invisible moderators/admins have the same permission as as visible ones, but their moderator/admin status is only visible to other
/// moderators, not to ordinary room participants.
///
/// The default if this field is omitted is true for room-specific moderators/admins and false for server-level global moderators/admins.
///
/// If an admin or moderator has both global and room-specific moderation permissions then the visibility of the admin/mod for that
/// room's moderator/admin list will use the room-specific visibility value, regardless of the global setting. (This differs from
/// moderator/admin permissions themselves, which are additive).
let visible: Bool
}
}