26 releases (4 breaking)
new 0.4.4 | Jan 10, 2025 |
---|---|
0.4.2 | Dec 22, 2024 |
0.4.1 | Nov 29, 2024 |
0.1.1 | Jun 23, 2024 |
0.0.4 | Mar 28, 2024 |
#385 in Cryptography
502 downloads per month
Used in 7 crates
(6 directly)
130KB
2.5K
SLoC
rpgpie 🦀️🔐🥧
A higher-level OpenPGP API based on rPGP.
rpgpie is an experimental wrapping API on top of the rPGP library.
Main goals of rpgpie include simplicity, collaboration and fun 🥳.
Objectives of rpgpie
More concretely, rpgpie currently has the following objectives:
- Expose an API to implement stateless OpenPGP (SOP) functionality (see rsop).
- Experiment with applying the terminology and conceptual framing of the "OpenPGP for application developers" documentation.
- Experiment with high level API design for OpenPGP.
- Add a basic policy to rPGP (e.g. to limit accepted algorithms).
Limitations and non-objectives
rpgpie does not currently process messages in an efficient, streaming manner. Messages that are too large to be conveniently processed in RAM can currently not be handled with rpgpie.
The rpgpie API currently limits itself to using certificates (also known as "OpenPGP public keys") and TSKs (also known as "OpenPGP secret/private keys") as they are. Updating or altering certificates or TSKs is currently out of scope.
For the current phase of exploration, proper error handling is not a goal of rpgpie. The code may panic in all kinds of circumstances.
API stability is not a goal in the current phase of development.
Technical Details
Rpgpie implements some higher-order OpenPGP facilities:
-
Certificate-level:
- A policy on cryptographic primitives (to reject use of weak algorithms).
- Asserting validity of individual OpenPGP signature packets.
- Evaluating stacks of OpenPGP signatures (which make statements about the same component) over time.
- OpenPGP semantics guarantees on the certificate level (evaluating self-signature graphs).
-
Message-level:
- Generate/validate data signatures,
- Encrypt/decrypt data.
- Apply a policy for acceptable cryptographic mechanisms.
Warning, early-stage project!
The code in this project is NOT currently intended for production use.
Dependencies
~17–24MB
~324K SLoC