Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(bindings/s2n-tls): add ja-3 apis #4009

Merged
merged 32 commits into from
Jun 16, 2023
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
4ddd06f
add fingerprint bindings
jmayclin May 4, 2023
de79ca8
add feature and initial client hello struct
jmayclin May 5, 2023
819c1a2
error handling and more test cases
jmayclin May 8, 2023
65d6041
switch to wrapper type implementation
jmayclin May 9, 2023
39d8f63
document safety assumptions and add doc test for borrow check
jmayclin May 10, 2023
0ff66be
clean up pair generation and add test case for io
jmayclin May 11, 2023
d96b0b1
make apis fallible
jmayclin May 11, 2023
83a8a97
remove autogenerated files from git repo
jmayclin May 11, 2023
1d47daf
gate behind feature flag
jmayclin May 11, 2023
5c0b7ae
add cargo test feature dry run with findgerprint
jmayclin May 11, 2023
2f62ffe
add debug impl
jmayclin May 16, 2023
01c2e59
cargo fmt and update ja3 comments
jmayclin May 16, 2023
1cb1856
add deref_mut_ptr method
jmayclin May 16, 2023
1055ca2
add positive example for doc test
jmayclin May 16, 2023
e9915a0
format with nightly toolchain
jmayclin May 16, 2023
532177d
make unstable headers visible
jmayclin May 16, 2023
c6f5026
PR feedback
jmayclin May 24, 2023
e4d0689
PR feedback
jmayclin May 24, 2023
d9e8ecf
Merge branch 'main' into ja-3-bindings
jmayclin May 25, 2023
794cdd1
update for necessary application changes after rebase
jmayclin May 25, 2023
545674a
remove unnecessary feature module
jmayclin May 25, 2023
f3a56e1
pr feedback
jmayclin May 25, 2023
97372f7
Update bindings/rust/s2n-tls/src/client_hello.rs
jmayclin May 31, 2023
8de0bfb
Update bindings/rust/s2n-tls/src/client_hello.rs
jmayclin May 31, 2023
f850c92
Address PR feedback
jmayclin May 31, 2023
b520dce
Update bindings/rust/s2n-tls/src/client_hello.rs
jmayclin May 31, 2023
3db016f
remove duplicate comments
jmayclin May 31, 2023
192eec3
Merge branch 'main' into ja-3-bindings
jmayclin Jun 6, 2023
6c98496
Merge branch 'main' into ja-3-bindings
jmayclin Jun 14, 2023
18b2f2e
PR feedback
jmayclin Jun 15, 2023
f0bfe29
Merge branch 'main' into ja-3-bindings
jmayclin Jun 15, 2023
9ea2a79
Merge branch 'main' into ja-3-bindings
jmayclin Jun 15, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/ci_rust.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,13 +37,13 @@ jobs:

- name: Tests
working-directory: ${{env.ROOT_PATH}}
run: cargo test
run: cargo test --all-features

- name: Test external build
if: ${{ matrix.os == 'ubuntu-latest' }}
run: |
cmake . -Bbuild -DBUILD_SHARED_LIBS=on -DBUILD_TESTING=off
cmake --build build
cmake --build build -j $(nproc)

export S2N_TLS_LIB_DIR=`pwd`/build/lib
export S2N_TLS_INCLUDE_DIR=`pwd`/api
Expand Down
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -284,7 +284,7 @@ endif ()
if(BUILD_TESTING AND BUILD_SHARED_LIBS)
target_compile_options(${PROJECT_NAME} PRIVATE -fvisibility=default)
else()
target_compile_options(${PROJECT_NAME} PRIVATE -fvisibility=hidden -DS2N_EXPORTS)
target_compile_options(${PROJECT_NAME} PRIVATE -fvisibility=default -DS2N_EXPORTS)
jmayclin marked this conversation as resolved.
Show resolved Hide resolved
endif()

if(S2N_LTO)
Expand Down
2 changes: 2 additions & 0 deletions bindings/rust/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,7 @@ Cargo.lock
s2n-tls-sys/files.rs
s2n-tls-sys/lib
s2n-tls-sys/src/api.rs
s2n-tls-sys/src/fingerprint.rs
s2n-tls-sys/src/internal.rs
s2n-tls-sys/src/quic.rs
s2n-tls-sys/src/tests.rs
7 changes: 4 additions & 3 deletions bindings/rust/generate.sh
Original file line number Diff line number Diff line change
Expand Up @@ -36,16 +36,17 @@ cp -r \
# generate the bindings modules from the copied sources
pushd generate
cargo run -- ../s2n-tls-sys
popd
popd

# make sure everything builds and passes sanity checks
pushd s2n-tls-sys
cargo test
cargo test --features fingerprint
cargo test --features internal
cargo test --features pq
cargo test --features quic
cargo test --features internal
cargo test --release
cargo publish --dry-run --allow-dirty
cargo publish --dry-run --allow-dirty
cargo publish --dry-run --allow-dirty --all-features
popd

Expand Down
19 changes: 19 additions & 0 deletions bindings/rust/generate/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,25 @@ fn main() {
.write_to_file(out_dir.join("src/internal.rs"))
.unwrap();

gen_bindings(
"#include \"unstable/fingerprint.h\"",
&out_dir.join("lib"),
functions.with_feature(Some("fingerprint")),
)
.allowlist_type("s2n_fingerprint_type")
.allowlist_function("s2n_client_hello_get_fingerprint.*")
.allowlist_function("s2n_client_hello_parse_message")
.allowlist_function("s2n_client_hello_free")
// bindgen will try and generate an opaque s2n_client_hello handle
// but that isn't necessary because that is already included in the
// "use crate::api::*;"
.blocklist_type("s2n_client_hello")
.raw_line("use crate::api::*;\n")
.generate()
.unwrap()
.write_to_file(out_dir.join("src/fingerprint.rs"))
.unwrap();

functions.tests(&out_dir.join("src/tests.rs")).unwrap();

gen_files(&out_dir.join("lib"), &out_dir.join("files.rs")).unwrap();
Expand Down
1 change: 1 addition & 0 deletions bindings/rust/s2n-tls-sys/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ default = []
pq = ["cmake"] # the pq build logic is complicated so just use cmake instead
quic = []
internal = []
fingerprint = []

[dependencies]
libc = "0.2"
Expand Down
33 changes: 0 additions & 33 deletions bindings/rust/s2n-tls-sys/src/internal.rs

This file was deleted.

7 changes: 7 additions & 0 deletions bindings/rust/s2n-tls-sys/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,13 @@ mod internal;
#[cfg(feature = "internal")]
pub use internal::*;

#[cfg(feature = "fingerprint")]
#[rustfmt::skip]
mod fingerprint;

#[cfg(feature = "fingerprint")]
pub use fingerprint::*;

// Additional defines that don't get imported with bindgen

pub mod s2n_status_code {
Expand Down
2 changes: 2 additions & 0 deletions bindings/rust/s2n-tls/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ license = "Apache-2.0"

[features]
default = []
fingerprint = ["s2n-tls-sys/fingerprint"]
quic = ["s2n-tls-sys/quic"]
pq = ["s2n-tls-sys/pq"]
testing = ["bytes"]
Expand All @@ -20,6 +21,7 @@ errno = { version = "0.3" }
libc = "0.2"
s2n-tls-sys = { version = "=0.0.31", path = "../s2n-tls-sys", features = ["internal"] }
pin-project-lite = "0.2"
hex = "0.4"

[dev-dependencies]
bytes = { version = "1" }
Expand Down
Loading