Skip to content

Post-quantum endpoint-to-endpoint encryption for messaging and file-sharing SDK

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

Avarok-Cybersecurity/Citadel-Protocol

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Website shields.io Crates.io codecov Build docs License: MIT License: Apache 2.0 Downloads Upload Coverage Report

🌍 Platform Support

Linux macOS Windows iOS Android Docker

🏰 Citadel Protocol

A post-quantum secure networking protocol that makes developing hyper-secure client-server and P2P applications easy. Built with 100% safe Rust, it provides a robust foundation for creating secure, high-performance network applications with built-in NAT traversal and post-quantum cryptography using a very low memory footprint.

πŸ“‘ Table of Contents

🌟 Key Features

πŸ” Advanced Post-Quantum Security

Multiple Key Encapsulation Mechanism (KEM) families:

  • Kyber (default) - NIST standardized
  • NTRU (Sntrup761)

Novel Multi-layered Security Architecture:

  • Patent-pending multi-layered ratcheting algorithm
  • Per-message re-keying mechanism
  • Multi-layered key exchange protocol
  • Multi-layered encryption with customizable algorithms
  • Encryption algorithms:
    • AES-256-GCM
    • ChaCha20-Poly1305
    • Ascon-80pq
    • Novel Kyber "scramcryption" for enhanced security
  • Customizable Security Modes:
    • True Perfect Forward Secrecy (PFS) mode with advanced ratcheting
    • Best-effort Mode (BEM) for high-throughput scenarios
    • Configurable security levels and algorithm combinations

🌐 Flexible Network Architecture

⚑ Advanced Features

πŸš€ Quick Start

πŸ“‹ Prerequisites

  • Rust toolchain
  • OpenSSL
  • Clang

πŸ“₯ Installation

  1. Add to your Cargo.toml:
[dependencies]
citadel_sdk = "latest_version"
  1. Setup the development environment:
cargo make install

πŸ’» Basic Usage

πŸ–₯️ Server Example

use citadel_sdk::prelude::*;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let server = NodeBuilder::default()
        .with_node_type(NodeType::server("127.0.0.1:25021")?)
        .build(EmptyKernel::default())?;
    
    server.await?;
    Ok(())
}

πŸ“± Client Example

use citadel_sdk::prelude::*;
use futures::StreamExt;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let client_kernel = SingleClientServerConnectionKernel::new_register_defaults(
        "John Doe",
        "john.doe",
        "password",
        "127.0.0.1:25021",
        |connect_success, remote| async move {
            let (sink, mut stream) = connect_success.channel.split();
            while let Some(message) = stream.next().await {
                // Handle incoming messages
            }
            Ok(())
        }
    )?;

    let client = NodeBuilder::default().build(client_kernel)?;
    client.await?;
    Ok(())
}

πŸ”’ Security Architecture

The Citadel Protocol implements a novel multi-layered security approach that goes beyond traditional encryption methods:

πŸ”„ Multi-layered Ratcheting

  • Implements an advanced patent-pending ratcheting algorithm that operates across multiple security layers
  • Each layer maintains its own independent key schedule
  • Provides enhanced forward secrecy by frequently rotating keys at different intervals
  • Resistant against quantum attacks through post-quantum primitives

πŸ›‘οΈ Security Modes

  • True Perfect Forward Secrecy (PFS):
    • Enforces re-keying on a per-message basis
    • Guarantees maximum security for messaging applications
    • Each message uses a new key derived from the previous state
    • Complete forward secrecy at message granularity
  • Best-effort Mode (BEM):
    • Optimized for high-performance scenarios
    • Re-keys as frequently as possible without blocking message transmission
    • Maintains security while prioritizing throughput
    • Ideal for streaming and high-bandwidth applications

πŸ”‘ Multi-layered Key Exchange

  • Multiple independent key exchanges occur simultaneously
  • Combines post-quantum KEMs with traditional algorithms
  • Provides defense in depth against both classical and quantum attacks
  • Configurable algorithm selection for each layer

βš™οΈ Customizable Security Levels

  • Flexible security modes to balance performance and security
  • Perfect Forward Secrecy (PFS) mode with advanced ratcheting
  • Best-effort Mode (BEM) for high-performance requirements
  • Configurable algorithm combinations per security layer

⚑ Threading Modes

The Citadel Protocol provides flexible threading configurations to accommodate different performance requirements and use cases:

Single-Threaded Mode (Default)

  • πŸš€ Optimized for low-latency and minimal resource usage
  • πŸ“‰ Extremely low memory footprint
  • ⚑ Rapid message processing with zero thread context switching
  • 🎯 Ideal for:
    • Edge devices and IoT applications
    • Real-time communication systems
    • Memory-constrained environments
    • Applications prioritizing consistent low latency

Multi-Threaded Mode

  • πŸ”„ Parallel processing for high-throughput scenarios
  • 🌐 Enhanced scalability for concurrent connections
  • πŸ’ͺ Optimal CPU utilization across multiple cores
  • 🎯 Perfect for:
    • Server applications handling numerous concurrent clients
    • High-traffic network services
    • CPU-intensive processing tasks
    • Systems requiring maximum throughput

Enable multi-threaded mode by setting the appropriate feature flag:

[dependencies]
citadel_sdk = { version = "latest_version", features = ["multi-threaded"] }

πŸ“‚ Remote Encrypted Virtual Filesystem

The Remote Encrypted Virtual Filesystem (RE-VFS) is a unique feature that enables secure remote data storage with unprecedented security guarantees:

🌟 Key Features

  • Store encrypted data on any remote node (peer or server)
  • Physical separation of data and decryption keys
  • Requires compromising both storage location and client for data access
  • Perfect for distributed secure storage solutions

πŸ”’ Security Architecture

  • Data is encrypted locally using Kyber public key encryption
  • Decryption key is never stored with the data
  • Uses Kyber scramcryption for minimal ciphertext size
  • Optional multiple encryption layers for enhanced security

🎯 Use Cases

  • Secure cloud storage alternatives
  • Distributed backup systems
  • P2P file sharing with enhanced security
  • Secure document management systems

πŸ’» Example Usage

use citadel_sdk::fs;

async fn store_file(remote: &mut NodeRemote) -> Result<(), Error> {
    // Write file with reinforced security
    fs::write_with_security_level(
        remote,
        "local_file.pdf",
        SecurityLevel::Reinforced,
        "/virtual/path/output.pdf"
    ).await?;

    // Read file back
    let local_path = fs::read(remote, "/virtual/path/output.pdf").await?;
    Ok(())
}

πŸ’Ύ Backend Storage

The Citadel Protocol offers flexible data persistence options to suit various deployment scenarios:

πŸ“ˆ Available Backends

  • πŸ”’ In-Memory Storage:

    • Fastest performance
    • Perfect for temporary sessions
    • Ideal for testing and development
  • πŸ’» Filesystem Backend (default):

    • Persistent storage using local filesystem
    • Automatic file management
    • Suitable for single-node deployments
  • πŸ“ˆ SQL Databases:

    • MySQL: Enterprise-grade reliability
    • PostgreSQL: Advanced features and scalability
    • SQLite: Embedded database option
  • πŸ“ˆ Redis Backend:

    • High-performance caching
    • Distributed deployment support
    • Perfect for session management

πŸ“Š Features

  • Seamless switching between backends
  • Automatic data serialization/deserialization
  • Concurrent access support
  • Transaction support (where applicable)
  • Built-in connection pooling

πŸ“š Documentation

πŸ“œ Patent and Open Source Commitment

The Citadel Protocol's core technology is a patent-pending innovative security architecture that combines multiple novel features into a unique, highly secure communication system. Despite the patent protection, we remain committed to keeping this technology free and open source for the benefit of the entire community. This approach ensures that:

  • The protocol remains freely available for everyone to use
  • The patent serves to protect the technology from being closed-source or restricted
  • Innovation and security improvements can continue to be community-driven
  • The core technology stays accessible while being legally protected from potential abuse

πŸ§ͺ Testing

The project includes comprehensive test suites. Use cargo-make for running tests:

# Install cargo-make
cargo install --force cargo-make

# Run local tests
cargo make test-local

# Run comprehensive tests (requires SQL/Redis setup)
cargo make test

πŸ›‘οΈ Security Considerations

While the Citadel Protocol implements cutting-edge security features:

  • The project is pending third-party security audits
  • Core cryptographic primitives come from verified Open Quantum Safe (OQS) and PQClean projects
  • For maximum security, consider using hybrid cryptography with TLS/QUIC as underlying protocols

🀝 Contributing

Contributions are welcome! Here's how you can help:

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Submit a pull request

Please ensure your code:

  • Follows Rust best practices
  • Includes appropriate tests
  • Is properly documented
  • Passes all CI checks

βš–οΈ License

This project is dual-licensed for maximum permissibility under:

πŸ“ž Contact

πŸ‘₯ Maintainers

About

Post-quantum endpoint-to-endpoint encryption for messaging and file-sharing SDK

Topics

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Security policy

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published

Languages