7个版本 (重大更新)

0.9.0 2024年4月13日
0.8.0 2024年4月10日
0.7.0 2023年10月4日
0.6.0 2023年10月4日
0.3.0 2023年1月18日

#355 in 网络编程

每月 33 次下载
2 个包中使用(通过 citadel_proto

MIT/Apache

345KB
7K SLoC

Website shields.io crates.io codecov Build docs License: MIT License: Apache 2.0 Slack Linux macOS Windows iOS Android

一种后量子信号协议,使得开发超安全的客户端到服务器和p2p应用变得简单

白皮书

Citadel协议的白皮书可以在以下仓库中找到:[链接](https://github.com/avarok-cybersecurity/citadel-protocol/blob/HEAD/citadel_wire/The_Citadel_Protocol.pdf)。注意:自2022年7月以来,这份白皮书未更新。虽然协议与白皮书中的内容非常相似,但已有所演变。白皮书将在不久的将来与源代码同步。

文档

有关构建应用的示例,请参阅[文档](https://avarok-cybersecurity.github.io/Citadel-Protocol/docs/)

构建说明

编译库需要OpenSSL和Clang。查看.github中的CI文件以获取在裸机编译代码的示例。或者,您可以使用以下命令设置环境:

cargo make install

测试说明

citadel_sdk中运行单元测试时,您必须使用Makefile。Makefile包含与cargo test接口的特殊标志和环境变量。首先,安装cargo make

cargo install --force cargo-make

要本地运行测试(设置简单),运行:

cargo make test-local

要运行需要设置SQL和/或redis服务器的综合测试套件(请查看Makefile.toml中的描述以获取设置环境变量的帮助),运行:

cargo make test

WASM(仅限开发,WIP)

目标三元组 wasm32-wasi 是正在进行的支持工作。以下命令应按顺序执行以编译为wasm。

# Allows execution of `cargo wasi test --package citadel_pqcrypto`
cargo install cargo-wasi
# install wasmtime
curl https://wasmtime.dev/install.sh -sSf | bash
# get the include/build files
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-12/wasi-sysroot-12.0.tar.gz
tar -xvzf wasi-sysroot-12.0.tar.gz
rm wasi-sysroot-12.0.tar.gz
# Set environment variables
export WASI_SDK_DIR="$(pwd)/wasi-sysroot"
export WASMTIME_HOME="$(pwd)/.wasmtime"
export PATH="$WASMTIME_HOME/bin:$PATH"
export RUSTFLAGS="--cfg tokio_unstable"
# If on Mac M1, make sure to use the clang/ar provided by homebrew. Make sure to replace <LATEST_VERSION>
export PATH="/opt/homebrew/Cellar/llvm/<LATEST_VERSION>/bin/:$PATH"
export AR="/opt/homebrew/Cellar/llvm/<LATEST_VERSION>/bin/llvm-ar"
export CC="/opt/homebrew/Cellar/llvm/<LATEST_VERSION>/bin/clang"

此外,在检查/编译时,应启用功能 wasm

免责声明

本项目尚未(尚)由第三方审计。虽然一些底层加密原语来自经过验证的Open Quantum Safe (OQS) 项目和/或PQClean项目,但Kyber库尚未接受审计(然而已通过已知答案测试)。

因此,如果您选择使用此库并承担其使用的风险,我们建议您使用混合加密,通过使用TLS或QUIC作为底层协议来确保该协议至少与椭圆曲线密码学一样安全。

作者

Thomas Braun - 创始人

贡献

欢迎贡献!在过去5年里,我一直是唯一的开发者,需要更多的人来帮助使生态系统繁荣。

依赖项

~5–21MB
~309K SLoC