Skip to content

raw binary representation protocol in swift. and some crypto too.

License

Notifications You must be signed in to change notification settings

tannerdsilva/rawdog

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rawdog

rawdog is a lean, dependency-free* Swift package created to simplify and expedite the binary encoding and decoding process for programming objects.

the primary utility of this library comes in its ability to express statically allocated memoryspace, while automatically handling alignment, endianness, and initialization to and from other types.

in c, the following syntax is common and efficient uint8_t[1024]. in swift, trying to achieve a similar result (unaligned memory allocations with static length) is a nightmare....tuple literals are radically more verbose and notably less flexable than the c equivalent in syntax. this is the swift-specific problem that rawdog solves and builds on, while maintaining a rational but powerful pattern around type strictness and memory safety that Swift syntax is known for.

Documentation

I'm really happy with the structure and clarity of the code itself but documentation coverage is incomplete.

Crypto

rawdog distributes and builds its own source material (in c) for all cryptographic functions, including:

  • blake2 hashing (keyed and unkeyed in all variants)
  • SHA1,256,512 hashing
  • MD5 hashing
  • ed25519 signature scheme
  • curve25519 keys
  • bcrypt blowfish password hashing
  • chachapoly AEAD
  • argon2 KDF

these sources come with a complete suite of tests that tested to pass on x86 and ARM, macOS and Linux. the code is also expected to handle endianness natively, although admittedly I do not have the means of verifying the

Cryptographic Attributions

rawdog cryptography is built on various open source contributions written in c. these references were taken as offered from their original authors in either MIT, ISC, or public domain licenses. All sources obtained have been heavily modified redistributed in this rawdog package with its MIT license.

  • cryptographic sources modified and redistributed in June 2024

    • blake2 hashing - claimed from public domain with test vectors referenced in Swift XCTest. Thank you Jean-Philippe Aumasson, Samuel Neves, Zooko Wilcox-O’Hearn, Christian Winnerlein.

    • curve25519 key pairs with ed25519 signatures - claimed with MIT license with unit tests maintained in modification. Thank you Mehdi Sotoodeh.

    • crypt_blowfish - claimed from public domain with unit tests mainted in modification. Thank you Solar Designer.

    • chacha, poly1305, & chachapoly - claimed with MIT license with unit tests maintained in modification. Thank you Grigori Goronzy.

    • SHA (implementations 1, 256, 512) & MD5 hashing - claimed from public domain with unit tests maintained in modification. Thank you WaterJuice.

    • Argon2 KDF - claimed from public domain with unit tests maintained in modification. Thank you Daniel Dinu, Dmitry Khovratovich, Jean-Philippe Aumasson, and Samuel Neves.

    • hchacha20 - claimed with ISC license with unit tests maintained in modification. Thank you Frank Denis.

Versioning

This project follows the tagging semantics outlined in SemVer 2.0.0.

Requirements

Given the critical use of macros in this suite, rawdog requires Swift language v5.9.0 or above to build and deploy successfully.

License

rawdog and the entirety of its source is offered without warranty or support under the MIT license.

About

raw binary representation protocol in swift. and some crypto too.

Resources

License

Stars

Watchers

Forks

Packages

No packages published