From 268df91e3ced5ca92e21c83021d6b431190656a6 Mon Sep 17 00:00:00 2001 From: Harald Eilertsen Date: Tue, 7 May 2019 22:40:47 +0200 Subject: Initial commit. --- src/lib.rs | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 src/lib.rs (limited to 'src/lib.rs') diff --git a/src/lib.rs b/src/lib.rs new file mode 100644 index 0000000..45add28 --- /dev/null +++ b/src/lib.rs @@ -0,0 +1,54 @@ +// 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 . + +use chrono::{ DateTime, Utc }; +use serde::Deserialize; +use serde_json; +use std::io::{ BufRead, Result }; +use std::net::IpAddr; + +#[derive(Deserialize)] +pub struct PhishTank { + pub phishes: Vec, +} + +#[derive(Deserialize)] +pub struct Phish { + pub phish_id: String, + pub url: String, + pub phish_detail_url: String, + pub submission_time: DateTime, + pub verified: String, + pub verified_time: Option>, + pub online: String, + pub target: String, + pub details: Vec, +} + +#[derive(Deserialize)] +pub struct PhishDetails { + pub ip_address: IpAddr, + pub cidr_block: String, + pub announcing_network: String, + pub rir: String, + pub country: String, + pub detail_time: DateTime, +} + +pub fn load_phistank(input: R) -> Result { + let phishes = serde_json::from_reader(input)?; + Ok(PhishTank { phishes }) +} -- cgit v1.2.3