4 changed files with 121 additions and 206 deletions
@ -1,7 +1,115 @@ |
|||||||
library argon2_ffi_base; |
library argon2_ffi_base; |
||||||
|
|
||||||
/// A Calculator. |
import 'dart:convert'; |
||||||
class Calculator { |
import 'dart:ffi'; |
||||||
/// Returns [value] plus 1. |
|
||||||
int addOne(int value) => value + 1; |
import 'dart:io'; |
||||||
|
import 'dart:typed_data'; |
||||||
|
|
||||||
|
import 'package:ffi/ffi.dart'; |
||||||
|
import 'package:ffi_helper/ffi_helper.dart'; |
||||||
|
|
||||||
|
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, |
||||||
|
IntPtr 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, |
||||||
|
); |
||||||
|
|
||||||
|
class Argon2Ffi { |
||||||
|
int Function(int x, int y) _nativeAdd; |
||||||
|
Argon2Hash argon2hash; |
||||||
|
|
||||||
|
Argon2Ffi() { |
||||||
|
final argon2lib = Platform.isAndroid |
||||||
|
? DynamicLibrary.open('libargon2_ffi.so') |
||||||
|
: Platform.isLinux |
||||||
|
? DynamicLibrary.open('libargon2_ffi_plugin.so') |
||||||
|
: DynamicLibrary.executable(); |
||||||
|
_nativeAdd = argon2lib |
||||||
|
.lookup<NativeFunction<Int32 Function(Int32, Int32)>>('native_add') |
||||||
|
.asFunction(); |
||||||
|
} |
||||||
|
|
||||||
|
int addIt(int x, int y) => _nativeAdd(x, y); |
||||||
|
} |
||||||
|
|
||||||
|
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); |
||||||
|
} |
||||||
} |
} |
||||||
|
@ -1,13 +0,0 @@ |
|||||||
import 'package:flutter_test/flutter_test.dart'; |
|
||||||
|
|
||||||
import 'package:argon2_ffi_base/argon2_ffi_base.dart'; |
|
||||||
|
|
||||||
void main() { |
|
||||||
test('adds one to input values', () { |
|
||||||
final calculator = Calculator(); |
|
||||||
expect(calculator.addOne(2), 3); |
|
||||||
expect(calculator.addOne(-7), -6); |
|
||||||
expect(calculator.addOne(0), 1); |
|
||||||
expect(() => calculator.addOne(null), throwsNoSuchMethodError); |
|
||||||
}); |
|
||||||
} |
|
Loading…
Reference in new issue