Я использую dj-rest-auth с реакцией и пытаюсь использовать внешний URL-адрес вместо внутреннего URL-адреса. Решение, которое я использую для электронного письма с подтверждением создания учетной записи, также влияет на электронное письмо для сброса пароля, но только частично. Это не влияет на порт. Он только пытается добавить ключ в ссылку сброса там, где его нет, и выдает мне ошибку.
Поэтому мне было интересно, есть ли способ изменить URL-адрес с порта 8000 на порт 3000. Это то, что я пробовал:
class AccountAdapter(DefaultAccountAdapter):
def is_open_for_signup(self, request: HttpRequest):
return getattr(settings, "ACCOUNT_ALLOW_REGISTRATION", True)
def send_mail(self, template_prefix, email, context):
if settings.DEBUG:
context["activate_url"] = (
"http://localhost:3000/accounts/confirm-email/" + context["key"]
)
else:
context["activate_url"] = (
settings.FRONTEND_URL + "/accounts/confirm-email/" + context["key"]
)
return super().send_mail(template_prefix, email, context)
Если я избавлюсь от ключевой части, это не выдаст мне ошибку, но сохранит порт 8000 и сломает электронные письма с подтверждением моей учетной записи. Если я не избавлюсь от ключа, он дает мне:
django | "http://localhost:3000/accounts/confirm-email/" + context["key"]
django | KeyError: 'key'
Это исправило это для меня: https://stackoverflow.com/a/70624462/3530084
сериализаторы.py
class CustomAllAuthPasswordResetForm(AllAuthPasswordResetForm):
def save(self, request, **kwargs):
current_site = get_current_site(request)
email = self.cleaned_data['email']
token_generator = kwargs.get('token_generator',
default_token_generator)
for user in self.users:
temp_key = token_generator.make_token(user)
# save it to the password reset model
# password_reset = PasswordReset(user=user, temp_key=temp_key)
# password_reset.save()
# send the password reset email
path = reverse(
'password_reset_confirm',
args=[user_pk_to_url_str(user), temp_key],
)
url = build_absolute_uri(None, path) # PASS NONE INSTEAD OF REQUEST
context = {
'current_site': current_site,
'user': user,
'password_reset_url': url,
'request': request,
}
if app_settings.AUTHENTICATION_METHOD != app_settings.AuthenticationMethod.EMAIL:
context['username'] = user_username(user)
get_adapter(request).send_mail('account/email/password_reset_key',
email, context)
return self.cleaned_data['email']
class CustomPasswordResetSerializer(PasswordResetSerializer):
@property
def password_reset_form_class(self):
return CustomAllAuthPasswordResetForm
settings.py
REST_AUTH_SERIALIZERS = {
'PASSWORD_RESET_SERIALIZER':
'seniorpark.users.api.serializers.CustomPasswordResetSerializer',
}