Files
        @ e91e25f449ee
    
        
              Branch filter: 
        
    Location: libtransport.git/include/transport/buddy.h - annotation
        
            
            e91e25f449ee
            5.3 KiB
            text/plain
        
        
    
    Allow setting libpurple proxy
    | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 | eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 eaa9d7f3bd43 cc64a76c8be5 eaa9d7f3bd43 eaa9d7f3bd43 88865c1234e3 88865c1234e3 88865c1234e3 eaa9d7f3bd43 49e5cd3ac405 49e5cd3ac405 0d320a2990d7 0d320a2990d7 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 b5c026470f07 eaa9d7f3bd43 3949b84ed027 3949b84ed027 3949b84ed027 49e5cd3ac405 d39705842a2a d39705842a2a d39705842a2a d39705842a2a bb4ac38e5089 49e5cd3ac405 49e5cd3ac405 b5c026470f07 eaa9d7f3bd43 d39705842a2a d39705842a2a d39705842a2a 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 d39705842a2a d39705842a2a d39705842a2a 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 d39705842a2a 49e5cd3ac405 49e5cd3ac405 18a72df6850b eaa9d7f3bd43 49e5cd3ac405 d39705842a2a 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 e5aab1415d9e eaa9d7f3bd43 8ee031044843 0d320a2990d7 0d320a2990d7 0d320a2990d7 0d320a2990d7 8ee031044843 8ee031044843 8ee031044843 7e8720849725 8ee031044843 8ee031044843 49e5cd3ac405 d39705842a2a 49e5cd3ac405 3949b84ed027 49e5cd3ac405 49e5cd3ac405 d39705842a2a 49e5cd3ac405 3949b84ed027 eaa9d7f3bd43 49e5cd3ac405 d39705842a2a 49e5cd3ac405 49e5cd3ac405 eaa9d7f3bd43 49e5cd3ac405 d39705842a2a 49e5cd3ac405 49e5cd3ac405 eaa9d7f3bd43 d39705842a2a d39705842a2a d39705842a2a 88865c1234e3 88865c1234e3 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 eeda35442237 18a72df6850b e5aab1415d9e e5aab1415d9e d39705842a2a 35e56d515d97 d39705842a2a d39705842a2a d39705842a2a d39705842a2a d39705842a2a 35e56d515d97 49e5cd3ac405 eaa9d7f3bd43 eaa9d7f3bd43 49e5cd3ac405 d39705842a2a 49e5cd3ac405 eaa9d7f3bd43 eaa9d7f3bd43 49e5cd3ac405 d39705842a2a 49e5cd3ac405 eaa9d7f3bd43 eaa9d7f3bd43 49e5cd3ac405 d39705842a2a 49e5cd3ac405 49e5cd3ac405 49e5cd3ac405 eaa9d7f3bd43 eaa9d7f3bd43 d39705842a2a d39705842a2a 49e5cd3ac405 eaa9d7f3bd43 eaa9d7f3bd43 e5aab1415d9e e5aab1415d9e d39705842a2a d39705842a2a d39705842a2a d39705842a2a 62f3fbf99c88 7b287fdc66eb 62f3fbf99c88 4ea0afca8c48 132dfb379d42 83f5f36c94a2 e5aab1415d9e 132dfb379d42 4ea0afca8c48 eaa9d7f3bd43 49e5cd3ac405 88865c1234e3 3949b84ed027 eaa9d7f3bd43 88865c1234e3 88865c1234e3 | /**
 * XMPP - libpurple transport
 *
 * Copyright (C) 2009, Jan Kaluza <hanzz@soc.pidgin.im>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
 */
#pragma once
#include <string>
#include <algorithm>
#include "transport/transport.h"
#include "Swiften/Elements/VCard.h"
namespace Transport {
class RosterManager;
typedef enum { 	BUDDY_NO_FLAG = 0,
				BUDDY_JID_ESCAPING = 2,
				BUDDY_IGNORE = 4,
				BUDDY_BLOCKED = 8,
			} BuddyFlag;
/// Represents one legacy network Buddy.
class Buddy {
	public:
		typedef enum { 	Ask,
						Both,
					} Subscription;
		/// Constructor.
		/// \param rosterManager RosterManager associated with this buddy.
		/// \param id ID which identifies the buddy in database or -1 if it's new buddy which is
		/// not in database yet.
		Buddy(RosterManager *rosterManager, long id = -1, BuddyFlag flags = BUDDY_NO_FLAG);
		/// Destructor
		virtual ~Buddy();
		
		/// Sets unique ID used to identify this buddy by StorageBackend.
		
		/// This is set
		/// by RosterStorage class once the buddy is stored into database or when the
		/// buddy is loaded from database.
		/// You should not need to set this ID manually.
		/// \param id ID
		void setID(long id);
		/// Returns unique ID used to identify this buddy by StorageBackend.
		/// \return ID which identifies the buddy in database or -1 if it's new buddy which is
		/// not in database yet.
		long getID();
		/// Returns full JID of this buddy.
		/// \param hostname hostname used as domain in returned JID
		/// \return full JID of this buddy
		const Swift::JID &getJID();
		/// Generates whole Presennce stanza with current status/show for this buddy.
		/// Presence stanza does not containt "to" attribute, it has to be added manually.
		/// \param features features used in returned stanza
		/// \param only_new if True, this function returns Presence stanza only if it's different
		/// than the previously generated one.
		/// \return Presence stanza or NULL.
		std::vector<Swift::Presence::ref> &generatePresenceStanzas(int features, bool only_new = false);
		void setBlocked(bool block) {
			if (block)
				m_flags = (BuddyFlag) (m_flags | BUDDY_BLOCKED);
			else
				m_flags = (BuddyFlag) (m_flags & ~BUDDY_BLOCKED);
		}
		bool isBlocked() {
			return (m_flags & BUDDY_BLOCKED)  != 0;
		}
		/// Sets current subscription.
		/// \param subscription "to", "from", "both", "ask"
		void setSubscription(Subscription subscription);
		/// Returns current subscription
		/// \return subscription "to", "from", "both", "ask"
		Subscription getSubscription();
		/// Sets this buddy's flags.
		/// \param flags flags
		void setFlags(BuddyFlag flags);
		/// Returns this buddy's flags.
		/// \param flags flags
		BuddyFlag getFlags();
		/// Returns RosterManager associated with this buddy.
		/// \return RosterManager associated with this buddy.
		RosterManager *getRosterManager() { return m_rosterManager; }
		/// Returns legacy network username which does not contain unsafe characters,
		/// so it can be used in JIDs.
		std::string getSafeName();
		void sendPresence();
		void handleRawPresence(Swift::Presence::ref);
		/// Handles VCard from legacy network and forwards it to XMPP user.
		/// \param id ID used in IQ-result.
		/// \param vcard VCard which will be sent.
		void handleVCardReceived(const std::string &id, Swift::VCard::ref vcard);
		/// Returns legacy network username of this buddy. (for example UIN for ICQ, JID for Jabber, ...).
		/// \return legacy network username
		virtual std::string getName() = 0;
		/// Returns alias (nickname) of this buddy.
		/// \return alias (nickname)
		virtual std::string getAlias() = 0;
		/// Returns list of groups this buddy is in.
		/// \return groups
		virtual std::vector<std::string> getGroups() = 0;
		/// Returns current legacy network status and statuMessage of this buddy.
		/// \param status current status/show is stored here
		/// \param statusMessage current status message is stored here
		/// \return true if status was stored successfully
		virtual bool getStatus(Swift::StatusShow &status, std::string &statusMessage) = 0;
		/// Returns SHA-1 hash of buddy icon (avatar) or empty string if there is no avatar for this buddy.
		/// \return avatar hash or empty string.
		virtual std::string getIconHash() = 0;
		virtual bool isAvailable() = 0;
		/// Returns legacy name of buddy from JID.
		/// \param jid Jabber ID.
		/// \return legacy name of buddy from JID.
		static std::string JIDToLegacyName(const Swift::JID &jid);
		static BuddyFlag buddyFlagsFromJID(const Swift::JID &jid);
	protected:
		void generateJID();
		Swift::JID m_jid;
		std::vector<Swift::Presence::ref> m_presences;
	private:
		long m_id;
		BuddyFlag m_flags;
		RosterManager *m_rosterManager;
		Subscription m_subscription;
};
}
 |