diff --git a/html/index.html b/html/index.html index f745d43..bd2b6f2 100644 --- a/html/index.html +++ b/html/index.html @@ -36,8 +36,8 @@
diff --git a/html/script/cadesplugin_api.js b/html/script/cadesplugin_api.js new file mode 100644 index 0000000..bc46069 --- /dev/null +++ b/html/script/cadesplugin_api.js @@ -0,0 +1,757 @@ +/* eslint-disable */ +(function () { + //already loaded + if (window.cadesplugin) return; + + var pluginObject; + var plugin_resolved = 0; + var plugin_reject; + var plugin_resolve; + var isOpera = 0; + var isFireFox = 0; + var isEdge = 0; + var failed_extensions = 0; + + var canPromise = !!window.Promise; + var cadesplugin; + + if (canPromise) { + cadesplugin = new Promise(function (resolve, reject) { + plugin_resolve = resolve; + plugin_reject = reject; + }); + } else { + cadesplugin = {}; + } + + function check_browser() { + var ua = navigator.userAgent, + tem, + M = + ua.match( + /(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i, + ) || []; + if (/trident/i.test(M[1])) { + tem = /\brv[ :]+(\d+)/g.exec(ua) || []; + return { + name: 'IE', + version: tem[1] || '', + }; + } + if (M[1] === 'Chrome') { + tem = ua.match(/\b(OPR|Edge)\/(\d+)/); + if (tem != null) + return { + name: tem[1].replace('OPR', 'Opera'), + version: tem[2], + }; + } + M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, '-?']; + if ((tem = ua.match(/version\/(\d+)/i)) != null) M.splice(1, 1, tem[1]); + return { + name: M[0], + version: M[1], + }; + } + var browserSpecs = check_browser(); + + function cpcsp_console_log(level, msg) { + //IE9 не может писать в консоль если не открыта вкладка developer tools + if (typeof console === 'undefined') return; + if (level <= cadesplugin.current_log_level) { + if (level === cadesplugin.LOG_LEVEL_DEBUG) console.log('DEBUG: %s', msg); + if (level === cadesplugin.LOG_LEVEL_INFO) console.info('INFO: %s', msg); + if (level === cadesplugin.LOG_LEVEL_ERROR) + console.error('ERROR: %s', msg); + return; + } + } + + function set_log_level(level) { + if ( + !( + level === cadesplugin.LOG_LEVEL_DEBUG || + level === cadesplugin.LOG_LEVEL_INFO || + level === cadesplugin.LOG_LEVEL_ERROR + ) + ) { + cpcsp_console_log( + cadesplugin.LOG_LEVEL_ERROR, + 'cadesplugin_api.js: Incorrect log_level: ' + level, + ); + return; + } + cadesplugin.current_log_level = level; + if (cadesplugin.current_log_level === cadesplugin.LOG_LEVEL_DEBUG) + cpcsp_console_log( + cadesplugin.LOG_LEVEL_INFO, + 'cadesplugin_api.js: log_level = DEBUG', + ); + if (cadesplugin.current_log_level === cadesplugin.LOG_LEVEL_INFO) + cpcsp_console_log( + cadesplugin.LOG_LEVEL_INFO, + 'cadesplugin_api.js: log_level = INFO', + ); + if (cadesplugin.current_log_level === cadesplugin.LOG_LEVEL_ERROR) + cpcsp_console_log( + cadesplugin.LOG_LEVEL_INFO, + 'cadesplugin_api.js: log_level = ERROR', + ); + if (isNativeMessageSupported()) { + if (cadesplugin.current_log_level === cadesplugin.LOG_LEVEL_DEBUG) + window.postMessage('set_log_level=debug', '*'); + if (cadesplugin.current_log_level === cadesplugin.LOG_LEVEL_INFO) + window.postMessage('set_log_level=info', '*'); + if (cadesplugin.current_log_level === cadesplugin.LOG_LEVEL_ERROR) + window.postMessage('set_log_level=error', '*'); + } + } + + function set_constantValues() { + cadesplugin.CAPICOM_LOCAL_MACHINE_STORE = 1; + cadesplugin.CAPICOM_CURRENT_USER_STORE = 2; + cadesplugin.CADESCOM_LOCAL_MACHINE_STORE = 1; + cadesplugin.CADESCOM_CURRENT_USER_STORE = 2; + cadesplugin.CADESCOM_CONTAINER_STORE = 100; + + cadesplugin.CAPICOM_MY_STORE = 'My'; + + cadesplugin.CAPICOM_STORE_OPEN_MAXIMUM_ALLOWED = 2; + + cadesplugin.CAPICOM_CERTIFICATE_FIND_SUBJECT_NAME = 1; + + cadesplugin.CADESCOM_XML_SIGNATURE_TYPE_ENVELOPED = 0; + cadesplugin.CADESCOM_XML_SIGNATURE_TYPE_ENVELOPING = 1; + cadesplugin.CADESCOM_XML_SIGNATURE_TYPE_TEMPLATE = 2; + + cadesplugin.XmlDsigGost3410UrlObsolete = + 'http://www.w3.org/2001/04/xmldsig-more#gostr34102001-gostr3411'; + cadesplugin.XmlDsigGost3411UrlObsolete = + 'http://www.w3.org/2001/04/xmldsig-more#gostr3411'; + cadesplugin.XmlDsigGost3410Url = + 'urn:ietf:params:xml:ns:cpxmlsec:algorithms:gostr34102001-gostr3411'; + cadesplugin.XmlDsigGost3411Url = + 'urn:ietf:params:xml:ns:cpxmlsec:algorithms:gostr3411'; + + cadesplugin.CADESCOM_CADES_DEFAULT = 0; + cadesplugin.CADESCOM_CADES_BES = 1; + cadesplugin.CADESCOM_CADES_T = 0x5; + cadesplugin.CADESCOM_CADES_X_LONG_TYPE_1 = 0x5d; + + cadesplugin.CADESCOM_ENCODE_BASE64 = 0; + cadesplugin.CADESCOM_ENCODE_BINARY = 1; + cadesplugin.CADESCOM_ENCODE_ANY = -1; + + cadesplugin.CAPICOM_CERTIFICATE_INCLUDE_CHAIN_EXCEPT_ROOT = 0; + cadesplugin.CAPICOM_CERTIFICATE_INCLUDE_WHOLE_CHAIN = 1; + cadesplugin.CAPICOM_CERTIFICATE_INCLUDE_END_ENTITY_ONLY = 2; + + cadesplugin.CAPICOM_CERT_INFO_SUBJECT_SIMPLE_NAME = 0; + cadesplugin.CAPICOM_CERT_INFO_ISSUER_SIMPLE_NAME = 1; + + cadesplugin.CAPICOM_CERTIFICATE_FIND_SHA1_HASH = 0; + cadesplugin.CAPICOM_CERTIFICATE_FIND_SUBJECT_NAME = 1; + cadesplugin.CAPICOM_CERTIFICATE_FIND_ISSUER_NAME = 2; + cadesplugin.CAPICOM_CERTIFICATE_FIND_ROOT_NAME = 3; + cadesplugin.CAPICOM_CERTIFICATE_FIND_TEMPLATE_NAME = 4; + cadesplugin.CAPICOM_CERTIFICATE_FIND_EXTENSION = 5; + cadesplugin.CAPICOM_CERTIFICATE_FIND_EXTENDED_PROPERTY = 6; + cadesplugin.CAPICOM_CERTIFICATE_FIND_APPLICATION_POLICY = 7; + cadesplugin.CAPICOM_CERTIFICATE_FIND_CERTIFICATE_POLICY = 8; + cadesplugin.CAPICOM_CERTIFICATE_FIND_TIME_VALID = 9; + cadesplugin.CAPICOM_CERTIFICATE_FIND_TIME_NOT_YET_VALID = 10; + cadesplugin.CAPICOM_CERTIFICATE_FIND_TIME_EXPIRED = 11; + cadesplugin.CAPICOM_CERTIFICATE_FIND_KEY_USAGE = 12; + + cadesplugin.CAPICOM_DIGITAL_SIGNATURE_KEY_USAGE = 128; + + cadesplugin.CAPICOM_PROPID_ENHKEY_USAGE = 9; + + cadesplugin.CAPICOM_OID_OTHER = 0; + cadesplugin.CAPICOM_OID_KEY_USAGE_EXTENSION = 10; + + cadesplugin.CAPICOM_EKU_CLIENT_AUTH = 2; + cadesplugin.CAPICOM_EKU_SMARTCARD_LOGON = 5; + cadesplugin.CAPICOM_EKU_OTHER = 0; + + cadesplugin.CAPICOM_AUTHENTICATED_ATTRIBUTE_SIGNING_TIME = 0; + cadesplugin.CADESCOM_AUTHENTICATED_ATTRIBUTE_DOCUMENT_NAME = 1; + cadesplugin.CADESCOM_AUTHENTICATED_ATTRIBUTE_DOCUMENT_DESCRIPTION = 2; + cadesplugin.CADESCOM_ATTRIBUTE_OTHER = -1; + + cadesplugin.CADESCOM_STRING_TO_UCS2LE = 0; + cadesplugin.CADESCOM_BASE64_TO_BINARY = 1; + + cadesplugin.CADESCOM_DISPLAY_DATA_NONE = 0; + cadesplugin.CADESCOM_DISPLAY_DATA_CONTENT = 1; + cadesplugin.CADESCOM_DISPLAY_DATA_ATTRIBUTE = 2; + + cadesplugin.CADESCOM_ENCRYPTION_ALGORITHM_RC2 = 0; + cadesplugin.CADESCOM_ENCRYPTION_ALGORITHM_RC4 = 1; + cadesplugin.CADESCOM_ENCRYPTION_ALGORITHM_DES = 2; + cadesplugin.CADESCOM_ENCRYPTION_ALGORITHM_3DES = 3; + cadesplugin.CADESCOM_ENCRYPTION_ALGORITHM_AES = 4; + cadesplugin.CADESCOM_ENCRYPTION_ALGORITHM_GOST_28147_89 = 25; + + cadesplugin.CADESCOM_HASH_ALGORITHM_SHA1 = 0; + cadesplugin.CADESCOM_HASH_ALGORITHM_MD2 = 1; + cadesplugin.CADESCOM_HASH_ALGORITHM_MD4 = 2; + cadesplugin.CADESCOM_HASH_ALGORITHM_MD5 = 3; + cadesplugin.CADESCOM_HASH_ALGORITHM_SHA_256 = 4; + cadesplugin.CADESCOM_HASH_ALGORITHM_SHA_384 = 5; + cadesplugin.CADESCOM_HASH_ALGORITHM_SHA_512 = 6; + cadesplugin.CADESCOM_HASH_ALGORITHM_CP_GOST_3411 = 100; + cadesplugin.CADESCOM_HASH_ALGORITHM_CP_GOST_3411_2012_256 = 101; + cadesplugin.CADESCOM_HASH_ALGORITHM_CP_GOST_3411_2012_512 = 102; + + cadesplugin.LOG_LEVEL_DEBUG = 4; + cadesplugin.LOG_LEVEL_INFO = 2; + cadesplugin.LOG_LEVEL_ERROR = 1; + + cadesplugin.CADESCOM_AllowNone = 0; + cadesplugin.CADESCOM_AllowNoOutstandingRequest = 0x1; + cadesplugin.CADESCOM_AllowUntrustedCertificate = 0x2; + cadesplugin.CADESCOM_AllowUntrustedRoot = 0x4; + cadesplugin.CADESCOM_SkipInstallToStore = 0x10000000; + } + + function async_spawn(generatorFunc) { + function continuer(verb, arg) { + var result; + try { + result = generator[verb](arg); + } catch (err) { + return Promise.reject(err); + } + if (result.done) { + return result.value; + } else { + return Promise.resolve(result.value).then(onFulfilled, onRejected); + } + } + var generator = generatorFunc(Array.prototype.slice.call(arguments, 1)); + var onFulfilled = continuer.bind(continuer, 'next'); + var onRejected = continuer.bind(continuer, 'throw'); + return onFulfilled(); + } + + function isIE() { + // var retVal = (("Microsoft Internet Explorer" === navigator.appName) || // IE < 11 + // navigator.userAgent.match(/Trident\/./i)); // IE 11 + return browserSpecs.name === 'IE' || browserSpecs.name === 'MSIE'; + } + + function isIOS() { + var retVal = + navigator.userAgent.match(/ipod/i) || + navigator.userAgent.match(/ipad/i) || + navigator.userAgent.match(/iphone/i); + return retVal; + } + + function isNativeMessageSupported() { + // В IE работаем через NPAPI + if (isIE()) return false; + // В Edge работаем через NativeMessage + if (browserSpecs.name === 'Edge') { + isEdge = true; + return true; + } + // В Chrome, Firefox и Opera работаем через асинхронную версию в зависимости от версии + if (browserSpecs.name === 'Opera') { + isOpera = true; + if (browserSpecs.version >= 33) { + return true; + } else { + return false; + } + } + if (browserSpecs.name === 'Firefox') { + isFireFox = true; + if (browserSpecs.version >= 52) { + return true; + } else { + return false; + } + } + if (browserSpecs.name === 'Chrome') { + if (browserSpecs.version >= 42) { + return true; + } else { + return false; + } + } + } + + // Функция активации объектов КриптоПро ЭЦП Browser plug-in + function CreateObject(name) { + if (isIOS()) { + // На iOS для создания объектов используется функция + // call_ru_cryptopro_npcades_10_native_bridge, определенная в IOS_npcades_supp.js + return call_ru_cryptopro_npcades_10_native_bridge('CreateObject', [name]); + } + if (isIE()) { + // В Internet Explorer создаются COM-объекты + if (name.match(/X509Enrollment/i)) { + try { + // Объекты CertEnroll создаются через CX509EnrollmentWebClassFactory + var objCertEnrollClassFactory = document.getElementById( + 'certEnrollClassFactory', + ); + return objCertEnrollClassFactory.CreateObject(name); + } catch (e) { + throw 'Для создания обьектов X509Enrollment следует настроить веб-узел на использование проверки подлинности по протоколу HTTPS'; + } + } + // Объекты CAPICOM и CAdESCOM создаются через CAdESCOM.WebClassFactory + try { + var objWebClassFactory = document.getElementById('webClassFactory'); + return objWebClassFactory.CreateObject(name); + } catch (e) { + // Для версий плагина ниже 2.0.12538 + return new ActiveXObject(name); // eslint-disable-line no-undef + } + } + // создаются объекты NPAPI + return pluginObject.CreateObject(name); + } + + function decimalToHexString(number) { + if (number < 0) { + number = 0xffffffff + number + 1; + } + + return number.toString(16).toUpperCase(); + } + + function GetMessageFromException(e) { + var err = e.message; + if (!err) { + err = e; + } else if (e.number) { + err += ' (0x' + decimalToHexString(e.number) + ')'; + } + return err; + } + + function getLastError(exception) { + if (isNativeMessageSupported() || isIE() || isIOS()) { + return GetMessageFromException(exception); + } + + try { + return pluginObject.getLastError(); + } catch (e) { + return GetMessageFromException(exception); + } + } + + // Функция для удаления созданных объектов + function ReleasePluginObjects() { + return cpcsp_chrome_nmcades.ReleasePluginObjects(); // eslint-disable-line no-undef + } + + // Функция активации асинхронных объектов КриптоПро ЭЦП Browser plug-in + function CreateObjectAsync(name) { + return pluginObject.CreateObjectAsync(name); + } + + //Функции для IOS + var ru_cryptopro_npcades_10_native_bridge = { + callbacksCount: 1, + callbacks: {}, + + // Automatically called by native layer when a result is available + resultForCallback: function resultForCallback(callbackId, resultArray) { + var callback = + ru_cryptopro_npcades_10_native_bridge.callbacks[callbackId]; + if (!callback) return; + callback.apply(null, resultArray); + }, + + // Use this in javascript to request native objective-c code + // functionName : string (I think the name is explicit :p) + // args : array of arguments + // callback : function with n-arguments that is going to be called when the native code returned + call: function call(functionName, args, callback) { + var hasCallback = callback && typeof callback === 'function'; + var callbackId = hasCallback + ? ru_cryptopro_npcades_10_native_bridge.callbacksCount++ + : 0; + + if (hasCallback) + ru_cryptopro_npcades_10_native_bridge.callbacks[callbackId] = callback; + + var iframe = document.createElement('IFRAME'); + var arrObjs = new Array('_CPNP_handle'); + try { + iframe.setAttribute( + 'src', + 'cpnp-js-call:' + + functionName + + ':' + + callbackId + + ':' + + encodeURIComponent(JSON.stringify(args, arrObjs)), + ); + } catch (e) { + alert(e); + } + document.documentElement.appendChild(iframe); + iframe.parentNode.removeChild(iframe); + iframe = null; + }, + }; + + function call_ru_cryptopro_npcades_10_native_bridge(functionName, array) { + var tmpobj; + var ex; + ru_cryptopro_npcades_10_native_bridge.call( + functionName, + array, + function (e, response) { + ex = e; + var str = 'tmpobj=' + response; + eval(str); + if (typeof tmpobj === 'string') { + tmpobj = tmpobj.replace(/\\\n/gm, '\n'); + tmpobj = tmpobj.replace(/\\\r/gm, '\r'); + } + }, + ); + if (ex) throw ex; + return tmpobj; + } + + function show_firefox_missing_extension_dialog() { + if (!window.cadesplugin_skip_extension_install) { + var ovr = document.createElement('div'); + ovr.id = 'cadesplugin_ovr'; + ovr.style = + 'visibility: hidden; position: fixed; left: 0px; top: 0px; width:100%; height:100%; background-color: rgba(0,0,0,0.7)'; + ovr.innerHTML = + "Для работы КриптоПро ЭЦП Browser plugin на данном сайте необходимо расширение для браузера. Убедитесь, что оно у Вас включено или установите его.' + + "
" + + 'Для работы КриптоПро ЭЦП Browser plugin на данном сайте необходимо установить расширение из каталога дополнений Opera.' + + "
" + + '+ Доступ к личному кабинету для юридических лиц осуществляется исключительно через браузеры Яндекс или Chromium gost. +
++ Пожалуйста, попробуйте снова, выбрав один из этих браузеров. +
+