Force reconnect button
This commit is contained in:
parent
0e70f4a234
commit
80fa6909d9
@ -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');
|
||||||
|
@ -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[],
|
||||||
|
@ -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.",
|
||||||
|
@ -7,7 +7,8 @@
|
|||||||
export enum ConnectionStatus {
|
export enum ConnectionStatus {
|
||||||
Connected,
|
Connected,
|
||||||
Connecting,
|
Connecting,
|
||||||
Closed
|
Closed,
|
||||||
|
TimedOut
|
||||||
};
|
};
|
||||||
|
|
||||||
export type ConnectionStatusChange = {
|
export type ConnectionStatusChange = {
|
||||||
|
@ -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) => {
|
||||||
|
@ -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();
|
||||||
|
@ -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);
|
||||||
|
@ -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();
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user