Seq holes improved

This commit is contained in:
Igor Zhukov 2014-06-13 20:30:01 +04:00
parent ed69c39849
commit ec4a2b55ce
2 changed files with 211 additions and 160 deletions

View File

@ -1575,16 +1575,17 @@ angular.module('myApp.controllers', [])
});
function onStatedMessage (statedMessage) {
AppUsersManager.saveApiUsers(statedMessage.users);
AppChatsManager.saveApiChats(statedMessage.chats);
if (ApiUpdatesManager.saveSeq(statedMessage.seq)) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
users: statedMessage.users,
chats: statedMessage.chats,
seq: statedMessage.seq,
updates: [{
_: 'updateNewMessage',
message: statedMessage.message,
pts: statedMessage.pts
}]
});
}
$rootScope.$broadcast('history_focus', {peerString: $scope.chatFull.peerString});
}
@ -1618,16 +1619,17 @@ angular.module('myApp.controllers', [])
user_id: {_: 'inputUserContact', user_id: userID},
fwd_limit: 100
}).then(function (addResult) {
AppUsersManager.saveApiUsers(addResult.users);
AppChatsManager.saveApiChats(addResult.chats);
if (ApiUpdatesManager.saveSeq(addResult.seq)) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
seq: addResult.seq,
users: addResult.users,
chats: addResult.chats,
updates: [{
_: 'updateNewMessage',
message: addResult.message,
pts: addResult.pts
}]
});
}
});
});
@ -1748,12 +1750,15 @@ angular.module('myApp.controllers', [])
}).then(function (updateResult) {
AppUsersManager.saveApiUsers(updateResult.users);
MtpApiManager.getUserID().then(function (id) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updateShort',
update: {
_: 'updateUserPhoto',
user_id: id,
date: tsNow(true),
photo: AppUsersManager.getUser(id).photo,
previous: true
}
});
$scope.photo = AppUsersManager.getUserPhoto(id, 'User');
});
@ -1770,12 +1775,15 @@ angular.module('myApp.controllers', [])
crop: {_: 'inputPhotoCropAuto'}
}).then(function (updateResult) {
MtpApiManager.getUserID().then(function (id) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updateShort',
update: {
_: 'updateUserPhoto',
user_id: id,
date: tsNow(true),
photo: updateResult,
previous: true
}
});
$scope.photo = AppUsersManager.getUserPhoto(id, 'User');
});
@ -2024,16 +2032,17 @@ angular.module('myApp.controllers', [])
title: $scope.group.name,
users: inputUsers
}).then(function (createdResult) {
AppUsersManager.saveApiUsers(createdResult.users);
AppChatsManager.saveApiChats(createdResult.chats);
if (ApiUpdatesManager.saveSeq(createdResult.seq)) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
seq: createdResult.seq,
users: createdResult.users,
chats: createdResult.chats,
updates: [{
_: 'updateNewMessage',
message: createdResult.message,
pts: createdResult.pts
}]
});
}
var peerString = AppChatsManager.getChatString(createdResult.message.to_id.chat_id);
$rootScope.$broadcast('history_focus', {peerString: peerString});
@ -2063,16 +2072,17 @@ angular.module('myApp.controllers', [])
chat_id: $scope.chatID,
title: $scope.group.name
}).then(function (editResult) {
AppUsersManager.saveApiUsers(editResult.users);
AppChatsManager.saveApiChats(editResult.chats);
if (ApiUpdatesManager.saveSeq(editResult.seq)) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
seq: editResult.seq,
users: editResult.users,
chats: editResult.chats,
updates: [{
_: 'updateNewMessage',
message: editResult.message,
pts: editResult.pts
}]
});
}
var peerString = AppChatsManager.getChatString($scope.chatID);
$rootScope.$broadcast('history_focus', {peerString: peerString});

View File

@ -1170,12 +1170,13 @@ angular.module('myApp.services', [])
return MtpApiManager.invokeApi('messages.deleteMessages', {
id: messageIDs
}).then(function (deletedMessageIDs) {
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updateShort',
update: {
_: 'updateDeleteMessages',
messages: deletedMessageIDs
}
});
return deletedMessageIDs;
});
}
@ -1361,22 +1362,25 @@ angular.module('myApp.services', [])
peer: inputPeer,
message: text,
random_id: randomID
}, sentRequestOptions).then(function (result) {
if (ApiUpdatesManager.saveSeq(result.seq)) {
ApiUpdatesManager.saveUpdate({
}, sentRequestOptions).then(function (sentMessage) {
message.date = sentMessage.date;
message.id = sentMessage.id;
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
users: [],
chats: [],
seq: sentMessage.seq,
updates: [{
_: 'updateMessageID',
random_id: randomIDS,
id: result.id
});
message.date = result.date;
message.id = result.id;
ApiUpdatesManager.saveUpdate({
id: sentMessage.id
}, {
_: 'updateNewMessage',
message: message,
pts: result.pts
pts: sentMessage.pts
}]
});
}
}, function (error) {
toggleError(true);
})['finally'](function () {
@ -1503,25 +1507,26 @@ angular.module('myApp.services', [])
peer: inputPeer,
media: inputMedia,
random_id: randomID
}).then(function (result) {
if (ApiUpdatesManager.saveSeq(result.seq)) {
ApiUpdatesManager.saveUpdate({
}).then(function (statedMessage) {
message.date = statedMessage.message.date;
message.id = statedMessage.message.id;
message.media = statedMessage.message.media;
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
users: statedMessage.users,
chats: statedMessage.chats,
seq: statedMessage.seq,
updates: [{
_: 'updateMessageID',
random_id: randomIDS,
id: result.message.id
});
message.date = result.message.date;
message.id = result.message.id;
message.media = result.message.media;
ApiUpdatesManager.saveUpdate({
id: statedMessage.message.id
}, {
_: 'updateNewMessage',
message: message,
pts: result.pts
pts: statedMessage.pts
}]
});
}
}, function (error) {
toggleError(true);
});
@ -1617,24 +1622,26 @@ angular.module('myApp.services', [])
peer: inputPeer,
media: inputMedia,
random_id: randomID
}).then(function (result) {
if (ApiUpdatesManager.saveSeq(result.seq)) {
ApiUpdatesManager.saveUpdate({
}).then(function (statedMessage) {
message.date = statedMessage.message.date;
message.id = statedMessage.message.id;
message.media = statedMessage.message.media;
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
users: statedMessage.users,
chats: statedMessage.chats,
seq: statedMessage.seq,
updates: [{
_: 'updateMessageID',
random_id: randomIDS,
id: result.message.id
});
message.date = result.message.date;
message.id = result.message.id;
message.media = result.message.media;
ApiUpdatesManager.saveUpdate({
id: statedMessage.message.id
}, {
_: 'updateNewMessage',
message: message,
pts: result.pts
pts: statedMessage.pts
}]
});
}
}, function (error) {
toggleError(true);
});
@ -1656,22 +1663,23 @@ angular.module('myApp.services', [])
return MtpApiManager.invokeApi('messages.forwardMessages', {
peer: AppPeersManager.getInputPeerByID(peerID),
id: msgIDs
}).then(function (forwardResult) {
AppUsersManager.saveApiUsers(forwardResult.users);
AppChatsManager.saveApiChats(forwardResult.chats);
if (ApiUpdatesManager.saveSeq(forwardResult.seq)) {
angular.forEach(forwardResult.messages, function(apiMessage) {
ApiUpdatesManager.saveUpdate({
}).then(function (statedMessages) {
var updates = [];
angular.forEach(statedMessages.messages, function(apiMessage) {
updates.push({
_: 'updateNewMessage',
message: apiMessage,
pts: forwardResult.pts
pts: statedMessages.pts
});
});
ApiUpdatesManager.processUpdateMessage({
_: 'updates',
users: statedMessages.users,
chats: statedMessages.chats,
seq: statedMessages.seq,
updates: updates
});
}
});
};
@ -1686,9 +1694,12 @@ angular.module('myApp.services', [])
historyStorage = historiesStorage[peerID],
i;
ApiUpdatesManager.saveUpdate({
ApiUpdatesManager.processUpdateMessage({
_: 'updateShort',
update: {
_: 'updateDeleteMessages',
messages: [tempID]
}
});
for (i = 0; i < historyStorage.pending.length; i++) {
@ -2828,15 +2839,28 @@ angular.module('myApp.services', [])
.service('ApiUpdatesManager', function ($rootScope, MtpNetworkerFactory, AppUsersManager, AppChatsManager, AppPeersManager, MtpApiManager) {
var curState = {invalid: true};
var isSynchronizing = true,
getDifferencePending = false,
curState = {},
pendingUpdates = {};
function processUpdateMessage (updateMessage) {
if (curState.invalid) {
return false;
function popPendingUpdate () {
var updateMessage = pendingUpdates[curState.seq + 1];
if (updateMessage && processUpdateMessage(updateMessage)) {
delete pendingUpdates[curState.seq + 1];
}
}
function forceGetDifference () {
if (!isSynchronizing) {
getDifference();
}
}
function processUpdateMessage (updateMessage) {
if (updateMessage.seq) {
if (!saveSeq(updateMessage.seq, updateMessage.seq_start)) {
pendingUpdates[updateMessage.seq_start || updateMessage.seq] = updateMessage;
return false;
}
if (updateMessage.date) {
@ -2847,47 +2871,18 @@ angular.module('myApp.services', [])
switch (updateMessage._) {
case 'updatesTooLong':
getDifference();
forceGetDifference();
break;
case 'updateShort':
saveUpdate(updateMessage.update);
break;
case 'updatesCombined':
case 'updates':
AppUsersManager.saveApiUsers(updateMessage.users);
AppChatsManager.saveApiChats(updateMessage.chats);
var i, update, message;
for (var i = 0; i < updateMessage.updates.length; i++) {
update = updateMessage.updates[i];
switch (update._) {
case 'updateNewMessage':
message = update.message;
if (message.from_id && !AppUsersManager.hasUser(message.from_id)) {
console.log('User not found', message.from_id, 'getDiff');
getDifference();
return false;
}
if (message.to_id.chat_id && !AppChatsManager.hasChat(message.to_id.chat_id)) {
console.log('Chat not found', message.to_id.chat_id, 'getDiff');
getDifference();
return false;
}
break;
}
}
angular.forEach(updateMessage.updates, function (update) {
saveUpdate(update);
});
break;
case 'updateShortMessage':
if (!AppUsersManager.hasUser(updateMessage.from_id)) {
console.log('User not found', updateMessage.from_id, 'getDiff');
getDifference();
forceGetDifference();
break;
}
saveUpdate({
@ -2911,7 +2906,7 @@ angular.module('myApp.services', [])
if (!AppUsersManager.hasUser(updateMessage.from_id) ||
!AppChatsManager.hasChat(updateMessage.chat_id)) {
console.log('User or chat not found', updateMessage.from_id, updateMessage.chat_id, 'getDiff');
getDifference();
forceGetDifference();
break;
}
saveUpdate({
@ -2930,22 +2925,63 @@ angular.module('myApp.services', [])
pts: updateMessage.pts
});
break;
case 'updatesCombined':
case 'updates':
default:
AppUsersManager.saveApiUsers(updateMessage.users);
AppChatsManager.saveApiChats(updateMessage.chats);
var i, update, message;
for (var i = 0; i < updateMessage.updates.length; i++) {
update = updateMessage.updates[i];
switch (update._) {
case 'updateNewMessage':
message = update.message;
if (message.from_id && !AppUsersManager.hasUser(message.from_id)) {
console.log('User not found', message.from_id, 'getDiff');
forceGetDifference();
return false;
}
if (message.to_id.chat_id && !AppChatsManager.hasChat(message.to_id.chat_id)) {
console.log('Chat not found', message.to_id.chat_id, 'getDiff');
forceGetDifference();
return false;
}
break;
}
}
angular.forEach(updateMessage.updates, function (update) {
saveUpdate(update);
});
break;
}
popPendingUpdate();
if (getDifferencePending && curState.seq >= getDifferencePending.seqAwaiting) {
clearTimeout(getDifferencePending.timeout);
getDifferencePending = false;
}
return true;
}
function getDifference (force) {
if (curState.invalid && !force) {
return false;
function getDifference () {
isSynchronizing = true;
if (getDifferencePending) {
clearTimeout(getDifferencePending.timeout);
getDifferencePending = false;
}
curState.invalid = true;
MtpApiManager.invokeApi('updates.getDifference', {pts: curState.pts, date: curState.date, qts: 0}).then(function (differenceResult) {
if (differenceResult._ == 'updates.differenceEmpty') {
curState.date = differenceResult.date;
curState.seq = differenceResult.seq;
delete curState.invalid;
isSynchronizing = false;
popPendingUpdate();
return false;
}
@ -2954,7 +2990,7 @@ angular.module('myApp.services', [])
// Should be first because of updateMessageID
angular.forEach(differenceResult.other_updates, function(update){
saveUpdate(update, true);
saveUpdate(update);
});
angular.forEach(differenceResult.new_messages, function (apiMessage) {
@ -2962,7 +2998,7 @@ angular.module('myApp.services', [])
_: 'updateNewMessage',
message: apiMessage,
pts: curState.pts
}, true);
});
});
var nextState = differenceResult.intermediate_state || differenceResult.state;
@ -2973,15 +3009,12 @@ angular.module('myApp.services', [])
if (differenceResult._ == 'updates.differenceSlice') {
getDifference(true);
} else {
delete curState.invalid;
isSynchronizing = false;
}
});
}
function saveUpdate (update, force) {
if (curState.invalid && !force) {
return false;
}
function saveUpdate (update) {
if (update.pts) {
curState.pts = update.pts;
}
@ -2989,23 +3022,31 @@ angular.module('myApp.services', [])
$rootScope.$broadcast('apiUpdate', update);
}
function saveSeq (seq, seqStart) {
// console.log('saving seq', curState.invalid, seq, seqStart, curState.seq);
if (curState.invalid) {
return false;
}
seqStart = seqStart || seq;
if (!seqStart) {
return true;
}
if (isSynchronizing) {
return false;
}
if (seqStart != curState.seq + 1) {
if (seqStart > curState.seq) {
console.warn('Seq hole', seqStart, curState.seq);
if (!getDifferencePending) {
getDifferencePending = {
seqAwaiting: seqStart,
timeout: setTimeout(function () {
getDifference();
}, 5000)
};
}
}
return false;
}
@ -3021,13 +3062,13 @@ angular.module('myApp.services', [])
curState.seq = stateResult.seq;
curState.pts = stateResult.pts;
curState.date = stateResult.date;
delete curState.invalid;
isSynchronizing = false;
})
}
return {
saveUpdate: saveUpdate,
processUpdateMessage: processUpdateMessage,
saveSeq: saveSeq,
attach: attach
}