/** * @file llavatarpropertiesprocessor.h * @brief LLAvatatIconCtrl base class * * $LicenseInfo:firstyear=2001&license=viewerlgpl$ * Second Life Viewer Source Code * Copyright (C) 2010, Linden Research, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License only. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA * $/LicenseInfo$ */ #ifndef LL_LLAVATARPROPERTIESPROCESSOR_H #define LL_LLAVATARPROPERTIESPROCESSOR_H #include "lluuid.h" #include "llsingleton.h" #include "v3dmath.h" // LLVector3d #include <list> #include <map> // For Flags in AvatarPropertiesReply const U32 AVATAR_ALLOW_PUBLISH = 0x1 << 0; // whether profile is externally visible or not const U32 AVATAR_MATURE_PUBLISH = 0x1 << 1; // profile is "mature" const U32 AVATAR_IDENTIFIED = 0x1 << 2; // whether avatar has provided payment info const U32 AVATAR_TRANSACTED = 0x1 << 3; // whether avatar has actively used payment info const U32 AVATAR_ONLINE = 0x1 << 4; // the online status of this avatar, if known. const U32 AVATAR_AGEVERIFIED = 0x1 << 5; // whether avatar has been age-verified /* *TODO Vadim: This needs some refactoring: - Remove EAvatarProcessorType in favor of separate observers, derived from a common parent (to get rid of void*). */ class LLMessageSystem; enum EAvatarProcessorType { APT_PROPERTIES, APT_NOTES, APT_GROUPS, APT_PICKS, APT_PICK_INFO, APT_TEXTURES, APT_INTERESTS_INFO, APT_CLASSIFIEDS, APT_CLASSIFIED_INFO }; struct LLInterestsData { LLUUID agent_id; LLUUID avatar_id; //target id U32 want_to_mask; std::string want_to_text; U32 skills_mask; std::string skills_text; std::string languages_text; }; struct LLAvatarData { LLUUID agent_id; LLUUID avatar_id; //target id LLUUID image_id; LLUUID fl_image_id; LLUUID partner_id; std::string about_text; std::string fl_about_text; LLDate born_on; std::string profile_url; U8 caption_index; std::string caption_text; std::string customer_type; U32 flags; BOOL allow_publish; }; struct LLAvatarPicks { LLUUID agent_id; LLUUID target_id; //target id typedef std::pair<LLUUID,std::string> pick_data_t; typedef std::list< pick_data_t> picks_list_t; picks_list_t picks_list; }; struct LLPickData { LLUUID agent_id; LLUUID pick_id; LLUUID creator_id; BOOL top_pick; LLUUID parcel_id; std::string name; std::string desc; LLUUID snapshot_id; LLVector3d pos_global; S32 sort_order; BOOL enabled; //used only in read requests std::string user_name; std::string original_name; std::string sim_name; //used only in write (update) requests LLUUID session_id; }; struct LLAvatarNotes { LLUUID agent_id; LLUUID target_id; //target id std::string notes; }; struct LLAvatarGroups { LLUUID agent_id; LLUUID avatar_id; //target id BOOL list_in_profile; struct LLGroupData; typedef std::list<LLGroupData> group_list_t; group_list_t group_list; struct LLGroupData { U64 group_powers; BOOL accept_notices; std::string group_title; LLUUID group_id; std::string group_name; LLUUID group_insignia_id; }; }; struct LLAvatarClassifieds { LLUUID agent_id; LLUUID target_id; struct classified_data; typedef std::list<classified_data> classifieds_list_t; classifieds_list_t classifieds_list; struct classified_data { LLUUID classified_id; std::string name; }; }; struct LLAvatarClassifiedInfo { LLUUID agent_id; LLUUID classified_id; LLUUID creator_id; U32 creation_date; U32 expiration_date; U32 category; std::string name; std::string description; LLUUID parcel_id; U32 parent_estate; LLUUID snapshot_id; std::string sim_name; LLVector3d pos_global; std::string parcel_name; U8 flags; S32 price_for_listing; }; class LLAvatarPropertiesObserver { public: virtual ~LLAvatarPropertiesObserver() {} virtual void processProperties(void* data, EAvatarProcessorType type) = 0; }; class LLAvatarPropertiesProcessor : public LLSingleton<LLAvatarPropertiesProcessor> { LLSINGLETON(LLAvatarPropertiesProcessor); virtual ~LLAvatarPropertiesProcessor(); public: void addObserver(const LLUUID& avatar_id, LLAvatarPropertiesObserver* observer); void removeObserver(const LLUUID& avatar_id, LLAvatarPropertiesObserver* observer); // Request various types of avatar data. Duplicate requests will be // suppressed while waiting for a response from the network. void sendAvatarPropertiesRequest(const LLUUID& avatar_id); void sendAvatarPicksRequest(const LLUUID& avatar_id); void sendAvatarNotesRequest(const LLUUID& avatar_id); void sendAvatarGroupsRequest(const LLUUID& avatar_id); void sendAvatarTexturesRequest(const LLUUID& avatar_id); void sendAvatarClassifiedsRequest(const LLUUID& avatar_id); // Duplicate pick info requests are not suppressed. void sendPickInfoRequest(const LLUUID& creator_id, const LLUUID& pick_id); void sendClassifiedInfoRequest(const LLUUID& classified_id); void sendAvatarPropertiesUpdate(const LLAvatarData* avatar_props); void sendPickInfoUpdate(const LLPickData* new_pick); void sendClassifiedInfoUpdate(const LLAvatarClassifiedInfo* c_data); void sendFriendRights(const LLUUID& avatar_id, S32 rights); void sendNotes(const LLUUID& avatar_id, const std::string notes); void sendPickDelete(const LLUUID& pick_id); void sendClassifiedDelete(const LLUUID& classified_id); void sendInterestsInfoUpdate(const LLInterestsData* interests_data); // Returns translated, human readable string for account type, such // as "Resident" or "Linden Employee". Used for profiles, inspectors. static std::string accountType(const LLAvatarData* avatar_data); // Returns translated, human readable string for payment info, such // as "Payment Info on File" or "Payment Info Used". // Used for profiles, inspectors. static std::string paymentInfo(const LLAvatarData* avatar_data); static bool hasPaymentInfoOnFile(const LLAvatarData* avatar_data); static void requestAvatarPropertiesCoro(std::string cap_url, LLUUID agent_id); static void processAvatarPropertiesReply(LLMessageSystem* msg, void**); static void processAvatarInterestsReply(LLMessageSystem* msg, void**); static void processAvatarClassifiedsReply(LLMessageSystem* msg, void**); static void processClassifiedInfoReply(LLMessageSystem* msg, void**); static void processAvatarGroupsReply(LLMessageSystem* msg, void**); static void processAvatarNotesReply(LLMessageSystem* msg, void**); static void processAvatarPicksReply(LLMessageSystem* msg, void**); static void processPickInfoReply(LLMessageSystem* msg, void**); protected: void sendRequest(const LLUUID& avatar_id, EAvatarProcessorType type, const std::string &method); void sendGenericRequest(const LLUUID& avatar_id, EAvatarProcessorType type, const std::string &method); void sendAvatarPropertiesRequestMessage(const LLUUID& avatar_id); void initAgentProfileCapRequest(const LLUUID& avatar_id, const std::string& cap_url); void notifyObservers(const LLUUID& id,void* data, EAvatarProcessorType type); // Is there a pending, not timed out, request for this avatar's data? // Use this to suppress duplicate requests for data when a request is // pending. bool isPendingRequest(const LLUUID& avatar_id, EAvatarProcessorType type); // Call this when a request has been sent void addPendingRequest(const LLUUID& avatar_id, EAvatarProcessorType type); // Call this when the reply to the request is received void removePendingRequest(const LLUUID& avatar_id, EAvatarProcessorType type); typedef void* (*processor_method_t)(LLMessageSystem*); static processor_method_t getProcessor(EAvatarProcessorType type); protected: typedef std::multimap<LLUUID, LLAvatarPropertiesObserver*> observer_multimap_t; observer_multimap_t mObservers; // Keep track of pending requests for data by avatar id and type. // Maintain a timestamp for each request so a request that receives no reply // does not block future requests forever. // Map avatar_id+request_type -> U32 timestamp in seconds typedef std::map< std::pair<LLUUID, EAvatarProcessorType>, U32> timestamp_map_t; timestamp_map_t mRequestTimestamps; }; #endif // LL_LLAVATARPROPERTIESPROCESSOR_H