Тайна сигнала Django ... сервер разработки против удаленного сервера - PullRequest
0 голосов
/ 04 февраля 2012

После многих часов растягивания волос я обращаюсь к stackoverflow, чтобы помочь мне решить эту проблему.

Я создал два сигнала для запуска функций авто-электронной почты.Сигналы запускаются с помощью модификации save_model в моем файле admin.py.

Единственная проблема в том, что ... ОБА сигналов работают при запуске через сервер разработки Django (отправляются автоматические электронные письма),но только один из сигналов работает при тестировании на удаленном сервере.Я не понимаю, как это возможно, и я не смог найти ошибку.

Я знаю, что здесь не так много информации для работы.Любые предложения о том, что может происходить здесь?

Что касается структуры файла / каталога, эти сигналы сохраняются в файле signal.py, расположенном в каталоге для этого конкретного приложения.Сигнал запускается через изменение определения save_model в моем файле admin.py, в той же директории.

Вот определения сигналов:

notify_status_change_signal = Signal(providing_args=['status', 'restaurant', 'delivery_date', 'contact_email', 'contact_phone'])
notify_on_change_signal = Signal(providing_args=['organization', 'identifier', 'id', 'restaurant', 'delivery_date'])

@receiver(notify_on_change_signal)
def notify_on_change(sender, organization, identifier, id, restaurant, delivery_date, signal, *args, **kwargs):
    "This is the signal that only functions when run through the local development server"
    order_id = identifier + str(id)
    subject = r'A change has been made to order %s' % order_id
    body = """
    System Message: The details for order %s (%s) have been updated by the client.""" % (order_id, organization)

    send_mail(subject, body, 'System Notification <system@expressdelivery.com>', [admin_email], fail_silently=False)    


@receiver(notify_status_change_signal)
def notify_status_change(sender, status, restaurant, delivery_date, contact_email, contact_phone, signal, *args, **kwargs):
    """This is the signal that works on both servers"""
    stat_body = {
    'Confirmed':"""

Message 1 """,

    'Placed': """

Message 2 """,

    'En Route': """

Message 3 """,

    'Completed':"""

Message 4 """,
    }

    #Auto email
    from_addr = 'Order Status <status@expressdelivery.com>'
    to_addrs = [contact_email]
    subject = u'Order %s %s status changed to %s.' % (restaurant, delivery_date, status)
    body = ''
    for stat_label, description in stat_body.iteritems():
        if status == stat_label: body = description

    if status == "Confirmed" or status == "En Route" or status == "Completed":    
        send_mail(subject, body, from_addr, to_addrs, fail_silently=False)

    #Auto text message
    if status == 'En Route':
        client = TwilioRestClient(settings.TWILIO_ACCOUNT_SID, settings.TWILIO_AUTH_TOKEN)
        message = client.sms.messages.create(to=contact_phone,
                                     from_="5555555555",
                                     body="Your order, %s %s, is now en route." % (restaurant, delivery_date))

1 Ответ

0 голосов
/ 05 февраля 2012

Хотя я определенно перезапустил сервер, когда обновил код этими сигналами, перезапуск сервера снова сделал свое дело.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...