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)
}