Skip to main content

A python library to send mails easily

Project description

Imhotep Mail

This is a simple Python library for sending emails. It provides an easy way to configure and send emails from any Python code.

Installation

To install the imhotep_mail library, you can use pip:

pip install imhotep-mail

Usage

Recommended Method: Configure SMTP Settings Globally

The recommended way to use the library is by configuring SMTP settings globally using the set_mail_config function:

from imhotep_mail import set_mail_config

# Set global SMTP configuration
set_mail_config(
    smtp_server='smtp.example.com',
    smtp_port=465,
    username='your-email@example.com',
    password='your-password',
    user_tls=True,  # Optional, default is True
    user_ssl=False  # Optional, default is False
)

Then, send emails using the send_mail function:

from imhotep_mail import send_mail

# Sending an email
success, error = send_mail(
    to_email='recipient@example.com',
    subject='Hello from Imhotep Mail!',
    body='This is a test email sent using the Imhotep Mail library.',
    is_html=False
)
if error:
    print(f"Error: {error}")
else:
    print(success)

Legacy Method: Passing SMTP Configuration Directly

For backward compatibility, you can still use the send_mail function by passing SMTP configuration directly. This method is not recommended for new code:

from imhotep_mail import send_mail

# Sending an email using the legacy method
success, error = send_mail(
    'smtp.example.com', 465, 'your-email@example.com', 'your-password',
    to_email='recipient@example.com',
    subject='Hello from Imhotep Mail!',
    body='This is a test email sent using the Imhotep Mail library.',
    is_html=False
)
if error:
    print(f"Error: {error}")
else:
    print(success)

Using Gmail with App Passwords

If you are using Gmail, you need to enable "App Passwords" to use this library. Follow these steps:

  1. Go to your Google Account Security Settings.
  2. Enable 2-Step Verification if it is not already enabled.
  3. Under "Signing in to Google," click on "App Passwords."
  4. Generate an app password for "Mail" and "Other" (e.g., "Imhotep Mail").
  5. Use the generated password in place of your Gmail account password in the set_mail_config function.

Example:

from imhotep_mail import set_mail_config, send_mail

# Set global SMTP configuration for Gmail
set_mail_config(
    smtp_server='smtp.gmail.com',
    smtp_port=587,
    username='your-email@gmail.com',
    password='your-app-password',
    user_tls=True,
    user_ssl=False
)

# Send an email
success, error = send_mail(
    to_email='recipient@example.com',
    subject='Hello from Imhotep Mail!',
    body='This is a test email sent using Gmail with App Passwords.',
    is_html=False
)
if error:
    print(f"Error: {error}")
else:
    print(success)

Sending an Email with Attachments

Both methods support sending emails with attachments. For example, using the recommended method:

from imhotep_mail import send_mail

# Sending an email with attachments
success, error = send_mail(
    to_email='recipient@example.com',
    subject='Hello from Imhotep Mail!',
    body='This is a test email sent using the Imhotep Mail library.',
    is_html=False,
    attachments=['path/to/attachment1.pdf', 'path/to/attachment2.jpg']
)
if error:
    print(f"Error: {error}")
else:
    print(success)

Using the CLI

The library also provides a CLI tool for sending emails. To use it, run the following command:

imhotep-mail-cli --to recipient@example.com --subject "Hello from CLI" --body "This is a test email sent using the CLI." --is-html --attachments path/to/attachment1.pdf path/to/attachment2.jpg --smtp-server smtp.gmail.com --smtp-port 587 --smtp-username your-email@gmail.com --smtp-password your-app-password --use-tls

CLI Arguments

  • --to: Recipient email address (required).
  • --subject: Email subject (required).
  • --body: Email body (required).
  • --is-html: Send email as HTML (optional).
  • --attachments: Paths to attachment files (optional).
  • --smtp-server: SMTP server address (optional, overrides environment variables).
  • --smtp-port: SMTP server port (optional, overrides environment variables).
  • --smtp-username: SMTP username (optional, overrides environment variables).
  • --smtp-password: SMTP password (optional, overrides environment variables).
  • --use-tls: Use TLS for SMTP (optional).
  • --use-ssl: Use SSL for SMTP (optional).

Contributing

Contributions are welcome! You can submit issues and pull requests to help improve the library.

License

MIT License. See LICENSE for more information.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

imhotep_mail-1.0.0.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

imhotep_mail-1.0.0-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file imhotep_mail-1.0.0.tar.gz.

File metadata

  • Download URL: imhotep_mail-1.0.0.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for imhotep_mail-1.0.0.tar.gz
Algorithm Hash digest
SHA256 4a42fda6af6c4402b9bc6ac44c2536755efc51d89937377ce15297bc55f13c3d
MD5 a9e0bf9c20da82c14adfc728c468ba48
BLAKE2b-256 41280d00c8e2edcc0b3e0c062f583b7bef7a8d3797a30b0c68d36e15995d6c95

See more details on using hashes here.

File details

Details for the file imhotep_mail-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: imhotep_mail-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 6.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for imhotep_mail-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fbaa02314fada5e44adb308fa58c1ef844cad04db648ca9a3f23e36a48edd1d8
MD5 741964cb01c137a914aa366e761d6866
BLAKE2b-256 5c064bd9879981809e38c1b4e8e9aa95d75bc70db871f752c8b154cae34e6f4f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page