mirror of
https://github.com/RetroShare/RetroShare.git
synced 2024-12-16 03:14:31 -05:00
custom status now sent without needing to have a private chat
- getcustom status now generate a requests to that peer. - setowncustom status now generates an 'status available' item sent to all peers git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@2769 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
c5208b29f1
commit
101e0d9dc6
@ -325,7 +325,7 @@ std::list<RsChatMsgItem *> p3ChatService::getChatQueue()
|
|||||||
//
|
//
|
||||||
if(it!=_avatars.end() && it->second->_peer_is_new)
|
if(it!=_avatars.end() && it->second->_peer_is_new)
|
||||||
{
|
{
|
||||||
std::cerr << "Adatar is new for peer. ending info above" << std::endl ;
|
std::cerr << "Avatar is new for peer. ending info above" << std::endl ;
|
||||||
ci->chatFlags |= RS_CHAT_FLAG_AVATAR_AVAILABLE ;
|
ci->chatFlags |= RS_CHAT_FLAG_AVATAR_AVAILABLE ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -337,29 +337,36 @@ std::list<RsChatMsgItem *> p3ChatService::getChatQueue()
|
|||||||
|
|
||||||
RsChatStatusItem *cs = dynamic_cast<RsChatStatusItem*>(item) ;
|
RsChatStatusItem *cs = dynamic_cast<RsChatStatusItem*>(item) ;
|
||||||
|
|
||||||
if(cs != NULL)
|
if(cs != NULL){
|
||||||
{
|
|
||||||
// we should notify for a status string for the current peer.
|
|
||||||
#ifdef CHAT_DEBUG
|
#ifdef CHAT_DEBUG
|
||||||
std::cerr << "Received status string \"" << cs->status_string << "\"" << std::endl ;
|
std::cerr << "Received status string \"" << cs->status_string << "\"" << std::endl ;
|
||||||
#endif
|
#endif
|
||||||
if(cs->flags & RS_CHAT_FLAG_PRIVATE)
|
|
||||||
rsicontrol->getNotify().notifyChatStatus(cs->PeerId(),cs->status_string,true) ;
|
|
||||||
|
|
||||||
if(cs->flags & RS_CHAT_FLAG_PUBLIC)
|
if(cs->flags & RS_CHAT_FLAG_REQUEST_CUSTOM_STATE){ // no state here just a request.
|
||||||
rsicontrol->getNotify().notifyChatStatus(cs->PeerId(),cs->status_string,false) ;
|
sendCustomState(cs->PeerId()) ;
|
||||||
|
|
||||||
if(cs->flags & RS_CHAT_FLAG_CUSTOM_STATE)
|
|
||||||
{
|
|
||||||
#ifdef CHAT_DEBUG
|
|
||||||
std::cout << "Received custom status string packet from peer " << cs->PeerId() << ": " << cs->status_string << ". Storing it and notifying." << std::endl ;
|
|
||||||
#endif
|
|
||||||
receiveStateString(cs->PeerId(),cs->status_string) ; // store it
|
|
||||||
rsicontrol->getNotify().notifyCustomState(cs->PeerId()) ;
|
|
||||||
}
|
}
|
||||||
|
else // Check if new custom string is available at peer's. If so, send a request to get the custom string.
|
||||||
|
if(cs->flags & RS_CHAT_FLAG_CUSTOM_STATE){
|
||||||
|
|
||||||
delete item ;
|
receiveStateString(cs->PeerId(),cs->status_string) ; // store it
|
||||||
|
rsicontrol->getNotify().notifyCustomState(cs->PeerId()) ;
|
||||||
|
}else
|
||||||
|
if(cs->flags & RS_CHAT_FLAG_CUSTOM_STATE_AVAILABLE){
|
||||||
|
|
||||||
|
std::cerr << "New custom state is available for peer " << cs->PeerId() << ", sending request" << std::endl ;
|
||||||
|
sendCustomStateRequest(cs->PeerId()) ;
|
||||||
|
}else
|
||||||
|
if(cs->flags & RS_CHAT_FLAG_PRIVATE)
|
||||||
|
rsicontrol->getNotify().notifyChatStatus(cs->PeerId(),cs->status_string,true) ;
|
||||||
|
else
|
||||||
|
if(cs->flags & RS_CHAT_FLAG_PUBLIC)
|
||||||
|
rsicontrol->getNotify().notifyChatStatus(cs->PeerId(),cs->status_string,false) ;
|
||||||
|
|
||||||
|
delete item;
|
||||||
continue ;
|
continue ;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RsChatAvatarItem *ca = dynamic_cast<RsChatAvatarItem*>(item) ;
|
RsChatAvatarItem *ca = dynamic_cast<RsChatAvatarItem*>(item) ;
|
||||||
@ -383,6 +390,7 @@ std::list<RsChatMsgItem *> p3ChatService::getChatQueue()
|
|||||||
|
|
||||||
void p3ChatService::setOwnCustomStateString(const std::string& s)
|
void p3ChatService::setOwnCustomStateString(const std::string& s)
|
||||||
{
|
{
|
||||||
|
std::list<std::string> onlineList;
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mChatMtx); /********** STACK LOCKED MTX ******/
|
RsStackMutex stack(mChatMtx); /********** STACK LOCKED MTX ******/
|
||||||
|
|
||||||
@ -393,9 +401,23 @@ void p3ChatService::setOwnCustomStateString(const std::string& s)
|
|||||||
|
|
||||||
for(std::map<std::string,StateStringInfo>::iterator it(_state_strings.begin());it!=_state_strings.end();++it)
|
for(std::map<std::string,StateStringInfo>::iterator it(_state_strings.begin());it!=_state_strings.end();++it)
|
||||||
it->second._own_is_new = true ;
|
it->second._own_is_new = true ;
|
||||||
|
|
||||||
|
mConnMgr->getOnlineList(onlineList);
|
||||||
}
|
}
|
||||||
|
|
||||||
rsicontrol->getNotify().notifyOwnStatusMessageChanged() ;
|
rsicontrol->getNotify().notifyOwnStatusMessageChanged() ;
|
||||||
|
|
||||||
|
// alert your online peers to your newly set status
|
||||||
|
std::list<std::string>::iterator it(onlineList.begin());
|
||||||
|
for(; it != onlineList.end(); it++){
|
||||||
|
|
||||||
|
RsChatStatusItem *cs = new RsChatStatusItem();
|
||||||
|
cs->flags = RS_CHAT_FLAG_CUSTOM_STATE_AVAILABLE;
|
||||||
|
cs->status_string = "";
|
||||||
|
cs->PeerId(*it);
|
||||||
|
sendItem(cs);
|
||||||
|
}
|
||||||
|
|
||||||
IndicateConfigChanged();
|
IndicateConfigChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -430,7 +452,7 @@ void p3ChatService::receiveStateString(const std::string& id,const std::string&
|
|||||||
{
|
{
|
||||||
RsStackMutex stack(mChatMtx); /********** STACK LOCKED MTX ******/
|
RsStackMutex stack(mChatMtx); /********** STACK LOCKED MTX ******/
|
||||||
#ifdef CHAT_DEBUG
|
#ifdef CHAT_DEBUG
|
||||||
std::cerr << "p3chatservice: received avatar jpeg data for peer " << id << ". Storing it." << std::endl ;
|
std::cerr << "p3chatservice: received custom state string for peer " << id << ". Storing it." << std::endl ;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
bool new_peer = (_state_strings.find(id) == _state_strings.end()) ;
|
bool new_peer = (_state_strings.find(id) == _state_strings.end()) ;
|
||||||
@ -501,13 +523,15 @@ std::string p3ChatService::getCustomStateString(const std::string& peer_id)
|
|||||||
#endif
|
#endif
|
||||||
return it->second._custom_status_string ;
|
return it->second._custom_status_string ;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
#ifdef CHAT_DEBUG
|
#ifdef CHAT_DEBUG
|
||||||
std::cerr << "No status string for this peer. Not requesting it." << std::endl ;
|
std::cerr << "No status string for this peer. requesting it." << std::endl ;
|
||||||
#endif
|
#endif
|
||||||
return std::string() ;
|
|
||||||
}
|
|
||||||
|
sendCustomStateRequest(peer_id);
|
||||||
|
return std::string() ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void p3ChatService::getAvatarJpegData(const std::string& peer_id,unsigned char *& data,int& size)
|
void p3ChatService::getAvatarJpegData(const std::string& peer_id,unsigned char *& data,int& size)
|
||||||
@ -520,7 +544,7 @@ void p3ChatService::getAvatarJpegData(const std::string& peer_id,unsigned char *
|
|||||||
#ifdef CHAT_DEBUG
|
#ifdef CHAT_DEBUG
|
||||||
std::cerr << "p3chatservice:: avatar for peer " << peer_id << " requested from above. " << std::endl ;
|
std::cerr << "p3chatservice:: avatar for peer " << peer_id << " requested from above. " << std::endl ;
|
||||||
#endif
|
#endif
|
||||||
// has avatar. Return it strait away.
|
// has avatar. Return it straight away.
|
||||||
//
|
//
|
||||||
if(it!=_avatars.end())
|
if(it!=_avatars.end())
|
||||||
{
|
{
|
||||||
@ -560,6 +584,22 @@ void p3ChatService::sendAvatarRequest(const std::string& peer_id)
|
|||||||
sendItem(ci);
|
sendItem(ci);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void p3ChatService::sendCustomStateRequest(const std::string& peer_id){
|
||||||
|
|
||||||
|
RsChatStatusItem* cs = new RsChatStatusItem;
|
||||||
|
|
||||||
|
cs->PeerId(peer_id);
|
||||||
|
cs->flags = RS_CHAT_FLAG_PRIVATE | RS_CHAT_FLAG_REQUEST_CUSTOM_STATE ;
|
||||||
|
cs->status_string = std::string();
|
||||||
|
|
||||||
|
#ifdef CHAT_DEBUG
|
||||||
|
std::cerr << "p3ChatService::sending request for status, to peer " << peer_id << std::endl ;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
sendItem(cs);
|
||||||
|
}
|
||||||
|
|
||||||
RsChatStatusItem *p3ChatService::makeOwnCustomStateStringItem()
|
RsChatStatusItem *p3ChatService::makeOwnCustomStateStringItem()
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mChatMtx); /********** STACK LOCKED MTX ******/
|
RsStackMutex stack(mChatMtx); /********** STACK LOCKED MTX ******/
|
||||||
@ -608,6 +648,24 @@ void p3ChatService::sendAvatarJpegData(const std::string& peer_id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void p3ChatService::sendCustomState(const std::string& peer_id){
|
||||||
|
|
||||||
|
#ifdef CHAT_DEBUG
|
||||||
|
std::cerr << "p3chatservice: sending requested status string for peer " << peer_id << std::endl ;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if(_custom_status_string != ""){
|
||||||
|
RsChatStatusItem *cs = makeOwnCustomStateStringItem();
|
||||||
|
cs->PeerId(peer_id);
|
||||||
|
|
||||||
|
sendItem(cs);
|
||||||
|
}else{
|
||||||
|
#ifdef CHAT_DEBUG
|
||||||
|
std::cerr << "doing nothing" << std::endl;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool p3ChatService::loadList(std::list<RsItem*> load)
|
bool p3ChatService::loadList(std::list<RsItem*> load)
|
||||||
{
|
{
|
||||||
for(std::list<RsItem*>::const_iterator it(load.begin());it!=load.end();++it)
|
for(std::list<RsItem*>::const_iterator it(load.begin());it!=load.end();++it)
|
||||||
|
@ -91,6 +91,9 @@ class p3ChatService: public p3Service, public p3Config
|
|||||||
/// Send avatar info to peer in jpeg format.
|
/// Send avatar info to peer in jpeg format.
|
||||||
void sendAvatarJpegData(const std::string& peer_id) ;
|
void sendAvatarJpegData(const std::string& peer_id) ;
|
||||||
|
|
||||||
|
/// Send custom state info to peer
|
||||||
|
void sendCustomState(const std::string& peer_id);
|
||||||
|
|
||||||
/// Receive the avatar in a chat item, with RS_CHAT_RECEIVE_AVATAR flag.
|
/// Receive the avatar in a chat item, with RS_CHAT_RECEIVE_AVATAR flag.
|
||||||
void receiveAvatarJpegData(RsChatAvatarItem *ci) ; // new method
|
void receiveAvatarJpegData(RsChatAvatarItem *ci) ; // new method
|
||||||
void receiveStateString(const std::string& id,const std::string& s) ;
|
void receiveStateString(const std::string& id,const std::string& s) ;
|
||||||
@ -98,6 +101,9 @@ class p3ChatService: public p3Service, public p3Config
|
|||||||
/// Sends a request for an avatar to the peer of given id
|
/// Sends a request for an avatar to the peer of given id
|
||||||
void sendAvatarRequest(const std::string& peer_id) ;
|
void sendAvatarRequest(const std::string& peer_id) ;
|
||||||
|
|
||||||
|
/// Send a request for custom status string
|
||||||
|
void sendCustomStateRequest(const std::string& peer_id);
|
||||||
|
|
||||||
RsChatAvatarItem *makeOwnAvatarItem() ;
|
RsChatAvatarItem *makeOwnAvatarItem() ;
|
||||||
RsChatStatusItem *makeOwnCustomStateStringItem() ;
|
RsChatStatusItem *makeOwnCustomStateStringItem() ;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user