Handle 'CONNECTION_NOT_INITED'

This commit is contained in:
Eduard Kuzmenko 2022-02-07 19:50:20 +04:00
parent 3b4184f34e
commit d38c5adeb5
4 changed files with 17 additions and 0 deletions

View File

@ -576,6 +576,9 @@ export class ApiManager {
} else { } else {
rejectPromise(error); rejectPromise(error);
} }
} else if(error.code === 400 && error.type === 'CONNECTION_NOT_INITED') {
networkerFactory.unsetConnectionInited();
performRequest(cachedNetworker);
} else if(!options.rawError && error.code === 420) { } else if(!options.rawError && error.code === 420) {
const waitTime = +error.type.match(/^FLOOD_WAIT_(\d+)/)[1] || 1; const waitTime = +error.type.match(/^FLOOD_WAIT_(\d+)/)[1] || 1;

View File

@ -375,6 +375,8 @@ export default class MTPNetworker {
this.nextReq = 0; this.nextReq = 0;
} }
this.connectionInited = false;
/// #if MTPROTO_HAS_HTTP /// #if MTPROTO_HAS_HTTP
if(this.longPollInterval !== undefined) { if(this.longPollInterval !== undefined) {
clearInterval(this.longPollInterval); clearInterval(this.longPollInterval);
@ -1336,7 +1338,9 @@ export default class MTPNetworker {
return; return;
} }
// deserializer.setMtproto(false);
result.result = deserializer.fetchObject(type, field + '[result]'); result.result = deserializer.fetchObject(type, field + '[result]');
// deserializer.setMtproto(true);
// self.log(dT(), 'override rpc_result', sentMessage, type, result); // self.log(dT(), 'override rpc_result', sentMessage, type, result);
} }
} }

View File

@ -65,6 +65,12 @@ export class NetworkerFactory {
} }
} }
public unsetConnectionInited() {
for(const networker of this.networkers) {
networker.connectionInited = false;
}
}
public forceReconnectTimeout() { public forceReconnectTimeout() {
for(const networker of this.networkers) { for(const networker of this.networkers) {
networker.forceReconnectTimeout(); networker.forceReconnectTimeout();

View File

@ -491,6 +491,10 @@ class TLDeserialization<FetchLongAs extends Long> {
this.debug = options.debug !== undefined ? options.debug : /* Modes.debug */false; this.debug = options.debug !== undefined ? options.debug : /* Modes.debug */false;
} }
/* public setMtproto(mtproto: boolean) {
this.mtproto = mtproto;
} */
private readInt(field: string) { private readInt(field: string) {
//if(this.offset >= this.intView.length * 4) { //if(this.offset >= this.intView.length * 4) {
if((this.byteView.length - this.offset) < 4) { if((this.byteView.length - this.offset) < 4) {