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
use crate::CipherResult;
pub fn xor(uw: &str, vw: &str) -> CipherResult {
let alphabet = "abcdefghijklmnopqrstuvwxyz";
let mut binary_vw_word = "".to_string();
let mut binary_uw_word = "".to_string();
let mut new_pass = String::from("");
for i in &mut (*vw).bytes() {
binary_vw_word += &format!("0{:b}", i);
}
for i in &mut (*uw).bytes() {
binary_uw_word += &format!("0{:b}", i);
}
let mut x = 0;
let mut binary_pass = String::new();
for i in 0..binary_uw_word.len() {
if x == 8 {
binary_pass += " ";
x = 0
}
let uw_val = &(binary_uw_word.as_bytes()[{
if i > binary_uw_word.len() - 1 {
i - (binary_uw_word.len() * (i / binary_uw_word.len() as usize))
} else {
i
}
}] as char)
.to_string()
.parse::<u8>()
.unwrap();
let vw_val = &(binary_vw_word.as_bytes()[i] as char)
.to_string()
.parse()
.unwrap();
binary_pass += &format!("{:b}", uw_val ^ vw_val);
x += 1;
}
let binary_vec: Vec<&str> = binary_pass.split(' ').collect();
for i in binary_vec {
let number = usize::from_str_radix(i, 2).unwrap();
let val = match alphabet.as_bytes().get(number) {
Some(v) => v,
None => continue,
};
new_pass += &(*val as char).to_string();
}
println!("{:?}", binary_pass);
Ok(new_pass)
}