Расшифровывает буфер данных при помощи криптографического алгоритма AES128 ассоциированного с компонентом (Feature). Выполняет проверку лицензионный условий компонента.
Если лицензия ограничена по количеству запусков, то эта функция уменьшает значение счетчика запусков для лицензии.
Флаги шифрования могут применяться дополнительно к выбранному режиму шифрования. Если установлен флаг GRD_NO_COUNTER_DECREMENT, то функция использует другой ключ шифрования и счетчик запусков не уменьшается. Флаг GRD_SOFTWARE_ACCELERATION позволяет значительно ускорить работу функции, т.к. данные будут расшифровываться программным алгоритмом, ключ для которого зависит от компонента.
Если данные шифровались с флагом GRD_NO_COUNTER_DECREMENT, то расшифровывать нужно тоже с ним
Режимы шифрования GRD_EM_CFB и GRD_EM_OFB доступны только при одновременном использовании флага GRD_SOFTWARE_ACCELERATION
Синтаксис
int GRD_API GrdFeatureDecrypt(GrdHandle handle, grd_uint32 dataSize, void* data, grd_uint32 mode, void* context, grd_uint32 contextSize);
Параметры
handle | Дескриптор сеcсии |
dataSize | Размер (в байтах) буфера на зашифрованное сообщение |
data | Указатель на буфер, содержащий зашифрованное сообщение |
mode |
Флаги шифрования:
|
context | Указатель на контекcт GrdAesContext, необходимый для операций шифрования с помощью AES. Может быть NULL |
contextSize | Размер контекста. Должен быть равен sizeof(GrdAesContext). Допускается нулевое значение |