def send_emails(email_id): members_not_sent_to = dao_get_members_not_sent_to(email_id) if current_app.config['ENVIRONMENT'] != 'live': limit = 3 current_app.logger.info('Task send_emails received %s, sending %d emails', email_id, limit or len(members_not_sent_to)) email = dao_get_email_by_id(email_id) for index, (member_id, email_to) in enumerate(members_not_sent_to): if limit and index > limit - 1: break subject = email.get_subject() message = None if email.email_type == EVENT: message = get_email_html(email.email_type, event_id=email.event_id, details=email.details, extra_txt=email.extra_txt, member_id=member_id) email_status_code = send_email(email_to, subject, message) dao_add_member_sent_to_email(email_id, member_id, status_code=email_status_code)
def send_emails(email_id): members_not_sent_to = dao_get_members_not_sent_to(email_id) if current_app.config.get('EMAIL_RESTRICT'): limit = 1 elif current_app.config.get('ENVIRONMENT') == 'live': email_provider = get_email_provider() limit = email_provider.limit else: limit = current_app.config.get('EMAIL_LIMIT') current_app.logger.info( 'Task send_emails received %s, sending %d emails', str(email_id), len(members_not_sent_to) if len(members_not_sent_to) < limit else limit) email = dao_get_email_by_id(email_id) try: for index, (member_id, email_to) in enumerate(members_not_sent_to): if limit and index > limit - 1 or email.email_state != APPROVED: current_app.logger.info("Email stopped - {}".format( "not approved" if email.email_state != APPROVED else f"limit reached: {limit}")) break subject = email.get_subject() message = None if email.email_type == EVENT: message = get_email_html(email.email_type, event_id=email.event_id, details=email.details, extra_txt=email.extra_txt, member_id=member_id) elif email.email_type == MAGAZINE: message = get_email_html(MAGAZINE, magazine_id=email.magazine_id, member_id=member_id) email_status_code, email_provider_id = send_email( email_to, subject, message) dao_add_member_sent_to_email(email_id, member_id, status_code=email_status_code, email_provider_id=email_provider_id) send_ga_event( f"Sent {email.email_type} email, {subject} - {str(email.id)}", "email", "send success" if email_status_code in [200, 201, 202] else "send failed", f"{subject} - {email.id}") except InvalidRequest as e: if e.status_code == 429: current_app.logger.error("Email limit reached: %r", e.message) if "Minute" in e.message: send_periodic_emails.apply_async(countdown=60) raise
def send_emails(email_id): members_not_sent_to = dao_get_members_not_sent_to(email_id) current_app.logger.info('Task send_emails received %s, sending %d emails', email_id, len(members_not_sent_to)) email = dao_get_email_by_id(email_id) for member_id, email_to in members_not_sent_to: subject = email.get_subject() message = None if email.email_type == EVENT: message = get_email_html( email.email_type, event_id=email.event_id, details=email.details, extra_txt=email.extra_txt) email_status_code = send_email(email_to, subject, message) dao_add_member_sent_to_email(email_id, member_id, status_code=email_status_code)
def update_email(email_id): data = request.get_json(force=True) validate(data, post_update_email_schema) if data['email_type'] == EVENT: try: event = dao_get_event_by_id(data.get('event_id')) except NoResultFound: raise InvalidRequest( 'event not found: {}'.format(data.get('event_id')), 400) email_data = {} for k in data.keys(): if hasattr(Email, k): email_data[k] = data[k] current_app.logger.info('Update email: {}'.format(email_data)) res = dao_update_email(email_id, **email_data) if res: email = dao_get_email_by_id(email_id) response = None emails_to = [user.email for user in dao_get_users()] if data.get('email_state') == READY: # send email to admin users and ask them to log in in order to approve the email review_part = '<div>Please review this email: {}/emails/{}</div>'.format( current_app.config['FRONTEND_ADMIN_URL'], str(email.id)) subject = None if email.email_type == EVENT: event = dao_get_event_by_id(email.event_id) subject = 'Please review {}'.format(event.title) event_html = get_email_html(**data) response = send_smtp_email(emails_to, subject, review_part + event_html) elif email.email_type == MAGAZINE: magazine = dao_get_magazine_by_id(email.magazine_id) subject = 'Please review {}'.format(magazine.title) magazine_html = get_email_html(MAGAZINE, magazine_id=magazine.id) response = send_smtp_email(emails_to, subject, review_part + magazine_html) elif data.get('email_state') == REJECTED: dao_update_email(email_id, email_state=REJECTED) message = '<div>Please correct this email <a href="{}">{}</a></div>'.format( '{}/emails/{}'.format(current_app.config['FRONTEND_ADMIN_URL'], str(email.id)), email.get_subject()) message += '<div>Reason: {}</div>'.format( data.get('reject_reason')) response = send_smtp_email( emails_to, '{} email needs to be corrected'.format(event.title), message) elif data.get('email_state') == APPROVED: later = datetime.utcnow() + timedelta( hours=current_app.config['EMAIL_DELAY']) if later < email.send_starts_at: later = email.send_starts_at + timedelta(hours=9) dao_update_email(email_id, send_after=later) review_part = '<div>Email will be sent after {}, log in to reject: {}/emails/{}</div>'.format( later.strftime("%d/%m/%Y %H:%M"), current_app.config['FRONTEND_ADMIN_URL'], str(email.id)) if email.email_type == EVENT: event_html = get_email_html(**data) response = send_smtp_email( emails_to, "{} has been approved".format(email.get_subject()), review_part + event_html) email_json = email.serialize() if response: email_json['email_status_code'] = response return jsonify(email_json), 200 raise InvalidRequest('{} did not update email'.format(email_id), 400)
def it_gets_an_email_by_id(self, db, db_session, sample_email): email = create_email(details='new event details') fetched_email = dao_get_email_by_id(email.id) assert fetched_email == email
def update_email(email_id): data = request.get_json(force=True) validate(data, post_update_email_schema) if data['email_type'] == EVENT: try: event = dao_get_event_by_id(data.get('event_id')) except NoResultFound: raise InvalidRequest('event not found: {}'.format(data.get('event_id')), 400) email_data = {} for k in data.keys(): if hasattr(Email, k): email_data[k] = data[k] current_app.logger.info('Update email: {}'.format(email_data)) res = dao_update_email(email_id, **email_data) if res: email = dao_get_email_by_id(email_id) response = None emails_to = [user.email for user in dao_get_users()] if data.get('email_state') == READY: subject = None if data['email_type'] == EVENT: event = dao_get_event_by_id(data.get('event_id')) subject = 'Please review {}'.format(event.title) # send email to admin users and ask them to log in in order to approve the email review_part = '<div>Please review this email: {}/emails/{}</div>'.format( current_app.config['FRONTEND_ADMIN_URL'], str(email.id)) event_html = get_email_html(**data) response = send_email(emails_to, subject, review_part + event_html) elif data.get('email_state') == REJECTED: if email.task_id: revoke_task(email.task_id) message = '<div>Please correct this email <a href="{}">{}</a></div>'.format( '{}/emails/{}'.format(current_app.config['FRONTEND_ADMIN_URL'], str(email.id)), email.get_subject()) message += '<div>Reason: {}</div>'.format(data.get('reject_reason')) response = send_email(emails_to, '{} email needs to be corrected'.format(event.title), message) elif data.get('email_state') == APPROVED: # send the email later in order to allow it to be rejected later = datetime.utcnow() + timedelta(seconds=current_app.config['EMAIL_DELAY']) if later < email.send_starts_at: later = email.send_starts_at + timedelta(hours=9) result = email_tasks.send_emails.apply_async(((str(email_id)),), eta=later) dao_update_email(email_id, task_id=result.id) current_app.logger.info('Task: send_email: %d, %r at %r', email_id, result.id, later) review_part = '<div>Email will be sent at {}, log in to reject: {}/emails/{}</div>'.format( later, current_app.config['FRONTEND_ADMIN_URL'], str(email.id)) event_html = get_email_html(**data) response = send_email( emails_to, "{} has been approved".format(email.get_subject()), review_part + event_html) email_json = email.serialize() if response: email_json['email_status_code'] = response return jsonify(email_json), 200 raise InvalidRequest('{} did not update email'.format(email_id), 400)