mtcute/packages/crypto-node/src/index.ts

28 lines
892 B
TypeScript
Raw Normal View History

import { NodeCryptoProvider } from '@mtcute/core/src/utils/crypto/node-crypto.js'
import { IEncryptionScheme } from '@mtcute/core/utils.js'
import { native } from './native.cjs'
// eslint-disable-next-line camelcase
const { ige256_decrypt, ige256_encrypt } = native
/**
* 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: Uint8Array, iv: Uint8Array): IEncryptionScheme {
return {
encrypt(data: Uint8Array): Uint8Array {
return ige256_encrypt(data, key, iv)
},
decrypt(data: Uint8Array): Uint8Array {
return ige256_decrypt(data, key, iv)
},
}
}
}