Я перенес старую установку Joomla в Django. Хэши паролей - это проблема. Мне пришлось изменить get_hexdigest в contrib.auth.models, чтобы иметь дополнительный оператор if, чтобы изменить способ генерирования хеша.
# Custom for Joomla
if algorithm == 'joomla':
return md5_constructor(raw_password + salt).hexdigest()
# Djangos original md5
if algorithm == 'md5':
return md5_constructor(salt + raw_password).hexdigest()
Я также добавил в модель User следующее, чтобы обновить пароли после входа в систему, если они имеют старый стиль joomla:
# Joomla Backwards compat
algo, salt, hsh = self.password.split('$')
if algo == 'joomla':
is_correct = (hsh == get_hexdigest(algo, salt, raw_password))
if is_correct:
# Convert the password to the new more secure format.
self.set_password(raw_password)
self.save()
return is_correct
Все работает отлично, но я бы не стал редактировать этот код непосредственно в дереве django. Есть ли более чистый способ сделать это в моем собственном проекте?
Спасибо