From 34af714c51173075d3a0ac7148ce60334d248aba Mon Sep 17 00:00:00 2001 From: gabrielgio Date: Fri, 25 Mar 2022 20:31:58 +0100 Subject: feat: Add options for password generator Add new options to generate a passowrd: - upper letters - lower letters - numbers - special Special needs to be worked on still, as probably there are some char missing. --- src/lib.rs | 34 +++++++++++++++++++++++++++------- 1 file changed, 27 insertions(+), 7 deletions(-) (limited to 'src/lib.rs') diff --git a/src/lib.rs b/src/lib.rs index cfa078a..a4fa227 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -14,18 +14,38 @@ extern { fn alert(s: &str); } + #[wasm_bindgen] -pub fn generate(len: usize) -> String { - const CHARSET: &[u8] = b"ABCDEFGHIJKLMNOPQRSTUVWXYZ\ - abcdefghijklmnopqrstuvwxyz\ - 1234567890\ - !@#$%^&*()+{}[]"; +pub fn generate(len: usize, lower: bool, upper: bool, number: bool, special: bool) -> String { + let mut upper_charset: Vec = String::from("ABCDEFGHIJKLMNOPQRSTUVWXYZ").chars().collect(); + let mut lower_charset: Vec = String::from("abcdefghijklmnopqrstuvwxyz").chars().collect(); + let mut number_charset: Vec = String::from("1234567890").chars().collect(); + let mut special_charset: Vec = String::from("!@#$%^&*()+{}[]").chars().collect(); + let mut result: Vec = Vec::new(); + let mut rng = rand::thread_rng(); + if lower { + result.append(&mut lower_charset); + } + + if upper { + result.append(&mut upper_charset); + } + + if number { + result.append(&mut number_charset); + } + + if special { + result.append(&mut special_charset); + } + + (0..len) .map(|_| { - let idx = rng.gen_range(0..CHARSET.len()); - CHARSET[idx] as char + let idx = rng.gen_range(0..result.len()); + result[idx] as char }) .collect() } -- cgit v1.2.3