1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
// 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,
}