123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- import 'dart:typed_data';
- import 'dart:io' as io;
- import 'package:aes_crypt/aes_crypt.dart';
- import 'package:computer/computer.dart';
- import 'package:encrypt/encrypt.dart';
- import 'package:photos/core/configuration.dart';
- import 'package:steel_crypt/steel_crypt.dart' as steel;
- import 'package:uuid/uuid.dart';
- class CryptoUtil {
- static Uint8List getSecureRandomBytes({int length = 32}) {
- return SecureRandom(length).bytes;
- }
- static String getSecureRandomString({int length = 32}) {
- return SecureRandom(length).utf8;
- }
- static Uint8List scrypt(Uint8List plainText, Uint8List salt) {
- return steel.PassCryptRaw.scrypt()
- .hash(salt: salt, plain: plainText, len: 32);
- }
- static Uint8List aesEncrypt(
- Uint8List plainText, Uint8List key, Uint8List iv) {
- final encrypter = AES(Key(key), mode: AESMode.cbc);
- return encrypter
- .encrypt(
- plainText,
- iv: IV(iv),
- )
- .bytes;
- }
- static Uint8List aesDecrypt(
- Uint8List cipherText, Uint8List key, Uint8List iv) {
- final encrypter = AES(Key(key), mode: AESMode.cbc);
- return encrypter.decrypt(
- Encrypted(cipherText),
- iv: IV(iv),
- );
- }
- static Future<String> encryptFileToFile(
- String sourcePath, String destinationPath, String password) async {
- final args = Map<String, dynamic>();
- args["password"] = password;
- args["source"] = sourcePath;
- args["destination"] = destinationPath;
- return Computer().compute(runEncryptFileToFile, param: args);
- }
- static Future<String> encryptDataToFile(
- Uint8List source, String destinationPath, String password) async {
- final args = Map<String, dynamic>();
- args["password"] = password;
- args["source"] = source;
- args["destination"] = destinationPath;
- return Computer().compute(runEncryptDataToFile, param: args);
- }
- static Future<Uint8List> encryptDataToData(
- Uint8List source, String password) async {
- final destinationPath =
- Configuration.instance.getTempDirectory() + Uuid().v4();
- return encryptDataToFile(source, destinationPath, password).then((value) {
- final file = io.File(destinationPath);
- final data = file.readAsBytesSync();
- file.deleteSync();
- return data;
- });
- }
- static Future<void> decryptFileToFile(
- String sourcePath, String destinationPath, String password) async {
- final args = Map<String, dynamic>();
- args["password"] = password;
- args["source"] = sourcePath;
- args["destination"] = destinationPath;
- return Computer().compute(runDecryptFileToFile, param: args);
- }
- static Future<Uint8List> decryptFileToData(
- String sourcePath, String password) {
- final args = Map<String, dynamic>();
- args["password"] = password;
- args["source"] = sourcePath;
- return Computer().compute(runDecryptFileToData, param: args);
- }
- static Future<Uint8List> decryptDataToData(
- Uint8List source, String password) {
- final sourcePath = Configuration.instance.getTempDirectory() + Uuid().v4();
- final file = io.File(sourcePath);
- file.writeAsBytesSync(source);
- return decryptFileToData(sourcePath, password).then((value) {
- file.deleteSync();
- return value;
- });
- }
- }
- Future<String> runEncryptFileToFile(Map<String, dynamic> args) {
- final encrypter = getEncrypter(args["password"]);
- return encrypter.encryptFile(args["source"], args["destination"]);
- }
- Future<String> runEncryptDataToFile(Map<String, dynamic> args) {
- final encrypter = getEncrypter(args["password"]);
- return encrypter.encryptDataToFile(args["source"], args["destination"]);
- }
- Future<String> runDecryptFileToFile(Map<String, dynamic> args) async {
- final encrypter = getEncrypter(args["password"]);
- return encrypter.decryptFile(args["source"], args["destination"]);
- }
- Future<Uint8List> runDecryptFileToData(Map<String, dynamic> args) async {
- final encrypter = getEncrypter(args["password"]);
- return encrypter.decryptDataFromFile(args["source"]);
- }
- AesCrypt getEncrypter(String password) {
- final encrypter = AesCrypt(password);
- encrypter.aesSetMode(AesMode.cbc);
- encrypter.setOverwriteMode(AesCryptOwMode.on);
- return encrypter;
- }
|