steel_crypt 3.0.0+1 copy "steel_crypt: ^3.0.0+1" to clipboard
steel_crypt: ^3.0.0+1 copied to clipboard

A comprehensive library of high-level, cryptographic APIs. This library supports hashing, password hashing, two-way encryption, MAC authentication, and key/IV generation.

example/example.dart

//This Source Code Form is subject to the terms of the Mozilla Public
//License, v. 2.0. If a copy of the MPL was not distributed with this
//file, You can obtain one at https://mozilla.org/MPL/2.0/.

// © 2021 Aditya Kishore

import 'package:steel_crypt/steel_crypt.dart';

void main() {
  // Generate keys/ivs/nonces
  // --------
  // Key generator
  var keyGen = CryptKey();
  //generate 32 byte key using Fortuna
  var key32 = keyGen.genFortuna(len: 32);
  //generate 16 byte key using Fortuna
  var key16 = keyGen.genFortuna(len: 16);
  //generate iv for AES
  var iv16 = keyGen.genDart(len: 16);
  //generate iv for ChaCha20
  var iv8 = keyGen.genDart(len: 8);

  // Generate cryptography machines
  // --------
  // generated AES encrypter with key + padding
  var aes = AesCrypt(key: key32, padding: PaddingAES.pkcs7);
  // generate ChaCha20/12 encrypter
  var stream = LightCrypt(key: key32, algo: StreamAlgo.chacha20_12);
  // generate Blake2b hasher
  var hasher = HashCrypt(algo: HashAlgo.Blake2b);
  // CMAC AES CBC Hasher
  var mac = MacCrypt(key: key16, type: MacType.CMAC);
  // generate scrypt password hasher
  var passHash = PassCrypt.scrypt();

  // Examples + Debugging
  // --------
  //Print key
  print('Keys:');
  print('key32: $key32 \nkey16: $key16');
  print('');

  //Print IV
  print('IVs:');
  print('For AES/SCrypt: $iv16 \nFor ChaCha20: $iv8');
  print('');

  //SHA-3 512 Hash
  print('SHA-3 512 Hash:');
  var hash = hasher.hash(inp: 'example'); //perform hash
  print(hash);
  print(hasher.check(plain: 'example', hashed: hash)); //perform check
  print('');

  //CMAC AES CBC Hash
  print('CMAC AES CBC Hash:');
  var hash2 = mac.process(inp: 'words'); //perform hash
  print(hash2);
  print(mac.check(plain: 'words', hashed: hash2)); //perform check
  print('');

  //Password (scrypt)
  print('Password hash (scrypt):');
  var hash3 = passHash.hash(salt: iv16, inp: 'words'); //perform hash
  print(hash3);
  print(passHash.check(
      salt: iv16, plain: 'words', hashed: hash3)); //perform check
  print('');

  //12-Round ChaCha20; Symmetric stream cipher
  print('ChaCha20 Symmetric:');
  var crypted3 = stream.encrypt(inp: 'broken', iv: iv8); //encrypt
  print(crypted3);
  print(stream.decrypt(enc: crypted3, iv: iv8)); //decrypt
  print('');

  //AES GCM encryption/decryption
  print('AES Symmetric GCM:');
  var crypted = aes.gcm.encrypt(inp: 'words', iv: iv16); //encrypt
  print(crypted);
  print(aes.gcm.decrypt(enc: crypted, iv: iv16)); //decrypt
  print('');

  //AES CTR; Symmetric stream cipher
  print('AES Symmetric CTR:');
  var crypted2 = aes.ctr.encrypt(inp: 'words', iv: iv16); //Encrypt.
  print(crypted2);
  print(aes.ctr.decrypt(enc: crypted2, iv: iv16)); //Decrypt.
  print('');
}
70
likes
140
pub points
91%
popularity

Publisher

verified publisherkishoredev.live

A comprehensive library of high-level, cryptographic APIs. This library supports hashing, password hashing, two-way encryption, MAC authentication, and key/IV generation.

Repository (GitHub)
View/report issues

Documentation

API reference

License

MPL-2.0 (license)

Dependencies

args, pointycastle

More

Packages that depend on steel_crypt