mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-25 00:18:10 +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 urllib.parse import urlparse
|
||||||
|
|
||||||
from django.apps import apps
|
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.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.dispatch import receiver
|
||||||
from django.db import models, transaction
|
from django.db import models, transaction
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
@ -356,8 +356,14 @@ class User(OrderedCollectionPageMixin, AbstractUser):
|
||||||
|
|
||||||
# make users editors by default
|
# make users editors by default
|
||||||
try:
|
try:
|
||||||
self.groups.add(Group.objects.get(name="editor"))
|
group = (
|
||||||
except Group.DoesNotExist:
|
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
|
# this should only happen in tests
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
|
@ -109,6 +109,36 @@ class User(TestCase):
|
||||||
self.assertEqual(activity["id"], self.user.outbox)
|
self.assertEqual(activity["id"], self.user.outbox)
|
||||||
self.assertEqual(activity["totalItems"], 0)
|
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):
|
def test_set_remote_server(self):
|
||||||
server = models.FederatedServer.objects.create(
|
server = models.FederatedServer.objects.create(
|
||||||
server_name=DOMAIN, application_type="test type", application_version=3
|
server_name=DOMAIN, application_type="test type", application_version=3
|
||||||
|
|
Loading…
Reference in a new issue