import re from datetime import datetime from db import insert_lead def parse_tradingtwins_email(body): data = {} # Simple regex extraction based on the email format patterns = { 'id': r'Lead-ID:\s*(\d+)', 'company': r'Firma:\s*(.+)', 'contact_first': r'Vorname:\s*(.+)', 'contact_last': r'Nachname:\s*(.+)', 'email': r'E-Mail:\s*([^\s<]+)', 'phone': r'Rufnummer:\s*([^\n]+)', 'area': r'Reinigungs-Flche:\s*([^\n]+)', 'purpose': r'Einsatzzweck:\s*([^\n]+)' } for key, pattern in patterns.items(): match = re.search(pattern, body) if match: data[key] = match.group(1).strip() # Combine names if 'contact_first' in data and 'contact_last' in data: data['contact'] = f"{data['contact_first']} {data['contact_last']}" data['raw_body'] = body return data def is_free_mail(email_addr): """Checks if an email belongs to a known free-mail provider.""" if not email_addr: return False free_domains = { 'gmail.com', 'googlemail.com', 'outlook.com', 'hotmail.com', 'live.com', 'msn.com', 'icloud.com', 'me.com', 'mac.com', 'yahoo.com', 'ymail.com', 'rocketmail.com', 'gmx.de', 'gmx.net', 'web.de', 't-online.de', 'freenet.de', 'mail.com', 'protonmail.com', 'proton.me', 'online.de' } domain = email_addr.split('@')[-1].lower() return domain in free_domains def parse_tradingtwins_html(html_body): """ Extracts data from the Tradingtwins HTML table structure. Pattern:
Label:
...Value
""" data = {} # Map label names in HTML to our keys field_map = { 'Firma': 'company', 'Vorname': 'contact_first', 'Nachname': 'contact_last', 'Anrede': 'salutation', 'E-Mail': 'email', 'Rufnummer': 'phone', 'Einsatzzweck': 'purpose', 'Reinigungs-Funktionen': 'cleaning_functions', 'Reinigungs-Fläche': 'area', 'PLZ': 'zip', 'Stadt': 'city', 'Lead-ID': 'source_id' } for label, key in field_map.items(): pattern = fr'>\s*{re.escape(label)}:\s*.*?]*>(.*?)
' match = re.search(pattern, html_body, re.DOTALL | re.IGNORECASE) if match: raw_val = match.group(1).strip() clean_val = re.sub(r'<[^>]+>', '', raw_val).strip() data[key] = clean_val # Composite fields if data.get('contact_first') and data.get('contact_last'): data['contact'] = f"{data['contact_first']} {data['contact_last']}" # Quality Check: Free mail or missing company email = data.get('email', '') company = data.get('company', '-') data['is_free_mail'] = is_free_mail(email) data['is_low_quality'] = data['is_free_mail'] or company == '-' or not company # Ensure source_id is present and map to 'id' for db.py compatibility if not data.get('source_id'): data['source_id'] = f"tt_unknown_{int(datetime.now().timestamp())}" data['id'] = data['source_id'] # db.py expects 'id' for source_id column return data def parse_roboplanet_form(html_body): """ Parses the Roboplanet website contact form (HTML format). Example: Vorname: Gordana