Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/maxbezs/cartel-connect

Google Sheets Email Sender with OAuth2 Authentication. A Flask-based web application to authenticate users using Google OAuth2 and send emails to recipients specified in a Google Sheet.
https://github.com/maxbezs/cartel-connect

bulk-email-sender bulkemail email-sender emailsender flask googleoauth2 mongodb

Last synced: about 1 month ago
JSON representation

Google Sheets Email Sender with OAuth2 Authentication. A Flask-based web application to authenticate users using Google OAuth2 and send emails to recipients specified in a Google Sheet.

Awesome Lists containing this project

README

        

> I am not responsible for your actions. By downloading software from this repository, you agree to follow the law. Use it for your own risk. I don't want to be another Oppenheimer and made this tool with good intentions




Project Banner



Google Sheets Email Sender with OAuth2 Authentication


Send Emails in Seconds using Google Sheets and a User-Friendly Website

## 📋 Table of Contents

1. 🤖 [Introduction](#introduction)
2. 🔋 [Features](#features)
3. 🤸 [Quick Start](#quick-start)

## 🤖 Introduction

This project is a Flask-based web application designed to streamline the process of sending emails using data from a Google Sheet. With the power of Google OAuth2 authentication, users can securely sign in with their Google accounts, access specific Google Sheets, and send personalized emails to recipients listed in the sheet.

## 🔋 Features

👉**User Authentication with Google OAuth2**

- Users can sign in with their Google accounts.
- The application requests access to:
- Google Drive metadata
- Google Spreadsheets
- Gmail (to send emails)
- User email and profile information (to display data in email)

👉**Email Sending from Google Sheet Data**

- Users can specify the columns and ranges from a Google Sheet to fetch recipient emails, email subjects, and email bodies.
- Emails are sent to the specified recipients using the Gmail API.
- The application handles potential errors, such as invalid email addresses and reaching the Gmail API daily limit.

👉**Environment Variables:**

- **ALLOWED_ORIGINS**: List of allowed CORS origins.
- **FLASK_SECRET_KEY**: Secret key for Flask session.
- **MONGO_URI**: MongoDB connection string.
- **CLIENT_ID**: Google OAuth2 client ID.
- **PROJECT_ID**: Google OAuth2 project ID.
- **CLIENT_SECRET**: Google OAuth2 client secret.
- **REDIRECT_URIS**: List of allowed redirect URIs for OAuth2.
- **JAVASCRIPT_ORIGINS**: List of JavaScript origins for OAuth2.

👉**Endpoints:**

- **/**: Home route to serve sign-in page and account details.
- **/authorize**: Initiates the OAuth2 authorization flow.
- **/oauth2callback**: Callback URL for OAuth2 authorization.
- **/account**: Account management route to fetch and display user data and send emails.
- **/clear**: Route to clear user session and logout.

👉**Functions:**

- **serve()**: Handles GET and POST requests for the home route. It checks the user's session and redirects to the account page after successful authentication.
- **authorize()**: Initiates the OAuth2 authorization flow and redirects the user to Google's authorization page.
- **oauth2callback()**: Handles the OAuth2 callback, fetches user credentials, and redirects to the home route.
- **account()**: Handles GET and POST requests for the account route. It fetches the specified Google Sheet data and sends emails.
- **clear()**: Clears the user's session and redirects to the home page.
- **send_email()**: Sends emails using the Gmail API based on the fetched Google Sheet data.
- **credentials_to_dict()**: Converts OAuth2 credentials to a dictionary format.

## 🤸 Quick Start

1. Clone the repository.
2. Install the required dependencies using `pip install -r requirements.txt`.
3. Set up the required environment variables in a `.env` file.
4. Make enviroment: `py -3 -m venv .venv `.
5. Activate flask enviroment `.venv\Scripts\activate`.
6. Install all required dependencies.
7. Run the application using `flask run`.