mirror of
https://github.com/crypto-pro-web/crypto-pro-js.git
synced 2025-04-19 12:03:10 +03:00
81 lines
2.9 KiB
TypeScript
81 lines
2.9 KiB
TypeScript
import { TranscodeEncoding } from 'buffer';
|
||
import { _afterPluginsLoaded } from '../helpers/_afterPluginsLoaded';
|
||
import { _extractMeaningfulErrorMessage } from '../helpers/_extractMeaningfulErrorMessage';
|
||
import { __cadesAsyncToken__, __createCadesPluginObject__, _generateCadesFn } from '../helpers/_generateCadesFn';
|
||
|
||
/** Дополнительные настройки */
|
||
type Options = {
|
||
/**
|
||
* Алгоритм хеширования
|
||
*
|
||
* @defaultValue `cadesplugin.CADESCOM_HASH_ALGORITHM_CP_GOST_3411_2012_256`
|
||
*/
|
||
hashedAlgorithm?: number;
|
||
/**
|
||
* Кодировка сообщения для хеширования
|
||
*
|
||
* @defaultValue `utf8`
|
||
*/
|
||
encoding?: TranscodeEncoding;
|
||
};
|
||
|
||
/**
|
||
* Создает хеш сообщения по ГОСТ Р 34.11-2012 (по умолчанию 256 бит)
|
||
* https://ru.wikipedia.org/wiki/%D0%A1%D1%82%D1%80%D0%B8%D0%B1%D0%BE%D0%B3_(%D1%85%D0%B5%D1%88-%D1%84%D1%83%D0%BD%D0%BA%D1%86%D0%B8%D1%8F)
|
||
*
|
||
* @param unencryptedMessage - сообщение для хеширования
|
||
* @options - дополнительные настройки
|
||
*
|
||
* @returns хеш
|
||
*/
|
||
export const createHash = _afterPluginsLoaded(
|
||
async (unencryptedMessage: string | ArrayBuffer, options?: Options): Promise<string> => {
|
||
const { cadesplugin } = window;
|
||
|
||
return eval(
|
||
_generateCadesFn(function createHash(): string {
|
||
const cadesHashedData = __cadesAsyncToken__ + __createCadesPluginObject__('CAdESCOM.HashedData');
|
||
let messageBase64;
|
||
let hash;
|
||
|
||
try {
|
||
if (options?.encoding && typeof unencryptedMessage === 'string') {
|
||
messageBase64 = Buffer.from(unencryptedMessage, options?.encoding).toString('base64');
|
||
} else {
|
||
messageBase64 = Buffer.from(unencryptedMessage).toString('base64');
|
||
}
|
||
} catch (error) {
|
||
console.error(error);
|
||
|
||
throw new Error('Ошибка при преобразовании сообщения в Base64');
|
||
}
|
||
|
||
try {
|
||
void (
|
||
__cadesAsyncToken__ +
|
||
cadesHashedData.propset_Algorithm(
|
||
options?.hashedAlgorithm ?? cadesplugin.CADESCOM_HASH_ALGORITHM_CP_GOST_3411_2012_256,
|
||
)
|
||
);
|
||
void (__cadesAsyncToken__ + cadesHashedData.propset_DataEncoding(cadesplugin.CADESCOM_BASE64_TO_BINARY));
|
||
void (__cadesAsyncToken__ + cadesHashedData.Hash(messageBase64));
|
||
} catch (error) {
|
||
console.error(error);
|
||
|
||
throw new Error(_extractMeaningfulErrorMessage(error) || 'Ошибка при инициализации хэширования');
|
||
}
|
||
|
||
try {
|
||
hash = __cadesAsyncToken__ + cadesHashedData.Value;
|
||
} catch (error) {
|
||
console.error(error);
|
||
|
||
throw new Error(_extractMeaningfulErrorMessage(error) || 'Ошибка при создании хэша');
|
||
}
|
||
|
||
return hash;
|
||
}),
|
||
);
|
||
},
|
||
);
|