2020-05-06 04:03:31 +03:00
|
|
|
//import apiManager from '../lib/mtproto/apiManager';
|
|
|
|
import apiManager from '../lib/mtproto/mtprotoworker';
|
|
|
|
import Page from './page';
|
|
|
|
import pageIm from './pageIm';
|
|
|
|
import pagePassword from './pagePassword';
|
2020-05-10 04:23:21 +03:00
|
|
|
import pageSignIn from './pageSignIn';
|
2020-05-06 04:03:31 +03:00
|
|
|
import { App } from '../lib/mtproto/mtproto_config';
|
|
|
|
import serverTimeManager from '../lib/mtproto/serverTimeManager';
|
2020-09-17 22:33:23 +03:00
|
|
|
import { AuthAuthorization, AuthLoginToken } from '../layer';
|
2020-10-29 19:11:09 +02:00
|
|
|
import { bytesCmp, bytesToBase64 } from '../helpers/bytes';
|
2020-05-06 04:03:31 +03:00
|
|
|
|
|
|
|
let onFirstMount = async() => {
|
|
|
|
const pageElement = page.pageEl;
|
|
|
|
const imageDiv = pageElement.querySelector('.auth-image') as HTMLDivElement;
|
2020-05-10 04:23:21 +03:00
|
|
|
|
|
|
|
page.pageEl.querySelector('.a-qr').addEventListener('click', () => {
|
|
|
|
pageSignIn.mount();
|
2020-05-30 09:44:54 +03:00
|
|
|
stop = true;
|
2020-05-10 04:23:21 +03:00
|
|
|
});
|
2020-05-06 04:03:31 +03:00
|
|
|
|
|
|
|
const results = await Promise.all([
|
|
|
|
import('qr-code-styling' as any)
|
|
|
|
]);
|
|
|
|
const QRCodeStyling = results[0].default;
|
|
|
|
|
|
|
|
let stop = false;
|
|
|
|
document.addEventListener('user_auth', () => {
|
|
|
|
stop = true;
|
2020-05-30 09:44:54 +03:00
|
|
|
cachedPromise = null;
|
2020-05-06 04:03:31 +03:00
|
|
|
}, {once: true});
|
|
|
|
|
2020-05-30 09:44:54 +03:00
|
|
|
let options: {dcID?: number, ignoreErrors: true} = {ignoreErrors: true};
|
2020-09-17 22:33:23 +03:00
|
|
|
let prevToken: Uint8Array | number[];
|
2020-05-06 04:03:31 +03:00
|
|
|
|
2020-05-30 09:44:54 +03:00
|
|
|
return async() => {
|
|
|
|
stop = false;
|
2020-05-06 04:03:31 +03:00
|
|
|
|
2020-05-30 09:44:54 +03:00
|
|
|
do {
|
|
|
|
if(stop) {
|
2020-05-06 04:03:31 +03:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2020-05-30 09:44:54 +03:00
|
|
|
try {
|
2020-09-17 22:33:23 +03:00
|
|
|
let loginToken = await apiManager.invokeApi('auth.exportLoginToken', {
|
2020-05-30 09:44:54 +03:00
|
|
|
api_id: App.id,
|
|
|
|
api_hash: App.hash,
|
|
|
|
except_ids: []
|
|
|
|
}, {ignoreErrors: true});
|
|
|
|
|
|
|
|
if(loginToken._ == 'auth.loginTokenMigrateTo') {
|
|
|
|
if(!options.dcID) {
|
|
|
|
options.dcID = loginToken.dc_id;
|
|
|
|
apiManager.setBaseDcID(loginToken.dc_id);
|
|
|
|
//continue;
|
2020-05-06 04:03:31 +03:00
|
|
|
}
|
2020-05-30 09:44:54 +03:00
|
|
|
|
|
|
|
loginToken = await apiManager.invokeApi('auth.importLoginToken', {
|
|
|
|
token: loginToken.token
|
2020-09-17 22:33:23 +03:00
|
|
|
}, options) as AuthLoginToken.authLoginToken;
|
2020-05-30 09:44:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if(loginToken._ == 'auth.loginTokenSuccess') {
|
2020-09-17 22:33:23 +03:00
|
|
|
const authorization = loginToken.authorization as any as AuthAuthorization.authAuthorization;
|
2020-11-16 00:34:48 +02:00
|
|
|
apiManager.setUserAuth(authorization.user.id);
|
2020-05-30 09:44:54 +03:00
|
|
|
pageIm.mount();
|
2020-05-06 04:03:31 +03:00
|
|
|
break;
|
2020-05-30 09:44:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* // to base64
|
|
|
|
var decoder = new TextDecoder('utf8');
|
|
|
|
var b64encoded = btoa(String.fromCharCode.apply(null, [...loginToken.token])); */
|
|
|
|
|
|
|
|
if(!prevToken || !bytesCmp(prevToken, loginToken.token)) {
|
|
|
|
prevToken = loginToken.token;
|
|
|
|
|
|
|
|
let encoded = bytesToBase64(loginToken.token);
|
|
|
|
let url = "tg://login?token=" + encoded.replace(/\+/g, "-").replace(/\//g, "_").replace(/\=+$/, "");
|
|
|
|
|
|
|
|
imageDiv.innerHTML = '';
|
|
|
|
const qrCode = new QRCodeStyling({
|
|
|
|
width: 166,
|
|
|
|
height: 166,
|
|
|
|
data: url,
|
|
|
|
image: "assets/img/logo_padded.svg",
|
|
|
|
dotsOptions: {
|
|
|
|
color: "#000000",
|
|
|
|
type: "rounded"
|
|
|
|
},
|
|
|
|
imageOptions: {
|
|
|
|
imageSize: .75
|
|
|
|
},
|
|
|
|
backgroundOptions: {
|
|
|
|
color: "#ffffff"
|
|
|
|
},
|
|
|
|
qrOptions: {
|
|
|
|
errorCorrectionLevel: "L"
|
|
|
|
}
|
|
|
|
});
|
|
|
|
qrCode.append(imageDiv);
|
|
|
|
}
|
|
|
|
|
|
|
|
let timestamp = Date.now() / 1000;
|
|
|
|
let diff = loginToken.expires - timestamp - serverTimeManager.serverTimeOffset;
|
|
|
|
|
|
|
|
await new Promise((resolve, reject) => setTimeout(resolve, diff > 5 ? 5e3 : 1e3 * diff | 0));
|
|
|
|
} catch(err) {
|
|
|
|
switch(err.type) {
|
|
|
|
case 'SESSION_PASSWORD_NEEDED':
|
|
|
|
console.warn('pageSignQR: SESSION_PASSWORD_NEEDED');
|
|
|
|
err.handled = true;
|
|
|
|
pagePassword.mount();
|
|
|
|
stop = true;
|
|
|
|
cachedPromise = null;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
console.error('pageSignQR: default error:', err);
|
|
|
|
break;
|
|
|
|
}
|
2020-05-06 04:03:31 +03:00
|
|
|
}
|
2020-05-30 09:44:54 +03:00
|
|
|
} while(true);
|
|
|
|
};
|
2020-05-06 04:03:31 +03:00
|
|
|
};
|
|
|
|
|
2020-05-30 09:44:54 +03:00
|
|
|
let cachedPromise: Promise<() => Promise<void>>;
|
2020-05-06 04:03:31 +03:00
|
|
|
const page = new Page('page-signQR', true, () => {
|
2020-05-30 09:44:54 +03:00
|
|
|
return cachedPromise;
|
|
|
|
}, () => {
|
2020-09-02 02:32:39 +03:00
|
|
|
//console.log('onMount');
|
2020-05-30 09:44:54 +03:00
|
|
|
if(!cachedPromise) cachedPromise = onFirstMount();
|
|
|
|
cachedPromise.then(func => {
|
|
|
|
func();
|
|
|
|
});
|
2020-05-06 04:03:31 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
export default page;
|