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

Xor-el.CryptoLib4Pascal

Ugochukwu Mmaduekwe b305f05ff0 validate required fields 1 mesiac pred
.github 97402c12c8 Fix memory leaks and ci pipeline (#53) 1 mesiac pred
CryptoLib b305f05ff0 validate required fields 1 mesiac pred
CryptoLib.Samples bdd7a0abad Add PKCS#10 CSR generation with ECDSA and EdDSA support 1 mesiac pred
CryptoLib.Tests bdd7a0abad Add PKCS#10 CSR generation with ECDSA and EdDSA support 1 mesiac pred
.gitignore 5130859868 updated gitignore to support FreePascal and Lazarus. 8 rokov pred
LICENSE bddead3264 update license year 7 rokov pred
README.md 230ccbb503 Closes #13 6 rokov pred

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)

  • KMAC (KMAC128, KMAC256)

Hashes


  • MD2

  • MD4

  • MD5

  • SHA-1

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

  • Gost3411

  • Gost3411-2012 (256, 512)

  • RIPEMD (128, 160, 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 / Tested OSes


Tested OS boxes are checked

    • Windows XP+
    • Linux (Including Android and Raspberry PI)
    • Mac OS X
    • iOS 2.0+
    • (Oracle) Solaris
    • OpenBSD
    • FreeBSD
    • NetBSD
    • DragonFlyBSD

Acknowledgements


Tip Jar


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