diff options
author | Harald Eilertsen <haraldei@anduin.net> | 2019-05-07 22:40:47 +0200 |
---|---|---|
committer | Harald Eilertsen <haraldei@anduin.net> | 2019-05-07 22:40:47 +0200 |
commit | 268df91e3ced5ca92e21c83021d6b431190656a6 (patch) | |
tree | 1995ee7aaf7e9ad7eff81f8774b8b6e810943080 /src/main.rs | |
download | phisher-268df91e3ced5ca92e21c83021d6b431190656a6.tar.gz phisher-268df91e3ced5ca92e21c83021d6b431190656a6.tar.bz2 phisher-268df91e3ced5ca92e21c83021d6b431190656a6.zip |
Initial commit.
Diffstat (limited to 'src/main.rs')
-rw-r--r-- | src/main.rs | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/main.rs b/src/main.rs new file mode 100644 index 0000000..4e3076b --- /dev/null +++ b/src/main.rs @@ -0,0 +1,39 @@ +// A program to scan emails for phishing links. +// Copyright (C) 2019 Harald Eilertsen +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <https://www.gnu.org/licenses/>. + +use phisher; +use clap::{clap_app, crate_name, crate_authors, crate_version, crate_description}; +use std::fs::File; +use std::io::BufReader; +use std::time::SystemTime; + +fn main() { + let args = clap_app!(app => + (name: crate_name!()) + (version: crate_version!()) + (author: crate_authors!()) + (about: crate_description!()) + (@arg PHISHTANK: --phishtank +required +takes_value "The phishtank json data file to use.") + ).get_matches(); + + let start_time = SystemTime::now(); + let r = BufReader::new(File::open(args.value_of("PHISHTANK").unwrap()).unwrap()); + let tank = phisher::load_phistank(r).unwrap(); + + println!("Loaded {} phishes in {} seconds!", + tank.phishes.len(), + start_time.elapsed().unwrap().as_secs()); +} |