src/p4l/views.py
author ymh <ymh.work@gmail.com>
Mon, 02 Dec 2013 23:26:46 +0100
changeset 159 dbc7cce33ace
parent 145 7c6fe1dab213
child 161 216b3f9582aa
permissions -rw-r--r--
check that the value returned is an url. This effectively close bug #13, but really is a hack where the value should be tested to belong to a given thesaurus.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
d184767fdd52 first list view
cavaliet
parents:
diff changeset
     1
# -*- coding: utf-8 -*-
126
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     2
#
131
f1854630734f change copyright notice
ymh <ymh.work@gmail.com>
parents: 126
diff changeset
     3
# Copyright IRI (c) 2013
126
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     4
#
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     5
# contact@iri.centrepompidou.fr
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     6
#
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     7
# This software is governed by the CeCILL-B license under French law and
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     8
# abiding by the rules of distribution of free software.  You can  use, 
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
     9
# modify and/ or redistribute the software under the terms of the CeCILL-B
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    10
# license as circulated by CEA, CNRS and INRIA at the following URL
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    11
# "http://www.cecill.info". 
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    12
#
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    13
# As a counterpart to the access to the source code and  rights to copy,
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    14
# modify and redistribute granted by the license, users are provided only
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    15
# with a limited warranty  and the software's author,  the holder of the
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    16
# economic rights,  and the successive licensors  have only  limited
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    17
# liability. 
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    18
#
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    19
# In this respect, the user's attention is drawn to the risks associated
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    20
# with loading,  using,  modifying and/or developing or reproducing the
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    21
# software by the user in light of its specific status of free software,
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    22
# that may mean  that it is complicated to manipulate,  and  that  also
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    23
# therefore means  that it is reserved for developers  and  experienced
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    24
# professionals having in-depth computer knowledge. Users are therefore
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    25
# encouraged to load and test the software's suitability as regards their
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    26
# requirements in conditions enabling the security of their systems and/or 
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    27
# data to be ensured and,  more generally, to use and operate it in the 
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    28
# same conditions as regards security. 
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    29
#
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    30
# The fact that you are presently reading this means that you have had
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    31
# knowledge of the CeCILL-B license and that you accept its terms.
a345f1a67bf1 Python licence headers
ymh <ymh.work@gmail.com>
parents: 119
diff changeset
    32
#
1
d184767fdd52 first list view
cavaliet
parents:
diff changeset
    33
113
c05567404888 First version of indexation. Replace the list view by a search view
ymh <ymh.work@gmail.com>
parents: 99
diff changeset
    34
import json
c05567404888 First version of indexation. Replace the list view by a search view
ymh <ymh.work@gmail.com>
parents: 99
diff changeset
    35
import logging
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    36
import time
113
c05567404888 First version of indexation. Replace the list view by a search view
ymh <ymh.work@gmail.com>
parents: 99
diff changeset
    37
1
d184767fdd52 first list view
cavaliet
parents:
diff changeset
    38
from django.conf import settings
92
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
    39
from django.shortcuts import redirect, get_object_or_404
113
c05567404888 First version of indexation. Replace the list view by a search view
ymh <ymh.work@gmail.com>
parents: 99
diff changeset
    40
from django.views.generic import DetailView, View
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    41
from rest_framework.renderers import UnicodeJSONRenderer
113
c05567404888 First version of indexation. Replace the list view by a search view
ymh <ymh.work@gmail.com>
parents: 99
diff changeset
    42
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    43
from p4l.api.serializers import RecordSerializer
26
a0e152dd1fad first version of angular intégration
ymh <ymh.work@gmail.com>
parents: 20
diff changeset
    44
from p4l.models import Record
a0e152dd1fad first version of angular intégration
ymh <ymh.work@gmail.com>
parents: 20
diff changeset
    45
from p4l.utils import get_labels_for_uris
1
d184767fdd52 first list view
cavaliet
parents:
diff changeset
    46
7
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    47
1
d184767fdd52 first list view
cavaliet
parents:
diff changeset
    48
logger = logging.getLogger(__name__)
d184767fdd52 first list view
cavaliet
parents:
diff changeset
    49
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    50
QUERY_FIELDS_TRANSLATION = {
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    51
    'url': 'dataurl',
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    52
    'filter': 'dataquery',
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    53
    'root': 'datarootquery',
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    54
    'childs': 'datachildsquery',
145
7c6fe1dab213 Add a screen in the admin to launch commands. Fix bug #4 (https://github.com/IRI-Research/plan4learning/issues/4).
ymh <ymh.work@gmail.com>
parents: 131
diff changeset
    55
    'child-count': 'datachildcountquery'
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    56
}
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    57
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    58
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    59
def get_record_uri_labels(record, lang):
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    60
    uri_labels = get_labels_for_uris([s.uri for s in record.subjects.all()], settings.RDF_SCHEMES['subjects'], lang, False)
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    61
    uri_labels.update(get_labels_for_uris([s.uri for s in record.themes.all()], settings.RDF_SCHEMES['themes'], lang, False))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    62
    uri_labels.update(get_labels_for_uris([s.uri for s in record.countries.all()], settings.RDF_SCHEMES['countries'], lang, False))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    63
    uri_labels.update(get_labels_for_uris([record.language.uri] if record.language else [], settings.RDF_SCHEMES['languages'], lang, False))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    64
    uri_labels.update(get_labels_for_uris([s.uri for s in record.otherLanguages.all()], settings.RDF_SCHEMES['languages'], lang, False))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    65
    uri_labels.update(get_labels_for_uris([s.uri for s in record.projectNames.all()], settings.RDF_SCHEMES['projects'], None, True))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    66
    uri_labels.update(get_labels_for_uris([s.uri for s in record.subjectCorporateBodies.all()], settings.RDF_SCHEMES['organizations'], None, True))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    67
    uri_labels.update(get_labels_for_uris([s.uri for s in record.corporateAuthors.all()], settings.RDF_SCHEMES['organizations'], None, True))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    68
    uri_labels.update(get_labels_for_uris([record.recordType] if record.recordType else [], settings.RDF_SCHEMES['types'], lang, False))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    69
    uri_labels.update(get_labels_for_uris([s.uri for s in record.audiences.all()], settings.RDF_SCHEMES['audiences'], None, True))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    70
    return uri_labels
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    71
7
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    72
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    73
class RecordDetailView(DetailView):
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    74
    
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    75
    model = Record
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    76
    template_name = "p4l/record_view.html"
30
a84e31f1f223 update record view with slug
cavaliet
parents: 29
diff changeset
    77
    slug_field = "identifier"
7
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    78
    
17
b31a67614f76 fill labels with sparql request on the go
cavaliet
parents: 8
diff changeset
    79
    def get_context_data(self, **kwargs):
b31a67614f76 fill labels with sparql request on the go
cavaliet
parents: 8
diff changeset
    80
        context = DetailView.get_context_data(self, **kwargs)
20
fa466993084a get language for sparql request
cavaliet
parents: 17
diff changeset
    81
        # We get the language, "fr" by default
fa466993084a get language for sparql request
cavaliet
parents: 17
diff changeset
    82
        lang = "fr"
fa466993084a get language for sparql request
cavaliet
parents: 17
diff changeset
    83
        if "lang" in self.request.GET:
fa466993084a get language for sparql request
cavaliet
parents: 17
diff changeset
    84
            lang = self.request.GET["lang"]
fa466993084a get language for sparql request
cavaliet
parents: 17
diff changeset
    85
        elif hasattr(self.request, "LANGUAGE_CODE") and self.request.LANGUAGE_CODE in ["fr","en","es"]:
fa466993084a get language for sparql request
cavaliet
parents: 17
diff changeset
    86
            lang = self.request.LANGUAGE_CODE
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    87
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    88
        context['uri_labels'] = get_record_uri_labels(self.object,lang)
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    89
        
7
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    90
        
17
b31a67614f76 fill labels with sparql request on the go
cavaliet
parents: 8
diff changeset
    91
        return context
7
02008d61c3c8 record view + correct import
cavaliet
parents: 5
diff changeset
    92
34
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
    93
class RecordEditView(DetailView):
29
3a3b90b1abb2 Correction after rebase/merge
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
    94
    http_method_names = ['get']
3a3b90b1abb2 Correction after rebase/merge
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
    95
    template_name = 'p4l/record_update_form.html'
34
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
    96
    model = Record
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
    97
    slug_field = "identifier"
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    98
    is_create_view = False
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
    99
    
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   100
    def get_empty_object(self):
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   101
        
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   102
        obj = Record()
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   103
        obj.id = -1
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   104
        obj.identifier = "T" + str(int(time.time()))
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   105
        obj.uri = "http://www.iiep.unesco.org/plan4learning/record/" + obj.identifier
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   106
        
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   107
        return obj
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   108
    
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   109
    
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   110
    def get_object(self, *args, **kwargs):
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   111
        """
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   112
        Returns the object the view is displaying.
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   113
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   114
        By default this requires `self.queryset` and a `pk` or `slug` argument
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   115
        in the URLconf, but subclasses can override this to return any object.
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   116
        """
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   117
        if self.is_create_view:
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   118
            return self.get_empty_object()
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   119
        
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   120
        return super(RecordEditView, self).get_object(*args, **kwargs)
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   121
        
26
a0e152dd1fad first version of angular intégration
ymh <ymh.work@gmail.com>
parents: 20
diff changeset
   122
34
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   123
    def get_context_data(self, **kwargs):
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   124
        
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   125
        context = super(RecordEditView, self).get_context_data(**kwargs)
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   126
        
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   127
        if self.object:
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   128
            serializer = RecordSerializer(self.object)
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   129
            context['object_json'] = UnicodeJSONRenderer().render(serializer.data)
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   130
        else:
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   131
            context['object_json'] = "null"
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   132
        
34
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   133
        # We get the language, "fr" by default
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   134
        lang = "fr"
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   135
        if "lang" in self.request.GET:
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   136
            lang = self.request.GET["lang"]
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   137
        elif hasattr(self.request, "LANGUAGE_CODE") and self.request.LANGUAGE_CODE in ["fr","en","es"]:
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   138
            lang = self.request.LANGUAGE_CODE
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   139
        
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   140
        context['uri_labels'] = json.dumps(get_record_uri_labels(self.object,lang))
34
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   141
        
60
da37c87abbfb enhance add sem directive
cavaliet
parents: 57
diff changeset
   142
        # lang must be like "XX" in the sparql request 
da37c87abbfb enhance add sem directive
cavaliet
parents: 57
diff changeset
   143
        lang = '"' + lang + '"'
117
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   144
0a4e7d6ebe80 - Do not create object for new
ymh <ymh.work@gmail.com>
parents: 113
diff changeset
   145
        query_dicts = dict([(k , dict([ (QUERY_FIELDS_TRANSLATION[key],value.format(lang=lang)) for key,value in v.items()  ])) for k,v in settings.SPARQL_REF_QUERIES.items()])
57
3a8a55131180 clean and debug
cavaliet
parents: 52
diff changeset
   146
        context['query_dicts'] = json.dumps(query_dicts)
38
c4e5bb735ec1 jquery autocomplete with angular for subjects
cavaliet
parents: 35
diff changeset
   147
        
70
2ee11f57e318 language list in directive template
cavaliet
parents: 62
diff changeset
   148
        # Languages list used in drop down list
2ee11f57e318 language list in directive template
cavaliet
parents: 62
diff changeset
   149
        context['languages_list'] = json.dumps(settings.LANGUAGES_LIST)
119
ece69ca3ac24 - correct import pour indexation
ymh <ymh.work@gmail.com>
parents: 117
diff changeset
   150
        
ece69ca3ac24 - correct import pour indexation
ymh <ymh.work@gmail.com>
parents: 117
diff changeset
   151
        context['is_create_view'] = json.dumps(self.is_create_view)
74
ad7d84868c98 add back buttopn on edit
ymh <ymh.work@gmail.com>
parents: 70
diff changeset
   152
                
34
cfc090f440d0 add uri labels + dict
ymh <ymh.work@gmail.com>
parents: 33
diff changeset
   153
        return context
92
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   154
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   155
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   156
class RecordDeleteView(View):
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   157
    def get(self, request, slug, **kwargs):
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   158
        rec = get_object_or_404(Record, identifier=slug)
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   159
        rec.delete()
57633a3acc4f delete record
cavaliet
parents: 78
diff changeset
   160
        return redirect('p4l_home')
145
7c6fe1dab213 Add a screen in the admin to launch commands. Fix bug #4 (https://github.com/IRI-Research/plan4learning/issues/4).
ymh <ymh.work@gmail.com>
parents: 131
diff changeset
   161
7c6fe1dab213 Add a screen in the admin to launch commands. Fix bug #4 (https://github.com/IRI-Research/plan4learning/issues/4).
ymh <ymh.work@gmail.com>
parents: 131
diff changeset
   162