lox_client.rs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. // This seems like probably not the best way to do this, but it works.
  2. #[path = "../client_lib.rs"]
  3. mod client_lib;
  4. use client_lib::*;
  5. #[path = "../client_net.rs"]
  6. mod client_net;
  7. use client_net::HyperNet;
  8. use curve25519_dalek::scalar::Scalar;
  9. use getopts::Options;
  10. use lox::bridge_table::BridgeLine;
  11. use lox::IssuerPubKey;
  12. use serde::Serialize;
  13. use std::env::args;
  14. use std::fs::File;
  15. use std::io::Write;
  16. use std::path::Path;
  17. // Prints the argument details for this program
  18. fn print_usage(program: &str, opts: Options) {
  19. let brief = format!("Usage: {} [options]", program);
  20. print!("{}", opts.usage(&brief));
  21. }
  22. // Helper function to save serializable objects to files
  23. fn save_object<T: Serialize>(obj: T, filename: &str) {
  24. let mut outfile = File::create(filename).expect(&("Failed to create ".to_string() + filename));
  25. write!(outfile, "{}", serde_json::to_string(&obj).unwrap())
  26. .expect(&("Failed to write to ".to_string() + filename));
  27. }
  28. #[tokio::main]
  29. async fn main() {
  30. let args: Vec<String> = args().collect();
  31. let mut opts = Options::new();
  32. opts.optflag("h", "help", "print this help menu");
  33. opts.optflag("L", "level-up", "increase trust level");
  34. opts.optflag("N", "new-lox-cred", "get a new Lox Credential");
  35. opts.optopt(
  36. "",
  37. "server",
  38. "Lox Auth server address [http://localhost:8001]",
  39. "ADDR",
  40. );
  41. let matches = match opts.parse(&args[1..]) {
  42. Ok(m) => m,
  43. Err(f) => {
  44. panic!("{}", f.to_string())
  45. }
  46. };
  47. if matches.opt_present("h") {
  48. print_usage(&args[0], opts);
  49. return;
  50. }
  51. let net = if matches.opt_present("server") {
  52. HyperNet {
  53. hostname: matches.opt_str("server").unwrap(),
  54. }
  55. } else {
  56. HyperNet {
  57. hostname: "http://localhost:8001".to_string(),
  58. }
  59. };
  60. // Get Lox Authority public keys
  61. // TODO: Make this filename configurable
  62. let lox_auth_pubkeys_filename = "lox_auth_pubkeys.json";
  63. let lox_auth_pubkeys: Vec<IssuerPubKey> = if Path::new(lox_auth_pubkeys_filename).exists() {
  64. // read in file
  65. let lox_auth_pubkeys_infile = File::open(lox_auth_pubkeys_filename).unwrap();
  66. serde_json::from_reader(lox_auth_pubkeys_infile).unwrap()
  67. } else {
  68. // download from Lox Auth
  69. let pubkeys = get_lox_auth_keys(&net).await;
  70. // save to file for next time
  71. save_object(&pubkeys, &lox_auth_pubkeys_filename);
  72. pubkeys
  73. };
  74. // Get Lox Credential and BridgeLine
  75. let lox_cred_filename = "lox_cred.json";
  76. let bridgeline_filename = "bridgeline.json";
  77. let (lox_cred, bridgeline) = if matches.opt_present("N")
  78. || !Path::new(lox_cred_filename).exists()
  79. || !Path::new(bridgeline_filename).exists()
  80. {
  81. // get new Lox Credential
  82. let open_invite = get_open_invitation(&net).await;
  83. let (cred, bl) =
  84. get_lox_credential(&net, &open_invite, get_lox_pub(&lox_auth_pubkeys)).await;
  85. // save to files for next time
  86. save_object(&cred, &lox_cred_filename);
  87. save_object(&bl, &bridgeline_filename);
  88. (cred, bl)
  89. } else {
  90. // Read existing Lox Credential and BridgeLine from files
  91. let cred = serde_json::from_reader(File::open(lox_cred_filename).unwrap()).unwrap();
  92. let bl = serde_json::from_reader(File::open(bridgeline_filename).unwrap()).unwrap();
  93. (cred, bl)
  94. };
  95. let lox_cred = if matches.opt_present("L") {
  96. let old_level = get_cred_trust_level(&lox_cred);
  97. // If trust level is 0, do trust promotion, otherwise level up.
  98. let cred = if old_level == 0 {
  99. let migration_cred =
  100. trust_promotion(&net, &lox_cred, get_lox_pub(&lox_auth_pubkeys)).await;
  101. let cred = trust_migration(
  102. &net,
  103. &lox_cred,
  104. &migration_cred,
  105. get_lox_pub(&lox_auth_pubkeys),
  106. get_migration_pub(&lox_auth_pubkeys),
  107. )
  108. .await;
  109. cred
  110. } else {
  111. let encbuckets = get_reachability_credential(&net).await;
  112. let cred = level_up(
  113. &net,
  114. &lox_cred,
  115. &encbuckets,
  116. get_lox_pub(&lox_auth_pubkeys),
  117. get_reachability_pub(&lox_auth_pubkeys),
  118. )
  119. .await;
  120. cred
  121. };
  122. save_object(&cred, &lox_cred_filename);
  123. let new_level = get_cred_trust_level(&cred);
  124. if new_level > old_level {
  125. println!("Old level: {}\nNew level: {}", old_level, new_level);
  126. } else if new_level == old_level {
  127. println!("Unable to level up. Current level: {}", new_level);
  128. }
  129. cred
  130. } else {
  131. lox_cred
  132. };
  133. }