This commit is contained in:
Eduard Kuzmenko 2021-03-05 01:56:04 +04:00
parent f686a189a1
commit 0541485f5e
6 changed files with 20 additions and 10 deletions

View File

@ -13,7 +13,7 @@ type LazyLoadElement = Omit<LazyLoadElementBase, 'load'> & {
wasSeen?: boolean, wasSeen?: boolean,
}; };
const PARALLEL_LIMIT = Infinity; const PARALLEL_LIMIT = 8;
export class LazyLoadQueueBase { export class LazyLoadQueueBase {
public queueId = 0; public queueId = 0;

View File

@ -25,7 +25,7 @@ type UpdatesState = {
lastPtsUpdateTime?: number lastPtsUpdateTime?: number
}; };
const SYNC_DELAY = 25; const SYNC_DELAY = 6;
export class ApiUpdatesManager { export class ApiUpdatesManager {
public updatesState: UpdatesState = { public updatesState: UpdatesState = {
@ -38,7 +38,7 @@ export class ApiUpdatesManager {
public channelStates: {[channelId: number]: UpdatesState} = {}; public channelStates: {[channelId: number]: UpdatesState} = {};
private attached = false; private attached = false;
private log = logger('UPDATES', LogLevels.error/* | LogLevels.log */); private log = logger('UPDATES', LogLevels.error | LogLevels.log | LogLevels.warn | LogLevels.debug);
constructor() { constructor() {
// * false for test purposes // * false for test purposes
@ -137,7 +137,7 @@ export class ApiUpdatesManager {
} }
} }
processUpdateMessage = (updateMessage: any, options: Partial<{ public processUpdateMessage = (updateMessage: any, options: Partial<{
ignoreSyncLoading: boolean ignoreSyncLoading: boolean
}> = {}) => { }> = {}) => {
// return forceGetDifference() // return forceGetDifference()
@ -147,6 +147,8 @@ export class ApiUpdatesManager {
seqStart: updateMessage.seq_start, seqStart: updateMessage.seq_start,
ignoreSyncLoading: options.ignoreSyncLoading ignoreSyncLoading: options.ignoreSyncLoading
}; };
this.log('processUpdateMessage', updateMessage);
switch(updateMessage._) { switch(updateMessage._) {
case 'updatesTooLong': case 'updatesTooLong':
@ -425,7 +427,7 @@ export class ApiUpdatesManager {
if(update._ === 'updateChannelTooLong') { if(update._ === 'updateChannelTooLong') {
if(!curState.lastPtsUpdateTime || if(!curState.lastPtsUpdateTime ||
curState.lastPtsUpdateTime < Date.now() - 10000) { curState.lastPtsUpdateTime < (Date.now() - SYNC_DELAY)) {
// this.log.trace('channel too long, get diff', channelId, update) // this.log.trace('channel too long, get diff', channelId, update)
this.getChannelDifference(channelId); this.getChannelDifference(channelId);
} }
@ -579,7 +581,7 @@ export class ApiUpdatesManager {
} else { } else {
// ! for testing // ! for testing
/* state.seq = 1; /* state.seq = 1;
state.pts = state.pts - 1000; state.pts = state.pts - 15;
state.date = 1; */ state.date = 1; */
Object.assign(this.updatesState, state); Object.assign(this.updatesState, state);

View File

@ -36,7 +36,6 @@ import appDownloadManager from './appDownloadManager';
import appStateManager, { AppStateManager } from './appStateManager'; import appStateManager, { AppStateManager } from './appStateManager';
import { MOUNT_CLASS_TO } from '../../config/debug'; import { MOUNT_CLASS_TO } from '../../config/debug';
import appNavigationController from '../../components/appNavigationController'; import appNavigationController from '../../components/appNavigationController';
import { isSafari } from '../../helpers/userAgent';
//console.log('appImManager included33!'); //console.log('appImManager included33!');

View File

@ -257,7 +257,12 @@ export class AppMessagesManager {
} }
} }
if(removeUnread && dialog.unread_count) dialog.unread_count -= removeUnread; if(removeUnread && dialog.unread_count) dialog.unread_count -= removeUnread;
if(dialog.peerId < 0 && dialog.pts) {
const newPts = apiUpdatesManager.channelStates[-dialog.peerId].pts;
dialog.pts = newPts;
}
dialog.unread_count = Math.max(0, dialog.unread_count); dialog.unread_count = Math.max(0, dialog.unread_count);
dialogs.push(dialog); dialogs.push(dialog);
@ -3652,6 +3657,10 @@ export class AppMessagesManager {
this.saveMessages([message], {storage}); this.saveMessages([message], {storage});
// this.log.warn(dT(), 'message unread', message.mid, message.pFlags.unread) // this.log.warn(dT(), 'message unread', message.mid, message.pFlags.unread)
/* if((message as Message.message).grouped_id) {
this.log('updateNewMessage', message);
} */
const pendingMessage = this.checkPendingMessage(message); const pendingMessage = this.checkPendingMessage(message);
const historyStorage = this.getHistoryStorage(peerId); const historyStorage = this.getHistoryStorage(peerId);
this.updateMessageRepliesIfNeeded(message); this.updateMessageRepliesIfNeeded(message);

View File

@ -87,7 +87,7 @@ export class ApiFileManager {
public downloadCheck(dcId: string | number) { public downloadCheck(dcId: string | number) {
const downloadPull = this.downloadPulls[dcId]; const downloadPull = this.downloadPulls[dcId];
const downloadLimit = dcId === 'upload' ? 24 : 48; const downloadLimit = dcId === 'upload' ? 24 : 24;
//const downloadLimit = Infinity; //const downloadLimit = Infinity;
if(this.downloadActives[dcId] >= downloadLimit || !downloadPull || !downloadPull.length) { if(this.downloadActives[dcId] >= downloadLimit || !downloadPull || !downloadPull.length) {

View File

@ -18,7 +18,7 @@ export default class TcpObfuscated implements MTTransport {
bodySent: boolean bodySent: boolean
}>> = []; }>> = [];
private debug = Modes.debug && false; private debug = Modes.debug && false/* true */;
private log: ReturnType<typeof logger>; private log: ReturnType<typeof logger>;
public connected = false; public connected = false;
private lastCloseTime: number; private lastCloseTime: number;