/******************************************************************************
 * THIS FILE IS GENERATED - ANY EDITS WILL BE OVERWRITTEN
 */

#pragma once

#include "jobs/basejob.h"

namespace Quotient {

/*! \brief Create a new mapping from room alias to room ID.
 *
 */
class QUOTIENT_API SetRoomAliasJob : public BaseJob {
public:
    /*! \brief Create a new mapping from room alias to room ID.
     *
     * \param roomAlias
     *   The room alias to set.
     *
     * \param roomId
     *   The room ID to set.
     */
    explicit SetRoomAliasJob(const QString& roomAlias, const QString& roomId);
};

/*! \brief Get the room ID corresponding to this room alias.
 *
 * Requests that the server resolve a room alias to a room ID.
 *
 * The server will use the federation API to resolve the alias if the
 * domain part of the alias does not correspond to the server's own
 * domain.
 */
class QUOTIENT_API GetRoomIdByAliasJob : public BaseJob {
public:
    /*! \brief Get the room ID corresponding to this room alias.
     *
     * \param roomAlias
     *   The room alias.
     */
    explicit GetRoomIdByAliasJob(const QString& roomAlias);

    /*! \brief Construct a URL without creating a full-fledged job object
     *
     * This function can be used when a URL for GetRoomIdByAliasJob
     * is necessary but the job itself isn't.
     */
    static QUrl makeRequestUrl(QUrl baseUrl, const QString& roomAlias);

    // Result properties

    /// The room ID for this room alias.
    QString roomId() const { return loadFromJson<QString>("room_id"_ls); }

    /// A list of servers that are aware of this room alias.
    QStringList servers() const
    {
        return loadFromJson<QStringList>("servers"_ls);
    }
};

/*! \brief Remove a mapping of room alias to room ID.
 *
 * Remove a mapping of room alias to room ID.
 *
 * Servers may choose to implement additional access control checks here, for
 * instance that room aliases can only be deleted by their creator or a server
 * administrator.
 *
 * **Note:**
 * Servers may choose to update the `alt_aliases` for the
 * `m.room.canonical_alias` state event in the room when an alias is removed.
 * Servers which choose to update the canonical alias event are recommended to,
 * in addition to their other relevant permission checks, delete the alias and
 * return a successful response even if the user does not have permission to
 * update the `m.room.canonical_alias` event.
 */
class QUOTIENT_API DeleteRoomAliasJob : public BaseJob {
public:
    /*! \brief Remove a mapping of room alias to room ID.
     *
     * \param roomAlias
     *   The room alias to remove.
     */
    explicit DeleteRoomAliasJob(const QString& roomAlias);

    /*! \brief Construct a URL without creating a full-fledged job object
     *
     * This function can be used when a URL for DeleteRoomAliasJob
     * is necessary but the job itself isn't.
     */
    static QUrl makeRequestUrl(QUrl baseUrl, const QString& roomAlias);
};

/*! \brief Get a list of local aliases on a given room.
 *
 * Get a list of aliases maintained by the local server for the
 * given room.
 *
 * This endpoint can be called by users who are in the room (external
 * users receive an `M_FORBIDDEN` error response). If the room's
 * `m.room.history_visibility` maps to `world_readable`, any
 * user can call this endpoint.
 *
 * Servers may choose to implement additional access control checks here,
 * such as allowing server administrators to view aliases regardless of
 * membership.
 *
 * **Note:**
 * Clients are recommended not to display this list of aliases prominently
 * as they are not curated, unlike those listed in the `m.room.canonical_alias`
 * state event.
 */
class QUOTIENT_API GetLocalAliasesJob : public BaseJob {
public:
    /*! \brief Get a list of local aliases on a given room.
     *
     * \param roomId
     *   The room ID to find local aliases of.
     */
    explicit GetLocalAliasesJob(const QString& roomId);

    /*! \brief Construct a URL without creating a full-fledged job object
     *
     * This function can be used when a URL for GetLocalAliasesJob
     * is necessary but the job itself isn't.
     */
    static QUrl makeRequestUrl(QUrl baseUrl, const QString& roomId);

    // Result properties

    /// The server's local aliases on the room. Can be empty.
    QStringList aliases() const
    {
        return loadFromJson<QStringList>("aliases"_ls);
    }
};

} // namespace Quotient