Pregunta

Documentos dicen:

 ``success_url``
    The name of a URL pattern to redirect to on successful
    acivation. This is optional; if not specified, this will be
    obtained by calling the backend's
    ``post_activation_redirect()`` method.

¿Cómo puedo hacerlo?

¿Fue útil?

Solución

Puede hacerlo en su urls.py, por ejemplo:.

url(r'^account/activate/(?P<activation_key>\w+)/$', 'registration.views.activate', {'success_url': 'registration_activation_complete'}, name='registration_activate'),
url(r'^account/activate/success/$', direct_to_template, {'template': 'registration/activation_complete.html', name='registration_activation_complete'),

El otro enfoque es crear su propio backend (que es más sencillo de lo que parece) heredando desde el servidor por defecto:

from registration.backends.default import DefaultBackend

class MyRegistrationBackend(DefaultBackend):
    def post_activation_redirect(self, request, user):
        # return your URL here

La solución más fácil es simplemente el nombre de su patrón de URL que django-registro debe utilizar registration_activation_complete. Ver patrones de URL de nombres en la documentación de Django .

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