Force reconnect button

This commit is contained in:
Eduard Kuzmenko 2021-06-22 18:16:23 +03:00
parent 0e70f4a234
commit 80fa6909d9
9 changed files with 71 additions and 19 deletions

View File

@ -31,6 +31,7 @@ export default class ConnectionStatusComponent {
private hadConnect = false; private hadConnect = false;
private retryAt: number; private retryAt: number;
private connecting = false; private connecting = false;
private timedOut = false;
private updating = false; private updating = false;
private log: ReturnType<typeof logger>; private log: ReturnType<typeof logger>;
@ -114,7 +115,8 @@ export default class ConnectionStatusComponent {
if(online && !this.hadConnect) { if(online && !this.hadConnect) {
this.hadConnect = true; this.hadConnect = true;
} }
this.timedOut = status && status.status === ConnectionStatus.TimedOut;
this.connecting = !online; this.connecting = !online;
this.retryAt = status && status.retryAt; this.retryAt = status && status.retryAt;
DEBUG && this.log('connecting', this.connecting); DEBUG && this.log('connecting', this.connecting);
@ -129,10 +131,25 @@ export default class ConnectionStatusComponent {
this.statusPreloader.attach(this.statusEl); this.statusPreloader.attach(this.statusEl);
}; };
private getA(langPackKey: LangPackKey, callback: () => void) {
const a = document.createElement('a');
a.classList.add('force-reconnect');
a.append(i18n(langPackKey));
a.addEventListener('click', (e) => {
cancelEvent(e);
callback();
});
return a;
}
private setState = () => { private setState = () => {
const timeout = ConnectionStatusComponent.CHANGE_STATE_DELAY; const timeout = ConnectionStatusComponent.CHANGE_STATE_DELAY;
if(this.connecting) { if(this.connecting) {
if(this.hadConnect) { if(this.timedOut) {
const a = this.getA('ConnectionStatus.ForceReconnect', () => apiManager.forceReconnect());
this.setStatusText('ConnectionStatus.TimedOut', [a]);
} else if(this.hadConnect) {
if(this.retryAt !== undefined) { if(this.retryAt !== undefined) {
const timerSpan = document.createElement('span'); const timerSpan = document.createElement('span');
const retryAt = this.retryAt; const retryAt = this.retryAt;
@ -146,13 +163,7 @@ export default class ConnectionStatusComponent {
setTime(); setTime();
const interval = setInterval(setTime, 1e3); const interval = setInterval(setTime, 1e3);
const a = document.createElement('a'); const a = this.getA('ConnectionStatus.Reconnect', () => apiManager.forceReconnectTimeout());
a.classList.add('force-reconnect');
a.append(i18n('ConnectionStatus.Reconnect'));
a.addEventListener('click', (e) => {
cancelEvent(e);
apiManager.forceReconnect();
});
this.setStatusText('ConnectionStatus.ReconnectIn', [timerSpan, a]); this.setStatusText('ConnectionStatus.ReconnectIn', [timerSpan, a]);
} else { } else {
this.setStatusText('ConnectionStatus.Reconnecting'); this.setStatusText('ConnectionStatus.Reconnecting');

View File

@ -15,7 +15,7 @@ const App = {
id: 1025907, id: 1025907,
hash: '452b0359b988148995f22ff0f4229750', hash: '452b0359b988148995f22ff0f4229750',
version: '0.5.8', version: '0.5.8',
langPackVersion: '0.2.6', langPackVersion: '0.2.9',
langPack: 'macos', langPack: 'macos',
langPackCode: 'en', langPackCode: 'en',
domains: [] as string[], domains: [] as string[],

View File

@ -46,9 +46,11 @@ const lang = {
//"ChatList.Menu.Archived": "Archived", //"ChatList.Menu.Archived": "Archived",
"ChatList.Menu.SwitchTo.Webogram": "Switch to Old Version", "ChatList.Menu.SwitchTo.Webogram": "Switch to Old Version",
"ChatList.Menu.SwitchTo.Z": "Switch to Z version", "ChatList.Menu.SwitchTo.Z": "Switch to Z version",
"ConnectionStatus.ForceReconnect": "force reconnect",
"ConnectionStatus.ReconnectIn": "Reconnect in %ds, %s", "ConnectionStatus.ReconnectIn": "Reconnect in %ds, %s",
"ConnectionStatus.Reconnect": "reconnect", "ConnectionStatus.Reconnect": "reconnect",
"ConnectionStatus.Reconnecting": "Reconnecting...", "ConnectionStatus.Reconnecting": "Reconnecting...",
"ConnectionStatus.TimedOut": "Request timed out, %s",
"ConnectionStatus.Waiting": "Waiting for network...", "ConnectionStatus.Waiting": "Waiting for network...",
"Deactivated.Title": "Too many tabs...", "Deactivated.Title": "Too many tabs...",
"Deactivated.Subtitle": "Telegram supports only one active tab with the app.\nClick anywhere to continue using this tab.", "Deactivated.Subtitle": "Telegram supports only one active tab with the app.\nClick anywhere to continue using this tab.",

View File

@ -7,7 +7,8 @@
export enum ConnectionStatus { export enum ConnectionStatus {
Connected, Connected,
Connecting, Connecting,
Closed Closed,
TimedOut
}; };
export type ConnectionStatusChange = { export type ConnectionStatusChange = {

View File

@ -90,7 +90,11 @@ const taskListeners = {
online: () => { online: () => {
networkerFactory.forceReconnectTimeout(); networkerFactory.forceReconnectTimeout();
} },
forceReconnect: () => {
networkerFactory.forceReconnect();
},
}; };
const onMessage = async(e: any) => { const onMessage = async(e: any) => {

View File

@ -189,7 +189,7 @@ export class ApiManagerProxy extends CryptoWorkerMethods {
}); });
window.addEventListener('online', (event) => { window.addEventListener('online', (event) => {
this.forceReconnect(); this.forceReconnectTimeout();
}); });
/// #if !MTPROTO_SW /// #if !MTPROTO_SW
@ -544,9 +544,13 @@ export class ApiManagerProxy extends CryptoWorkerMethods {
return this.performTaskWorkerVoid('startAll'); return this.performTaskWorkerVoid('startAll');
} }
public forceReconnect() { public forceReconnectTimeout() {
this.postMessage({type: 'online'}); this.postMessage({type: 'online'});
} }
public forceReconnect() {
this.postMessage({type: 'forceReconnect'});
}
} }
const apiManagerProxy = new ApiManagerProxy(); const apiManagerProxy = new ApiManagerProxy();

View File

@ -382,6 +382,12 @@ export default class MTPNetworker {
} }
} }
public forceReconnect() {
if((this.transport as TcpObfuscated).forceReconnect) {
(this.transport as TcpObfuscated).forceReconnect();
}
}
// private sendPingDelayDisconnect = () => { // private sendPingDelayDisconnect = () => {
// if(this.pingPromise || true) return; // if(this.pingPromise || true) return;
@ -696,7 +702,9 @@ export default class MTPNetworker {
} }
this.log.error('timeout', message); this.log.error('timeout', message);
this.setConnectionStatus(ConnectionStatus.Closed); if(this.isOnline) {
this.setConnectionStatus(ConnectionStatus.TimedOut);
}
/* this.getEncryptedOutput(message).then(bytes => { /* this.getEncryptedOutput(message).then(bytes => {
this.log.error('timeout encrypted', bytes); this.log.error('timeout encrypted', bytes);

View File

@ -73,6 +73,15 @@ export class NetworkerFactory {
networker.forceReconnectTimeout(); networker.forceReconnectTimeout();
} }
} }
public forceReconnect() {
for(const networker of this.networkers) {
if(!networker.isFileNetworker) {
networker.forceReconnect();
break;
}
}
}
} }
const networkerFactory = new NetworkerFactory(); const networkerFactory = new NetworkerFactory();

View File

@ -135,7 +135,7 @@ export default class TcpObfuscated implements MTTransport {
} }
}; };
private clear() { public clear() {
this.connected = false; this.connected = false;
if(this.connection) { if(this.connection) {
@ -174,14 +174,28 @@ export default class TcpObfuscated implements MTTransport {
this.connect(); this.connect();
} }
public forceReconnect() {
this.close();
this.reconnect();
}
public destroy() { public destroy() {
this.setAutoReconnect(false); this.setAutoReconnect(false);
this.close(); this.close();
} }
public close() { public close() {
if(this.connection) { const connection = this.connection;
this.connection.close(); if(connection) {
const connected = this.connected;
this.clear();
if(connected) { // wait for buffered messages if they are there
connection.addEventListener('message', this.onMessage);
connection.addEventListener('close', () => {
connection.removeEventListener('message', this.onMessage);
}, true);
connection.close();
}
} }
} }
@ -205,7 +219,6 @@ export default class TcpObfuscated implements MTTransport {
private connect() { private connect() {
if(this.connection) { if(this.connection) {
this.close(); this.close();
this.clear();
} }
this.connection = new this.Connection(this.dcId, this.url, this.logSuffix); this.connection = new this.Connection(this.dcId, this.url, this.logSuffix);