diff options
| -rw-r--r-- | Swift/Controllers/Roster/RosterController.cpp | 16 | ||||
| -rw-r--r-- | Swift/Controllers/Roster/RosterController.h | 1 | 
2 files changed, 16 insertions, 1 deletions
| diff --git a/Swift/Controllers/Roster/RosterController.cpp b/Swift/Controllers/Roster/RosterController.cpp index ecca9fe..e823a1c 100644 --- a/Swift/Controllers/Roster/RosterController.cpp +++ b/Swift/Controllers/Roster/RosterController.cpp @@ -282,7 +282,7 @@ void RosterController::updateItem(const XMPPRosterItem& item) {  	roster->addItem(itemPayload);  	SetRosterRequest::ref request = SetRosterRequest::create(roster, iqRouter_); -	request->onResponse.connect(boost::bind(&RosterController::handleRosterSetError, this, _1, roster)); +	request->onResponse.connect(boost::bind(&RosterController::handleRosterItemUpdated, this, _1, roster));  	request->send();  } @@ -300,6 +300,20 @@ void RosterController::initBlockingCommand() {  	}  } +void RosterController::handleRosterItemUpdated(ErrorPayload::ref error, boost::shared_ptr<RosterPayload> rosterPayload) { +	if (!!error) { +		handleRosterSetError(error, rosterPayload); +	} +	boost::shared_ptr<BlockList> blockList = clientBlockListManager_->getBlockList(); +	std::vector<RosterItemPayload> items = rosterPayload->getItems(); +	if (blockList->getState() == BlockList::Available && items.size() > 0) { +		std::vector<JID> jids = blockList->getItems(); +		if (std::find(jids.begin(), jids.end(), items[0].getJID()) != jids.end()) { +			roster_->applyOnItems(SetBlockingState(items[0].getJID(), ContactRosterItem::IsBlocked)); +		} +	} +} +  void RosterController::handleRosterSetError(ErrorPayload::ref error, boost::shared_ptr<RosterPayload> rosterPayload) {  	if (!error) {  		return; diff --git a/Swift/Controllers/Roster/RosterController.h b/Swift/Controllers/Roster/RosterController.h index d0c7024..3338d7f 100644 --- a/Swift/Controllers/Roster/RosterController.h +++ b/Swift/Controllers/Roster/RosterController.h @@ -80,6 +80,7 @@ namespace Swift {  			void handleSubscriptionRequestAccepted(SubscriptionRequestEvent* event);  			void handleSubscriptionRequestDeclined(SubscriptionRequestEvent* event);  			void handleUIEvent(boost::shared_ptr<UIEvent> event); +			void handleRosterItemUpdated(ErrorPayload::ref error, boost::shared_ptr<RosterPayload> rosterPayload);  			void handleRosterSetError(ErrorPayload::ref error, boost::shared_ptr<RosterPayload> rosterPayload);  			void applyAllPresenceTo(const JID& jid);  			void handleEditProfileRequest(); | 
 Swift
 Swift