mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2025-01-22 16:14:28 +00:00
354 lines
9 KiB
Python
354 lines
9 KiB
Python
# -*- mode: python; coding: utf-8 -*-
|
|
# Re2o est un logiciel d'administration développé initiallement au Rézo Metz. Il
|
|
# se veut agnostique au réseau considéré, de manière à être installable en
|
|
# quelques clics.
|
|
#
|
|
# Copyright © 2017 Gabriel Détraz
|
|
# Copyright © 2017 Lara Kermarec
|
|
# Copyright © 2017 Augustin Lemesle
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
"""
|
|
Admin views basic definition, include basic definition of admin view.
|
|
|
|
Except for Admin edition and creation of users and services users;
|
|
with AdherentAdmin, ClubAdmin and ServiceUserAdmin.
|
|
"""
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
from django.contrib import admin
|
|
from django.contrib.auth.models import Group
|
|
from django.contrib.auth.admin import UserAdmin as BaseUserAdmin
|
|
from reversion.admin import VersionAdmin
|
|
|
|
from .models import (
|
|
User,
|
|
EMailAddress,
|
|
ServiceUser,
|
|
School,
|
|
ListRight,
|
|
ListShell,
|
|
Adherent,
|
|
Club,
|
|
Ban,
|
|
Whitelist,
|
|
Request,
|
|
LdapUser,
|
|
LdapServiceUser,
|
|
LdapServiceUserGroup,
|
|
LdapUserGroup,
|
|
)
|
|
from .forms import (
|
|
UserAdminForm,
|
|
ServiceUserAdminForm,
|
|
)
|
|
|
|
|
|
class LdapUserAdmin(admin.ModelAdmin):
|
|
"""LdapUser Admin view. Can't change password, manage
|
|
by User General model.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
list_display = ("name", "uidNumber", "login_shell")
|
|
exclude = ("user_password", "sambat_nt_password")
|
|
search_fields = ("name",)
|
|
|
|
|
|
class LdapServiceUserAdmin(admin.ModelAdmin):
|
|
"""LdapServiceUser Admin view. Can't change password, manage
|
|
by User General model.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
list_display = ("name",)
|
|
exclude = ("user_password",)
|
|
search_fields = ("name",)
|
|
|
|
|
|
class LdapUserGroupAdmin(admin.ModelAdmin):
|
|
"""LdapUserGroup Admin view.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
list_display = ("name", "members", "gid")
|
|
search_fields = ("name",)
|
|
|
|
|
|
class LdapServiceUserGroupAdmin(admin.ModelAdmin):
|
|
"""LdapServiceUserGroup Admin view.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
list_display = ("name",)
|
|
search_fields = ("name",)
|
|
|
|
|
|
class SchoolAdmin(VersionAdmin):
|
|
"""School Admin view and management.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
class ListRightAdmin(VersionAdmin):
|
|
"""ListRight and groups Admin view and management.
|
|
Even if it is possible, gid should NOT be changed
|
|
as it is the ldap primary key.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
list_display = ("unix_name",)
|
|
|
|
|
|
class ListShellAdmin(VersionAdmin):
|
|
"""Users Shell Admin view and management.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
class RequestAdmin(admin.ModelAdmin):
|
|
"""User Request Admin view and management, for
|
|
change password and email validation.
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
list_display = ("user", "type", "created_at", "expires_at")
|
|
|
|
|
|
class BanAdmin(VersionAdmin):
|
|
"""Ban Admin view and management, for
|
|
User Ban
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
class EMailAddressAdmin(VersionAdmin):
|
|
"""EmailAddress Admin view and management, for
|
|
auxiliary and local email addresses
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
class WhitelistAdmin(VersionAdmin):
|
|
"""Whitelist Admin view and management, for
|
|
free access whitelisted users
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
class AdherentAdmin(VersionAdmin, BaseUserAdmin):
|
|
"""Adherent Admin view and management, for
|
|
Adherent fields : password, pseudo, etc, admin can
|
|
edit all fields on user instance.
|
|
Inherit from django BaseUserAdmin
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
# The forms to add and change user instances
|
|
|
|
add_form = UserAdminForm
|
|
form = UserAdminForm
|
|
|
|
list_display = (
|
|
"pseudo",
|
|
"name",
|
|
"surname",
|
|
"email",
|
|
"local_email_redirect",
|
|
"local_email_enabled",
|
|
"school",
|
|
"shell",
|
|
)
|
|
list_filter = ()
|
|
fieldsets = (
|
|
(None, {"fields": ("pseudo",)}),
|
|
(
|
|
"Personal info",
|
|
{"fields": ("surname", "name", "email", "school", "shell", "uid_number", "password1", "password2")},
|
|
),
|
|
)
|
|
# add_fieldsets is not a standard ModelAdmin attribute. UserAdmin
|
|
# overrides get_fieldsets to use this attribute when creating a user.
|
|
add_fieldsets = (
|
|
(
|
|
None,
|
|
{
|
|
"classes": ("wide",),
|
|
"fields": (
|
|
"pseudo",
|
|
"surname",
|
|
"name",
|
|
"email",
|
|
"school",
|
|
"password1",
|
|
"password2",
|
|
"is_superuser",
|
|
),
|
|
},
|
|
),
|
|
)
|
|
search_fields = ("pseudo", "surname", "name")
|
|
ordering = ("pseudo",)
|
|
filter_horizontal = ()
|
|
|
|
|
|
class ClubAdmin(VersionAdmin, BaseUserAdmin):
|
|
"""Club Admin view and management, for
|
|
Club fields : password, pseudo, etc, admin can
|
|
edit all fields on user instance.
|
|
Inherit from django BaseUserAdmin
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
# The forms to add and change user instances
|
|
add_form = UserAdminForm
|
|
form = UserAdminForm
|
|
|
|
list_display = (
|
|
"pseudo",
|
|
"surname",
|
|
"email",
|
|
"local_email_redirect",
|
|
"local_email_enabled",
|
|
"school",
|
|
"shell",
|
|
)
|
|
list_filter = ()
|
|
fieldsets = (
|
|
(None, {"fields": ("pseudo",)}),
|
|
(
|
|
"Personal info",
|
|
{"fields": ("surname", "email", "school", "shell", "uid_number", "password1", "password2")},
|
|
),
|
|
)
|
|
|
|
add_fieldsets = (
|
|
(
|
|
None,
|
|
{
|
|
"classes": ("wide",),
|
|
"fields": (
|
|
"pseudo",
|
|
"surname",
|
|
"email",
|
|
"school",
|
|
"password1",
|
|
"password2",
|
|
"is_superuser",
|
|
),
|
|
},
|
|
),
|
|
)
|
|
search_fields = ("pseudo", "surname")
|
|
ordering = ("pseudo",)
|
|
filter_horizontal = ()
|
|
|
|
|
|
class ServiceUserAdmin(VersionAdmin, BaseUserAdmin):
|
|
"""ServiceUser Admin view and management, for
|
|
User fields : password, pseudo, etc, admin can
|
|
edit all fields on user instance.
|
|
Inherit from django BaseUserAdmin
|
|
|
|
Parameters:
|
|
Django ModelAdmin: Apply on django ModelAdmin
|
|
|
|
"""
|
|
|
|
# The forms to add and change user instances
|
|
form = ServiceUserAdminForm
|
|
add_form = ServiceUserAdminForm
|
|
|
|
# The fields to be used in displaying the User model.
|
|
# These override the definitions on the base UserAdmin
|
|
# that reference specific fields on auth.User.
|
|
list_display = ("pseudo", "access_group")
|
|
list_filter = ()
|
|
fieldsets = ((None, {"fields": ("pseudo", "access_group", "comment", "password1", "password2")}),)
|
|
# add_fieldsets is not a standard ModelAdmin attribute. UserAdmin
|
|
# overrides get_fieldsets to use this attribute when creating a user.
|
|
add_fieldsets = (
|
|
(None, {"classes": ("wide",), "fields": ("pseudo", "password1", "password2")}),
|
|
)
|
|
search_fields = ("pseudo",)
|
|
ordering = ("pseudo",)
|
|
filter_horizontal = ()
|
|
|
|
|
|
admin.site.register(Adherent, AdherentAdmin)
|
|
admin.site.register(Club, ClubAdmin)
|
|
admin.site.register(ServiceUser, ServiceUserAdmin)
|
|
admin.site.register(LdapUser, LdapUserAdmin)
|
|
admin.site.register(LdapUserGroup, LdapUserGroupAdmin)
|
|
admin.site.register(LdapServiceUser, LdapServiceUserAdmin)
|
|
admin.site.register(LdapServiceUserGroup, LdapServiceUserGroupAdmin)
|
|
admin.site.register(School, SchoolAdmin)
|
|
admin.site.register(ListRight, ListRightAdmin)
|
|
admin.site.register(ListShell, ListShellAdmin)
|
|
admin.site.register(Ban, BanAdmin)
|
|
admin.site.register(EMailAddress, EMailAddressAdmin)
|
|
admin.site.register(Whitelist, WhitelistAdmin)
|
|
admin.site.register(Request, RequestAdmin)
|
|
# ... and, since we're not using Django's built-in permissions,
|
|
# unregister the Group model from admin.
|
|
admin.site.unregister(Group)
|