Herbert Poul
5 years ago
9 changed files with 5 additions and 174 deletions
@ -1,95 +0,0 @@
|
||||
import 'dart:convert'; |
||||
import 'dart:ffi'; |
||||
import 'dart:typed_data'; |
||||
|
||||
import 'package:ffi/ffi.dart'; |
||||
import 'package:ffi_helper/ffi_helper.dart'; |
||||
import 'package:meta/meta.dart'; |
||||
|
||||
// ignore_for_file: non_constant_identifier_names |
||||
typedef Argon2HashNative = Pointer<Utf8> Function( |
||||
Pointer<Uint8> key, |
||||
Uint32 keyLen, |
||||
Pointer<Uint8> salt, |
||||
Uint32 saltlen, |
||||
Uint32 m_cost, // memory cost |
||||
Uint32 t_cost, // time cost (number iterations) |
||||
Uint32 parallelism, |
||||
Uint32 hashlen, |
||||
Uint8 type, |
||||
Uint32 version, |
||||
); |
||||
|
||||
typedef Argon2Hash = Pointer<Utf8> Function( |
||||
Pointer<Uint8> key, |
||||
int keyLen, |
||||
Pointer<Uint8> salt, |
||||
int saltlen, |
||||
int m_cost, // memory cost |
||||
int t_cost, // time cost (number iterations) |
||||
int parallelism, |
||||
int hashlen, |
||||
int type, |
||||
int version, |
||||
); |
||||
|
||||
abstract class Argon2 { |
||||
Uint8List argon2(Argon2Arguments args); |
||||
|
||||
Future<Uint8List> argon2Async(Argon2Arguments args); |
||||
} |
||||
|
||||
class Argon2Arguments { |
||||
Argon2Arguments(this.key, this.salt, this.memory, this.iterations, |
||||
this.length, this.parallelism, this.type, this.version); |
||||
|
||||
final Uint8List key; |
||||
final Uint8List salt; |
||||
final int memory; |
||||
final int iterations; |
||||
final int length; |
||||
final int parallelism; |
||||
final int type; |
||||
final int version; |
||||
} |
||||
|
||||
abstract class Argon2Base extends Argon2 { |
||||
@protected |
||||
Argon2Hash get argon2hash; |
||||
|
||||
@override |
||||
Uint8List argon2(Argon2Arguments args) { |
||||
final keyArray = Uint8Array.fromTypedList(args.key); |
||||
final saltArray = Uint8Array.fromTypedList(args.salt); |
||||
// final saltArray = allocate<Uint8>(count: args.salt.length); |
||||
// final saltList = saltArray.asTypedList(args.length); |
||||
// saltList.setAll(0, args.salt); |
||||
// const memoryCost = 1 << 16; |
||||
|
||||
// _logger.fine('saltArray: ${ByteUtils.toHexList(saltArray.view)}'); |
||||
|
||||
final result = argon2hash( |
||||
keyArray.rawPtr, |
||||
keyArray.length, |
||||
saltArray.rawPtr, |
||||
saltArray.length, |
||||
args.memory, |
||||
args.iterations, |
||||
args.parallelism, |
||||
args.length, |
||||
args.type, |
||||
args.version, |
||||
); |
||||
|
||||
keyArray.free(); |
||||
saltArray.free(); |
||||
// free(saltArray); |
||||
final resultString = Utf8.fromUtf8(result); |
||||
return base64.decode(resultString); |
||||
} |
||||
|
||||
@override |
||||
Future<Uint8List> argon2Async(Argon2Arguments args) async { |
||||
return argon2(args); |
||||
} |
||||
} |
Loading…
Reference in new issue