mirror of
https://github.com/MarshalX/telegram-crawler.git
synced 2025-01-04 10:21:28 +01:00
413 lines
16 KiB
JavaScript
413 lines
16 KiB
JavaScript
(function(window) {
|
|
if (!Array.isArray) {
|
|
Array.isArray = function(arg) {
|
|
return Object.prototype.toString.call(arg) === '[object Array]';
|
|
};
|
|
}
|
|
if (!Object.isSimpleObject) {
|
|
Object.isSimpleObject = function(arg) {
|
|
return arg != null && typeof arg === 'object';
|
|
};
|
|
}
|
|
function isFunction(func) {
|
|
return func && {}.toString.call(func) === '[object Function]';
|
|
}
|
|
function getEl(elOrId) {
|
|
if (elOrId.nodeType) return elOrId;
|
|
return document.getElementById(elOrId);
|
|
}
|
|
function preventDefault(event) {
|
|
if (window.event) {
|
|
window.event.returnValue = false;
|
|
}
|
|
else if (event.preventDefault) {
|
|
event.preventDefault();
|
|
}
|
|
else {
|
|
event.returnValue = false;
|
|
}
|
|
}
|
|
function addEvent(el, event, handler) {
|
|
var events = event.split(/\s+/);
|
|
for (var i = 0; i < events.length; i++) {
|
|
if (el.addEventListener) {
|
|
el.addEventListener(events[i], handler, false);
|
|
} else {
|
|
el.attachEvent('on' + events[i], handler);
|
|
}
|
|
}
|
|
}
|
|
|
|
var UA = window.navigator.userAgent || '';
|
|
var ScopeAliases = {
|
|
personal_details: 'pd',
|
|
passport: 'pp',
|
|
driver_license: 'dl',
|
|
identity_card: 'ic',
|
|
internal_passport: 'ip',
|
|
id_document: 'idd',
|
|
address: 'ad',
|
|
utility_bill: 'ub',
|
|
bank_statement: 'bs',
|
|
rental_agreement: 'ra',
|
|
passport_registration: 'pr',
|
|
temporary_registration: 'tr',
|
|
address_document: 'add',
|
|
phone_number: 'pn',
|
|
email: 'em',
|
|
};
|
|
|
|
function openDeepLink(url, tooltipToggle) {
|
|
var is_ios = /ios|iphone os|iphone|ipod|ipad/i.test(UA);
|
|
var is_firefox = /firefox/i.test(UA);
|
|
var use_iframe = (is_ios || is_firefox);
|
|
var use_once = (!is_ios && is_firefox);
|
|
var timeOpen;
|
|
var ttNeedHide = false;
|
|
var pageShown = true;
|
|
var onPageHide = function() {
|
|
pageShown = false;
|
|
};
|
|
tooltipToggle = tooltipToggle || function(){};
|
|
var onPageShow = function() {
|
|
pageShown = true;
|
|
if (ttNeedHide && (+(new Date) - timeOpen) > 5000) {
|
|
tooltipToggle(false);
|
|
}
|
|
};
|
|
addEvent(window, 'pagehide', onPageHide);
|
|
addEvent(window, 'pageshow', onPageShow);
|
|
addEvent(window, 'blur', onPageHide);
|
|
addEvent(window, 'focus', onPageShow);
|
|
var showTooltip = function() {
|
|
tooltipToggle(true);
|
|
if (!pageShown) {
|
|
ttNeedHide = true;
|
|
}
|
|
};
|
|
if (use_iframe) {
|
|
var iframeEl = document.createElement('iframe');
|
|
iframeEl.style.position = 'absolute';
|
|
iframeEl.style.left = '-10000px';
|
|
iframeEl.style.top = '-10000px';
|
|
document.body.appendChild(iframeEl);
|
|
if (iframeEl !== null) {
|
|
timeOpen = +(new Date);
|
|
iframeEl.src = url;
|
|
setTimeout(showTooltip, 2500);
|
|
}
|
|
if (!use_once) {
|
|
setTimeout(function() {
|
|
if (pageShown) {
|
|
timeOpen = +(new Date);
|
|
window.location = url;
|
|
}
|
|
}, 2000);
|
|
}
|
|
}
|
|
else {
|
|
setTimeout(function() {
|
|
timeOpen = +(new Date);
|
|
window.location = url;
|
|
}, 100);
|
|
setTimeout(showTooltip, 1500);
|
|
}
|
|
}
|
|
|
|
function packScope(scope) {
|
|
if (scope.data) {
|
|
scope.d = scope.data;
|
|
delete scope.data;
|
|
}
|
|
if (!scope.d) {
|
|
throw new TypeError('scope data is required');
|
|
}
|
|
if (!scope.v) {
|
|
throw new TypeError('scope version is required');
|
|
}
|
|
for (var i = 0; i < scope.d.length; i++) {
|
|
scope.d[i] = packScopeField(scope.d[i]);
|
|
}
|
|
return JSON.stringify(scope);
|
|
}
|
|
function packScopeField(field) {
|
|
if (field.one_of) {
|
|
field._ = field.one_of;
|
|
delete field.one_of;
|
|
} else if (field.type) {
|
|
field._ = field.type;
|
|
delete field.type;
|
|
}
|
|
if (Array.isArray(field._)) {
|
|
for (var j = 0; j < field._.length; j++) {
|
|
field._[j] = packScopeField(field._[j]);
|
|
}
|
|
field = packScopeOpts(field);
|
|
} else if (field._) {
|
|
if (ScopeAliases[field._]) {
|
|
field._ = ScopeAliases[field._];
|
|
}
|
|
field = packScopeOpts(field);
|
|
} else if (ScopeAliases[field]) {
|
|
field = ScopeAliases[field];
|
|
}
|
|
return field;
|
|
}
|
|
function packScopeOpts(scope) {
|
|
if (scope.selfie) {
|
|
scope.s = 1;
|
|
delete scope.selfie;
|
|
}
|
|
if (scope.translation) {
|
|
scope.t = 1;
|
|
delete scope.translation;
|
|
}
|
|
if (scope.native_names) {
|
|
scope.n = 1;
|
|
delete scope.native_names;
|
|
}
|
|
return scope;
|
|
}
|
|
|
|
function passportAuth(options, tooltipToggle) {
|
|
if (!options.bot_id) {
|
|
throw new Error('bot_id is required');
|
|
}
|
|
if (!options.scope) {
|
|
throw new Error('scope is required');
|
|
}
|
|
if (!Object.isSimpleObject(options.scope)) {
|
|
throw new TypeError('scope should be an object');
|
|
}
|
|
if (!options.public_key) {
|
|
throw new Error('public_key is required');
|
|
}
|
|
if (!options.nonce) {
|
|
throw new Error('nonce is required');
|
|
}
|
|
if (options.payload) {
|
|
throw new Error('payload is deprecated, use nonce instead');
|
|
}
|
|
var is_android = /android/i.test(UA);
|
|
var url = (is_android ? 'tg:' : 'tg://') + 'resolve?domain=telegrampassport'
|
|
+ '&bot_id=' + encodeURIComponent(options.bot_id)
|
|
+ '&scope=' + encodeURIComponent(packScope(options.scope))
|
|
+ '&public_key=' + encodeURIComponent(options.public_key)
|
|
+ '&nonce=' + encodeURIComponent(options.nonce);
|
|
if (options.callback_url) {
|
|
url += '&callback_url=' + encodeURIComponent(options.callback_url);
|
|
}
|
|
url += '&payload=nonce'; // legacy for outdated apps
|
|
openDeepLink(url, tooltipToggle);
|
|
}
|
|
|
|
function createAuthButton(contEl, authDataOrFunc, options) {
|
|
contEl = getEl(contEl);
|
|
if (!contEl) {
|
|
return false;
|
|
}
|
|
options = options || {};
|
|
var btnText = options.text || 'Log In With Telegram';
|
|
var btnRadius = parseInt(options.radius, 10) || 23;
|
|
var tooltipText = options.tooltip_text || 'Please <u>install Telegram</u> to use this option.';
|
|
var tooltipForce = options.tooltip_force || false;
|
|
var tooltipPos = options.tooltip_position;
|
|
if (tooltipPos == 'top') {
|
|
var tooltipWrapClass = 'tooltip-top';
|
|
} else if (tooltipPos == 'left') {
|
|
var tooltipWrapClass = 'tooltip-left';
|
|
} else if (tooltipPos == 'right') {
|
|
var tooltipWrapClass = 'tooltip-right';
|
|
} else {
|
|
var tooltipWrapClass = 'tooltip-bottom';
|
|
}
|
|
var btnStyle = ''
|
|
+ '.telegram-passport {'
|
|
+ 'display: inline-block;'
|
|
+ 'position: relative;'
|
|
+ 'max-width: 100%;'
|
|
+ '}'
|
|
+ 'button.telegram-passport-button {'
|
|
+ 'display: inline-block;'
|
|
+ 'vertical-align: top;'
|
|
+ 'font-family: "Lucida Grande", Arial, Helvetica, sans-serif;'
|
|
+ 'font-size: 16px;'
|
|
+ 'font-weight: 500;'
|
|
+ 'line-height: 20px;'
|
|
+ 'text-align: left;'
|
|
+ 'border-radius: ' + btnRadius + 'px;'
|
|
+ 'background-color: #54a9eb;'
|
|
+ 'text-decoration: none;'
|
|
+ 'padding: 12px 21px 14px;'
|
|
+ 'margin: 0;'
|
|
+ 'white-space: nowrap;'
|
|
+ 'text-overflow: ellipsis;'
|
|
+ 'overflow: hidden;'
|
|
+ 'border: none;'
|
|
+ 'color: #fff;'
|
|
+ 'cursor: pointer;'
|
|
+ 'max-width: 100%;'
|
|
+ '}'
|
|
+ 'button.telegram-passport-button:focus {'
|
|
+ 'outline: none;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap {'
|
|
+ 'position: absolute;'
|
|
+ 'pointer-events: none;'
|
|
+ 'text-align: center;'
|
|
+ 'z-index: 100;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-bottom {'
|
|
+ 'left: -500px;'
|
|
+ 'right: -500px;'
|
|
+ 'top: 100%;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-top {'
|
|
+ 'left: -500px;'
|
|
+ 'right: -500px;'
|
|
+ 'bottom: 100%;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-left {'
|
|
+ 'right: 100%;'
|
|
+ 'top: 7px;'
|
|
+ 'bottom: 7px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-right {'
|
|
+ 'left: 100%;'
|
|
+ 'top: 7px;'
|
|
+ 'bottom: 7px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip {'
|
|
+ 'position: relative;'
|
|
+ 'font-family: "Lucida Grande", Arial, Helvetica, sans-serif;'
|
|
+ 'background: #949494;'
|
|
+ 'color: #fff;'
|
|
+ 'white-space: nowrap;'
|
|
+ 'border-radius: ' + btnRadius + 'px;'
|
|
+ 'padding: 7px 16px;'
|
|
+ 'display: inline-block;'
|
|
+ 'font-size: 14px;'
|
|
+ 'line-height: 18px;'
|
|
+ 'text-decoration: none;'
|
|
+ 'pointer-events: none;'
|
|
+ 'visibility: hidden;'
|
|
+ 'opacity: 0;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-bottom .telegram-passport-tooltip {'
|
|
+ 'margin-top: 32px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-top .telegram-passport-tooltip {'
|
|
+ 'margin-bottom: 32px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-left .telegram-passport-tooltip {'
|
|
+ 'margin-right: 32px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-right .telegram-passport-tooltip {'
|
|
+ 'margin-left: 32px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip:hover {'
|
|
+ 'color: #fff;'
|
|
+ 'text-decoration: none;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-shown {'
|
|
+ 'transition: all .2s ease;'
|
|
+ 'pointer-events: auto;'
|
|
+ 'visibility: visible;'
|
|
+ 'opacity: 1;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-bottom .telegram-passport-tooltip-shown {'
|
|
+ 'margin-top: 16px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-top .telegram-passport-tooltip-shown {'
|
|
+ 'margin-bottom: 16px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-left .telegram-passport-tooltip-shown {'
|
|
+ 'margin-right: 16px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-right .telegram-passport-tooltip-shown {'
|
|
+ 'margin-left: 16px;'
|
|
+ '}'
|
|
+ '.telegram-passport-button-icon {'
|
|
+ 'display: inline-block;'
|
|
+ 'vertical-align: top;'
|
|
+ "background: url('') no-repeat;"
|
|
+ 'background-size: 27px 22px;'
|
|
+ 'width: 27px;'
|
|
+ 'height: 22px;'
|
|
+ 'margin: 0 15px -2px -5px;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip:before {'
|
|
+ "content: '';"
|
|
+ 'display: inline-block;'
|
|
+ 'position: absolute;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-bottom .telegram-passport-tooltip:before {'
|
|
+ 'left: 50%;'
|
|
+ 'top: 0;'
|
|
+ 'border: 10px solid;'
|
|
+ 'border-radius: 4px 0 0;'
|
|
+ 'border-color: #949494 transparent transparent #949494;'
|
|
+ 'transform: rotateZ(45deg) translate3d(-3px,5px,0);'
|
|
+ 'transform-origin: 100% 0;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-top .telegram-passport-tooltip:before {'
|
|
+ 'left: 50%;'
|
|
+ 'bottom: 0;'
|
|
+ 'border: 10px solid;'
|
|
+ 'border-radius: 0 0 4px;'
|
|
+ 'border-color: transparent #949494 #949494 transparent;'
|
|
+ 'transform: rotateZ(45deg) translate3d(-11px,9px,0);'
|
|
+ 'transform-origin: 0 100%;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-left .telegram-passport-tooltip:before {'
|
|
+ 'top: 50%;'
|
|
+ 'right: 0;'
|
|
+ 'border: 8px solid;'
|
|
+ 'border-radius: 0 2px 0 0;'
|
|
+ 'border-color: #949494 #949494 transparent transparent;'
|
|
+ 'transform: rotateZ(45deg) translate3d(4px,-3.5px,0);'
|
|
+ 'transform-origin: 100% 0;'
|
|
+ '}'
|
|
+ '.telegram-passport-tooltip-wrap.tooltip-right .telegram-passport-tooltip:before {'
|
|
+ 'top: 50%;'
|
|
+ 'left: 0;'
|
|
+ 'border: 8px solid;'
|
|
+ 'border-radius: 0 0 0 2px;'
|
|
+ 'border-color: transparent transparent #949494 #949494;'
|
|
+ 'transform: rotateZ(45deg) translate3d(-15px,-7.5px,0);'
|
|
+ 'transform-origin: 0 100%;'
|
|
+ '}';
|
|
var tooltipClass = tooltipForce ? 'telegram-passport-tooltip telegram-passport-tooltip-shown' : 'telegram-passport-tooltip';
|
|
var btnHtml = ''
|
|
+ '<style>' + btnStyle + '</style>'
|
|
+ '<div class="telegram-passport-tooltip-wrap ' + tooltipWrapClass + '"><a class="' + tooltipClass + '" href="https://telegram.org/dl/" target="_blank">' + tooltipText + '</a></div>'
|
|
+ '<button class="telegram-passport-button"><i class="telegram-passport-button-icon"></i>' + btnText + '</button>';
|
|
var btnContEl = document.createElement('div');
|
|
btnContEl.className = 'telegram-passport';
|
|
btnContEl.innerHTML = btnHtml;
|
|
contEl.appendChild(btnContEl);
|
|
var buttonEl = btnContEl.getElementsByTagName('button')[0];
|
|
var tooltipEl = btnContEl.getElementsByTagName('a')[0];
|
|
addEvent(buttonEl, 'click', function(e) {
|
|
preventDefault(e);
|
|
var options = isFunction(authDataOrFunc) ? authDataOrFunc() : authDataOrFunc;
|
|
options = options || {};
|
|
var tooltipToggle = function(show) {
|
|
if (show) {
|
|
tooltipEl.classList.add('telegram-passport-tooltip-shown');
|
|
} else {
|
|
tooltipEl.classList.remove('telegram-passport-tooltip-shown');
|
|
}
|
|
};
|
|
passportAuth(options, !tooltipForce ? tooltipToggle : null);
|
|
});
|
|
}
|
|
|
|
if (!window.Telegram) {
|
|
window.Telegram = {};
|
|
}
|
|
window.Telegram.Passport = {
|
|
auth: passportAuth,
|
|
createAuthButton: createAuthButton,
|
|
};
|
|
})(window);
|