Облачные функции Google - скрипт электронной почты - ошибка CORS - PullRequest
0 голосов
/ 04 марта 2020

Я делаю функцию, которая получает данные через запрос POST и отправляет электронное письмо с этими данными. Когда я пытаюсь вызвать мою функцию из другого домена, я получаю следующую ошибку:

Доступ к XMLHttpRequest в 'моей функции' из источника 'chrome -поиск: // local-ntp' заблокирован Политика CORS: в запрошенном ресурсе отсутствует заголовок «Access-Control-Allow-Origin».

Я следовал инструкциям в облачной документации и добавил в начало моего кода следующее:

headers = {
    'Access-Control-Allow-Origin': '*',
    'Access-Control-Allow-Methods': '*',
    'Access-Control-Allow-Headers': 'Authorization',
    'Access-Control-Max-Age': '3600',
    'Access-Control-Allow-Credentials': 'true'
}
return ('', 204, headers)

Ошибка была устранена, но остальная часть моего кода не запускается после оператора return. Как я могу вставить заголовки и затем продолжить выполнение моего скрипта?

Весь код выглядит так:

import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.image import MIMEImage
from google.cloud import storage
import requests

def teste_email(request):

    headers = {
            'Access-Control-Allow-Origin': '*',
            'Access-Control-Allow-Methods': '*',
            'Access-Control-Allow-Headers': 'Authorization',
            'Access-Control-Max-Age': '3600',
            'Access-Control-Allow-Credentials': 'true'
    }
    return ('', 204, headers)


    # Pega as variáveis passadas no request
    request_json = request.get_json()
    nome_projeto = request_json['nome_projeto']
    logo_ic = request_json['logo_ic']
    logo_aplicacao = request_json['logo_aplicacao']
    title = request_json['title']
    link = request_json['link']
    descricao = request_json['descricao']
    base = request_json['base']

    # Lê o arquivo do template armazenado no cloud storage e o atribui a uma variável
    client = storage.Client()
    bucket = client.get_bucket('templates_email_icherry')
    blob = bucket.get_blob("template-1.txt")
    downloaded_blob = blob.download_as_string()
    template = downloaded_blob.decode("utf-8")

    # Substitui as variáveis no template pelos valores passados na chamada
    template = template.replace("{title}", title)
    template = template.replace("{logo_ic}", logo_ic)
    template = template.replace("{logo_aplicacao}", logo_aplicacao)
    template = template.replace("{descricao}", descricao)
    template = template.replace("{link}", link)
    template = template.replace("{nome_projeto}", nome_projeto)
    template = template.replace("{base}", base)

    # Variáveis para o envio do e-mail
    email = 'email'
    password = 'password'
    send_to_email = 'email'
    subject = 'Assunto do email'
    messagePlain = 'Message Plain'

    msg = MIMEMultipart('alternative')
    msg['From'] = email
    msg['To'] = send_to_email
    msg['Subject'] = subject

    msg.attach(MIMEText (messagePlain, 'plain'))
    msg.attach(MIMEText (template, 'html'))

    server = smtplib.SMTP('smtp.gmail.com', 587)
    server.starttls()
    server.login(email, password)
    text = msg.as_string()
    server.sendmail(email, send_to_email, text)
    server.quit()

1 Ответ

0 голосов
/ 06 марта 2020

В вашем коде вы должны поместить оператор return в конце вызова. Это потому, что return - это инструкция, которая останавливает выполнение текущего вызова функции и возвращает соответствующее значение.

Поэтому, если вы хотите, чтобы ваш код выполнялся И возвращал заголовки CORS, это должен быть последний вызов твоя функция. Вот такой код:

import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.image import MIMEImage
from google.cloud import storage
import requests

def teste_email(request):

    # Pega as variáveis passadas no request
    request_json = request.get_json()
    nome_projeto = request_json['nome_projeto']
    logo_ic = request_json['logo_ic']
    logo_aplicacao = request_json['logo_aplicacao']
    title = request_json['title']
    link = request_json['link']
    descricao = request_json['descricao']
    base = request_json['base']

    # Lê o arquivo do template armazenado no cloud storage e o atribui a uma variável
    client = storage.Client()
    bucket = client.get_bucket('templates_email_icherry')
    blob = bucket.get_blob("template-1.txt")
    downloaded_blob = blob.download_as_string()
    template = downloaded_blob.decode("utf-8")

    # Substitui as variáveis no template pelos valores passados na chamada
    template = template.replace("{title}", title)
    template = template.replace("{logo_ic}", logo_ic)
    template = template.replace("{logo_aplicacao}", logo_aplicacao)
    template = template.replace("{descricao}", descricao)
    template = template.replace("{link}", link)
    template = template.replace("{nome_projeto}", nome_projeto)
    template = template.replace("{base}", base)

    # Variáveis para o envio do e-mail
    email = 'email'
    password = 'password'
    send_to_email = 'email'
    subject = 'Assunto do email'
    messagePlain = 'Message Plain'

    msg = MIMEMultipart('alternative')
    msg['From'] = email
    msg['To'] = send_to_email
    msg['Subject'] = subject

    msg.attach(MIMEText (messagePlain, 'plain'))
    msg.attach(MIMEText (template, 'html'))

    server = smtplib.SMTP('smtp.gmail.com', 587)
    server.starttls()
    server.login(email, password)
    text = msg.as_string()
    server.sendmail(email, send_to_email, text)
    server.quit()

    headers = {
        'Access-Control-Allow-Origin': '*',
        'Access-Control-Allow-Methods': '*',
        'Access-Control-Allow-Headers': 'Authorization',
        'Access-Control-Max-Age': '3600',
        'Access-Control-Allow-Credentials': 'true'
    }
    return ('', 204, headers)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...