2017-01-17 13:22:49 +03:00
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 ) || v ersionIdentifier
}
}
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
2017-01-17 15:25:37 +03:00
* @ param { Boolean } signType -- тип подписи открепленная ( true ) / присоединенная ( false ) ( default : true )
2017-01-17 13:22:49 +03:00
* @ returns { Promise } -- обещание , которое зарезолвится с данными о подписи { String }
* * /
function signData ( hash , dataBase64 , signType ) {
2017-01-17 15:25:37 +03:00
signType = typeof signType === 'undefined' ? true : Boolean ( signType ) ;
2017-01-17 13:22:49 +03:00
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 ,
2017-01-17 15:25:37 +03:00
signType
2017-01-17 13:22:49 +03:00
) ;
} 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