keybase-protocol 0.1.1

Provides the Keybase types defined in the Keybase AVDL Protocol files for Rust.
Documentation
// Namespace: "keybase.1"
// Protocol: "saltpack"
#![allow(dead_code)]
#![allow(non_snake_case)]
#![allow(non_camel_case_types)]
#![allow(unused_imports)]
use serde::{Serialize, Deserialize};
use serde_repr::{Deserialize_repr, Serialize_repr};use super::*;

use super::common::*;
use super::identify_common::*;
#[derive(Serialize_repr, Deserialize_repr, Debug, Hash, PartialEq, Eq)]
#[repr(u8)]
pub enum AuthenticityType {
  Signed_0,
  Repudiable_1,
  Anonymous_2,
}

pub struct SaltpackEncryptOptions {
  pub recipients: Option<Vec<String>>,
  pub teamRecipients: Option<Vec<String>>,
  pub authenticityType: AuthenticityType,
  pub useEntityKeys: bool,
  pub useDeviceKeys: bool,
  pub usePaperKeys: bool,
  pub noSelfEncrypt: bool,
  pub binary: bool,
  pub saltpackVersion: i32,
  pub useKBFSKeysOnlyForTesting: bool,
}

pub struct SaltpackDecryptOptions {
  pub interactive: bool,
  pub forceRemoteCheck: bool,
  pub usePaperKey: bool,
}

pub struct SaltpackSignOptions {
  pub detached: bool,
  pub binary: bool,
  pub saltpackVersion: i32,
}

pub struct SaltpackVerifyOptions {
  pub signedBy: Option<String>,
  pub signature: Option<String>,
}



pub struct SaltpackEncryptedMessageInfo {
  pub devices: Option<Vec<Device>>,
  pub numAnonReceivers: i32,
  pub receiverIsAnon: bool,
  pub sender: SaltpackSender,
}