Skip to content

Cryptographic library for Embarcadero Delphi and potentially for FPC as well

License

Notifications You must be signed in to change notification settings

GitCnSH-DSLIN/DelphiEncryptionCompendium

 
 

DEC - Delphi Encryption Compendium

What is DEC?

DEC is a library for Embarcadero Delphi, containing different cryptographic algorithms . It contains algorithms for these categories:

  • Ciphers: encryption/decryption of data
  • Hashes: "cryptographic checksums"
  • Key deviation algorithms like Kdf1-Kdf3
  • A cryptographic pseudo random number generator
  • CRCs: non cryptographic checksums based on CRC algorithms

Which Delphi versions are compatible?

The last released version 5.2 is compatible with Delphi 7-2007 at least. For using it with newer versions some small modification is necessary in order to compile it. If done it is compatible up to 10.2 Tokio at least. This version is only compatible with Win32/Win64!

This version 6.0 is compatible with Delphi 2009 - Delphi 10.4.1 Sydney. When defining the NO_ASM define in DECOptions.inc it is compatible with all platforms! It might be compatible with FPC, but this has not been focus and is not tested.

What is the current status of this project?

After some years of work we finally managed to release V6.0 now. Details about the changes and additions in V6.0 can be found in the DEC60.pdf file in the docs subfolder of the development branch.

In comparison to 5.2 we added some console, VCL and FMX based demo applications. The FMX based demos are even available via Google play as "DEC cipher demo" and "DEC hash demo".

Where can I get further information? For example if I'd like to contribute?

In the root folder of DEC V6.0 you will find further files with information about this project like NOTICE.txt, CONTRIBUTING.md, SECURITY.md. Also take the time to read DEC60.pdf in the Docs folder or look at the demos provided in the Demos subfolder.

Has it been tested?

DEC 5.2 comes with some "arcane" test program testing the algoithms implemented using test data supplied via some text file. For many algorithms this test data stems from official documentation of the algorithms itsself. DEC 5.2 passes these tests.

DEC 6.0 reworked these tests into DUnit and DUnitX tests. We also added some more tests and with this replaced the "arcane" test program which used hard to understand code. A few of the implemented unit tests still fail, but this is simply because they are empty sceletons at this point in time waiting to be filled in. We first need to work out how to implement these tests and maybe look for test data. Why don't you help out by researching useful test data for those few tests?

Contained hash algorithms

  • MD2
  • MD4
  • MD5
  • RipeMD128
  • RipeMD160
  • RipeMD256
  • RipeMD320
  • SHA0
  • SHA1
  • SHA256
  • SHA384
  • SHA512
  • Haval128
  • Haval160
  • Haval192
  • Haval224
  • Haval256
  • Tiger
  • Panama
  • Whirlpool0
  • Whirlpool1
  • WhirlpoolT
  • Square
  • Snefru128
  • Snefru256
  • Sapphire

Contained cipher algorithms

  • Null
  • Blowfish
  • Twofish
  • IDEA
  • Cast256
  • Mars
  • RC4
  • RC6
  • AES
  • Square
  • SCOP
  • Sapphire
  • 1DES
  • 2DES
  • 3DES
  • 2DDES
  • 3DDES
  • 3TDES
  • 3Way
  • Cast128
  • Gost
  • Magma
  • Misty
  • NewDES
  • Q128
  • RC2
  • RC5
  • SAFER
  • Shark
  • Skipjack
  • TEA
  • XTEA
  • TEAN

Contained block concatenating modes

Modes ending on x have been invented by the original developer of DEC

  • ECBx
  • CBCx
  • CTSx
  • CTS3
  • CFB8
  • CFBx
  • OFB8
  • OFBx
  • CFS8
  • CFSx

Contained key deviation algorithms:

  • KDF1
  • KDF2
  • KDF3
  • MGF1

Contained formattings

  • Copy
  • HEX
  • HEXL
  • Base16
  • Base16L
  • DECMIME32
  • Base64
  • MIME64
  • Radix64
  • PGP
  • UU
  • XX
  • ESCAPE

Contained CRCs

  • 8
  • 10
  • 12
  • 16
  • 16CCITT
  • 16XModem
  • 24
  • 32
  • 32CCITT
  • 32ZModem
  • 8ATMHEC
  • 8SMBus
  • 15CAN
  • 16ZMODEM

About

Cryptographic library for Embarcadero Delphi and potentially for FPC as well

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Pascal 60.4%
  • Assembly 39.1%
  • Other 0.5%