mirror of
https://github.com/etesync/server
synced 2025-01-13 18:10:55 +00:00
Change user creation to not ask for a password (and clarify the readme).
This commit is contained in:
parent
801826b8b6
commit
47103df48a
@ -84,10 +84,9 @@ Create yourself an admin user:
|
||||
```
|
||||
|
||||
At this stage you need to create accounts to be used with the EteSync apps. To do that, please go to:
|
||||
`www.your-etesync-install.com/admin` and create a new user to be used with the service. Set a random
|
||||
password for the user such as `j3PmCRftyQMtM3eWvi8f`. No need to remember it, as it won't be used.
|
||||
Etebase uses a zero-knowledge proof for authentication, so the user will just create a password when
|
||||
creating the account from the apps.
|
||||
`www.your-etesync-install.com/admin` and create a new user to be used with the service. No need to set
|
||||
a password, as Etebase uses a zero-knowledge proof for authentication, so the user will just create
|
||||
a password when creating the account from the apps.
|
||||
|
||||
After this user has been created, you can use any of the EteSync apps to signup (or login) with the same username and
|
||||
email in order to set up the account. The password used at that point will be used to setup the account.
|
||||
|
@ -1,5 +1,16 @@
|
||||
from django.contrib import admin
|
||||
from django.contrib.auth.admin import UserAdmin
|
||||
from django.contrib.auth.admin import UserAdmin as DjangoUserAdmin
|
||||
from .models import User
|
||||
from .forms import AdminUserCreationForm
|
||||
|
||||
|
||||
class UserAdmin(DjangoUserAdmin):
|
||||
add_form = AdminUserCreationForm
|
||||
add_fieldsets = (
|
||||
(None, {
|
||||
'classes': ('wide',),
|
||||
'fields': ('username', ),
|
||||
}),
|
||||
)
|
||||
|
||||
admin.site.register(User, UserAdmin)
|
||||
|
30
myauth/forms.py
Normal file
30
myauth/forms.py
Normal file
@ -0,0 +1,30 @@
|
||||
from django import forms
|
||||
from django.contrib.auth import get_user_model
|
||||
from django.contrib.auth.forms import UsernameField
|
||||
|
||||
User = get_user_model()
|
||||
|
||||
|
||||
class AdminUserCreationForm(forms.ModelForm):
|
||||
"""
|
||||
A form that creates a user, with no privileges, from the given username and
|
||||
password.
|
||||
"""
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = ("username",)
|
||||
field_classes = {'username': UsernameField}
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
if self._meta.model.USERNAME_FIELD in self.fields:
|
||||
self.fields[self._meta.model.USERNAME_FIELD].widget.attrs['autofocus'] = True
|
||||
|
||||
def save(self, commit=True):
|
||||
user = super().save(commit=False)
|
||||
user.set_unusable_password()
|
||||
if commit:
|
||||
user.save()
|
||||
return user
|
||||
|
Loading…
Reference in New Issue
Block a user