mirror of
https://github.com/crypto-pro-web/crypto-pro-js.git
synced 2025-04-19 12:03:10 +03:00
82 lines
3.5 KiB
TypeScript
82 lines
3.5 KiB
TypeScript
import { CADESCOM_AUTHENTICATED_ATTRIBUTE_SIGNING_TIME } from '../constants';
|
|
import { _afterPluginsLoaded } from '../helpers/_afterPluginsLoaded';
|
|
import { _extractMeaningfulErrorMessage } from '../helpers/_extractMeaningfulErrorMessage';
|
|
import { __cadesAsyncToken__, __createCadesPluginObject__, _generateCadesFn } from '../helpers/_generateCadesFn';
|
|
import { _getCadesCert } from '../helpers/_getCadesCert';
|
|
import { _getDateObj } from '../helpers/_getDateObj';
|
|
|
|
/**
|
|
* Создает подпись base64 строки по отпечатку сертификата
|
|
*
|
|
* @param thumbprint - отпечаток сертификата
|
|
* @param dataBase64 - строковые данные в формате base64
|
|
* @param detachedSignature = true - тип подписи открепленная (true) / присоединенная (false)
|
|
* @returns подпись
|
|
*/
|
|
export const createSignature = _afterPluginsLoaded(
|
|
async (thumbprint: string, dataBase64: string, detachedSignature: boolean = true): Promise<string> => {
|
|
const { cadesplugin } = window;
|
|
const cadesCertificate = await _getCadesCert(thumbprint);
|
|
|
|
return eval(
|
|
_generateCadesFn(function createSignature(): string {
|
|
let cadesAttrs;
|
|
let cadesSignedData;
|
|
let cadesSigner;
|
|
|
|
try {
|
|
cadesAttrs = __cadesAsyncToken__ + __createCadesPluginObject__('CADESCOM.CPAttribute');
|
|
cadesSignedData = __cadesAsyncToken__ + __createCadesPluginObject__('CAdESCOM.CadesSignedData');
|
|
cadesSigner = __cadesAsyncToken__ + __createCadesPluginObject__('CAdESCOM.CPSigner');
|
|
} catch (error) {
|
|
console.error(error);
|
|
|
|
throw new Error(_extractMeaningfulErrorMessage(error) || 'Ошибка при инициализации подписи');
|
|
}
|
|
|
|
const currentTime = _getDateObj(new Date());
|
|
|
|
try {
|
|
void (__cadesAsyncToken__ + cadesAttrs.propset_Name(CADESCOM_AUTHENTICATED_ATTRIBUTE_SIGNING_TIME));
|
|
void (__cadesAsyncToken__ + cadesAttrs.propset_Value(currentTime));
|
|
} catch (error) {
|
|
console.error(error);
|
|
|
|
throw new Error(_extractMeaningfulErrorMessage(error) || 'Ошибка при установке времени подписи');
|
|
}
|
|
|
|
let cadesAuthAttrs;
|
|
|
|
try {
|
|
void (__cadesAsyncToken__ + cadesSigner.propset_Certificate(cadesCertificate));
|
|
cadesAuthAttrs = __cadesAsyncToken__ + cadesSigner.AuthenticatedAttributes2;
|
|
void (__cadesAsyncToken__ + cadesAuthAttrs.Add(cadesAttrs));
|
|
void (__cadesAsyncToken__ + cadesSignedData.propset_ContentEncoding(cadesplugin.CADESCOM_BASE64_TO_BINARY));
|
|
void (__cadesAsyncToken__ + cadesSignedData.propset_Content(dataBase64));
|
|
void (
|
|
__cadesAsyncToken__ + cadesSigner.propset_Options(cadesplugin.CAPICOM_CERTIFICATE_INCLUDE_END_ENTITY_ONLY)
|
|
);
|
|
} catch (error) {
|
|
console.error(error);
|
|
|
|
throw new Error(_extractMeaningfulErrorMessage(error) || 'Ошибка при указании данных для подписи');
|
|
}
|
|
|
|
let signature: string;
|
|
|
|
try {
|
|
signature =
|
|
__cadesAsyncToken__ +
|
|
cadesSignedData.SignCades(cadesSigner, cadesplugin.CADESCOM_CADES_BES, detachedSignature);
|
|
} catch (error) {
|
|
console.error(error);
|
|
|
|
throw new Error(_extractMeaningfulErrorMessage(error) || 'Ошибка при подписании данных');
|
|
}
|
|
|
|
return signature;
|
|
}),
|
|
);
|
|
},
|
|
);
|