aes256DecryptBytes method
Future<List<int>>
aes256DecryptBytes(
{ - required FlutterAesGcm algorithm,
- required String rawKey,
- required int rawKeyLength,
- required Uint8List data,
- required int iteration,
- required int saltLength,
- required int ivLength,
})
Implementation
Future<List<int>> aes256DecryptBytes({
required FlutterAesGcm algorithm,
required String rawKey,
required int rawKeyLength,
required Uint8List data,
required int iteration,
required int saltLength,
required int ivLength
}) async {
final cText = data;
final salt = cText.sublist(0, saltLength);
final iv = cText.sublist(saltLength, saltLength + ivLength);
final mac = cText.sublist(cText.length - saltLength);
final text = cText.sublist(saltLength + ivLength, cText.length - saltLength);
final key = await _deriveKey(rawKey, rawKeyLength, salt, iteration);
final secretBox = SecretBox(text, nonce: iv, mac: Mac(mac));
final cleartext = await algorithm.decrypt(
secretBox,
secretKey: key,
);
return cleartext;
}