takproto 0.4.2

Rust library for TAK (Team Awareness Kit) Protocol - send CoT messages to TAK servers with mTLS support
Documentation
//! Test normal P12 connection (no dangerous options)
//!
//! This tests if the issue is specific to danger_accept_invalid_certs

use takproto::helpers::contact;
use takproto::{CotEventBuilder, TakClient, TlsConfig};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let args: Vec<String> = std::env::args().collect();
    if args.len() < 5 {
        eprintln!(
            "Usage: {} <server:port> <server_name> <p12_file> <password>",
            args[0]
        );
        std::process::exit(1);
    }

    let server_addr = &args[1];
    let server_name = &args[2];
    let p12_file = &args[3];
    let password = &args[4];

    println!("===================================================");
    println!("Testing: Normal P12 Connection (FULL VALIDATION)");
    println!("===================================================");
    println!("Server: {}", server_addr);
    println!("P12 File: {}", p12_file);
    println!("✓ Using normal certificate validation\n");

    println!("Loading P12 with FULL validation...");
    let tls_config = TlsConfig::new_with_p12(p12_file, password)?;
    println!("✓ TLS configuration created\n");

    println!("Connecting to {}...", server_addr);
    let mut client = TakClient::connect_tls(server_addr, server_name, tls_config).await?;
    println!("✓ Connected!\n");

    println!("Negotiating protocol...");
    client.negotiate_protocol(1, 60).await?;
    println!("✓ Protocol negotiated (protobuf mode)\n");

    println!("Sending test event...");
    let event = CotEventBuilder::new()
        .uid("NORMAL-P12-TEST")
        .cot_type("a-f-G-U-C")
        .lat_lon(39.377445, -76.832160)
        .hae(10.0)
        .ce_le(9.9, 9.9)
        .how("m-g")
        .stale_minutes(5)
        .with_contact(contact("NormalP12", None))
        .build()?;

    client.send_cot_event(event).await?;
    println!("✓ Event sent successfully!\n");

    println!("===================================================");
    println!("✅ Normal P12 connection works!");
    println!("===================================================");
    println!("If this works but danger_accept_invalid_certs doesn't,");
    println!("the issue is with our custom certificate verifier.");

    Ok(())
}