📄 adhochandler.h
字号:
/* Copyright (c) 2004-2008 by Jakob Schroeter <js@camaya.net> This file is part of the gloox library. http://camaya.net/gloox This software is distributed under a license. The full license agreement can be found in the file LICENSE in this distribution. This software may not be copied, modified, sold or distributed other than expressed in the named license agreement. This software is distributed without any warranty.*/#ifndef ADHOCHANDLER_H__#define ADHOCHANDLER_H__#include "adhoc.h"#include "dataform.h"#include <map>namespace gloox{ /** * @brief A virtual interface for an Ad-hoc Command users according to XEP-0050. * * Derived classes can be registered with the Adhoc object to receive notifications * about Adhoc Commands remote entities support. * * @author Jakob Schroeter <js@camaya.net> * @since 0.9 */ class GLOOX_API AdhocHandler { public: /** * Virtual destructor. */ virtual ~AdhocHandler() {} /** * This function is called in response to a call to Adhoc::checkSupport(). * @param remote The queried remote entity's JID. * @param support Whether the remote entity supports Adhoc Commands. */ virtual void handleAdhocSupport( const JID& remote, bool support ) = 0; /** * This function is called in response to a call to Adhoc::getCommands() * and delivers a list of supported commands. * @param remote The queried remote entity's JID. * @param commands A map of supported commands and their human-readable name. * The map may be empty. */ virtual void handleAdhocCommands( const JID& remote, const StringMap& commands ) = 0; /** * This function is called in response to a call to Adhoc::getCommands() or * Adhoc::checkSupport() in case the respective request returned an error. * @param remote The queried remote entity's JID. * @param error The error condition. */ virtual void handleAdhocError( const JID& remote, StanzaError error ) = 0; /** * This function is called in response to a remote command execution. * @param remote The remote entity's JID. * @param command The command being executed. * @param status The command's execution status. * @param sessionid The current execution cycle's ID. * @param form A Data Form for the client to display, containing a result or additional * input fields for the user to fill in. * @param actions ORed AdhocExecuteActions which are allowed to be executed from the current * stage. * @param defaultAction The default action that will be executed if none of the allowed * @b actions is chosen. * @param note A textual note containing information about current conditions in a command * sequence. May be empty (no note). * @param type The note's severity. */ virtual void handleAdhocExecutionResult( const JID& remote, const std::string& command, Adhoc::AdhocCommandStatus status, const std::string& sessionid, const DataForm& form, int actions, Adhoc::AdhocExecuteActions defaultAction, const std::string& note, Adhoc::AdhocNoteType type ) = 0; };}#endif // ADHOCHANDLER_H__
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -