Pregunta

Quiero resolver un estado 405 que obtengo de la cola de tareas al intentar generar un informe:

2012-02-16 03:56:53.012 /report/ 405 3ms 0kb AppEngine-Google; (+http://code.google.com/appengine)

2012-02-16 03:56:53.007 /createreport/ 302 20ms 0kb Mozilla/5.0 (X11; Linux x86_64; rv:2.0) Gecko/20100101 Firefox/4.0
I 2012-02-16 03:56:52.990 creating report task

El código que crea la tarea es

class CreateReportHandler(webapp2.RequestHandler):

    def get(self):
        logging.info('creating report task')
        taskqueue.add(url=r'/report/')
        self.redirect('/')

Y lo tengo enrutado con WebApp2:

Route(r'/createreport/', handler=CreateReportHandler, name='createreport'),

Entonces debería poder convertirlo en un trabajo de cron, pero cuando lo pruebo, obtengo un 405 del acceso de este código qué tiempos de salida si intento ejecutarlo directamente:

class Report(webapp2.RequestHandler):

    def get(self):
        # Create a conversion request from HTML to PDF.
        users = User.query()
        today = date.today()
        startdate = date(today.year, today.month, 1) # first day of month   
        html = None     
        for user in users: 
            if user.activity() > 0:
                logging.info('found active user %s %s' % (user.firstname, user.lastname))
                html = '<html><body><table border="1">'
                html = html + '<tr><td>ORDER</td><td colspan="2">----DISTRIBUTOR----</td><td>ORDER</td><td>Silver</td><td>%</td><td>Total</td><td>Bonus</td></tr>'
                level = user.level()
                distributor = user
                while distributor.has_downline():
                    downline = User.query(User.sponsor == distributor.key).order(User.lastname).fetch()
                    for person in downline:  # to this for whole downline
                        orders = model.Order.all().filter('distributor_id =' , person.key.id()).filter('created >' , startdate).filter('status =', 'PAID').fetch(999999)
                        silver = 0
                        name = person.firstname +' '+ person.lastname
                        for order in orders:
                            logging.info('found orders')
                            for idx,item in enumerate(order.items):
                                purchase = model.Item.get_by_id(long(item.id()))
                                amount = int(order.amounts[idx])
                                silver = silver + amount*purchase.silver/1000.000 
                            if len(name) > 13:
                                name = name[13]
                            html = html + '<tr><td>' + str(order.created.date().day)+'/'+ str(order.created.date().month )+'</td><td>' + filters.makeid(person.key.id()) +'</td><td>' + name + '</td><td>' + str(order.key().id()) + '</td><td>' + str(silver) 
                            dist_level = order.dist_level
                            bonus = 0   
                            if level == 5 and dist_level == 4:                          
                                bonus = 0.05
                            if level == 5 and dist_level == 3:
                                bonus = 0.1
                            if level == 5 and dist_level == 2:
                                bonus = 0.13
                            if level == 5 and dist_level == 1:
                                bonus = 0.35

                            if level == 4 and dist_level == 3:                          
                                bonus = 0.05
                            if level == 4 and dist_level == 2:
                                bonus = 0.08
                            if level == 4 and dist_level == 1:
                                bonus = 0.3

                            if level == 3 and dist_level == 2:                          
                                bonus = 0.03
                            if level == 3 and dist_level == 1:
                                bonus = 0.25

                            if level == 2 and dist_level == 1:                          
                                bonus = 0.2

                            html = html + '</td><td>' + str(bonus) + '</td><td>' + str(order.total)
                            bonusmoney = bonus * float(order.total)
                            html = html + '</td><td>' + str(bonusmoney) + '</td></tr>'

                        distributor = person

                html = html + '</table>'

            asset = conversion.Asset("text/html", html, "test.html")
            conversion_obj = conversion.Conversion(asset, "application/pdf")        
            rpc = conversion.create_rpc()
            conversion.make_convert_call(rpc, conversion_obj)

            result = rpc.get_result()
            if result.assets:
                for asset in result.assets:
                    logging.info('emailing report')# to %s' % user.email)
                    message = mail.EmailMessage(sender='noreply@bnano.se',
                                    subject='Report %s %s' % (user.firstname, user.lastname))
                    message.body = 'Here is the monthly report'
                    message.to = 'niklasro@gmail.com'
                    message.bcc = 'fridge@koolbusiness.com'
                    message.attachments = ['report.pdf', asset.data]
                    message.send()
                    logging.info('message sent')

¿Cómo puedo resolver el estado 405 y superar la ejecución?

Gracias

¿Fue útil?

Solución

Vine de Gae/J-tierna, así que no estoy familiarizado con Python, pero había encontrado 405 Respuesta de mi trabajador de tareas antes. En mi caso, se debe a la configuración del TaskOption método a POST mientras construye el Task, mientras mi manejador solo sirve GET peticiones.

Editar: después de verificar el Taskqueue.add () documentos, parece que el método predeterminado utilizado si el método no se especifica (como en su ejemplo de código) es Post, mientras que su controlador parece que solo puede servir a las solicitudes GET.

Mi sugerencia sería especificar explícitamente que su tarea usa el método Get en lugar de POST, o cambiar el método manejado de su controlador en Post en lugar de obtener.

Otros consejos

Solo quiero agregar un escenario posible ya que una búsqueda rápida de "TaskQueue 405"Todo termina en esta página:

Obtuve 405 errores porque no especificó un parámetro de "objetivo". taskqueue.add() termina agregando la tarea al objetivo predeterminado, donde mis manejadores están en un módulo de backend separado.

Si el objetivo no se especifica, las tareas se invocan en la misma versión de la aplicación donde estaban enqueadas. Por lo tanto, si realizó una tarea de la versión de aplicación predeterminada sin especificar un objetivo en la cola, la tarea se invoca en la versión de aplicación predeterminada.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top