Skip to main content

Simple lightweight mail library for FastApi

Project description

Fastapi-mail

The fastapi-mail simple lightweight mail system, sending emails and attachments(individual && bulk)

MIT licensed GitHub stars GitHub forks GitHub issues Downloads

🔨 Installation

 $ pip install fastapi-mail

Documentation: FastApi-MAIL

The key features are:

  • sending emails with either with FastApi or using asyncio module
  • sending emails using FastApi background task managment
  • sending files either from form-data or files from server
  • Using Jinja2 HTML Templates
  • email utils (utility allows you to check temporary email addresses, you can block any email or domain)
  • email utils has two available classes DefaultChecker and WhoIsXmlApi
  • Unittests using FastapiMail

More information on Getting-Started

Guide

from fastapi import FastAPI, BackgroundTasks, UploadFile, File, Form
from starlette.responses import JSONResponse
from starlette.requests import Request
from fastapi_mail import FastMail, MessageSchema,ConnectionConfig
from pydantic import BaseModel, EmailStr
from typing import List



class EmailSchema(BaseModel):
    email: List[EmailStr]


conf = ConnectionConfig(
    MAIL_USERNAME = "YourUsername",
    MAIL_PASSWORD = "strong_password",
    MAIL_FROM = "your@email.com",
    MAIL_PORT = 587,
    MAIL_SERVER = "your mail server",
    MAIL_TLS = True,
    MAIL_SSL = False,
    USE_CREDENTIALS = True,
    VALIDATE_CERTS = True
)

app = FastAPI()


html = """
<p>Thanks for using Fastapi-mail</p> 
"""


@app.post("/email")
async def simple_send(email: EmailSchema) -> JSONResponse:

    message = MessageSchema(
        subject="Fastapi-Mail module",
        recipients=email.dict().get("email"),  # List of recipients, as many as you can pass 
        body=html,
        subtype="html"
        )

    fm = FastMail(conf)
    await fm.send_message(message)
    return JSONResponse(status_code=200, content={"message": "email has been sent"})     

List of Examples

For more examples of using fastapi-mail please check example section

Contributing

Feel free to open issues and send pull requests.

Contributors ✨

Thanks goes to these wonderful people (🚧):


🚧

Sabuhi Shukurov

💬 👀 🚧

Tural Muradov

📖 👀 🔧

Hasan Aliyev

📖 🚧 👀

Ashwani

🚧

Leon Xu

🚧

Gabriel Oliveira

📖 🚧

Onothoja Marho

📖 🚧 🔧

Tim Kiely

🚧

Dmitriy Solodkiy

🚧

Peter Boers

🚧

James Valentine

📖 🚧 🔧

Gogoku

📖 🚧 🔧

Kucera-Lukas

📖 🚧 🔧

LLYX

📖 🚧 🔧

floodpants

🚧

André Felipe Dias

📖 👀 🔧

This project follows the all-contributors specification. Contributions of any kind are welcome!

Before you start please read CONTRIBUTING

LICENSE

MIT

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

fastapi-mail-0.4.0.4.tar.gz (14.9 kB view details)

Uploaded Source

Built Distribution

fastapi_mail-0.4.0.4-py3-none-any.whl (15.2 kB view details)

Uploaded Python 3

File details

Details for the file fastapi-mail-0.4.0.4.tar.gz.

File metadata

  • Download URL: fastapi-mail-0.4.0.4.tar.gz
  • Upload date:
  • Size: 14.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.9 CPython/3.8.11 Linux/5.8.0-1041-azure

File hashes

Hashes for fastapi-mail-0.4.0.4.tar.gz
Algorithm Hash digest
SHA256 9222f323814113637bcea03c5d3055e556cdc71a2635afe401705d9866e02dee
MD5 ab8074cab5ca0a901b3787eda5ceffb9
BLAKE2b-256 7ca3c92febb35b820ed9ae210d114317c7f0ab6b9787f718a572f7668f017f25

See more details on using hashes here.

File details

Details for the file fastapi_mail-0.4.0.4-py3-none-any.whl.

File metadata

  • Download URL: fastapi_mail-0.4.0.4-py3-none-any.whl
  • Upload date:
  • Size: 15.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.9 CPython/3.8.11 Linux/5.8.0-1041-azure

File hashes

Hashes for fastapi_mail-0.4.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a3c1174ebe454d98327e180cdeac96152e4b72ae8c67ab8497a42886ff0caac9
MD5 466010e457d52d5ac25ca3f8c6e7ef10
BLAKE2b-256 5e644837875e7ca867f015b985f09ece8d8338a020998a15e2a7951388dfafdc

See more details on using hashes here.

Supported by

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