2023-09-21 13:18:09 +03:00
|
|
|
import { IEncryptionScheme, NodeCryptoProvider } from '@mtcute/core/utils'
|
2022-06-30 16:32:56 +03:00
|
|
|
|
2023-06-05 03:30:48 +03:00
|
|
|
// eslint-disable-next-line camelcase
|
2021-06-06 19:23:43 +03:00
|
|
|
import { ige256_decrypt, ige256_encrypt } from './native'
|
2021-05-01 21:22:20 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Crypto provider for NodeJS that uses a native extension to improve
|
|
|
|
* performance of the IGE mode.
|
|
|
|
*
|
|
|
|
* Other modes are supported natively by OpenSSL, and
|
|
|
|
* they *are* faster than the custom ones.
|
|
|
|
*/
|
|
|
|
export class NodeNativeCryptoProvider extends NodeCryptoProvider {
|
|
|
|
createAesIge(key: Buffer, iv: Buffer): IEncryptionScheme {
|
|
|
|
return {
|
|
|
|
encrypt(data: Buffer): Buffer {
|
|
|
|
return ige256_encrypt(data, key, iv)
|
|
|
|
},
|
|
|
|
decrypt(data: Buffer): Buffer {
|
|
|
|
return ige256_decrypt(data, key, iv)
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|