#pragma once #include <xmpp/xmpp_stanza.hpp> #include <functional> #include <string> #include <map> class XmppComponent; class AdhocCommand; class AdhocSession; /** * A function executed as an ad-hoc command step. It takes a <command/> * XmlNode and modifies it accordingly (inserting for example an <error/> * node, or a data form…). */ using AdhocStep = std::function<void(XmppComponent&, AdhocSession&, XmlNode&)>; class AdhocSession { public: explicit AdhocSession(const AdhocCommand& command, const std::string& owner_jid, const std::string& to_jid); ~AdhocSession() = default; AdhocSession(const AdhocSession&) = delete; AdhocSession(AdhocSession&&) = delete; AdhocSession& operator=(const AdhocSession&) = delete; AdhocSession& operator=(AdhocSession&&) = delete; /** * Return the function to be executed, found in our AdhocCommand, for the * current_step. And increment the current_step. */ const AdhocStep& get_next_step(); /** * Return the number of remaining steps. */ size_t remaining_steps() const; /** * This may be modified by an AdhocStep, to indicate that this session * should no longer exist, because we encountered an error, and we can't * execute any more step of it. */ void terminate(); bool is_terminated() const; std::string get_target_jid() const { return this->to_jid; } std::string get_owner_jid() const { return this->owner_jid; } private: /** * A reference of the command concerned by this session. Used for example * to get the next step of that command, things like that. */ const AdhocCommand& command; /** * The full JID of the XMPP user that created this session by executing * the first step of a command. Only that JID must be allowed to access * this session. */ const std::string& owner_jid; /** * The 'to' attribute in the request stanza. This is the target of the current session. */ const std::string& to_jid; /** * The current step we are at. It starts at zero. It is used to index the * associated AdhocCommand::callbacks vector. */ size_t current_step; bool terminated; public: /** * A map to store various things that we may want to remember between two * steps of the same session. A step can insert any value associated to * any key in there. */ std::map<std::string, std::string> vars; };