- enum ClientMode {
- LocalCore,
- RemoteCore
- };
-
- static Client *instance();
- static void destroy();
- static void init(AbstractUi *);
-
- static QList<BufferInfo> allBufferInfos();
- static QList<Buffer *> buffers();
- // static Buffer *buffer(BufferId bufferUid);
- static Buffer *buffer(BufferInfo);
-
- static QList<NetworkId> networkIds();
- static const Network * network(NetworkId);
-
- static QList<IdentityId> identityIds();
- static const Identity * identity(IdentityId);
-
- //! Request creation of an identity with the given data.
- /** The request will be sent to the core, and will be propagated back to all the clients
- * with a new valid IdentityId.
- * \param identity The identity template for the new identity. It does not need to have a valid ID.
- */
- static void createIdentity(const Identity &identity);
-
- //! Request update of an identity with the given data.
- /** The request will be sent to the core, and will be propagated back to all the clients.
- * \param id The identity to be updated.
- * \param serializedData The identity's content (cf. SyncableObject::toVariantMap())
- */
- static void updateIdentity(IdentityId id, const QVariantMap &serializedData);
-
- //! Request removal of the identity with the given ID from the core (and all the clients, of course).
- /** \param id The ID of the identity to be removed.
- */
- static void removeIdentity(IdentityId id);
-
- static void createNetwork(const NetworkInfo &info);
- static void updateNetwork(const NetworkInfo &info);
- static void removeNetwork(NetworkId id);
-
- static inline NetworkModel *networkModel() { return instance()->_networkModel; }
- static inline BufferModel *bufferModel() { return instance()->_bufferModel; }
- static inline MessageModel *messageModel() { return instance()->_messageModel; }
- static inline AbstractMessageProcessor *messageProcessor() { return instance()->_messageProcessor; }
- static inline SignalProxy *signalProxy() { return instance()->_signalProxy; }
-
- static inline ClientBacklogManager *backlogManager() { return instance()->_backlogManager; }
- static inline ClientIrcListHelper *ircListHelper() { return instance()->_ircListHelper; }
- static inline BufferViewManager *bufferViewManager() { return instance()->_bufferViewManager; }
-
- static AccountId currentCoreAccount();
-
- static bool isConnected();
- static bool isSynced();
-
- static void userInput(BufferInfo bufferInfo, QString message);
-
- static void setBufferLastSeenMsg(BufferId id, const MsgId &msgId); // this is synced to core and other clients
- static void removeBuffer(BufferId id);
+ enum ClientMode
+ {
+ LocalCore,
+ RemoteCore
+ };
+
+ Client(std::unique_ptr<AbstractUi>, QObject* parent = nullptr);
+ ~Client() override;
+
+ static AbstractUi* mainUi();
+
+ static QList<NetworkId> networkIds();
+ static const Network* network(NetworkId);
+
+ static QList<IdentityId> identityIds();
+ static const Identity* identity(IdentityId);
+
+ //! Request creation of an identity with the given data.
+ /** The request will be sent to the core, and will be propagated back to all the clients
+ * with a new valid IdentityId.
+ * \param identity The identity template for the new identity. It does not need to have a valid ID.
+ */
+ static void createIdentity(const CertIdentity& identity);
+
+ //! Request update of an identity with the given data.
+ /** The request will be sent to the core, and will be propagated back to all the clients.
+ * \param id The identity to be updated.
+ * \param serializedData The identity's content (cf. SyncableObject::toVariantMap())
+ */
+ static void updateIdentity(IdentityId id, const QVariantMap& serializedData);
+
+ //! Request removal of the identity with the given ID from the core (and all the clients, of course).
+ /** \param id The ID of the identity to be removed.
+ */
+ static void removeIdentity(IdentityId id);
+
+ static void createNetwork(const NetworkInfo& info, const QStringList& persistentChannels = QStringList());
+ static void updateNetwork(const NetworkInfo& info);
+ static void removeNetwork(NetworkId id);
+
+ static inline NetworkModel* networkModel() { return instance()->_networkModel; }
+ static inline BufferModel* bufferModel() { return instance()->_bufferModel; }
+ static inline MessageModel* messageModel() { return instance()->_messageModel; }
+ static inline AbstractMessageProcessor* messageProcessor() { return instance()->_messageProcessor; }
+ static inline SignalProxy* signalProxy() { return instance()->_signalProxy; }
+
+ static inline ClientAliasManager* aliasManager() { return instance()->_aliasManager; }
+ static inline ClientBacklogManager* backlogManager() { return instance()->_backlogManager; }
+ static inline CoreInfo* coreInfo() { return instance()->_coreInfo; }
+ static inline DccConfig* dccConfig() { return instance()->_dccConfig; }
+ static inline ClientIrcListHelper* ircListHelper() { return instance()->_ircListHelper; }
+ static inline ClientBufferViewManager* bufferViewManager() { return instance()->_bufferViewManager; }
+ static inline BufferViewOverlay* bufferViewOverlay() { return instance()->_bufferViewOverlay; }
+ static inline ClientUserInputHandler* inputHandler() { return instance()->_inputHandler; }
+ static inline NetworkConfig* networkConfig() { return instance()->_networkConfig; }
+ static inline ClientIgnoreListManager* ignoreListManager() { return instance()->_ignoreListManager; }
+ static inline HighlightRuleManager* highlightRuleManager() { return instance()->_highlightRuleManager; }
+ static inline ClientTransferManager* transferManager() { return instance()->_transferManager; }
+ static inline TransferModel* transferModel() { return instance()->_transferModel; }
+
+ static inline BufferSyncer* bufferSyncer() { return instance()->_bufferSyncer; }
+
+ static inline CoreAccountModel* coreAccountModel() { return instance()->_coreAccountModel; }
+ static inline CoreConnection* coreConnection() { return instance()->_coreConnection; }
+ static inline CoreAccount currentCoreAccount() { return coreConnection()->currentAccount(); }
+ static bool isCoreFeatureEnabled(Quassel::Feature feature);
+
+ static bool isConnected();
+ static bool internalCore();
+
+ static void userInput(const BufferInfo& bufferInfo, const QString& message);
+
+ static void setBufferLastSeenMsg(BufferId id, const MsgId& msgId); // this is synced to core and other clients
+ static void setMarkerLine(BufferId id, const MsgId& msgId); // this is synced to core and other clients
+ static MsgId markerLine(BufferId id);
+
+ static void removeBuffer(BufferId id);
+ static void renameBuffer(BufferId bufferId, const QString& newName);
+ static void mergeBuffersPermanently(BufferId bufferId1, BufferId bufferId2);
+ static void purgeKnownBufferIds();
+
+ /**
+ * Requests client to resynchronize the CoreInfo object for legacy (pre-0.13) cores
+ *
+ * This provides compatibility with updating core information for legacy cores, and can be
+ * removed after protocol break.
+ *
+ * NOTE: On legacy (pre-0.13) cores, any existing connected signals will be destroyed and must
+ * be re-added after calling this, in addition to checking for existing data in coreInfo().
+ */
+ static void refreshLegacyCoreInfo();
+
+ static void changePassword(const QString& oldPassword, const QString& newPassword);
+ static void kickClient(int peerId);
+
+ void displayIgnoreList(QString ignoreRule) { emit showIgnoreList(ignoreRule); }
+
+ /**
+ * Request to show the channel list dialog for the network, optionally searching by channel name
+ *
+ * @see Client::showChannelList()
+ *
+ * @param networkId Network ID for associated network
+ * @param channelFilters Partial channel name to search for, or empty to show all
+ * @param listImmediately If true, immediately list channels, otherwise just show dialog
+ */
+ void displayChannelList(NetworkId networkId, const QString& channelFilters = {}, bool listImmediately = false)
+ {
+ emit showChannelList(networkId, channelFilters, listImmediately);
+ }