Fixing vibe coding and adding more features

Going through code to ensure readability and removing redundancy's from Claude Code, also adding more mail services for forwarding and receiving.
This commit is contained in:
Tyler
2026-03-25 21:27:28 -04:00
committed by GitHub
parent 7ca1ebd466
commit a8dfb048fe
3 changed files with 157 additions and 16 deletions
+1
View File
@@ -3,6 +3,7 @@
Usage examples: Usage examples:
python main.py --setup First-time setup wizard python main.py --setup First-time setup wizard
python main.py Start the background service (prompts for master password) python main.py Start the background service (prompts for master password)
python main.py --debug Start MailRelay with debug logs (prompts for master password)
python main.py --run-now Immediate sync then keep running python main.py --run-now Immediate sync then keep running
python main.py --status Print last-run summary and exit python main.py --status Print last-run summary and exit
python main.py --logs Tail the log file and exit python main.py --logs Tail the log file and exit
+153 -14
View File
@@ -14,6 +14,10 @@ Config schema (as TOML):
email = "user@icloud.com" email = "user@icloud.com"
password = "..." # app-specific password password = "..." # app-specific password
[gmail]
email = "user@gmail.com"
password = "..." # app-specific password
[preferences] [preferences]
delivery_mode = "imap" # "imap" | "mbox" delivery_mode = "imap" # "imap" | "mbox"
poll_interval_min = 60 # integer minutes poll_interval_min = 60 # integer minutes
@@ -31,11 +35,17 @@ CONFIG_PATH = Path(__file__).parent.parent / "data" / "config.age"
# Keys we expose to the rest of the app # Keys we expose to the rest of the app
REQUIRED_KEYS = { REQUIRED_KEYS = {
"proton": ["email", "password", "totp_secret"], "proton": ["email", "password", "totp_secret"],
"proton_receive": ["email", "password", "totp_secret"],
"icloud": ["email", "password"], "icloud": ["email", "password"],
"icloud_receive": ["email", "password"],
"gmail": ["email", "password"],
"gmail_receive": ["email", "password"],
"outlook": ["email", "password"],
"outlook_receive": ["email", "password"],
"preferences": ["delivery_mode", "poll_interval_min"], "preferences": ["delivery_mode", "poll_interval_min"],
} }
DELIVERY_MODES = ("imap", "mbox") DELIVERY_MODES = ("imap", "mbox", "proton")
MIN_INTERVAL_MIN = 15 MIN_INTERVAL_MIN = 15
@@ -142,21 +152,124 @@ def build_config_interactively() -> tuple[dict[str, Any], str]:
print("\n=== MailRelay First-Time Setup ===\n") print("\n=== MailRelay First-Time Setup ===\n")
proton_email = input("Proton Mail email address: ").strip() # Service to forward
proton_password = getpass.getpass("Proton Mail password: ") print("\nWhat service do you want to forward?")
proton_mailbox_pw = getpass.getpass( print(" 1) Proton Email")
"Proton Mail mailbox password (leave blank if none): " print(" 2) Gmail")
) print(" 3) Outlook")
totp_secret = input("TOTP secret key (base32, from your 2FA setup): ").strip() print(" 4) iCloud")
icloud_email = input("\niCloud email address: ").strip() # Ensuring vaild choice
icloud_password = getpass.getpass("iCloud app-specific password: ") while True:
export_choice = input("Choose [1/2/3/4]: ").strip()
print("\nDelivery mode:") try:
print(" 1) Automatic IMAP push to iCloud (default)") if int(export_choice) in [1,2,3,4]:
print(" 2) Manual MBOX download") break
mode_choice = input("Choose [1/2, default 1]: ").strip() or "1" print("Invalid option")
delivery_mode = "imap" if mode_choice != "2" else "mbox" except ValueError:
print("Invalid option")
# Service to receive
print("\nWhat service do you want to receive?")
print(" 1) Different Proton email" if export_choice == "1" else " 1) Proton email")
print(" 2) Different Gmail" if export_choice == "2" else " 2) Gmail")
print(" 3) Different Outlook" if export_choice == "3" else " 3) Outlook")
print(" 4) Different iCloud" if export_choice == "4" else " 4) iCloud")
# Ensuring vaild choice
while True:
forward_choice = input("Choose [1/2/3/4]: ").strip()
try:
if int(forward_choice) in [1,2,3,4]:
break
print("Invalid option")
except ValueError:
print("Invalid option")
# Ensuring no missing value errors
proton_email = None
proton_email_receive = None
proton_password = None
proton_password_receive = None
proton_mailbox_pw = None
proton_mailbox_pw_receive = None
totp_secret = None
totp_secret_receive = None
gmail_email = None
gmail_email_receive = None
gmail_password = None
gmail_password_receive = None
outlook_email = None
outlook_email_receive = None
outlook_password = None
outlook_password_receive = None
icloud_email = None
icloud_email_receive = None
icloud_password = None
icloud_password_receive = None
# Proton account login info
if export_choice == "1":
proton_email = input("Proton email address to forward: ").strip()
proton_password = getpass.getpass("Proton password: ")
proton_mailbox_pw = getpass.getpass(
"Proton Mail mailbox password (leave blank if none): "
)
totp_secret = input("TOTP secret key (base32, from your 2FA setup): ").strip()
if forward_choice == "1":
proton_email_receive = input("Proton email address to receive: ").strip()
proton_password_receive = getpass.getpass("Proton password: ")
proton_mailbox_pw_receive = getpass.getpass(
"Proton Mail mailbox password (leave blank if none): "
)
totp_secret_receive = input("TOTP secret key (base32, from your 2FA setup): ").strip()
# Gmail login info
if export_choice == "2":
gmail_email = input("\nGmail email address to forward: ").strip()
gmail_password = getpass.getpass("Google account app-specific password: ")
if forward_choice == "2":
gmail_email_receive = input("\nGmail email address to receive: ").strip()
gmail_password_receive = getpass.getpass("Google account app-specific password: ")
# Outlook login info
if export_choice == "3":
outlook_email = input("\nOutlook email address to forward: ").strip()
outlook_password = getpass.getpass("Microsoft app-specific password: ")
if forward_choice == "3":
outlook_email_receive = input("\nOutlook email address to receive: ").strip()
outlook_password_receive = getpass.getpass("Microsoft app-specific password: ")
# iCloud login info
if export_choice == "4":
icloud_email = input("\niCloud email address to forward: ").strip()
icloud_password = getpass.getpass("iCloud app-specific password: ")
if forward_choice == "4":
icloud_email_receive = input("\niCloud email address to receive: ").strip()
icloud_password_receive = getpass.getpass("iCloud app-specific password: ")
# Delivery Dialog
if forward_choice == "4":
print("\nDelivery mode:")
print(" 1) Automatic IMAP push (default)")
print(" 2) Manual MBOX download")
mode_choice = input("Choose [1/2, default 1]: ").strip() or "1"
delivery_mode = "imap" if mode_choice != "2" else "mbox"
elif forward_choice == "1":
print("\nUsing Proton export/import CLI tool")
delivery_mode = "proton"
else:
print("\nWARNING: GMAIL AND OUTLOOK DO NOT SUPPORT MBOX \nUsing IMAP push")
delivery_mode = "imap"
print("\nPolling interval:") print("\nPolling interval:")
print(" 1) 15 minutes") print(" 1) 15 minutes")
@@ -191,10 +304,36 @@ def build_config_interactively() -> tuple[dict[str, Any], str]:
"mailbox_password": proton_mailbox_pw, "mailbox_password": proton_mailbox_pw,
"totp_secret": totp_secret, "totp_secret": totp_secret,
}, },
"proton_receive": {
"email": proton_email_receive,
"password": proton_password_receive,
"mailbox_password": proton_mailbox_pw_receive,
"totp_secret": totp_secret_receive,
},
"icloud": { "icloud": {
"email": icloud_email, "email": icloud_email,
"password": icloud_password, "password": icloud_password,
}, },
"icloud_receive": {
"email": icloud_email_receive,
"password": icloud_password_receive,
},
"gmail": {
"email": gmail_email,
"password": gmail_password,
},
"gmail_receive": {
"email": gmail_email_receive,
"password": gmail_password_receive,
},
"outlook": {
"email": outlook_email,
"password": outlook_password,
},
"outlook_receive": {
"email": outlook_email_receive,
"password": outlook_password_receive,
},
"preferences": { "preferences": {
"delivery_mode": delivery_mode, "delivery_mode": delivery_mode,
"poll_interval_min": poll_interval, "poll_interval_min": poll_interval,
+3 -2
View File
@@ -72,6 +72,7 @@ echo ""
green "Setup complete!" green "Setup complete!"
echo "" echo ""
echo " Activate the environment: source .venv/bin/activate" echo " Activate the environment: source .venv/bin/activate"
echo " Run first-time setup: python main.py --setup" echo " Run first-time setup: python mailrelay.py --setup"
echo " Start MailRelay: python main.py" echo " Start with Debug Logs: python mailrelay.py --debug"
echo " Start MailRelay: python mailrelay.py"
echo "" echo ""