Threats Watcher - Core Algorithm
- Watcher.threats_watcher.core.cleanup()
Remove words with a creation date greater than 30 days.
- Watcher.threats_watcher.core.fetch_last_posts(nb_max_post)
Fetch the nb last posts for each feed.
- Parameters:
nb_max_post – The deepness of the search on each feed.
- Watcher.threats_watcher.core.focus_five_letters()
Focus on 5 letters long words.
- Watcher.threats_watcher.core.focus_on_top(words_occurrence)
Focus on top words. Populated the database with only words with a minimum occurrence of “words_occurence” in feeds.
- Parameters:
words_occurrence – Word occurence in feeds.
- Watcher.threats_watcher.core.load_feeds()
Load feeds.
- Watcher.threats_watcher.core.main_watch()
- Main function:
close_old_connections()
load_feeds()
fetch_last_posts(settings.POSTS_DEPTH)
tokenize_count_urls()
remove_banned_words()
focus_five_letters()
focus_on_top(settings.WORDS_OCCURRENCE)
send_threats_watcher_notifications()
- Watcher.threats_watcher.core.remove_banned_words()
Clean the posts for specific patterns: BannedWord, then english + french common words.
- Watcher.threats_watcher.core.send_threats_watcher_notifications(email_words)
Sends notifications to Slack, Citadel, TheHive or Email based on Threats Watcher.
- Watcher.threats_watcher.core.start_scheduler()
- Launch multiple planning tasks in background:
Fire main_watch every 30 minutes from Monday to Friday (daylight only)
Fire main_watch at 18h00 on Saturday
Fire cleanup every day at 8 am
- Watcher.threats_watcher.core.tokenize_count_urls()
Tokenize phrases to words, Count word occurences and keep the word post source urls.