Skip to main content

Python module to, send SMS, emails and read unread emails.

Project description

Pypi-version Pypi-py-version

docs pypi

Pypi-format Pypi-status

Maintained GitHub Repo created GitHub commit activity GitHub last commit

Gmail Connector

Python module to, send SMS, emails and read unread emails in inbox folder.

Uses the default python modules:
  • email - Format emails as MIMEMultipart object, read emails from bytes and str and decode headers.
  • smtplib - SMTP Simple Mail Transfer Protocol to connect to gmail server, do auth and perform outgoing tasks.
  • imaplib - IMAP Internet Message Access Protocol to access messages in an email mailbox.
  • datetime - Uses datetime module to skim the date and time when the email arrived.

Pypi Module

https://pypi.org/project/gmail-connector/

Usage

pip install gmail-connector


Send SMS

from gmailconnector.send_sms import Messenger

response = Messenger(
    gmail_user='username@gmail.com',
    gmail_pass='<ACCOUNT_PASSWORD>',
    phone_number='+11234567890',
    message='Test SMS using gmail-connector'
).send_sms()
if response.ok:
    print(response.json())

Send Email

from gmailconnector.send_email import SendEmail

response = SendEmail(
        gmail_user='username@gmail.com',
        gmail_pass='<ACCOUNT_PASSWORD>',
        recipient='another_username@gmail.com',
        subject='Howdy!'
    ).send_email()
if response.ok:
    print(response.json())
More on SendEmail
Additional args:
  • body: Body of the email. Defaults to blank.
  • attachment: Filename that has to be attached.
  • cc: Email address of the recipient to whom the email has to be CC'd.
  • bcc: Email address of the recipient to whom the email has to be BCC'd.

Note: To send email to more than one recipient, wrap recipient/cc/bcc in a list.

recipient=['username1@gmail.com', 'username2@gmail.com']

Read Email

from gmailconnector.read_email import ReadEmail

ReadEmail(
    gmail_user='username@gmail.com',
    gmail_pass='<ACCOUNT_PASSWORD>'
).read_email()

Linting

PreCommit will ensure linting, and the doc creation are run on every commit.

Requirement
pip install --no-cache --upgrade sphinx pre-commit recommonmark

Usage
pre-commit run --all-files

Change Log

Requirement pip install --no-cache --upgrade changelog-generator

Usage changelog

Runbook

https://thevickypedia.github.io/gmail-connector/

License & copyright

© Vignesh Sivanandha Rao, Gmail Connector

Licensed under the MIT License

Change Log

0.3.6 (11/10/2021)

  • Return responses as a class object instead of a dictionary
  • Delete messages after sending an SMS
  • Do not remove docs directory if version is not bumped
  • Generate CHANGELOG in reverse

0.3.5 (10/16/2021)

  • Add project URLs and package requirements to pypi
  • Add markdown support to sphinx autodocs
  • Add a condition check for version upgrade
  • Update docs and changelog

0.3.4 (08/11/2021)

  • Add new lines to the message start to separate subject and body of the SMS
  • Update sphinx documentation to 4.1.2

0.3.3 (08/04/2021)

  • Fix incorrect HTTP return codes

0.3.2 (07/24/2021)

  • Remove logger module.
  • Add exception handlers for Messenger class.
  • Update docs and CHANGELOG
  • Bump version.

0.3.1 (07/22/2021)

  • Return a dictionary element after sending an email/SMS.
  • Add status code and description to return dict.
  • Update docs and CHANGELOG
  • Bump version.

0.3.0 (07/19/2021)

  • Allow users to add multiple recipients while sending email.
  • Add CC and BCC options.
  • Check if attachment file is available before trying to attach.
  • Wrap recipient, cc and bcc items in a single list before email kick off.
  • Remove sender arg and default to the user login email address.
  • Fix version number format.

0.2.9 (07/19/2021)

  • Add logging
  • Remove print statements
  • Bump version

0.2.8 (07/19/2021)

  • Bump version to support github action
  • Auto upload to pypi

0.2.7 (07/19/2021)

  • auto upload to pypi when tagged a release version

0.2.6 (07/19/2021)

  • onboard docs.yml but only prints a statement

0.2.5 (07/19/2021)

  • Add badges
  • Update README.md and CHANGELOG
  • Bump version

0.2.4 (07/18/2021)

  • Onboard pypi module
  • Add setup.py, setup.cfg, __init__.py, CHANGELOG
  • Update README.md and docs
  • Move files to gmailconnector support package

0.2.3 (07/18/2021)

  • Increase page width and update README.md

0.2.2 (07/18/2021)

  • Onboard send_sms.py and update docs

0.2.1 (07/17/2021)

  • Onboard sphinx auto generated documentation

0.2.0 (07/17/2021)

  • Refactor read_email.py and add send_email.py
  • Add pre-commit for linting
  • Update README.md

0.1.9 (06/28/2020)

  • update README.md

0.1.8 (06/28/2020)

  • add LICENSE

0.1.7 (06/28/2020)

  • look for env variables before failing

0.1.6 (06/27/2020)

  • included exception handler

0.1.5 (06/27/2020)

  • modify date time type standards instead of using index values

0.1.4 (06/11/2020)

  • fix typo

0.1.3 (06/09/2020)

  • improve coding standards

0.1.2 (06/08/2020)

  • improve coding standards

0.1.1 (06/08/2020)

  • added comments

0.1.0 (06/08/2020)

  • get user input before reading multiple emails

0.0.9 (06/08/2020)

  • get user input before showing any content

0.0.8 (06/08/2020)

  • include number of unread emails on top

0.0.7 (06/08/2020)

  • user input condition to read email

0.0.6 (06/08/2020)

  • pdt to cdt

0.0.5 (06/08/2020)

  • added time when the email was received

0.0.4 (06/08/2020)

  • decode body of the email and display only text part

0.0.3 (06/08/2020)

  • decode raw email using email library

0.0.2 (06/08/2020)

  • read raw email

0.0.1 (06/07/2020)

  • Initial commit

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

gmail-connector-0.3.6.tar.gz (10.7 kB view hashes)

Uploaded Source

Built Distribution

gmail_connector-0.3.6-py2.py3-none-any.whl (12.3 kB view hashes)

Uploaded Python 2 Python 3

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