8
0
Fork 0
mirror of https://gitlab2.federez.net/re2o/re2o synced 2024-12-23 23:43:47 +00:00

Merge branch 'crans' of https://gitlab.federez.net/federez/re2o into firewall

This commit is contained in:
grisel-davy 2018-07-16 15:39:10 +02:00
commit 50ab965ae3
4 changed files with 33 additions and 0 deletions

14
api/serializers.py Normal file → Executable file
View file

@ -631,6 +631,9 @@ class MailAliasSerializer(NamespacedHMSerializer):
fields = ('user', 'valeur', 'complete_mail')
# SERVICE REGEN
@ -648,6 +651,17 @@ class ServiceRegenSerializer(NamespacedHMSerializer):
'api_url': {'view_name': 'serviceregen-detail'}
}
# Configuration mail
class UserMailAliasSerializer(NamespacedHMSerializer):
get_mail_aliases = MailAliasSerializer(read_only=True, many=True)
class Meta:
model = users.User
fields = ('pseudo', 'get_mail_aliases')
# Switches et ports
class InterfaceVlanSerializer(NamespacedHMSerializer):

2
api/urls.py Normal file → Executable file
View file

@ -102,6 +102,8 @@ router.register_view(r'dhcp/hostmacip', views.HostMacIpView),
# Switches config
router.register_view(r'switchs/ports-config', views.SwitchPortView),
router.register_view(r'switchs/role', views.RoleView),
# Mail config
router.register_view(r'mail/alias', views.UserMailAliasView),
# Reminder
router.register_view(r'reminder/get-users', views.ReminderView),
# Firewall

11
api/views.py Normal file → Executable file
View file

@ -521,6 +521,17 @@ class RoleView(generics.ListAPIView):
serializer_class = serializers.RoleSerializer
# Server mail config
class UserMailAliasView(generics.ListAPIView):
"""Expose all the aliases of the users that activated the internal address
"""
queryset = users.User.objects.filter(internal_address=True)
serializer_class = serializers.UserMailAliasSerializer
# Rappel fin adhésion
class ReminderView(generics.ListAPIView):

6
users/models.py Normal file → Executable file
View file

@ -682,6 +682,12 @@ class User(RevMixin, FieldPermissionModelMixin, AbstractBaseUser,
else:
return str(self.mailalias_set.get(valeur=self.pseudo))
@cached_property
def get_mail_aliases(self):
if self.internal_address:
return self.mailalias_set.all()
return None
def get_next_domain_name(self):
"""Look for an available name for a new interface for
this user by trying "pseudo0", "pseudo1", "pseudo2", ...