Crypto for Modern Object Pascal #pascal #lazarus #freepascal #fpc #crypto #hash #cryptography #library

Xor-el.CryptoLib4Pascal

Ugochukwu Mmaduekwe 7bfedf726c getrandom API now works on Android versions >= 9 :) před 6 roky
.github 24a580b232 Update bug_report.md před 7 roky
CryptoLib 7bfedf726c getrandom API now works on Android versions >= 9 :) před 6 roky
CryptoLib.Samples b6689516d9 add support for Diffie–Hellman key exchange před 6 roky
CryptoLib.Tests 3fb0035f84 Merge branch 'master' into travis před 6 roky
.gitignore 5130859868 updated gitignore to support FreePascal and Lazarus. před 8 roky
.travis.install.py 42eb6b0e9c travis build. před 7 roky
.travis.yml 9e1eade1a6 some OSRandom refactorings před 6 roky
LICENSE bddead3264 update license year před 7 roky
README.md b6689516d9 add support for Diffie–Hellman key exchange před 6 roky

README.md

CryptoLib4Pascal: Crypto for Modern Object Pascal License

CryptoLib4Pascal is an Object Pascal cryptographic library released under the permissive MIT License.

CryptoLib4Pascal's goal is to be the best option for cryptography in Object Pascal by offering cryptographic recipes and primitives to Object Pascal developers.

Development is coordinated on GitHub and contributions are welcome. If you need help, please open an issue here.

Available Algorithms

### Symmetric Encryption

Block Ciphers
  • AES (128, 192, and 256)

  • Rijndael

  • Blowfish

  • Speck

Stream Ciphers
  • ChaCha

  • (X)Salsa20

Block Cipher Modes Of Operation

  • ECB

  • CBC

  • CFB

  • CTR

  • CTS

  • OFB

  • SIC

Block Cipher Padding Schemes

  • ISO 10126-2

  • ISO 7816-4

  • Bit (ISO/IEC 9797-1)

  • PKCS#5

  • PKCS#7

  • TBC (Trailing Bit Complement)

  • ANSI X9.23

  • Zero

Asymmetric Cryptography


  • DSA

  • (DET)ECDSA (supported curves: NIST, X9.62, SEC2, Brainpool)

  • ECNR

  • ECSchnorr

  • EdDSA (Ed25519, Ed25519Blake2B)

Key Agreement/Exchange


  • DH

  • ECDH

  • ECDHC

  • X25519

Key Derivation Functions


  • HKDF

  • KDF1

  • KDF2

Password Hashing Schemes (Password Based Key Derivation Functions)

  • PBKDF2

  • Argon2 (2i, 2d and 2id variants)

  • Scrypt

MAC


  • HMAC (all supported hashes)

  • X25519

Hashes


  • MD2

  • MD4

  • MD5

  • SHA-1

  • SHA-2 (224, 256, 384, 512, 512-224, 512-256)

  • Gost3411

  • Gost3411-2012 (256, 512)

  • RIPEMD (128, 256, 256, 320)

  • Tiger

  • WhirlPool

  • Blake2B (160, 256, 384, 512)

  • Blake2S (128, 160, 224, 256)

  • SHA-3 (224, 256, 384, 512)

  • Keccak (224, 256, 288, 384, 512)

XOF (Extendable Output Function)


  • Shake (Shake-128, Shake-256)

Other Useful Things


  • RNG wrappers for system RNG

  • ASN1 Parsing Utilities

  • Base Encoding and Decoding Utilities

Compile-Time Dependencies


Supported Compilers


  • FreePascal 3.2.0+

  • Delphi Tokyo+

Supported OSes


  • Windows XP+

  • Linux (Including Android and Raspberry PI)

  • macOS 10.7+

  • iOS 2.0+

  • FreeBSD, NetBSD, OpenBSD and DragonBSD

Acknowledgements


Tip Jar


  • :dollar: Bitcoin: 1MhFfW7tDuEHQSgie65uJcAfJgCNchGeKf
  • :euro: Ethereum: 0x6c1DC21aeC49A822A4f1E3bf07c623C2C1978a98
  • :pound: Pascalcoin: 345367-40