Dear team,
- Please find below trendy word(s) that match at least """ + str(words_occurrence) + """ times:
+ Please find the new trendy word(s) detected below:
""" + " ".join(email_words) + """
diff --git a/Watcher/Watcher/common/utils/send_thehive_alerts.py b/Watcher/Watcher/common/utils/send_thehive_alerts.py
index e71fadd..b4ece32 100644
--- a/Watcher/Watcher/common/utils/send_thehive_alerts.py
+++ b/Watcher/Watcher/common/utils/send_thehive_alerts.py
@@ -80,6 +80,11 @@ def send_thehive_alert(title, description, severity, tags, app_name, domain_name
if ticket_id is None:
ticket_id = generate_ref()
+ if app_name == 'website_monitoring' and domain_name:
+ site = Site.objects.get(domain_name=domain_name)
+ site.ticket_id = ticket_id
+ site.save()
+
if app_name == 'website_monitoring' and not ticket_id:
return
diff --git a/Watcher/Watcher/common/utils/update_thehive.py b/Watcher/Watcher/common/utils/update_thehive.py
index 3d4ffff..02ac89c 100644
--- a/Watcher/Watcher/common/utils/update_thehive.py
+++ b/Watcher/Watcher/common/utils/update_thehive.py
@@ -100,12 +100,16 @@ def create_observables(observables):
:return: A list of formatted observables ready for TheHive.
:rtype: list
"""
+
+ current_time = timezone.now().strftime("%H:%M:%S")
+ current_date = timezone.now().strftime("%d/%m/%y")
+
observables_data = []
for obs in observables:
observable_data = {
"dataType": obs['dataType'],
"data": obs['data'],
- "message": f"Observable added: {obs['data']} on {timezone.now()}",
+ "message": f"An observable was added on {current_date} at {current_time}.",
"ioc": True,
"sighted": True,
"tlp": 2
@@ -130,7 +134,6 @@ def update_existing_alert_case(item_type, existing_item, observables, comment, t
if observables:
observables_data = create_observables(observables)
- print(f"{timezone.now()} - Adding observables to {item_type} with ID {item_id}...")
add_observables_to_item(item_type, item_id, observables_data, thehive_url, api_key)
if comment:
@@ -224,10 +227,10 @@ def handle_alert_or_case(ticket_id, observables, comment, title, description, se
case_type, case_item = search_thehive_for_ticket_id(ticket_id, thehive_url, api_key, item_type="case")
if case_item:
- print(f"{timezone.now()} - Case found for {settings.THE_HIVE_CUSTOM_FIELD} {ticket_id}. Updating...")
+ print(f"{timezone.now()} - Case found for {settings.THE_HIVE_CUSTOM_FIELD} {ticket_id}. Proceeding with update.")
update_existing_alert_case("case", case_item, observables, comment, thehive_url, api_key)
elif alert_item:
- print(f"{timezone.now()} - Alert found for {settings.THE_HIVE_CUSTOM_FIELD} {ticket_id}. Updating...")
+ print(f"{timezone.now()} - Alert found for {settings.THE_HIVE_CUSTOM_FIELD} {ticket_id}. Proceeding with update.")
update_existing_alert_case("alert", alert_item, observables, comment, thehive_url, api_key)
else:
create_new_alert(
diff --git a/Watcher/Watcher/dns_finder/core.py b/Watcher/Watcher/dns_finder/core.py
index 4e16eda..c6e0c50 100644
--- a/Watcher/Watcher/dns_finder/core.py
+++ b/Watcher/Watcher/dns_finder/core.py
@@ -22,8 +22,7 @@ def start_scheduler():
- Fire main_certificate_transparency from Monday to Sunday: every hour.
"""
scheduler = BackgroundScheduler(timezone=str(tzlocal.get_localzone()))
- # scheduler.add_job(main_dns_twist, 'cron', day_of_week='mon-sun', hour='*/2', id='main_dns_twist',
- scheduler.add_job(main_dns_twist, 'cron', day_of_week='mon-sun', minute='*/2', id='main_dns_twist',
+ scheduler.add_job(main_dns_twist, 'cron', day_of_week='mon-sun', hour='*/2', id='main_dns_twist',
max_instances=10,
replace_existing=True)
scheduler.add_job(main_certificate_transparency, 'cron', day_of_week='mon-sun', hour='*/1',
diff --git a/Watcher/Watcher/threats_watcher/core.py b/Watcher/Watcher/threats_watcher/core.py
index 8936cd0..7c37a79 100644
--- a/Watcher/Watcher/threats_watcher/core.py
+++ b/Watcher/Watcher/threats_watcher/core.py
@@ -11,9 +11,6 @@
import feedparser
import requests
import re
-from email.mime.multipart import MIMEMultipart
-from email.mime.text import MIMEText
-import smtplib
from django.db import close_old_connections
from common.core import send_app_specific_notifications
from django.db.models import Q
diff --git a/Watcher/Watcher/watcher/settings.py b/Watcher/Watcher/watcher/settings.py
index 859af43..937782e 100755
--- a/Watcher/Watcher/watcher/settings.py
+++ b/Watcher/Watcher/watcher/settings.py
@@ -97,15 +97,13 @@
EMAIL_HOST_USER = os.environ.get('EMAIL_HOST_USER', '')
EMAIL_HOST_PASSWORD = os.environ.get('EMAIL_HOST_PASSWORD', '')
EMAIL_FROM = os.environ.get('EMAIL_FROM', '')
-EMAIL_SUBJECT_TAG_SITE_MONITORING = os.environ.get('EMAIL_SUBJECT_TAG_SITE_MONITORING', 'INCIDENT')
+SUBJECT_TAG_SITE_MONITORING = os.environ.get('SUBJECT_TAG_SITE_MONITORING', 'INCIDENT')
# Display at the end of the email notification
EMAIL_CLASSIFICATION = os.environ.get('EMAIL_CLASSIFICATION', 'Internal')
# Website url, link in e-mails body
-WATCHER_URL = os.environ.get('WATCHER_URL', 'https://cert-watcher.corp.thales/')
+WATCHER_URL = os.environ.get('WATCHER_URL', '')
# Watcher Logo
-WATCHER_LOGO = os.environ.get('WATCHER_LOGO', 'https://raw.githubusercontent.com/thalesgroup-cert/Watcher/master'
- '/Watcher/static/Watcher-logo-simple.png')
-WATCHER_LOGO_BASE64 = ""
+WATCHER_LOGO = os.environ.get('WATCHER_LOGO', '')
GITHUB_LOGO = os.environ.get('GITHUB_LOGO', '')
# Proxy setup
@@ -126,8 +124,6 @@
if THE_HIVE_VERIFY_SSL == "False":
THE_HIVE_VERIFY_SSL = False
THE_HIVE_KEY = os.environ.get('THE_HIVE_KEY', '')
-THE_HIVE_CASE_ASSIGNEE = os.environ.get('THE_HIVE_CASE_ASSIGNEE', 'watcher')
-THE_HIVE_TAGS = os.environ.get('THE_HIVE_TAGS', "Watcher,Impersonation,Malicious Domain,Typosquatting").split(",")
THE_HIVE_CUSTOM_FIELD = os.environ.get('THE_HIVE_CUSTOM_FIELD', 'watcher-id')
THE_HIVE_EMAIL_SENDER = os.environ.get('THE_HIVE_EMAIL_SENDER', 'watcher@watcher.com')
diff --git a/Watcher/requirements.txt b/Watcher/requirements.txt
index 66adf62..23c75f6 100644
--- a/Watcher/requirements.txt
+++ b/Watcher/requirements.txt
@@ -1,23 +1,37 @@
+# Web Framework and Application Enhancements
mysqlclient==2.1.1
-django==5.0.9
-django-mysql==4.13.0
+django==5.0.10
+django-mysql==4.15.0
djangorestframework==3.15.2
django-rest-knox==4.2.0
-apscheduler==3.10.4
-nltk==3.8.1
+whitenoise==6.8.2
+django-auth-ldap==5.1.0
+django-import-export==4.3.3
+
+# Job Scheduling and Task Management
+apscheduler==3.11.0
+
+# Parsing and Text Extraction
feedparser==6.0.11
-docutils==0.20.1
-sphinx==7.3.7
-sphinx-rtd-theme==2.0.0
-myst-parser==3.0.1
-whitenoise==6.6.0
+docutils==0.21.2
+Sphinx==8.1.3
+sphinx-rtd-theme==3.0.2
+myst-parser==4.0.0
+
+# Natural Language Processing and Similarity Checking
+nltk==3.8.1
python-tlsh==4.5.0
+
+# Networking and DNS Utilities
+dnspython==2.7.0
+dnstwist==20240812
+certstream==1.12
+
+# Environment Configuration
ipaddress==1.0.23
-dnspython==2.6.1
+
+# User-Agent Simulation
shadow-useragent==0.0.17
-thehive4py==1.8.1
-pymisp==2.4.190
-django-auth-ldap==4.8.0
-dnstwist==20240116
-django-import-export==4.0.3
-certstream==1.12
+
+# Cybersecurity and Incident Response
+pymisp==2.5.3
diff --git a/docker-compose.yml b/docker-compose.yml
index a1d31b1..1928195 100755
--- a/docker-compose.yml
+++ b/docker-compose.yml
@@ -54,40 +54,9 @@ services:
default:
ipv4_address: 10.10.10.6
tty: true
+ env_file:
+ - .env
environment:
- TZ: ${TZ}
- DJANGO_DEBUG: ${DJANGO_DEBUG}
- DJANGO_SECRET_KEY: ${DJANGO_SECRET_KEY}
- DB_USER: ${DB_USER}
- DB_PASSWORD: ${DB_PASSWORD}
- EMAIL_FROM: ${EMAIL_FROM}
- SMTP_SERVER: ${SMTP_SERVER}
- WATCHER_URL: ${WATCHER_URL}
- WATCHER_LOGO: ${WATCHER_LOGO}
- EMAIL_SUBJECT_TAG_SITE_MONITORING: ${EMAIL_SUBJECT_TAG_SITE_MONITORING}
- EMAIL_CLASSIFICATION: ${EMAIL_CLASSIFICATION}
- THE_HIVE_URL: ${THE_HIVE_URL}
- THE_HIVE_VERIFY_SSL: ${THE_HIVE_VERIFY_SSL}
- THE_HIVE_KEY: ${THE_HIVE_KEY}
- THE_HIVE_CASE_ASSIGNEE: ${THE_HIVE_CASE_ASSIGNEE}
- THE_HIVE_TAGS: ${THE_HIVE_TAGS}
- MISP_URL: ${MISP_URL}
- MISP_VERIFY_SSL: ${MISP_VERIFY_SSL}
- MISP_KEY: ${MISP_KEY}
- MISP_TICKETING_URL: ${MISP_TICKETING_URL}
- MISP_TAGS: ${MISP_TAGS}
- AUTH_LDAP_SERVER_URI: ${AUTH_LDAP_SERVER_URI}
- AUTH_LDAP_BIND_DN: ${AUTH_LDAP_BIND_DN}
- AUTH_LDAP_BIND_PASSWORD: ${AUTH_LDAP_BIND_PASSWORD}
- AUTH_LDAP_BASE_DN: ${AUTH_LDAP_BASE_DN}
- AUTH_LDAP_FILTER: ${AUTH_LDAP_FILTER}
- AUTH_LDAP_VERIFY_SSL: ${AUTH_LDAP_VERIFY_SSL}
- DATA_LEAK_SEARX_URL: ${SEARX_PROTOCOL}${SEARX_HOSTNAME}/
- ALLOWED_HOST: ${ALLOWED_HOST}
- CSRF_TRUSTED_ORIGINS: ${CSRF_TRUSTED_ORIGINS}
- HTTP_PROXY: ${HTTP_PROXY}
- HTTPS_PROXY: ${HTTPS_PROXY}
- CERT_STREAM_URL: ${CERT_STREAM_URL}
no_proxy: "10.10.10.3,10.10.10.5,10.10.10.7"
ports:
- "9002:9002"
|