mirror of
https://github.com/crypto-pro-web/crypto-pro-js.git
synced 2024-11-24 00:55:00 +03:00
1600 lines
58 KiB
JavaScript
1600 lines
58 KiB
JavaScript
|
webpackJsonpCryptoPro([2],[
|
|||
|
/* 0 */,
|
|||
|
/* 1 */,
|
|||
|
/* 2 */,
|
|||
|
/* 3 */
|
|||
|
/***/ function(module, exports, __webpack_require__) {
|
|||
|
|
|||
|
var bowser = __webpack_require__(4);
|
|||
|
var oids = __webpack_require__(6);
|
|||
|
|
|||
|
var subjectNameTagsTranslations = [
|
|||
|
{possibleNames: ['UnstructuredName'], translation: 'Неструктурированное имя'},
|
|||
|
{possibleNames: ['CN'], translation: 'Владелец'},
|
|||
|
{possibleNames: ['SN'], translation: 'Фамилия'},
|
|||
|
{possibleNames: ['G'], translation: 'Имя Отчество'},
|
|||
|
{possibleNames: ['C'], translation: 'Страна'},
|
|||
|
{possibleNames: ['S'], translation: 'Регион'},
|
|||
|
{possibleNames: ['STREET'], translation: 'Адрес'},
|
|||
|
{possibleNames: ['O'], translation: 'Компания'},
|
|||
|
{possibleNames: ['OU'], translation: 'Отдел/подразделение'},
|
|||
|
{possibleNames: ['T'], translation: 'Должность'},
|
|||
|
{possibleNames: ['ОГРН', 'OGRN'], translation: 'ОГРН'},
|
|||
|
{possibleNames: ['ОГРНИП', 'OGRNIP'], translation: 'ОГРНИП'},
|
|||
|
{possibleNames: ['СНИЛС', 'SNILS'], translation: 'СНИЛС'},
|
|||
|
{possibleNames: ['ИНН', 'INN'], translation: 'ИНН'},
|
|||
|
{possibleNames: ['E'], translation: 'Email'},
|
|||
|
{possibleNames: ['L'], translation: 'Город'}
|
|||
|
],
|
|||
|
|
|||
|
issuerNameTagsTranslations = [
|
|||
|
{possibleNames: ['UnstructuredName'], translation: 'Неструктурированное имя'},
|
|||
|
{possibleNames: ['CN'], translation: 'Удостоверяющий центр'},
|
|||
|
{possibleNames: ['S'], translation: 'Регион'},
|
|||
|
{possibleNames: ['C'], translation: 'Страна'},
|
|||
|
{possibleNames: ['STREET'], translation: 'Адрес'},
|
|||
|
{possibleNames: ['O'], translation: 'Компания'},
|
|||
|
{possibleNames: ['OU'], translation: 'Тип'},
|
|||
|
{possibleNames: ['T'], translation: 'Должность'},
|
|||
|
{possibleNames: ['ОГРН', 'OGRN'], translation: 'ОГРН'},
|
|||
|
{possibleNames: ['ОГРНИП', 'OGRNIP'], translation: 'ОГРНИП'},
|
|||
|
{possibleNames: ['СНИЛС', 'SNILS'], translation: 'СНИЛС'},
|
|||
|
{possibleNames: ['ИНН', 'INN'], translation: 'ИНН'},
|
|||
|
{possibleNames: ['E'], translation: 'Email'},
|
|||
|
{possibleNames: ['L'], translation: 'Город'}
|
|||
|
];
|
|||
|
|
|||
|
/**
|
|||
|
* Парсит информацию из строки с информацией о сертификате
|
|||
|
* */
|
|||
|
function parseCertInfo(tags, infoString) {
|
|||
|
/**
|
|||
|
* Пример входной строки:
|
|||
|
*
|
|||
|
|
|||
|
T=Генеральный директор, UnstructuredName="INN=7811514257/KPP=781101001/OGRN=1127847087884",
|
|||
|
STREET="Крыленко, д.3, лит.Б", CN=Король Анатолий Евгеньевич, G=Анатолий Евгеньевич, SN=Король,
|
|||
|
OU=Администрация, O="ООО ""Аксиома""", L=Санкт-Петербург, S=78 г. Санкт-Петербург, C=RU, E=korol@sferasro.ru,
|
|||
|
INN=007811514257, OGRN=1127847087884, SNILS=11617693460
|
|||
|
|
|||
|
* */
|
|||
|
var result = infoString.match(/([а-яА-Яa-zA-Z0-9\.]+)=(?:("[^"]+?")|(.+?))(?:,|$)/g);
|
|||
|
|
|||
|
if (result) {
|
|||
|
result = result.map(function (group) {
|
|||
|
/**
|
|||
|
* Пример входной строки:
|
|||
|
*
|
|||
|
|
|||
|
UnstructuredName="INN=7811514257/KPP=781101001/OGRN=1127847087884",
|
|||
|
|
|||
|
* */
|
|||
|
var parts = group.match(/^([а-яА-Яa-zA-Z0-9\.]+)=(.+?),?$/),
|
|||
|
title = parts && parts[1],
|
|||
|
descr = parts && parts[2],
|
|||
|
translated = false,
|
|||
|
oidTitle;
|
|||
|
|
|||
|
// Если тайтл содержит ОИД, пытаемся расшифровать
|
|||
|
if (/^OID./.test(title)) {
|
|||
|
oidTitle = title.match(/^OID\.(.*)/);
|
|||
|
|
|||
|
if (oidTitle && oidTitle[1]) {
|
|||
|
oidTitle = oids[oidTitle[1]];
|
|||
|
|
|||
|
if (oidTitle) {
|
|||
|
title = oidTitle;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// Вырезаем лишние кавычки
|
|||
|
descr = descr.replace(/^"(.*)"/, '$1');
|
|||
|
descr = descr.replace(/"{2}/g, '"');
|
|||
|
|
|||
|
tags.some(function (tag) {
|
|||
|
return tag.possibleNames.some(function (possible) {
|
|||
|
var match = possible === title;
|
|||
|
|
|||
|
if (match) {
|
|||
|
title = tag.translation;
|
|||
|
translated = true;
|
|||
|
}
|
|||
|
|
|||
|
return match;
|
|||
|
});
|
|||
|
});
|
|||
|
|
|||
|
return {
|
|||
|
title: title,
|
|||
|
descr: descr,
|
|||
|
translated: translated
|
|||
|
};
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
return result;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Возвращает дату в формате (dd.mm.yyyy hh:mm:ss) из строки, формата, используемого плагином cryptoPro
|
|||
|
* */
|
|||
|
function getReadableDate(date) {
|
|||
|
date = new Date(date);
|
|||
|
|
|||
|
return ([
|
|||
|
date.getDate(),
|
|||
|
date.getMonth() + 1,
|
|||
|
date.getFullYear()
|
|||
|
].join('.') + ' ' + [
|
|||
|
date.getHours(),
|
|||
|
date.getMinutes(),
|
|||
|
date.getSeconds()
|
|||
|
].join(':')).replace(/\b(\d)\b/g, '0$1');
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Преобразует дату для IE
|
|||
|
* */
|
|||
|
function getDateObj(dateObj) {
|
|||
|
return bowser.msie ? dateObj.getVarDate() : dateObj;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Подготавливает информацию о сертификатах
|
|||
|
* */
|
|||
|
function prepareCertsInfo(items) {
|
|||
|
return items.map(function (c) {
|
|||
|
c.name = c.subjectName.match(/CN=(.+?),/);
|
|||
|
|
|||
|
// Удалось ли вытащить Common Name
|
|||
|
if (c.name && c.name[1]) {
|
|||
|
c.name = c.name[1];
|
|||
|
}
|
|||
|
|
|||
|
c.validFrom = getReadableDate(c.validFrom);
|
|||
|
c.validTo = getReadableDate(c.validTo);
|
|||
|
|
|||
|
c.label = c.name + ' (до ' + c.validTo + ')';
|
|||
|
|
|||
|
return c;
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Возвращает расшифрованные ОИД'ы
|
|||
|
* */
|
|||
|
function getDecodedExtendedKeyUsage() {
|
|||
|
var that = this;
|
|||
|
|
|||
|
return new Promise(function (resolve) {
|
|||
|
that.getExtendedKeyUsage().then(function (certOids) {
|
|||
|
resolve(certOids.reduce(function (oidsLst, oid) {
|
|||
|
oid = {
|
|||
|
id: oid,
|
|||
|
descr: oids[oid] || null
|
|||
|
};
|
|||
|
|
|||
|
if (oid.descr) {
|
|||
|
oidsLst.unshift(oid);
|
|||
|
} else {
|
|||
|
oidsLst.push(oid);
|
|||
|
}
|
|||
|
|
|||
|
return oidsLst;
|
|||
|
}, []));
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Проверка наличия ОИД'а(ОИД'ов) у сертификата
|
|||
|
*
|
|||
|
* @param {String|Array} oids - ОИД'ы для проверки
|
|||
|
* @returns {Promise} с отложенным результатом типа {Boolean}
|
|||
|
* */
|
|||
|
function hasExtendedKeyUsage(oids) {
|
|||
|
var that = this;
|
|||
|
|
|||
|
return new Promise(function (resolve) {
|
|||
|
that.getExtendedKeyUsage().then(function (certOids) {
|
|||
|
var result;
|
|||
|
|
|||
|
if (Array.isArray(oids)) {
|
|||
|
result = oids.every(function (oidToCheck) {
|
|||
|
return certOids.some(function (certOid) {
|
|||
|
return certOid === oidToCheck;
|
|||
|
});
|
|||
|
});
|
|||
|
} else {
|
|||
|
result = certOids.some(function (certOid) {
|
|||
|
return certOid === oids;
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
resolve(result);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Выводит информацию о системе пользователя
|
|||
|
* */
|
|||
|
function getEnvInfo() {
|
|||
|
var parsed = bowser._detect(navigator.userAgent),
|
|||
|
info = {
|
|||
|
browserName: parsed.name,
|
|||
|
browserVersion: parsed.version
|
|||
|
};
|
|||
|
|
|||
|
if (parsed.mac) {
|
|||
|
info.os = 'Mac';
|
|||
|
} else if (parsed.windows) {
|
|||
|
info.os = 'Windows';
|
|||
|
} else if (parsed.linux) {
|
|||
|
info.os = 'Linux';
|
|||
|
}
|
|||
|
|
|||
|
return info;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Подходящая ли версия CSP
|
|||
|
* */
|
|||
|
function isValidCSPVersion(version) {
|
|||
|
version = version.match(/\d+?\b(?:\.\d+)?/);
|
|||
|
|
|||
|
return version >= 3.6;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Подходящая ли версия cades плагина
|
|||
|
* */
|
|||
|
function isValidCadesVersion(version) {
|
|||
|
version = version.split('.').reduce(function (verInfo, number, i) {
|
|||
|
if (i === 0) {
|
|||
|
verInfo.major = number;
|
|||
|
} else if (i === 1) {
|
|||
|
verInfo.minor = number;
|
|||
|
} else if (i === 2) {
|
|||
|
verInfo.patch = number;
|
|||
|
}
|
|||
|
|
|||
|
return verInfo;
|
|||
|
}, {});
|
|||
|
|
|||
|
if (version.major < 2) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
return version.patch >= 12438;
|
|||
|
}
|
|||
|
|
|||
|
module.exports = {
|
|||
|
subjectNameTagsTranslations: subjectNameTagsTranslations,
|
|||
|
issuerNameTagsTranslations: issuerNameTagsTranslations,
|
|||
|
parseCertInfo: parseCertInfo,
|
|||
|
getReadableDate: getReadableDate,
|
|||
|
getDateObj: getDateObj,
|
|||
|
prepareCertsInfo: prepareCertsInfo,
|
|||
|
getDecodedExtendedKeyUsage: getDecodedExtendedKeyUsage,
|
|||
|
hasExtendedKeyUsage: hasExtendedKeyUsage,
|
|||
|
getEnvInfo: getEnvInfo,
|
|||
|
isValidCSPVersion: isValidCSPVersion,
|
|||
|
isValidCadesVersion: isValidCadesVersion
|
|||
|
};
|
|||
|
|
|||
|
/***/ },
|
|||
|
/* 4 */
|
|||
|
/***/ function(module, exports, __webpack_require__) {
|
|||
|
|
|||
|
/*!
|
|||
|
* Bowser - a browser detector
|
|||
|
* https://github.com/ded/bowser
|
|||
|
* MIT License | (c) Dustin Diaz 2015
|
|||
|
*/
|
|||
|
|
|||
|
!function (root, name, definition) {
|
|||
|
if (typeof module != 'undefined' && module.exports) module.exports = definition()
|
|||
|
else if (true) __webpack_require__(5)(name, definition)
|
|||
|
else root[name] = definition()
|
|||
|
}(this, 'bowser', function () {
|
|||
|
/**
|
|||
|
* See useragents.js for examples of navigator.userAgent
|
|||
|
*/
|
|||
|
|
|||
|
var t = true
|
|||
|
|
|||
|
function detect(ua) {
|
|||
|
|
|||
|
function getFirstMatch(regex) {
|
|||
|
var match = ua.match(regex);
|
|||
|
return (match && match.length > 1 && match[1]) || '';
|
|||
|
}
|
|||
|
|
|||
|
function getSecondMatch(regex) {
|
|||
|
var match = ua.match(regex);
|
|||
|
return (match && match.length > 1 && match[2]) || '';
|
|||
|
}
|
|||
|
|
|||
|
var iosdevice = getFirstMatch(/(ipod|iphone|ipad)/i).toLowerCase()
|
|||
|
, likeAndroid = /like android/i.test(ua)
|
|||
|
, android = !likeAndroid && /android/i.test(ua)
|
|||
|
, nexusMobile = /nexus\s*[0-6]\s*/i.test(ua)
|
|||
|
, nexusTablet = !nexusMobile && /nexus\s*[0-9]+/i.test(ua)
|
|||
|
, chromeos = /CrOS/.test(ua)
|
|||
|
, silk = /silk/i.test(ua)
|
|||
|
, sailfish = /sailfish/i.test(ua)
|
|||
|
, tizen = /tizen/i.test(ua)
|
|||
|
, webos = /(web|hpw)os/i.test(ua)
|
|||
|
, windowsphone = /windows phone/i.test(ua)
|
|||
|
, samsungBrowser = /SamsungBrowser/i.test(ua)
|
|||
|
, windows = !windowsphone && /windows/i.test(ua)
|
|||
|
, mac = !iosdevice && !silk && /macintosh/i.test(ua)
|
|||
|
, linux = !android && !sailfish && !tizen && !webos && /linux/i.test(ua)
|
|||
|
, edgeVersion = getFirstMatch(/edge\/(\d+(\.\d+)?)/i)
|
|||
|
, versionIdentifier = getFirstMatch(/version\/(\d+(\.\d+)?)/i)
|
|||
|
, tablet = /tablet/i.test(ua)
|
|||
|
, mobile = !tablet && /[^-]mobi/i.test(ua)
|
|||
|
, xbox = /xbox/i.test(ua)
|
|||
|
, result
|
|||
|
|
|||
|
if (/opera/i.test(ua)) {
|
|||
|
// an old Opera
|
|||
|
result = {
|
|||
|
name: 'Opera'
|
|||
|
, opera: t
|
|||
|
, version: versionIdentifier || getFirstMatch(/(?:opera|opr|opios)[\s\/](\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
} else if (/opr|opios/i.test(ua)) {
|
|||
|
// a new Opera
|
|||
|
result = {
|
|||
|
name: 'Opera'
|
|||
|
, opera: t
|
|||
|
, version: getFirstMatch(/(?:opr|opios)[\s\/](\d+(\.\d+)?)/i) || versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/SamsungBrowser/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Samsung Internet for Android'
|
|||
|
, samsungBrowser: t
|
|||
|
, version: versionIdentifier || getFirstMatch(/(?:SamsungBrowser)[\s\/](\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/coast/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Opera Coast'
|
|||
|
, coast: t
|
|||
|
, version: versionIdentifier || getFirstMatch(/(?:coast)[\s\/](\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/yabrowser/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Yandex Browser'
|
|||
|
, yandexbrowser: t
|
|||
|
, version: versionIdentifier || getFirstMatch(/(?:yabrowser)[\s\/](\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/ucbrowser/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'UC Browser'
|
|||
|
, ucbrowser: t
|
|||
|
, version: getFirstMatch(/(?:ucbrowser)[\s\/](\d+(?:\.\d+)+)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/mxios/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Maxthon'
|
|||
|
, maxthon: t
|
|||
|
, version: getFirstMatch(/(?:mxios)[\s\/](\d+(?:\.\d+)+)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/epiphany/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Epiphany'
|
|||
|
, epiphany: t
|
|||
|
, version: getFirstMatch(/(?:epiphany)[\s\/](\d+(?:\.\d+)+)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/puffin/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Puffin'
|
|||
|
, puffin: t
|
|||
|
, version: getFirstMatch(/(?:puffin)[\s\/](\d+(?:\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/sleipnir/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Sleipnir'
|
|||
|
, sleipnir: t
|
|||
|
, version: getFirstMatch(/(?:sleipnir)[\s\/](\d+(?:\.\d+)+)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/k-meleon/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'K-Meleon'
|
|||
|
, kMeleon: t
|
|||
|
, version: getFirstMatch(/(?:k-meleon)[\s\/](\d+(?:\.\d+)+)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (windowsphone) {
|
|||
|
result = {
|
|||
|
name: 'Windows Phone'
|
|||
|
, windowsphone: t
|
|||
|
}
|
|||
|
if (edgeVersion) {
|
|||
|
result.msedge = t
|
|||
|
result.version = edgeVersion
|
|||
|
}
|
|||
|
else {
|
|||
|
result.msie = t
|
|||
|
result.version = getFirstMatch(/iemobile\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/msie|trident/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Internet Explorer'
|
|||
|
, msie: t
|
|||
|
, version: getFirstMatch(/(?:msie |rv:)(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
} else if (chromeos) {
|
|||
|
result = {
|
|||
|
name: 'Chrome'
|
|||
|
, chromeos: t
|
|||
|
, chromeBook: t
|
|||
|
, chrome: t
|
|||
|
, version: getFirstMatch(/(?:chrome|crios|crmo)\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
} else if (/chrome.+? edge/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Microsoft Edge'
|
|||
|
, msedge: t
|
|||
|
, version: edgeVersion
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/vivaldi/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Vivaldi'
|
|||
|
, vivaldi: t
|
|||
|
, version: getFirstMatch(/vivaldi\/(\d+(\.\d+)?)/i) || versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if (sailfish) {
|
|||
|
result = {
|
|||
|
name: 'Sailfish'
|
|||
|
, sailfish: t
|
|||
|
, version: getFirstMatch(/sailfish\s?browser\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/seamonkey\//i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'SeaMonkey'
|
|||
|
, seamonkey: t
|
|||
|
, version: getFirstMatch(/seamonkey\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/firefox|iceweasel|fxios/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Firefox'
|
|||
|
, firefox: t
|
|||
|
, version: getFirstMatch(/(?:firefox|iceweasel|fxios)[ \/](\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
if (/\((mobile|tablet);[^\)]*rv:[\d\.]+\)/i.test(ua)) {
|
|||
|
result.firefoxos = t
|
|||
|
}
|
|||
|
}
|
|||
|
else if (silk) {
|
|||
|
result = {
|
|||
|
name: 'Amazon Silk'
|
|||
|
, silk: t
|
|||
|
, version : getFirstMatch(/silk\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/phantom/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'PhantomJS'
|
|||
|
, phantom: t
|
|||
|
, version: getFirstMatch(/phantomjs\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/slimerjs/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'SlimerJS'
|
|||
|
, slimer: t
|
|||
|
, version: getFirstMatch(/slimerjs\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/blackberry|\bbb\d+/i.test(ua) || /rim\stablet/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'BlackBerry'
|
|||
|
, blackberry: t
|
|||
|
, version: versionIdentifier || getFirstMatch(/blackberry[\d]+\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (webos) {
|
|||
|
result = {
|
|||
|
name: 'WebOS'
|
|||
|
, webos: t
|
|||
|
, version: versionIdentifier || getFirstMatch(/w(?:eb)?osbrowser\/(\d+(\.\d+)?)/i)
|
|||
|
};
|
|||
|
/touchpad\//i.test(ua) && (result.touchpad = t)
|
|||
|
}
|
|||
|
else if (/bada/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Bada'
|
|||
|
, bada: t
|
|||
|
, version: getFirstMatch(/dolfin\/(\d+(\.\d+)?)/i)
|
|||
|
};
|
|||
|
}
|
|||
|
else if (tizen) {
|
|||
|
result = {
|
|||
|
name: 'Tizen'
|
|||
|
, tizen: t
|
|||
|
, version: getFirstMatch(/(?:tizen\s?)?browser\/(\d+(\.\d+)?)/i) || versionIdentifier
|
|||
|
};
|
|||
|
}
|
|||
|
else if (/qupzilla/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'QupZilla'
|
|||
|
, qupzilla: t
|
|||
|
, version: getFirstMatch(/(?:qupzilla)[\s\/](\d+(?:\.\d+)+)/i) || versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/chromium/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Chromium'
|
|||
|
, chromium: t
|
|||
|
, version: getFirstMatch(/(?:chromium)[\s\/](\d+(?:\.\d+)?)/i) || versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/chrome|crios|crmo/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Chrome'
|
|||
|
, chrome: t
|
|||
|
, version: getFirstMatch(/(?:chrome|crios|crmo)\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
}
|
|||
|
else if (android) {
|
|||
|
result = {
|
|||
|
name: 'Android'
|
|||
|
, version: versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if (/safari|applewebkit/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Safari'
|
|||
|
, safari: t
|
|||
|
}
|
|||
|
if (versionIdentifier) {
|
|||
|
result.version = versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if (iosdevice) {
|
|||
|
result = {
|
|||
|
name : iosdevice == 'iphone' ? 'iPhone' : iosdevice == 'ipad' ? 'iPad' : 'iPod'
|
|||
|
}
|
|||
|
// WTF: version is not part of user agent in web apps
|
|||
|
if (versionIdentifier) {
|
|||
|
result.version = versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else if(/googlebot/i.test(ua)) {
|
|||
|
result = {
|
|||
|
name: 'Googlebot'
|
|||
|
, googlebot: t
|
|||
|
, version: getFirstMatch(/googlebot\/(\d+(\.\d+))/i) || versionIdentifier
|
|||
|
}
|
|||
|
}
|
|||
|
else {
|
|||
|
result = {
|
|||
|
name: getFirstMatch(/^(.*)\/(.*) /),
|
|||
|
version: getSecondMatch(/^(.*)\/(.*) /)
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
// set webkit or gecko flag for browsers based on these engines
|
|||
|
if (!result.msedge && /(apple)?webkit/i.test(ua)) {
|
|||
|
if (/(apple)?webkit\/537\.36/i.test(ua)) {
|
|||
|
result.name = result.name || "Blink"
|
|||
|
result.blink = t
|
|||
|
} else {
|
|||
|
result.name = result.name || "Webkit"
|
|||
|
result.webkit = t
|
|||
|
}
|
|||
|
if (!result.version && versionIdentifier) {
|
|||
|
result.version = versionIdentifier
|
|||
|
}
|
|||
|
} else if (!result.opera && /gecko\//i.test(ua)) {
|
|||
|
result.name = result.name || "Gecko"
|
|||
|
result.gecko = t
|
|||
|
result.version = result.version || getFirstMatch(/gecko\/(\d+(\.\d+)?)/i)
|
|||
|
}
|
|||
|
|
|||
|
// set OS flags for platforms that have multiple browsers
|
|||
|
if (!result.windowsphone && !result.msedge && (android || result.silk)) {
|
|||
|
result.android = t
|
|||
|
} else if (!result.windowsphone && !result.msedge && iosdevice) {
|
|||
|
result[iosdevice] = t
|
|||
|
result.ios = t
|
|||
|
} else if (mac) {
|
|||
|
result.mac = t
|
|||
|
} else if (xbox) {
|
|||
|
result.xbox = t
|
|||
|
} else if (windows) {
|
|||
|
result.windows = t
|
|||
|
} else if (linux) {
|
|||
|
result.linux = t
|
|||
|
}
|
|||
|
|
|||
|
// OS version extraction
|
|||
|
var osVersion = '';
|
|||
|
if (result.windowsphone) {
|
|||
|
osVersion = getFirstMatch(/windows phone (?:os)?\s?(\d+(\.\d+)*)/i);
|
|||
|
} else if (iosdevice) {
|
|||
|
osVersion = getFirstMatch(/os (\d+([_\s]\d+)*) like mac os x/i);
|
|||
|
osVersion = osVersion.replace(/[_\s]/g, '.');
|
|||
|
} else if (android) {
|
|||
|
osVersion = getFirstMatch(/android[ \/-](\d+(\.\d+)*)/i);
|
|||
|
} else if (result.webos) {
|
|||
|
osVersion = getFirstMatch(/(?:web|hpw)os\/(\d+(\.\d+)*)/i);
|
|||
|
} else if (result.blackberry) {
|
|||
|
osVersion = getFirstMatch(/rim\stablet\sos\s(\d+(\.\d+)*)/i);
|
|||
|
} else if (result.bada) {
|
|||
|
osVersion = getFirstMatch(/bada\/(\d+(\.\d+)*)/i);
|
|||
|
} else if (result.tizen) {
|
|||
|
osVersion = getFirstMatch(/tizen[\/\s](\d+(\.\d+)*)/i);
|
|||
|
}
|
|||
|
if (osVersion) {
|
|||
|
result.osversion = osVersion;
|
|||
|
}
|
|||
|
|
|||
|
// device type extraction
|
|||
|
var osMajorVersion = osVersion.split('.')[0];
|
|||
|
if (
|
|||
|
tablet
|
|||
|
|| nexusTablet
|
|||
|
|| iosdevice == 'ipad'
|
|||
|
|| (android && (osMajorVersion == 3 || (osMajorVersion >= 4 && !mobile)))
|
|||
|
|| result.silk
|
|||
|
) {
|
|||
|
result.tablet = t
|
|||
|
} else if (
|
|||
|
mobile
|
|||
|
|| iosdevice == 'iphone'
|
|||
|
|| iosdevice == 'ipod'
|
|||
|
|| android
|
|||
|
|| nexusMobile
|
|||
|
|| result.blackberry
|
|||
|
|| result.webos
|
|||
|
|| result.bada
|
|||
|
) {
|
|||
|
result.mobile = t
|
|||
|
}
|
|||
|
|
|||
|
// Graded Browser Support
|
|||
|
// http://developer.yahoo.com/yui/articles/gbs
|
|||
|
if (result.msedge ||
|
|||
|
(result.msie && result.version >= 10) ||
|
|||
|
(result.yandexbrowser && result.version >= 15) ||
|
|||
|
(result.vivaldi && result.version >= 1.0) ||
|
|||
|
(result.chrome && result.version >= 20) ||
|
|||
|
(result.samsungBrowser && result.version >= 4) ||
|
|||
|
(result.firefox && result.version >= 20.0) ||
|
|||
|
(result.safari && result.version >= 6) ||
|
|||
|
(result.opera && result.version >= 10.0) ||
|
|||
|
(result.ios && result.osversion && result.osversion.split(".")[0] >= 6) ||
|
|||
|
(result.blackberry && result.version >= 10.1)
|
|||
|
|| (result.chromium && result.version >= 20)
|
|||
|
) {
|
|||
|
result.a = t;
|
|||
|
}
|
|||
|
else if ((result.msie && result.version < 10) ||
|
|||
|
(result.chrome && result.version < 20) ||
|
|||
|
(result.firefox && result.version < 20.0) ||
|
|||
|
(result.safari && result.version < 6) ||
|
|||
|
(result.opera && result.version < 10.0) ||
|
|||
|
(result.ios && result.osversion && result.osversion.split(".")[0] < 6)
|
|||
|
|| (result.chromium && result.version < 20)
|
|||
|
) {
|
|||
|
result.c = t
|
|||
|
} else result.x = t
|
|||
|
|
|||
|
return result
|
|||
|
}
|
|||
|
|
|||
|
var bowser = detect(typeof navigator !== 'undefined' ? navigator.userAgent || '' : '')
|
|||
|
|
|||
|
bowser.test = function (browserList) {
|
|||
|
for (var i = 0; i < browserList.length; ++i) {
|
|||
|
var browserItem = browserList[i];
|
|||
|
if (typeof browserItem=== 'string') {
|
|||
|
if (browserItem in bowser) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Get version precisions count
|
|||
|
*
|
|||
|
* @example
|
|||
|
* getVersionPrecision("1.10.3") // 3
|
|||
|
*
|
|||
|
* @param {string} version
|
|||
|
* @return {number}
|
|||
|
*/
|
|||
|
function getVersionPrecision(version) {
|
|||
|
return version.split(".").length;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Array::map polyfill
|
|||
|
*
|
|||
|
* @param {Array} arr
|
|||
|
* @param {Function} iterator
|
|||
|
* @return {Array}
|
|||
|
*/
|
|||
|
function map(arr, iterator) {
|
|||
|
var result = [], i;
|
|||
|
if (Array.prototype.map) {
|
|||
|
return Array.prototype.map.call(arr, iterator);
|
|||
|
}
|
|||
|
for (i = 0; i < arr.length; i++) {
|
|||
|
result.push(iterator(arr[i]));
|
|||
|
}
|
|||
|
return result;
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Calculate browser version weight
|
|||
|
*
|
|||
|
* @example
|
|||
|
* compareVersions(['1.10.2.1', '1.8.2.1.90']) // 1
|
|||
|
* compareVersions(['1.010.2.1', '1.09.2.1.90']); // 1
|
|||
|
* compareVersions(['1.10.2.1', '1.10.2.1']); // 0
|
|||
|
* compareVersions(['1.10.2.1', '1.0800.2']); // -1
|
|||
|
*
|
|||
|
* @param {Array<String>} versions versions to compare
|
|||
|
* @return {Number} comparison result
|
|||
|
*/
|
|||
|
function compareVersions(versions) {
|
|||
|
// 1) get common precision for both versions, for example for "10.0" and "9" it should be 2
|
|||
|
var precision = Math.max(getVersionPrecision(versions[0]), getVersionPrecision(versions[1]));
|
|||
|
var chunks = map(versions, function (version) {
|
|||
|
var delta = precision - getVersionPrecision(version);
|
|||
|
|
|||
|
// 2) "9" -> "9.0" (for precision = 2)
|
|||
|
version = version + new Array(delta + 1).join(".0");
|
|||
|
|
|||
|
// 3) "9.0" -> ["000000000"", "000000009"]
|
|||
|
return map(version.split("."), function (chunk) {
|
|||
|
return new Array(20 - chunk.length).join("0") + chunk;
|
|||
|
}).reverse();
|
|||
|
});
|
|||
|
|
|||
|
// iterate in reverse order by reversed chunks array
|
|||
|
while (--precision >= 0) {
|
|||
|
// 4) compare: "000000009" > "000000010" = false (but "9" > "10" = true)
|
|||
|
if (chunks[0][precision] > chunks[1][precision]) {
|
|||
|
return 1;
|
|||
|
}
|
|||
|
else if (chunks[0][precision] === chunks[1][precision]) {
|
|||
|
if (precision === 0) {
|
|||
|
// all version chunks are same
|
|||
|
return 0;
|
|||
|
}
|
|||
|
}
|
|||
|
else {
|
|||
|
return -1;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Check if browser is unsupported
|
|||
|
*
|
|||
|
* @example
|
|||
|
* bowser.isUnsupportedBrowser({
|
|||
|
* msie: "10",
|
|||
|
* firefox: "23",
|
|||
|
* chrome: "29",
|
|||
|
* safari: "5.1",
|
|||
|
* opera: "16",
|
|||
|
* phantom: "534"
|
|||
|
* });
|
|||
|
*
|
|||
|
* @param {Object} minVersions map of minimal version to browser
|
|||
|
* @param {Boolean} [strictMode = false] flag to return false if browser wasn't found in map
|
|||
|
* @param {String} [ua] user agent string
|
|||
|
* @return {Boolean}
|
|||
|
*/
|
|||
|
function isUnsupportedBrowser(minVersions, strictMode, ua) {
|
|||
|
var _bowser = bowser;
|
|||
|
|
|||
|
// make strictMode param optional with ua param usage
|
|||
|
if (typeof strictMode === 'string') {
|
|||
|
ua = strictMode;
|
|||
|
strictMode = void(0);
|
|||
|
}
|
|||
|
|
|||
|
if (strictMode === void(0)) {
|
|||
|
strictMode = false;
|
|||
|
}
|
|||
|
if (ua) {
|
|||
|
_bowser = detect(ua);
|
|||
|
}
|
|||
|
|
|||
|
var version = "" + _bowser.version;
|
|||
|
for (var browser in minVersions) {
|
|||
|
if (minVersions.hasOwnProperty(browser)) {
|
|||
|
if (_bowser[browser]) {
|
|||
|
if (typeof minVersions[browser] !== 'string') {
|
|||
|
throw new Error('Browser version in the minVersion map should be a string: ' + browser + ': ' + String(minVersions));
|
|||
|
}
|
|||
|
|
|||
|
// browser version and min supported version.
|
|||
|
return compareVersions([version, minVersions[browser]]) < 0;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return strictMode; // not found
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Check if browser is supported
|
|||
|
*
|
|||
|
* @param {Object} minVersions map of minimal version to browser
|
|||
|
* @param {Boolean} [strictMode = false] flag to return false if browser wasn't found in map
|
|||
|
* @param {String} [ua] user agent string
|
|||
|
* @return {Boolean}
|
|||
|
*/
|
|||
|
function check(minVersions, strictMode, ua) {
|
|||
|
return !isUnsupportedBrowser(minVersions, strictMode, ua);
|
|||
|
}
|
|||
|
|
|||
|
bowser.isUnsupportedBrowser = isUnsupportedBrowser;
|
|||
|
bowser.compareVersions = compareVersions;
|
|||
|
bowser.check = check;
|
|||
|
|
|||
|
/*
|
|||
|
* Set our detect method to the main bowser object so we can
|
|||
|
* reuse it to test other user agents.
|
|||
|
* This is needed to implement future tests.
|
|||
|
*/
|
|||
|
bowser._detect = detect;
|
|||
|
|
|||
|
return bowser
|
|||
|
});
|
|||
|
|
|||
|
|
|||
|
/***/ },
|
|||
|
/* 5 */
|
|||
|
/***/ function(module, exports) {
|
|||
|
|
|||
|
module.exports = function() { throw new Error("define cannot be used indirect"); };
|
|||
|
|
|||
|
|
|||
|
/***/ },
|
|||
|
/* 6 */
|
|||
|
/***/ function(module, exports) {
|
|||
|
|
|||
|
module.exports = {
|
|||
|
'1.2.840.113549.1.9.2': 'Неструктурированное имя',
|
|||
|
'1.2.643.3.141.1.1': 'РНС ФСС',
|
|||
|
'1.2.643.3.141.1.2': 'КП ФСС',
|
|||
|
'1.2.643.3.131.1.1': 'ИНН',
|
|||
|
'1.3.6.1.5.5.7.3.2': 'Проверка подлинности клиента',
|
|||
|
'1.3.6.1.5.5.7.3.4': 'Защищенная электронная почта',
|
|||
|
'1.2.643.3.8.100.1': 'Сертификат типа "ekey-ГОСТ"',
|
|||
|
'1.2.643.3.8.100.1.1': 'Общее использование в системах ИОК без права заверения финансовых документов',
|
|||
|
'1.2.643.3.8.100.1.2': 'Передача отчетности по ТКС',
|
|||
|
'1.2.643.3.8.100.1.3': 'Оформление взаимных обязательств, соглашений, договоров, актов и т.п.',
|
|||
|
'1.2.643.3.8.100.1.4': 'Внутрикорпоративный документооборот',
|
|||
|
'1.2.643.3.8.100.1.5': 'Использование в системах электронной торговли',
|
|||
|
'1.2.643.3.8.100.1.6': 'Использование в торгово-закупочной системе "ЭЛЕКТРА"',
|
|||
|
'1.2.643.6.2.1.7.2': 'Использование физическим лицом в отношениях, связанных с возникновением, исполнением (осуществлением) и прекращением гражданских прав и обязанностей в отношении инвестиционных паев паевых инвестиционных фондов, в том числе отношения, связанные с учетом и/или фиксацией прав на инвестиционные паи паевых инвестиционных фондов',
|
|||
|
'1.2.643.6.2.1.7.1': 'Использование единоличным исполнительным органом юридического лица или уполномоченными представителями юридического лица в отношениях, связанных с возникновением, исполнением (осуществлением) и прекращением гражданских и иных прав и обязанностей в сфере негосударственного пенсионного обеспечения, негосударственного пенсионного страхования, в сфере деятельности паевых инвестиционных фондов, акционерных инвестиционных фондов, профессиональных участников рынка ценных бумаг, а также связанной с обслуживанием указанной деятельности услуг кредитных и иных организаций',
|
|||
|
'1.3.6.1.4.1.29919.21': 'Использование в системе Портал государственных закупок Ростовской области "Рефери".',
|
|||
|
'1.2.643.3.2.100.65.13.11': 'Использование в системе АИС "Госзакупки" Сахалинской области.',
|
|||
|
'1.2.643.3.8.100.1.7': 'Использование в системе Портал государственных закупок Ставропольского края.',
|
|||
|
'1.2.643.3.8.100.1.8': 'Использование в Единой системе электронной торговли B2B-Center и B2G.',
|
|||
|
'1.2.643.3.8.100.1.9': 'Для участия в электронных торгах и подписания государственного контракта в электронной площадке ОАО «ЕЭТП» уполномоченными лицами участников размещения государственного или муниципального заказа',
|
|||
|
'1.2.643.3.8.100.1.10': 'Для участия в электронных торгах и подписания государственного контракта в информационных системах Тендерного комитета города Москвы уполномоченными лицами участников размещения государственного заказа города Москвы',
|
|||
|
'1.2.643.3.8.100.1.11': 'Подписание электронных документов в автоматизированной информационной системе размещения государственного и муниципального заказа Саратовской области',
|
|||
|
'1.2.643.3.8.100.1.12': 'Использование в системе государственного заказа Иркутской области',
|
|||
|
'1.2.643.3.8.100.1.13': 'Использование в электронной торговой площадке агентства государственного заказа Красноярского края',
|
|||
|
'1.3.6.1.4.1.24138.1.1.8.1': 'Обеспечение юридической значимости в Системе "Электронная Торговая Площадка"',
|
|||
|
'1.2.643.3.8.100.1.14': 'Использование в электронной торговой площадке "Тендер"',
|
|||
|
'1.2.643.6.3': 'Использование в электронных торговых системах и в программном обеспечении, связанным с обменом электронных сообщений',
|
|||
|
'1.2.643.2.2.34.6': 'Пользователь Центра Регистрации',
|
|||
|
'1.2.643.2.39.1.1': 'Использование в программных продуктах системы "1С:Предприятие 8"',
|
|||
|
'1.2.643.5.1.24.2.1.3': 'Формирование документов для получения государственных услуг в сфере ведения государственного кадастра недвижимости со стороны заявителя',
|
|||
|
'1.2.643.5.1.24.2.1.3.1': 'Формирование кадастровым инженером документов для получения государственных услуг в сфере ведения государственного кадастра недвижимости со стороны заявителя',
|
|||
|
'1.2.643.5.1.24.2.2.2': 'Формирование документов как результата оказания услуги со стороны органов регистрации прав',
|
|||
|
'1.2.643.5.1.24.2.2.3': 'Формирование документов для получения государственных услуг в сфере государственной регистрации прав на недвижимое имущество и сделок с ним со стороны заявителя',
|
|||
|
'1.2.643.6.3.1.1': 'Использование на электронных площадок отобранных для проведения аукционах в электронной форме',
|
|||
|
'1.2.643.6.3.1.2.1': 'Тип участника - Юридическое лицо',
|
|||
|
'1.2.643.6.3.1.2.2': 'Тип участника - Физическое лицо',
|
|||
|
'1.2.643.6.3.1.2.3': 'Тип участника - Индивидуальный предприниматель',
|
|||
|
'1.2.643.6.3.1.3.1': 'Участник размещения заказа',
|
|||
|
'1.2.643.6.3.1.4.1': 'Администратор организации',
|
|||
|
'1.2.643.6.3.1.4.2': 'Уполномоченный специалист',
|
|||
|
'1.2.643.6.3.1.4.3': 'Специалист с правом подписи контракта',
|
|||
|
'1.3.643.3.8.100.15': 'Использование в ЭТП "uTender"'
|
|||
|
};
|
|||
|
|
|||
|
/***/ },
|
|||
|
/* 7 */
|
|||
|
/***/ function(module, exports) {
|
|||
|
|
|||
|
module.exports = {
|
|||
|
// CAPICOM_STORE_LOCATION enumeration
|
|||
|
StoreLocation: {
|
|||
|
CAPICOM_MEMORY_STORE: 0,
|
|||
|
CAPICOM_LOCAL_MACHINE_STORE: 1,
|
|||
|
CAPICOM_CURRENT_USER_STORE: 2,
|
|||
|
CAPICOM_ACTIVE_DIRECTORY_USER_STORE: 3,
|
|||
|
CAPICOM_SMART_CARD_USER_STORE: 4
|
|||
|
},
|
|||
|
// CAPICOM_STORE_OPEN_MODE enumeration
|
|||
|
StoreOpenMode: {
|
|||
|
CAPICOM_STORE_OPEN_READ_ONLY: 0,
|
|||
|
CAPICOM_STORE_OPEN_READ_WRITE: 1,
|
|||
|
CAPICOM_STORE_OPEN_MAXIMUM_ALLOWED: 2,
|
|||
|
CAPICOM_STORE_OPEN_EXISTING_ONLY: 128,
|
|||
|
CAPICOM_STORE_OPEN_INCLUDE_ARCHIVED: 256
|
|||
|
},
|
|||
|
// CAPICOM_CERTIFICATE_FIND_TYPE enumeration
|
|||
|
CertFindType: {
|
|||
|
CAPICOM_CERTIFICATE_FIND_SHA1_HASH: 0,
|
|||
|
CAPICOM_CERTIFICATE_FIND_SUBJECT_NAME: 1,
|
|||
|
CAPICOM_CERTIFICATE_FIND_ISSUER_NAME: 2,
|
|||
|
CAPICOM_CERTIFICATE_FIND_ROOT_NAME: 3,
|
|||
|
CAPICOM_CERTIFICATE_FIND_TEMPLATE_NAME: 4,
|
|||
|
CAPICOM_CERTIFICATE_FIND_EXTENSION: 5,
|
|||
|
CAPICOM_CERTIFICATE_FIND_EXTENDED_PROPERTY: 6,
|
|||
|
CAPICOM_CERTIFICATE_FIND_APPLICATION_POLICY: 7,
|
|||
|
CAPICOM_CERTIFICATE_FIND_CERTIFICATE_POLICY: 8,
|
|||
|
CAPICOM_CERTIFICATE_FIND_TIME_VALID: 9,
|
|||
|
CAPICOM_CERTIFICATE_FIND_TIME_NOT_YET_VALID: 10,
|
|||
|
CAPICOM_CERTIFICATE_FIND_TIME_EXPIRED: 11,
|
|||
|
CAPICOM_CERTIFICATE_FIND_KEY_USAGE: 12
|
|||
|
},
|
|||
|
Time: {
|
|||
|
AUTHENTICATED_ATTRIBUTE_SIGNING_TIME: 0
|
|||
|
},
|
|||
|
Check: {
|
|||
|
CHECK_NONE: 0,
|
|||
|
CHECK_TRUSTED_ROOT: 1,
|
|||
|
CHECK_TIME_VALIDITY: 2,
|
|||
|
CHECK_SIGNATURE_VALIDITY: 4,
|
|||
|
CHECK_ONLINE_REVOCATION_STATUS: 8,
|
|||
|
CHECK_OFFLINE_REVOCATION_STATUS: 16,
|
|||
|
TRUST_IS_NOT_TIME_VALID: 1,
|
|||
|
TRUST_IS_NOT_TIME_NESTED: 2,
|
|||
|
TRUST_IS_REVOKED: 4,
|
|||
|
TRUST_IS_NOT_SIGNATURE_VALID: 8,
|
|||
|
TRUST_IS_NOT_VALID_FOR_USAGE: 16,
|
|||
|
TRUST_IS_UNTRUSTED_ROOT: 32,
|
|||
|
TRUST_REVOCATION_STATUS_UNKNOWN: 64,
|
|||
|
TRUST_IS_CYCLIC: 128,
|
|||
|
TRUST_IS_PARTIAL_CHAIN: 65536,
|
|||
|
TRUST_CTL_IS_NOT_TIME_VALID: 131072,
|
|||
|
TRUST_CTL_IS_NOT_SIGNATURE_VALID: 262144,
|
|||
|
TRUST_CTL_IS_NOT_VALID_FOR_USAGE: 524288,
|
|||
|
},
|
|||
|
// CAPICOM_PROPID enumeration
|
|||
|
PropId: {
|
|||
|
CAPICOM_PROPID_UNKNOWN: 0,
|
|||
|
CAPICOM_PROPID_KEY_PROV_HANDLE: 1,
|
|||
|
CAPICOM_PROPID_KEY_PROV_INFO: 2,
|
|||
|
CAPICOM_PROPID_SHA1_HASH: 3,
|
|||
|
CAPICOM_PROPID_HASH_PROP: 3,
|
|||
|
CAPICOM_PROPID_MD5_HASH: 4,
|
|||
|
CAPICOM_PROPID_KEY_CONTEXT: 5,
|
|||
|
CAPICOM_PROPID_KEY_SPEC: 6,
|
|||
|
CAPICOM_PROPID_IE30_RESERVED: 7,
|
|||
|
CAPICOM_PROPID_PUBKEY_HASH_RESERVED: 8,
|
|||
|
CAPICOM_PROPID_ENHKEY_USAGE: 9,
|
|||
|
CAPICOM_PROPID_CTL_USAGE: 9,
|
|||
|
CAPICOM_PROPID_NEXT_UPDATE_LOCATION: 10,
|
|||
|
CAPICOM_PROPID_FRIENDLY_NAME: 11,
|
|||
|
CAPICOM_PROPID_PVK_FILE: 12,
|
|||
|
CAPICOM_PROPID_DESCRIPTION: 13,
|
|||
|
CAPICOM_PROPID_ACCESS_STATE: 14,
|
|||
|
CAPICOM_PROPID_SIGNATURE_HASH: 15,
|
|||
|
CAPICOM_PROPID_SMART_CARD_DATA: 16,
|
|||
|
CAPICOM_PROPID_EFS: 17,
|
|||
|
CAPICOM_PROPID_FORTEZZA_DATA: 18,
|
|||
|
CAPICOM_PROPID_ARCHIVED: 19,
|
|||
|
CAPICOM_PROPID_KEY_IDENTIFIER: 20,
|
|||
|
CAPICOM_PROPID_AUTO_ENROLL: 21,
|
|||
|
CAPICOM_PROPID_PUBKEY_ALG_PARA: 22,
|
|||
|
CAPICOM_PROPID_CROSS_CERT_DIST_POINTS: 23,
|
|||
|
CAPICOM_PROPID_ISSUER_PUBLIC_KEY_MD5_HASH: 24,
|
|||
|
CAPICOM_PROPID_SUBJECT_PUBLIC_KEY_MD5_HASH: 25,
|
|||
|
CAPICOM_PROPID_ENROLLMENT: 26,
|
|||
|
CAPICOM_PROPID_DATE_STAMP: 27,
|
|||
|
CAPICOM_PROPID_ISSUER_SERIAL_NUMBER_MD5_HASH: 28,
|
|||
|
CAPICOM_PROPID_SUBJECT_NAME_MD5_HASH: 29,
|
|||
|
CAPICOM_PROPID_EXTENDED_ERROR_INFO: 30,
|
|||
|
CAPICOM_PROPID_RENEWAL: 64,
|
|||
|
CAPICOM_PROPID_ARCHIVED_KEY_HASH: 65,
|
|||
|
CAPICOM_PROPID_FIRST_RESERVED: 66,
|
|||
|
CAPICOM_PROPID_LAST_RESERVED: 0x00007FFF,
|
|||
|
CAPICOM_PROPID_FIRST_USER: 0x00008000,
|
|||
|
CAPICOM_PROPID_LAST_USER: 0x0000FFFF
|
|||
|
},
|
|||
|
// CADESCOM_XML_SIGNATURE_TYPE enumeration
|
|||
|
SignatureType: {
|
|||
|
CADESCOM_XML_SIGNATURE_TYPE_ENVELOPED: 0,
|
|||
|
CADESCOM_XML_SIGNATURE_TYPE_ENVELOPING: 1,
|
|||
|
CADESCOM_XML_SIGNATURE_TYPE_TEMPLATE: 2
|
|||
|
},
|
|||
|
// CADESCOM_HASH_ALGORITHM enumeration
|
|||
|
HashAlgorithm: {
|
|||
|
CADESCOM_HASH_ALGORITHM_CP_GOST_3411: 100,
|
|||
|
CADESCOM_HASH_ALGORITHM_MD2: 1,
|
|||
|
CADESCOM_HASH_ALGORITHM_MD4: 2,
|
|||
|
CADESCOM_HASH_ALGORITHM_MD5: 3,
|
|||
|
CADESCOM_HASH_ALGORITHM_SHA_256: 4,
|
|||
|
CADESCOM_HASH_ALGORITHM_SHA_384: 5,
|
|||
|
CADESCOM_HASH_ALGORITHM_SHA_512: 6,
|
|||
|
CADESCOM_HASH_ALGORITHM_SHA1: 0
|
|||
|
},
|
|||
|
CadesType: {
|
|||
|
CADESCOM_CADES_DEFAULT: 0,
|
|||
|
CADESCOM_CADES_BES: 1,
|
|||
|
CADESCOM_CADES_X_LONG_TYPE_1: 0x5d
|
|||
|
},
|
|||
|
ContentEncoding: {
|
|||
|
CADESCOM_BASE64_TO_BINARY: 0x01,
|
|||
|
CADESCOM_STRING_TO_UCS2LE: 0x00
|
|||
|
},
|
|||
|
StoreNames: {
|
|||
|
CAPICOM_MY_STORE: 'My'
|
|||
|
},
|
|||
|
Chain: {
|
|||
|
CAPICOM_CERTIFICATE_INCLUDE_CHAIN_EXCEPT_ROOT: 0,
|
|||
|
CAPICOM_CERTIFICATE_INCLUDE_WHOLE_CHAIN: 1,
|
|||
|
CAPICOM_CERTIFICATE_INCLUDE_END_ENTITY_ONLY: 2
|
|||
|
},
|
|||
|
GostXmlDSigUrls: {
|
|||
|
XmlDsigGost3410Url: 'urn:ietf:params:xml:ns:cpxmlsec:algorithms:gostr34102001-gostr3411',
|
|||
|
XmlDsigGost3411Url: 'urn:ietf:params:xml:ns:cpxmlsec:algorithms:gostr3411',
|
|||
|
XmlDsigGost3410UrlObsolete: 'http://www.w3.org/2001/04/xmldsig-more#gostr34102001-gostr3411',
|
|||
|
XmlDsigGost3411UrlObsolete: 'http://www.w3.org/2001/04/xmldsig-more#gostr3411'
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
/***/ },
|
|||
|
/* 8 */
|
|||
|
/***/ function(module, exports, __webpack_require__) {
|
|||
|
|
|||
|
var cryptoCommon = __webpack_require__(3),
|
|||
|
cryptoConstants = __webpack_require__(7),
|
|||
|
|
|||
|
_certProto = {
|
|||
|
/**
|
|||
|
* Проверяет, валиден ли сертификат
|
|||
|
* */
|
|||
|
isValid: function isValid() {
|
|||
|
var cert = this._cert;
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var result;
|
|||
|
|
|||
|
try {
|
|||
|
result = cert.IsValid();
|
|||
|
result = result.Result;
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при проверке сертификата: ', err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(result);
|
|||
|
});
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Достает указанное свойство у сертификата
|
|||
|
* */
|
|||
|
getProp: function (propName) {
|
|||
|
var cert = this._cert;
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var result;
|
|||
|
|
|||
|
try {
|
|||
|
result = cert[propName];
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при обращении к свойству сертификата: ', err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(result);
|
|||
|
});
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Экспорт base64 представления сертификата пользователя
|
|||
|
* */
|
|||
|
exportBase64: function exportBase64() {
|
|||
|
var cert = this._cert;
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var base64;
|
|||
|
|
|||
|
try {
|
|||
|
base64 = cert.Export(0);
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при экспорте сертификата: ', err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(base64);
|
|||
|
});
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Возвращает информацию об алгоритме
|
|||
|
* */
|
|||
|
getAlgorithm: function getAlgorithm() {
|
|||
|
var cert = this._cert;
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var result = {},
|
|||
|
algorithm;
|
|||
|
|
|||
|
try {
|
|||
|
algorithm = cert.PublicKey();
|
|||
|
algorithm = algorithm.Algorithm;
|
|||
|
|
|||
|
result.algorithm = algorithm.FriendlyName;
|
|||
|
result.oid = algorithm.Value;
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при получении алгоритма: ', err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(result);
|
|||
|
});
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Разбирает SubjectName сертификата по тэгам
|
|||
|
* */
|
|||
|
getOwnerInfo: function getOwnerInfo() {
|
|||
|
return getCertInfo.call(this, cryptoCommon.subjectNameTagsTranslations, 'SubjectName');
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Разбирает IssuerName сертификата по тэгам
|
|||
|
* */
|
|||
|
getIssuerInfo: function getIssuerInfo() {
|
|||
|
return getCertInfo.call(this, cryptoCommon.issuerNameTagsTranslations, 'IssuerName');
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* Получение OID сертификата
|
|||
|
* Возвращает массив OID (улучшенного ключа)
|
|||
|
* */
|
|||
|
getExtendedKeyUsage: function getExtendedKeyUsage() {
|
|||
|
var cert = this._cert;
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var OIDS = [],
|
|||
|
count,
|
|||
|
item;
|
|||
|
|
|||
|
try {
|
|||
|
count = cert.ExtendedKeyUsage();
|
|||
|
count = count.EKUs;
|
|||
|
count = count.Count;
|
|||
|
|
|||
|
if (count > 0) {
|
|||
|
while (count > 0) {
|
|||
|
item = cert.ExtendedKeyUsage();
|
|||
|
item = item.EKUs;
|
|||
|
item = item.Item(count);
|
|||
|
item = item.OID;
|
|||
|
|
|||
|
OIDS.push(item);
|
|||
|
|
|||
|
count--;
|
|||
|
}
|
|||
|
}
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при получении ОИД\'ов: ', err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(OIDS);
|
|||
|
});
|
|||
|
},
|
|||
|
|
|||
|
getDecodedExtendedKeyUsage: cryptoCommon.getDecodedExtendedKeyUsage,
|
|||
|
|
|||
|
hasExtendedKeyUsage: cryptoCommon.hasExtendedKeyUsage
|
|||
|
},
|
|||
|
|
|||
|
_certListCache;
|
|||
|
|
|||
|
/**
|
|||
|
* Проверяет корректность настроек ЭП на машине
|
|||
|
* */
|
|||
|
function isValidEDSSettings() {
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var result;
|
|||
|
|
|||
|
try {
|
|||
|
result = cadesplugin.CreateObject('CAdESCOM.About');
|
|||
|
} catch (error) {
|
|||
|
reject('Настройки ЭП на данной машине не верны');
|
|||
|
}
|
|||
|
|
|||
|
resolve();
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Получить сертификат в формате cades по хэшу
|
|||
|
* */
|
|||
|
function getCadesCert(hash) {
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var oStore = cadesplugin.CreateObject('CAdESCOM.Store'),
|
|||
|
certs,
|
|||
|
certCnt,
|
|||
|
cert;
|
|||
|
|
|||
|
if (!oStore) {
|
|||
|
reject('Не удалось получить доступ к хранилищу сертификатов');
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// Открываем хранилище
|
|||
|
try {
|
|||
|
oStore.Open(
|
|||
|
cadesplugin.CAPICOM_CURRENT_USER_STORE,
|
|||
|
cadesplugin.CAPICOM_MY_STORE,
|
|||
|
cadesplugin.CAPICOM_STORE_OPEN_MAXIMUM_ALLOWED
|
|||
|
);
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при открытии хранилища: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// Получаем доступ к сертификатам
|
|||
|
try {
|
|||
|
certs = oStore.Certificates;
|
|||
|
certCnt = certs.Count;
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка получения списка сертификатов: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (!certCnt) {
|
|||
|
reject('Нет доступных сертификатов');
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// Получаем сертификат по хэшу
|
|||
|
try {
|
|||
|
certs = certs.Find(cadesplugin.CAPICOM_CERTIFICATE_FIND_SHA1_HASH, hash);
|
|||
|
|
|||
|
if (certs.Count) {
|
|||
|
cert = certs.Item(1);
|
|||
|
} else {
|
|||
|
throw new Error('Нет доступных сертификатов');
|
|||
|
}
|
|||
|
} catch (err) {
|
|||
|
reject('Не удалось получить сертификат по хэшу: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
oStore.Close();
|
|||
|
|
|||
|
resolve(cert);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Разбирает информацию сертификата по тэгам
|
|||
|
* */
|
|||
|
function getCertInfo(tags, propName) {
|
|||
|
var cert = this._cert;
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var propInfo;
|
|||
|
|
|||
|
try {
|
|||
|
propInfo = cert[propName];
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при извлечении данных из сертификата: ', err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(cryptoCommon.parseCertInfo(tags, propInfo));
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Возвращает список сертификатов, доступных в системе
|
|||
|
*
|
|||
|
* @param {Boolean} [resetCache=false] -- нужно ли сбросить кэш списка сертификатов
|
|||
|
* @returns {Promise} -- со списком сертификатов {Array}
|
|||
|
* */
|
|||
|
function getCertsList(resetCache) {
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
if (!resetCache && _certListCache) {
|
|||
|
resolve(_certListCache);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var oStore = cadesplugin.CreateObject('CAdESCOM.Store'),
|
|||
|
result = [],
|
|||
|
certs,
|
|||
|
count,
|
|||
|
item;
|
|||
|
|
|||
|
// Открываем хранилище
|
|||
|
try {
|
|||
|
oStore.Open(
|
|||
|
cadesplugin.CAPICOM_CURRENT_USER_STORE,
|
|||
|
cadesplugin.CAPICOM_MY_STORE,
|
|||
|
cadesplugin.CAPICOM_STORE_OPEN_MAXIMUM_ALLOWED
|
|||
|
);
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при открытии хранилища: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// Получаем доступ к сертификатам
|
|||
|
try {
|
|||
|
certs = oStore.Certificates;
|
|||
|
|
|||
|
if (certs) {
|
|||
|
certs = certs.Find(cadesplugin.CAPICOM_CERTIFICATE_FIND_TIME_VALID);
|
|||
|
/**
|
|||
|
* Не рассматриваются сертификаты, в которых отсутствует закрытый ключ
|
|||
|
* или не действительны на данный момент
|
|||
|
* */
|
|||
|
certs = certs.Find(
|
|||
|
cadesplugin.CAPICOM_CERTIFICATE_FIND_EXTENDED_PROPERTY,
|
|||
|
cryptoConstants.PropId.CAPICOM_PROPID_KEY_PROV_INFO
|
|||
|
);
|
|||
|
|
|||
|
count = certs.Count;
|
|||
|
}
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка получения списка сертификатов: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (!count) {
|
|||
|
reject('Нет доступных сертификатов');
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
try {
|
|||
|
while (count) {
|
|||
|
item = certs.Item(count);
|
|||
|
|
|||
|
result.push(Object.assign(Object.create(_certProto), {
|
|||
|
_cert: item,
|
|||
|
thumbprint: item.Thumbprint,
|
|||
|
subjectName: item.SubjectName,
|
|||
|
issuerName: item.IssuerName,
|
|||
|
validFrom: item.ValidFromDate,
|
|||
|
validTo: item.ValidToDate
|
|||
|
}));
|
|||
|
|
|||
|
count--;
|
|||
|
}
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка обработки сертификатов: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
oStore.Close();
|
|||
|
|
|||
|
_certListCache = cryptoCommon.prepareCertsInfo(result);
|
|||
|
|
|||
|
resolve(_certListCache);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Получить сертификат по хэшу
|
|||
|
* */
|
|||
|
function getCert(hash) {
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
if (!hash) {
|
|||
|
reject('Хэш не указан');
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
getCertsList().then(function (list) {
|
|||
|
var foundCert;
|
|||
|
|
|||
|
list.some(function (cert) {
|
|||
|
if (hash === cert.thumbprint) {
|
|||
|
foundCert = cert;
|
|||
|
return true;
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
if (foundCert) {
|
|||
|
resolve(foundCert);
|
|||
|
} else {
|
|||
|
reject('Сертификат с хэшем: "' + hash + '" не найден');
|
|||
|
}
|
|||
|
}, reject);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Создает подпись base64 строки по hash'у сертификата
|
|||
|
*
|
|||
|
* @param {String} hash -- fingerprint (thumbprint) сертификата
|
|||
|
* @param {String} dataBase64 -- строковые данные в формате base64
|
|||
|
* @param {String} signType -- тип подписи открепленная (true) / присоединенная (false) (default: false)
|
|||
|
* @returns {Promise} -- обещание, которое зарезолвится с данными о подписи {String}
|
|||
|
* */
|
|||
|
function signData(hash, dataBase64, signType) {
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
getCadesCert(hash).then(function (cert) {
|
|||
|
var clientTime = new Date(),
|
|||
|
oAttrs = cadesplugin.CreateObject('CADESCOM.CPAttribute'),
|
|||
|
oSignedData = cadesplugin.CreateObject('CAdESCOM.CadesSignedData'),
|
|||
|
oSigner = cadesplugin.CreateObject('CAdESCOM.CPSigner'),
|
|||
|
attrs,
|
|||
|
signature;
|
|||
|
|
|||
|
clientTime = cryptoCommon.getDateObj(clientTime);
|
|||
|
|
|||
|
try {
|
|||
|
oAttrs.Name = cryptoConstants.Time.AUTHENTICATED_ATTRIBUTE_SIGNING_TIME;
|
|||
|
oAttrs.Value = clientTime;
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при установке данных подписи: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// Задаем настройки для подписи
|
|||
|
try {
|
|||
|
oSigner.Certificate = cert;
|
|||
|
attrs = oSigner.AuthenticatedAttributes2;
|
|||
|
attrs.Add(oAttrs);
|
|||
|
oSignedData.ContentEncoding = cadesplugin.CADESCOM_BASE64_TO_BINARY;
|
|||
|
oSignedData.Content = dataBase64;
|
|||
|
oSigner.Options = cadesplugin.CAPICOM_CERTIFICATE_INCLUDE_END_ENTITY_ONLY;
|
|||
|
} catch (err) {
|
|||
|
reject('Не удалось установить настройки для подписи: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
try {
|
|||
|
signature = oSignedData.SignCades(
|
|||
|
oSigner,
|
|||
|
cadesplugin.CADESCOM_CADES_BES,
|
|||
|
Boolean(signType)
|
|||
|
);
|
|||
|
} catch (err) {
|
|||
|
reject('Не удалось создать подпись: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(signature);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Создает подпись XML строки по hash'у сертификата
|
|||
|
*
|
|||
|
* @param {String} hash -- fingerprint (thumbprint) сертификата
|
|||
|
* @param {String} dataXML -- данные в формате XML
|
|||
|
* @returns {Promise} -- обещание, которое зарезолвится с данными о подписи {String}
|
|||
|
* */
|
|||
|
function signDataXML(hash, dataXML) {
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
getCadesCert(hash).then(function (cert) {
|
|||
|
var oSigner = cadesplugin.CreateObject('CAdESCOM.CPSigner'),
|
|||
|
signerXML = cadesplugin.CreateObject('CAdESCOM.SignedXML'),
|
|||
|
cnts = cryptoConstants,
|
|||
|
signature;
|
|||
|
|
|||
|
// Задаем настройки для подписи
|
|||
|
try {
|
|||
|
oSigner.Certificate = cert;
|
|||
|
// Добавляем данные для подписи
|
|||
|
signerXML.Content = dataXML;
|
|||
|
// Устанавливаем тип подписи
|
|||
|
signerXML.SignatureType = cnts.SignatureType.CADESCOM_XML_SIGNATURE_TYPE_ENVELOPED;
|
|||
|
// Устанавливаем алгоритм подписи
|
|||
|
signerXML.SignatureMethod = cnts.GostXmlDSigUrls.XmlDsigGost3410Url;
|
|||
|
// Устанавливаем алгоритм хэширования
|
|||
|
signerXML.DigestMethod = cnts.GostXmlDSigUrls.XmlDsigGost3411Url;
|
|||
|
} catch (err) {
|
|||
|
reject('Не удалось установить настройки для подписи: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
try {
|
|||
|
signature = signerXML.Sign(oSigner);
|
|||
|
} catch (err) {
|
|||
|
reject('Не удалось создать подпись: ' + err.message);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
resolve(signature);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Возвращает информацию о версии CSP и плагина
|
|||
|
* */
|
|||
|
function getSystemInfo() {
|
|||
|
var sysInfo = cryptoCommon.getEnvInfo();
|
|||
|
|
|||
|
return new Promise(function (resolve, reject) {
|
|||
|
var e;
|
|||
|
|
|||
|
try {
|
|||
|
e = cadesplugin.CreateObject('CAdESCOM.About');
|
|||
|
|
|||
|
sysInfo.cadesVersion = e.PluginVersion;
|
|||
|
// Возможен вызов в ранних версиях в виде sysInfo.cspVersion = e.CSPVersion('', 75);
|
|||
|
sysInfo.cspVersion = e.CSPVersion();
|
|||
|
|
|||
|
if (!sysInfo.cadesVersion) {
|
|||
|
sysInfo.cadesVersion = e.Version;
|
|||
|
}
|
|||
|
|
|||
|
sysInfo.cadesVersion = sysInfo.cadesVersion.toString();
|
|||
|
sysInfo.cspVersion = sysInfo.cspVersion.toString();
|
|||
|
|
|||
|
resolve(sysInfo);
|
|||
|
} catch (err) {
|
|||
|
reject('Ошибка при получении информации о системе: ', err.message);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Promise обертка для синхронного вызова проверки версии CSP
|
|||
|
* */
|
|||
|
function isValidCSPVersion(version) {
|
|||
|
return new Promise(function (resolve) {
|
|||
|
resolve(cryptoCommon.isValidCSPVersion(version));
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/**
|
|||
|
* Promise обертка для синхронного вызова проверки версии плагина
|
|||
|
* */
|
|||
|
function isValidCadesVersion(version) {
|
|||
|
return new Promise(function (resolve) {
|
|||
|
resolve(cryptoCommon.isValidCadesVersion(version));
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
module.exports = {
|
|||
|
isValidEDSSettings: isValidEDSSettings,
|
|||
|
getCertsList: getCertsList,
|
|||
|
getCert: getCert,
|
|||
|
signData: signData,
|
|||
|
signDataXML: signDataXML,
|
|||
|
getSystemInfo: getSystemInfo,
|
|||
|
isValidCSPVersion: isValidCSPVersion,
|
|||
|
isValidCadesVersion: isValidCadesVersion
|
|||
|
};
|
|||
|
|
|||
|
/***/ }
|
|||
|
]);
|
|||
|
//# sourceMappingURL=2.crypto-pro.js.map
|