This project includes three scripts designed to facilitate sending HTML emails with dynamic content:
-
send_html_email.py
: This is the core Python script that reads an HTML template file, replaces placeholders with client-specific information, and sends the email via SMTP using your email credentials. It also converts sensitive data, such as passwords, into secure images. -
mailer.bat
: A Batch script for Windows that simplifies the email-sending process by prompting you to select a client email address and an HTML template. It then callssend_html_email.py
to send the email. -
mailer.sh
: A Bash script for Unix-like systems that performs similar tasks asmailer.bat
. It prompts you to choose a client email address and template, then executessend_html_email.py
to handle the email sending.
This repo was designed to help automate the process of sending personalized HTML emails, making it easier to integrate this functionality into your automated systems such as web hosting and network administration. The project is open-source and can be extended for further customization.
Before using the script, make sure you have the following:
- Python 3.12.x (or any compatible version)
- Required Packages:
smtplib
(built-in to Python)email
(built-in to Python)python-dotenv
for loading environment variablesPillow
for image processing
Before running the script, ensure that all required Python packages are installed. The requirements.txt
file provided includes all necessary dependencies.
To install the required packages, use the following command:
pip install -r requirements.txt
Alternatively, if you prefer installing packages manually, you can use:
pip install python-dotenv pillow
Create a .env
file in the root of your project directory and add your email credentials and other settings:
SMTP_SERVER=smtp.yourserver.com
SMTP_PORT=587
[email protected]
EMAIL_PASSWORD=your_email_password
CLIENT_INFO_FILE=client_info.json
A sample client_info.json
file is included with client details replace these details with your clients information. You can add as namy as you like just add them as an object in the array:
{
"clients": [
{
"email": "[email protected]",
"name": "Client Name",
"userName": "clientuser",
"host": "smtp.yourserver.com",
"domain": "gorombo.com",
"password": "temporarypassword"
}
]
}
Place your HTML template files in a directory called template
(or another directory of your choice but you will have to edit this location in the .sh and .bat files).
For example, save an HTML file called welcome_email.html
in the template/
directory.
Use the following command to run the script from the command line:
python send_html_email.py [email protected] "Email Subject" template/welcome_email.html
[email protected]
: The recipient's email address."Email Subject"
: The subject of your email.template/welcome_email.html
: The path to your HTML template file.
python send_html_email.py [email protected] "Welcome to Our Platform" template/welcome_email.html
This will send an email to [email protected]
with the subject "Welcome to Our Platform," using the HTML content from welcome_email.html
.
If the script encounters any issues (e.g., failure to connect to the SMTP server), it will print an error message.
Success Output:
Email successfully sent to [email protected]
Failure Output:
Failed to send email to [email protected]
.
├── .env
├── client_info.json
├── README.md
├── send_html_email.py
├── mailer.bat
├── mailer.sh
└── template/
└── welcome_email.html
The script generates an image of the password using the Pillow library. Adjust the position and size of the text in the generate_password_image
function.
The script replaces the following placeholders in the HTML template:
{{name}}
: Client's name{{userName}}
: Client's username{{host}}
: Host information{{domain}}
: Domain information{{temporaryPassword}}
: The password image
The Windows batch script mailer.bat
simplifies the process of selecting a client and template from a list and sending the email.
- Ensure you have Python installed.
- Install
jq
if it is not already installed. The batch script will handle this. - Install
Pillow
if it is not already installed. The batch script will handle this.
-
Double-click
mailer.bat
or run it from the Command Prompt. -
Follow the prompts:
-
Select a client email:
Select a client email: 1: [email protected] 2: [email protected] Enter the number corresponding to the client email:
-
Select an email template:
Select an email template: 1: welcome_email.html 2: password_reset.html Enter the number corresponding to the template:
-
Enter the email subject:
Enter the email subject: Welcome!
-
Success Output:
Email successfully sent to [email protected]
Failure Output:
Failed to send email to [email protected]
The Unix-like shell script send_email.sh
is used to perform similar operations as the batch script but on Linux or macOS systems.
- Ensure you have Python installed.
- Install
jq
. The script will check and installjq
if it is not present.
-
Make the script executable:
chmod +x send_email.sh
-
Run the script:
./send_email.sh
-
Follow the prompts:
-
Select a client email:
Select a client email: 1: [email protected] 2: [email protected] Enter the number corresponding to the client email:
-
Select an email template:
Select an email template: 1: welcome_email.html 2: password_reset.html Enter the number corresponding to the template:
-
Enter the email subject:
Enter the email subject: Welcome!
-
Success Output:
Email successfully sent to [email protected]
Failure Output:
Failed to send email to [email protected]
This is an open-source project designed to integrate into your existing automated systems such as web hosting and network administration. It provides a basic framework that can be extended for further customization.
We welcome contributions to enhance this script. If you have ideas, improvements, or bug fixes, please consider submitting a pull request or opening an issue on GitHub. Your input will help make this a more robust and versatile tool.
This project is licensed under the MIT License.
For more insights on web development tools, asset management, and the Astro SSR SPA Template, visit Dan Sasser’s Blog and explore The Astro SSR SPA Template.
-
Customer Email Automation - The Customer Email Automation Documentation
-
GOROMBO - GOROMBO Web Development | Email Hosting | VPS Hosting | Cloud Hosting | Custom Software | API Integration
-
GitHub - a link to my GitHub profile
-
Customer Email Automation Article - My current article about email automation
-
dev.to - a link to my dev.to profile
-
LinkedIn - a link to my LinkedIn profile
-
Medium - a link to my Medium profile
-
Substack - a link to my Substack
If you enjoy my projects and want to support my work, consider buying me a coffee!