alcatel/controller/DocumentaryFile.py
author cobled
Wed, 14 Aug 2013 16:36:41 +0200
changeset 37 3848e1813a30
parent 27 8ca7f2cea729
child 42 de4e97ded3c6
permissions -rw-r--r--
last version
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     1
'''
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     2
Created on 27 juil. 2012
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     3
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     4
@author: gerard
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     5
'''
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     6
import datetime
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     7
import logging
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
     8
import simplejson
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
     9
from time import  mktime 
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    10
from django.core.cache import cache
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    11
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    12
from dataparser.ClientDocumentaryFileAttributes import ClientDocumentaryFileAttributes
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    13
from dataparser.ClientDocumentaryFileVisibilityAttributes import ClientDocumentaryFileVisibilityAttribute
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    14
from dataparser.ClientDocumentaryFileDeleteAttributes import ClientDocumentaryFileDeleteAttributes
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    15
from document.models import Cluster
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    16
from document.models import Image
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    17
from document.models import Document
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    18
from document.models import Documentaryfile
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    19
from document.models import Clusterdocumentweight
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    20
from django.contrib.auth.models import User
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    21
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    22
logger = logging.getLogger('document')
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    23
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    24
class DocumentaryFile(object):
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    25
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    26
    def __init__(self, request):
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    27
        logger.info('DocumentaryFile init')
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    28
        self.request = request
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    29
           
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    30
    def create(self):
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    31
        logger.info('create DocumentaryFile')
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    32
        attr = ClientDocumentaryFileAttributes(self.request)
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
    33
        '''logger.info('user = ' + str(attr.get_user()))
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    34
        logger.info('query_id = ' + str(attr.get_query_id()))
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
    35
        logger.info('public = ' + str(attr.get_visibility()))'''
3848e1813a30 last version
cobled
parents: 27
diff changeset
    36
        
3848e1813a30 last version
cobled
parents: 27
diff changeset
    37
        #query_id = attr.get_query_id()
3848e1813a30 last version
cobled
parents: 27
diff changeset
    38
        if attr.get_query_id():
3848e1813a30 last version
cobled
parents: 27
diff changeset
    39
            key1 = cache.get(attr.get_query_id())
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    40
            context = cache.get(key1['weblab_data_key'])
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
    41
        elif self.request.session['key1']:
3848e1813a30 last version
cobled
parents: 27
diff changeset
    42
            context = cache.get(self.request.session['key1'])
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    43
        else:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    44
            json = '{"Error": "Invalid query id"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    45
            logger.info(json)
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
    46
                   
3848e1813a30 last version
cobled
parents: 27
diff changeset
    47
        if context == None:
3848e1813a30 last version
cobled
parents: 27
diff changeset
    48
            logger.info("cache empty")
3848e1813a30 last version
cobled
parents: 27
diff changeset
    49
            json = '{"Error": "cache empty"}'
3848e1813a30 last version
cobled
parents: 27
diff changeset
    50
            logger.info(json)
3848e1813a30 last version
cobled
parents: 27
diff changeset
    51
        else:
3848e1813a30 last version
cobled
parents: 27
diff changeset
    52
            logger.info("cache not empty")
3848e1813a30 last version
cobled
parents: 27
diff changeset
    53
            list_concepts,concepts_with_detailed_documents_list = context
3848e1813a30 last version
cobled
parents: 27
diff changeset
    54
            logger.info('list_concepts' + str(list_concepts))
3848e1813a30 last version
cobled
parents: 27
diff changeset
    55
            logger.info('concepts_with_detailed_documents_list' + str(concepts_with_detailed_documents_list))
3848e1813a30 last version
cobled
parents: 27
diff changeset
    56
            #parse to get the value to save the documentary file
3848e1813a30 last version
cobled
parents: 27
diff changeset
    57
            json = self.parseAndSaveValue(list_concepts,concepts_with_detailed_documents_list, attr )
3848e1813a30 last version
cobled
parents: 27
diff changeset
    58
       
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    59
        return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    60
    
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    61
    def visibilityChange(self):
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    62
        logger.info('visibilityChange')
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    63
        attr = ClientDocumentaryFileVisibilityAttribute(self.request)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    64
        logger.info('get_user = ' + str(attr.get_user()))
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    65
        logger.info('get_documentary_file_id = ' + str(attr.get_documentary_file_id()))
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    66
        logger.info('get_visibility = ' + str(attr.get_visibility()))
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    67
        try:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    68
            documentaryfile = Documentaryfile.objects.get(pk=attr.get_documentary_file_id())
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    69
        except Documentaryfile.DoesNotExist:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    70
            json = '{"Error": "Invalid documentary id"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    71
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    72
            return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    73
        
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    74
        logger.info('documentaryfile.user.name = ' + str(documentaryfile.user.username))
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    75
        if documentaryfile.user.username == attr.get_user():
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    76
            if attr.get_visibility() == 'public':
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    77
                visibility_attr = True
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    78
            elif attr.get_visibility() == 'private':
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    79
                visibility_attr = False
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    80
            else:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    81
                json = '{"Error" : "Invalid visibility parameter"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    82
                logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    83
                return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    84
            
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    85
            for thecluster in documentaryfile.cluster_set.all():
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    86
                for thedocument in thecluster.document.all():
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    87
                    for theannotationdoc in thedocument.annotationdocument_set.all():
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    88
                        theannotationdoc.visibility = visibility_attr
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    89
                        theannotationdoc.save()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    90
                       
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    91
            documentaryfile.visibility = visibility_attr
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    92
            documentaryfile.save()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    93
            json = '{"visibility": "' + attr.get_visibility() + '"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    94
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    95
        else:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    96
            json = '{"Error": "User does not matched"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    97
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    98
       
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
    99
        return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   100
        
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   101
    def delete(self,docId):
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   102
        logger.info('delete DocumentaryFile')
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   103
        #attr = ClientDocumentaryFileDeleteAttributes(self.request)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   104
        '''logger.info('get_user = ' + str(attr.get_user()))
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   105
        logger.info('get_documentary_file_id = ' + str(attr.get_documentary_file_id()))
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   106
        docId = attr.get_documentary_file_id()'''
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   107
        if docId == '':
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   108
            json= '{"Error": "No documentary_file_id attribute in the http post request"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   109
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   110
            return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   111
        
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   112
        try:
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   113
            documentaryfile = Documentaryfile.objects.get(pk=docId)
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   114
        except Documentaryfile.DoesNotExist:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   115
            json= '{"Error": "Invalid documentary_file_id"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   116
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   117
            return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   118
        
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   119
        logger.info('documentaryfile.user.username = ' + str(documentaryfile.user.username))
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   120
        logger.info('self.request.user = ' + str(self.request.user))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   121
        if str(documentaryfile.user.username) == str(self.request.user):
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   122
            #verify if the associated documents are associated to another documentaryfile. if not delete the documents
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   123
            for thecluster in documentaryfile.cluster_set.all():     
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   124
                for thedocument in thecluster.document.all():
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   125
                    nb = (Clusterdocumentweight.objects.filter(document_id=thedocument.documentId)).count()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   126
                    logger.info('nb' + str(nb))
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   127
                    if nb == 1:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   128
                        thedocument.delete()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   129
           
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   130
            documentaryfile.delete()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   131
            json = '{"documentary_file_deleted" :' + str(docId) + '}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   132
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   133
        else:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   134
            json= '{"Error": "User does not match"}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   135
            logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   136
        return json  
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   137
    
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   138
    def parseAndSaveValue(self, list_concepts,concepts_with_detailed_documents_list, attr):
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   139
        #parse the context
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   140
        logger.info('query_context ********** ='+str(self.request.session.items()))
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   141
        try:
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   142
            #text = str(((attr.get_user()).replace(' ', '')).replace('\n', ''))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   143
            text = str(attr.get_user())
3848e1813a30 last version
cobled
parents: 27
diff changeset
   144
            logger.info('attr.get_user! !!! = '+text)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   145
            tutu = 'cobled'
3848e1813a30 last version
cobled
parents: 27
diff changeset
   146
            logger.info('attr.get_user! !!! = '+text)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   147
            user_attr = User.objects.get(username=tutu)
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   148
        except User.DoesNotExist, err:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   149
            logger.info(' Error: '+ str(err))
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   150
            json = '{"Error": "User does not existed"}' 
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   151
            return json
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   152
        visibility_attr = attr.get_visibility()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   153
        if visibility_attr == 'public':
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   154
            visibility_bool = True
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   155
        else:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   156
            visibility_bool = False
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   157
            
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   158
        title_attr = attr.get_title()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   159
        description_attr = attr.get_description()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   160
        #query_id_attr = attr.get_query_id()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   161
        #TODO url image
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   162
               
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   163
        now = datetime.datetime.now()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   164
        mktime(now.timetuple())
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   165
        logger.info(mktime(now.timetuple()))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   166
        
3848e1813a30 last version
cobled
parents: 27
diff changeset
   167
        for concept_index, concept_with_detailed_documents_list in enumerate(concepts_with_detailed_documents_list) :
3848e1813a30 last version
cobled
parents: 27
diff changeset
   168
            logger.info('url image first cluster'+list_concepts[concept_index]['url_image'])
3848e1813a30 last version
cobled
parents: 27
diff changeset
   169
            image1 = Image(url=list_concepts[concept_index]['url_image'])
3848e1813a30 last version
cobled
parents: 27
diff changeset
   170
            image1.save()
3848e1813a30 last version
cobled
parents: 27
diff changeset
   171
            break
3848e1813a30 last version
cobled
parents: 27
diff changeset
   172
        if  attr.get_json_streamgraph():
3848e1813a30 last version
cobled
parents: 27
diff changeset
   173
            logger.info('attr.get_json_streamgraph ****'+str(attr.get_json_streamgraph()))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   174
            jsonstreamgraph = attr.get_json_streamgraph()
3848e1813a30 last version
cobled
parents: 27
diff changeset
   175
        else:
3848e1813a30 last version
cobled
parents: 27
diff changeset
   176
            logger.info('request_streamgraph ****'+str(self.request.session['jsonStreamgraph']))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   177
            jsonstreamgraph = self.request.session['jsonStreamgraph']
3848e1813a30 last version
cobled
parents: 27
diff changeset
   178
        
3848e1813a30 last version
cobled
parents: 27
diff changeset
   179
        if attr.get_json_treemap():
3848e1813a30 last version
cobled
parents: 27
diff changeset
   180
            logger.info('attr.get_json_streamgraph ****'+str(attr.get_json_treemap()))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   181
            jsontreemap = attr.get_json_treemap()
3848e1813a30 last version
cobled
parents: 27
diff changeset
   182
        else:
3848e1813a30 last version
cobled
parents: 27
diff changeset
   183
            logger.info('request_streamgraph ****'+str(self.request.session['jsonTreemap']))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   184
            jsontreemap = self.request.session['jsonTreemap']
3848e1813a30 last version
cobled
parents: 27
diff changeset
   185
      
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   186
        # create the documentary file
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   187
        #dossierDoc1 = Documentaryfile(title=title_attr, date=now , description=description_attr, visibility=visibility_bool, list_concepts=list_concepts, concepts_with_detailed_documents_list = concepts_with_detailed_documents_list, image=image1, user=user_attr)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   188
        dossierDoc1 = Documentaryfile(title=title_attr, date=now , description=description_attr, visibility=visibility_bool, jsonstreamgraph=jsonstreamgraph, jsontreemap = jsontreemap, image=image1, user=user_attr, list_concepts=list_concepts, concepts_with_detailed_documents_list = concepts_with_detailed_documents_list,)
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   189
        dossierDoc1.save()
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   190
3848e1813a30 last version
cobled
parents: 27
diff changeset
   191
        data = simplejson.loads(self.request.session['jsonTreemap'])
3848e1813a30 last version
cobled
parents: 27
diff changeset
   192
        logger.info('DATA BEFORE ***'+str(data))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   193
        for cluster in data['clusters']:
3848e1813a30 last version
cobled
parents: 27
diff changeset
   194
            cluster['doc_id'] = int(dossierDoc1.id)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   195
            cluster['user'] = dossierDoc1.user.username
3848e1813a30 last version
cobled
parents: 27
diff changeset
   196
        logger.info('DATA AFTER ***'+str(data))
3848e1813a30 last version
cobled
parents: 27
diff changeset
   197
        jsontreemap = simplejson.dumps(data)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   198
        dossierDoc1.jsontreemap = jsontreemap
3848e1813a30 last version
cobled
parents: 27
diff changeset
   199
        dossierDoc1.save()
3848e1813a30 last version
cobled
parents: 27
diff changeset
   200
        #nb_concept = len(concepts_with_detailed_documents_list)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   201
        
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   202
        for concept_index, concept_with_detailed_documents_list in enumerate(concepts_with_detailed_documents_list) :
37
3848e1813a30 last version
cobled
parents: 27
diff changeset
   203
            imagecluster = Image(url=list_concepts[concept_index]['url_image'])
3848e1813a30 last version
cobled
parents: 27
diff changeset
   204
            imagecluster.save()
3848e1813a30 last version
cobled
parents: 27
diff changeset
   205
            cluster1 = Cluster.objects.create(title=list_concepts[concept_index]['title'], description=list_concepts[concept_index]['abstract'], weight=list_concepts[concept_index]['score'], documentaryfile=dossierDoc1, image=imagecluster)
3848e1813a30 last version
cobled
parents: 27
diff changeset
   206
            logger.info('CLUSTERID'+str(cluster1.id))
27
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   207
            for detailed_document in concept_with_detailed_documents_list:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   208
                #Verify if the document exist already in database
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   209
                try:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   210
                    doc1 = Document.objects.get(pk=detailed_document['id'])
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   211
                except Document.DoesNotExist:
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   212
                    doc1 = Document.objects.create(documentId=detailed_document['id'], title=detailed_document['title'],description=detailed_document['abstract'],date=datetime.datetime.fromtimestamp(int(detailed_document['date'])).isoformat(), image=image1)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   213
                    
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   214
                clusterDocWeight1 = Clusterdocumentweight(cluster=cluster1, document=doc1, weight=detailed_document['weight'])
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   215
                clusterDocWeight1.save()
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   216
        json= '{"documentary_file_created":' + str(dossierDoc1.id) + '}'
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   217
        logger.info(json)
8ca7f2cea729 add alcatel folder
cobled@FRVILN0H401086.emea.lucent.com
parents:
diff changeset
   218
        return json