Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
131 changes: 88 additions & 43 deletions docs/spec.md

Large diffs are not rendered by default.

25 changes: 23 additions & 2 deletions rust/vectorpin/examples/basic_usage.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
// Copyright 2025 Jascha Wanger / Tarnover, LLC
// SPDX-License-Identifier: Apache-2.0

//! Mirror of `examples/basic_usage.py` — runs the same four scenarios.
//! Mirror of `examples/basic_usage.py` — runs the same scenarios against
//! the v2 wire format.

use vectorpin::{Pin, Signer, Verifier};
use vectorpin::{Pin, Signer, Verifier, VerifyOptions};

fn main() {
let embedding: Vec<f32> = (0..128).map(|i| (i as f32) * 0.01).collect();
Expand Down Expand Up @@ -48,6 +49,26 @@ fn main() {
let r = verifier.verify_signature(&rogue_pin);
println!("4. forged with wrong key -> {:?}", r);

// 5. replay-protection: pin with a record_id; verifier enforces a
// different expected record_id.
let opts = vectorpin::signer::PinOptions {
extra: [("vectorpin.record_id".to_string(), "rec-1".to_string())]
.into_iter()
.collect(),
..vectorpin::signer::PinOptions::default()
};
let scoped_pin = signer
.pin_with_options(source, "m", embedding.as_slice(), opts)
.expect("scoped pin");
let r = verifier.verify(
&scoped_pin,
VerifyOptions {
expected_record_id: Some("rec-other"),
..VerifyOptions::default()
},
);
println!("5. record_id mismatch -> {:?}", r);

let restored = Pin::from_json(&pin.to_json()).expect("round trip");
assert_eq!(restored, pin);
println!("\nPin round-trip via JSON: OK");
Expand Down
Loading
Loading