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

205 lines
7.3 KiB
Python
Raw Normal View History

2017-01-15 23:01:18 +00:00
# Re2o est un logiciel d'administration développé initiallement au rezometz. Il
# se veut agnostique au réseau considéré, de manière à être installable en
# quelques clics.
#
# Copyright © 2017 Gabriel Détraz
# Copyright © 2017 Goulven 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.
2017-10-14 02:48:43 +00:00
"""
Fonctions de la page d'accueil et diverses fonctions utiles pour tous
les views
"""
2017-01-15 23:01:18 +00:00
from __future__ import unicode_literals
from django.http import Http404
2018-01-06 17:51:17 +00:00
from django.urls import reverse
from django.shortcuts import render, redirect
from django.template.context_processors import csrf
from django.contrib.auth.decorators import login_required, permission_required
from reversion.models import Version
from django.contrib import messages
from django.conf import settings
2018-04-10 22:07:26 +00:00
from django.utils.translation import ugettext as _
2018-04-11 11:40:55 +00:00
from django.views.decorators.cache import cache_page
2018-04-10 22:07:26 +00:00
import git
import os
import time
from itertools import chain
2018-04-11 11:40:55 +00:00
2018-04-10 22:07:26 +00:00
from preferences.models import Service
from preferences.models import OptionalUser, GeneralOption, AssoOption
2017-12-28 13:17:09 +00:00
import users, preferences, cotisations, topologie, machines
2018-04-11 11:40:55 +00:00
from .utils import re2o_paginator
2018-04-10 22:07:26 +00:00
from .settings import BASE_DIR, INSTALLED_APPS, MIDDLEWARE_CLASSES
from .contributors import CONTRIBUTORS
2017-10-14 02:48:43 +00:00
2016-07-19 01:12:48 +00:00
def form(ctx, template, request):
2017-10-14 02:48:43 +00:00
"""Form générique, raccourci importé par les fonctions views du site"""
2017-10-13 20:47:32 +00:00
context = ctx
context.update(csrf(request))
return render(request, template, context)
2016-07-19 01:12:48 +00:00
def index(request):
2017-10-14 02:48:43 +00:00
"""Affiche la liste des services sur la page d'accueil de re2o"""
services = [[], [], []]
for indice, serv in enumerate(Service.objects.all()):
services[indice % 3].append(serv)
2016-11-17 03:55:34 +00:00
return form({'services_urls': services}, 're2o/index.html', request)
2017-12-28 13:43:43 +00:00
#: Binding the corresponding char sequence of history url to re2o models.
HISTORY_BIND = {
'users' : {
'user' : users.models.User,
'ban' : users.models.Ban,
'whitelist' : users.models.Whitelist,
'school' : users.models.School,
'listright' : users.models.ListRight,
'serviceuser' : users.models.ServiceUser,
2018-03-28 18:46:17 +00:00
'listshell' : users.models.ListShell,
},
'preferences' : {
'service' : preferences.models.Service,
},
'cotisations' : {
'facture' : cotisations.models.Facture,
'article' : cotisations.models.Article,
'paiement' : cotisations.models.Paiement,
'banque' : cotisations.models.Banque,
},
'topologie' : {
'switch' : topologie.models.Switch,
'port' : topologie.models.Port,
'room' : topologie.models.Room,
'stack' : topologie.models.Stack,
2018-03-28 18:46:17 +00:00
'modelswitch' : topologie.models.ModelSwitch,
'constructorswitch' : topologie.models.ConstructorSwitch,
2018-03-28 17:58:38 +00:00
'accesspoint' : topologie.models.AccessPoint,
2018-04-07 18:45:29 +00:00
'switchbay' : topologie.models.SwitchBay,
'building' : topologie.models.Building,
},
'machines' : {
'machine' : machines.models.Machine,
'interface' : machines.models.Interface,
2018-04-02 02:31:04 +00:00
'domain' : machines.models.Domain,
'machinetype' : machines.models.MachineType,
'iptype' : machines.models.IpType,
'extension' : machines.models.Extension,
'soa' : machines.models.SOA,
'mx' : machines.models.Mx,
'txt' : machines.models.Txt,
'srv' : machines.models.Srv,
'ns' : machines.models.Ns,
'service' : machines.models.Service,
'vlan' : machines.models.Vlan,
2018-03-28 17:58:38 +00:00
'nas' : machines.models.Nas,
'ipv6list' : machines.models.Ipv6List,
},
}
@login_required
def history(request, application, object_name, object_id):
2017-12-28 13:43:43 +00:00
"""Render history for a model.
The model is determined using the `HISTORY_BIND` dictionnary if none is
found, raises a Http404. The view checks if the user is allowed to see the
history using the `can_view` method of the model.
Args:
request: The request sent by the user.
object_name: Name of the model.
object_id: Id of the object you want to acces history.
Returns:
The rendered page of history if access is granted, else the user is
redirected to their profile page, with an error message.
Raises:
Http404: This kind of models doesn't have history.
"""
try:
model = HISTORY_BIND[application][object_name]
except KeyError as e:
raise Http404(u"Il n'existe pas d'historique pour ce modèle.")
2018-03-28 16:04:25 +00:00
object_name_id = object_name + 'id'
kwargs = {object_name_id: object_id}
try:
2018-03-28 16:04:25 +00:00
instance = model.get_instance(**kwargs)
except model.DoesNotExist:
messages.error(request, u"Entrée inexistante")
return redirect(reverse('users:profil',
kwargs={'userid':str(request.user.id)}
))
can, msg = instance.can_view(request.user)
if not can:
messages.error(request, msg or "Vous ne pouvez pas accéder à ce menu")
return redirect(reverse(
'users:profil',
kwargs={'userid':str(request.user.id)}
))
pagination_number = GeneralOption.get_cached_value('pagination_number')
reversions = Version.objects.get_for_object(instance)
if hasattr(instance, 'linked_objects'):
for related_object in chain(instance.linked_objects()):
reversions = reversions | Version.objects.get_for_object(related_object)
reversions = re2o_paginator(request, reversions, pagination_number)
return render(
request,
're2o/history.html',
{'reversions': reversions, 'object': instance}
)
2018-04-11 11:40:55 +00:00
@cache_page(7 * 24 * 60 * 60)
def about_page(request):
option = AssoOption.objects.get()
2018-04-10 22:07:26 +00:00
git_info_contributors = CONTRIBUTORS
try:
git_repo = git.Repo(BASE_DIR)
git_info_remote = ", ".join(git_repo.remote().urls)
git_info_branch = git_repo.active_branch.name
last_commit = git_repo.commit()
git_info_commit = last_commit.hexsha
git_info_commit_date = last_commit.committed_datetime
except:
NO_GIT_MSG = _("Unable to get the information")
2018-04-10 22:07:26 +00:00
git_info_remote = NO_GIT_MSG
git_info_branch = NO_GIT_MSG
git_info_commit = NO_GIT_MSG
git_info_commit_date = NO_GIT_MSG
dependencies = INSTALLED_APPS + MIDDLEWARE_CLASSES
return render(
request,
"re2o/about.html",
2018-04-10 22:07:26 +00:00
{
'description': option.description ,
'AssoName' : option.name ,
'git_info_contributors': git_info_contributors,
'git_info_remote': git_info_remote,
'git_info_branch': git_info_branch,
'git_info_commit': git_info_commit,
'git_info_commit_date': git_info_commit_date,
'dependencies': dependencies
}
)