views.py 8.42 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
# 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.
chirac's avatar
chirac committed
22 23 24 25
"""
Fonctions de la page d'accueil et diverses fonctions utiles pour tous
les views
"""
26

27 28
from __future__ import unicode_literals

29 30
import git

31
from django.shortcuts import render
32
from django.template.context_processors import csrf
33
from django.conf import settings
34
from django.utils.translation import ugettext as _
35 36
from django.views.decorators.cache import cache_page

37 38
from preferences.models import (
    Service,
39 40
    MailContact,
    GeneralOption,
41
    AssoOption,
Gabriel Detraz's avatar
Gabriel Detraz committed
42
    HomeOption
43
)
44

45
from .contributors import CONTRIBUTORS
chirac's avatar
chirac committed
46

Maël Kervella's avatar
Maël Kervella committed
47

chirac's avatar
chirac committed
48
def form(ctx, template, request):
chirac's avatar
chirac committed
49
    """Form générique, raccourci importé par les fonctions views du site"""
chirac's avatar
chirac committed
50 51 52
    context = ctx
    context.update(csrf(request))
    return render(request, template, context)
chirac's avatar
chirac committed
53 54 55


def index(request):
chirac's avatar
chirac committed
56
    """Affiche la liste des services sur la page d'accueil de re2o"""
57 58 59
    services = [[], [], []]
    for indice, serv in enumerate(Service.objects.all()):
        services[indice % 3].append(serv)
Gabriel Detraz's avatar
Gabriel Detraz committed
60 61 62
    twitter_url = HomeOption.get_cached_value('twitter_url')
    facebook_url = HomeOption.get_cached_value('facebook_url')
    twitter_account_name = HomeOption.get_cached_value('twitter_account_name')
63 64
    asso_name = AssoOption.get_cached_value('pseudo')
    return form({
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183
         'services_urls': services,
         'twitter_url': twitter_url,
         'twitter_account_name' : twitter_account_name,
         'facebook_url': facebook_url,
         'asso_name': asso_name
         }, 're2o/index.html', request)


#: Binding the corresponding char sequence of history url to re2o models.
HISTORY_BIND = {
    'users': {
        'user': users.models.User,
        'ban': users.models.Ban,
        'mailalias': users.models.MailAlias,
        'whitelist': users.models.Whitelist,
        'school': users.models.School,
        'listright': users.models.ListRight,
        'serviceuser': users.models.ServiceUser,
        'listshell': users.models.ListShell,
    },
    'preferences': {
        'service': preferences.models.Service,
        'mailcontact': preferences.models.MailContact,
    },
    '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,
        'modelswitch': topologie.models.ModelSwitch,
        'constructorswitch': topologie.models.ConstructorSwitch,
        'accesspoint': topologie.models.AccessPoint,
        'switchbay': topologie.models.SwitchBay,
        'building': topologie.models.Building,
    },
    'machines': {
        'machine': machines.models.Machine,
        'interface': machines.models.Interface,
        '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,
        'dname': machines.models.DName,
        'srv': machines.models.Srv,
        'ns': machines.models.Ns,
        'service': machines.models.Service,
        'role': machines.models.Role,
        'vlan': machines.models.Vlan,
        'nas': machines.models.Nas,
        'ipv6list': machines.models.Ipv6List,
        'sshfingerprint': machines.models.SshFingerprint,
        'sshfpralgo': machines.models.SshFprAlgo,
    },
}


@login_required
def history(request, application, object_name, object_id):
    """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:
        raise Http404(u"Il n'existe pas d'historique pour ce modèle.")
    object_name_id = object_name + 'id'
    kwargs = {object_name_id: object_id}
    try:
        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}
    )
>>>>>>> e42b8f9... Page de contact coté utilisateur
184

185

186
@cache_page(7 * 24 * 60 * 60)
187
def about_page(request):
188 189 190
    """ The view for the about page.
    Fetch some info about the configuration of the project. If it can't
    get the info from the Git repository, fallback to default string """
191
    option = AssoOption.objects.get()
192 193
    git_info_contributors = CONTRIBUTORS
    try:
194
        git_repo = git.Repo(settings.BASE_DIR)
195 196 197 198 199 200 201
        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")
202 203 204 205 206
        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

207
    dependencies = settings.INSTALLED_APPS + settings.MIDDLEWARE_CLASSES
208

209 210 211
    return render(
        request,
        "re2o/about.html",
212
        {
Maël Kervella's avatar
Maël Kervella committed
213 214
            'description': option.description,
            'AssoName': option.name,
215 216 217 218 219 220 221
            '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
        }
222
    )
223

224 225 226 227 228 229 230 231 232 233 234 235 236 237 238
def contact_page(request):
    """The view for the contact page
    Send all the objects MailContact
    """
    address = MailContact.objects.all()

    return render(
        request,
        "re2o/contact.html",
        {
            'contacts': address,
            'asso_name': AssoOption.objects.first().name
        }
    )

239 240 241 242

def handler500(request):
    """The handler view for a 500 error"""
    return render(request, 'errors/500.html')
243 244 245 246 247


def handler404(request):
    """The handler view for a 404 error"""
    return render(request, 'errors/404.html')