mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-24 07:58:08 +00:00
Use default user auth group from site settings
This commit is contained in:
parent
2c680cb365
commit
7ae983acdf
2 changed files with 40 additions and 4 deletions
|
@ -3,9 +3,9 @@ import re
|
|||
from urllib.parse import urlparse
|
||||
|
||||
from django.apps import apps
|
||||
from django.contrib.auth.models import AbstractUser, Group
|
||||
from django.contrib.auth.models import AbstractUser
|
||||
from django.contrib.postgres.fields import ArrayField, CICharField
|
||||
from django.core.exceptions import PermissionDenied
|
||||
from django.core.exceptions import PermissionDenied, ObjectDoesNotExist
|
||||
from django.dispatch import receiver
|
||||
from django.db import models, transaction
|
||||
from django.utils import timezone
|
||||
|
@ -356,8 +356,14 @@ class User(OrderedCollectionPageMixin, AbstractUser):
|
|||
|
||||
# make users editors by default
|
||||
try:
|
||||
self.groups.add(Group.objects.get(name="editor"))
|
||||
except Group.DoesNotExist:
|
||||
group = (
|
||||
apps.get_model("bookwyrm.SiteSettings")
|
||||
.objects.get()
|
||||
.default_user_auth_group
|
||||
)
|
||||
if group:
|
||||
self.groups.add(group)
|
||||
except ObjectDoesNotExist:
|
||||
# this should only happen in tests
|
||||
pass
|
||||
|
||||
|
|
|
@ -109,6 +109,36 @@ class User(TestCase):
|
|||
self.assertEqual(activity["id"], self.user.outbox)
|
||||
self.assertEqual(activity["totalItems"], 0)
|
||||
|
||||
def test_save_auth_group(self):
|
||||
user_attrs = {"local": True}
|
||||
site = models.SiteSettings.get()
|
||||
|
||||
site.default_user_auth_group = Group.objects.get(name="editor")
|
||||
site.save()
|
||||
with patch("bookwyrm.suggested_users.rerank_suggestions_task.delay"), patch(
|
||||
"bookwyrm.activitystreams.populate_stream_task.delay"
|
||||
), patch("bookwyrm.lists_stream.populate_lists_task.delay"):
|
||||
user = models.User.objects.create_user(
|
||||
f"test2{DOMAIN}",
|
||||
"test2@bookwyrm.test",
|
||||
localname="test2",
|
||||
**user_attrs,
|
||||
)
|
||||
self.assertEqual(list(user.groups.all()), [Group.objects.get(name="editor")])
|
||||
|
||||
site.default_user_auth_group = None
|
||||
site.save()
|
||||
with patch("bookwyrm.suggested_users.rerank_suggestions_task.delay"), patch(
|
||||
"bookwyrm.activitystreams.populate_stream_task.delay"
|
||||
), patch("bookwyrm.lists_stream.populate_lists_task.delay"):
|
||||
user = models.User.objects.create_user(
|
||||
f"test1{DOMAIN}",
|
||||
"test1@bookwyrm.test",
|
||||
localname="test1",
|
||||
**user_attrs,
|
||||
)
|
||||
self.assertEqual(len(user.groups.all()), 0)
|
||||
|
||||
def test_set_remote_server(self):
|
||||
server = models.FederatedServer.objects.create(
|
||||
server_name=DOMAIN, application_type="test type", application_version=3
|
||||
|
|
Loading…
Reference in a new issue