alcatel/controller/DocumentaryFile.py
author obledc
Tue, 10 Sep 2013 13:25:16 +0200
changeset 42 de4e97ded3c6
parent 37 3848e1813a30
permissions -rw-r--r--
new

'''
Created on 27 juil. 2012

@author: gerard
'''
import datetime
import logging
import simplejson
from time import  mktime 
from django.core.cache import cache

from dataparser.ClientDocumentaryFileAttributes import ClientDocumentaryFileAttributes
from dataparser.ClientDocumentaryFileVisibilityAttributes import ClientDocumentaryFileVisibilityAttribute
from document.models import Cluster
from document.models import Image
from document.models import Document
from document.models import Documentaryfile
from document.models import Clusterdocumentweight
from django.contrib.auth.models import User

logger = logging.getLogger('document')

class DocumentaryFile(object):

    def __init__(self, request):
        logger.info('DocumentaryFile init')
        self.request = request
           
    def create(self):
        logger.info('create DocumentaryFile')
        attr = ClientDocumentaryFileAttributes(self.request)
        '''logger.info('user = ' + str(attr.get_user()))
        logger.info('query_id = ' + str(attr.get_query_id()))
        logger.info('public = ' + str(attr.get_visibility()))'''
        
        #query_id = attr.get_query_id()
        if attr.get_query_id():
            key1 = cache.get(attr.get_query_id())
            context = cache.get(key1['weblab_data_key'])
        elif self.request.session['key1']:
            context = cache.get(self.request.session['key1'])
        else:
            json = '{"Error": "Invalid query id"}'
            logger.info(json)
                   
        if context == None:
            logger.info("cache empty")
            json = '{"Error": "cache empty"}'
            logger.info(json)
        else:
            logger.info("cache not empty")
            list_concepts,concepts_with_detailed_documents_list = context
            logger.info('list_concepts' + str(list_concepts))
            logger.info('concepts_with_detailed_documents_list' + str(concepts_with_detailed_documents_list))
            #parse to get the value to save the documentary file
            json = self.parseAndSaveValue(list_concepts,concepts_with_detailed_documents_list, attr )
       
        return json
    
    
    def modify(self,attr):
        logger.info('modify')
        
        logger.info('get_description = ' + str(attr.get_description().encode("utf8")))
        logger.info('get_title = ' + str(attr.get_title().encode("utf8")))
        logger.info('get_visibility = ' + str(attr.get_visibility()))
        try:
            documentaryfile = Documentaryfile.objects.get(pk=attr.get_documentary_file_id())
        except Documentaryfile.DoesNotExist:
            json = '{"Error": "Invalid documentary id"}'
            logger.info(json)
            return json
        
        logger.info('documentaryfile.user.name = ' + str(documentaryfile.user.username))
        if documentaryfile.user.username == attr.get_user():
            if attr.get_visibility() == 'on':
                visibility_attr = True
            else:
                visibility_attr = False
            '''else:
                json = '{"Error" : "Invalid visibility parameter"}'
                logger.info(json)
                return json'''
            
            for thecluster in documentaryfile.cluster_set.all():
                for thedocument in thecluster.document.all():
                    for theannotationdoc in thedocument.annotationdocument_set.all():
                        theannotationdoc.visibility = visibility_attr
                        theannotationdoc.save()
            
            title_attr = str(attr.get_title().encode("utf8"))
            description_attr = str(attr.get_description().encode("utf8"))
                      
            documentaryfile.visibility = visibility_attr
            documentaryfile.title = title_attr
            documentaryfile.description = description_attr
            
            documentaryfile.save()
            json = '{"modif": ok "}'
            logger.info(json)
        else:
            json = '{"Error": "User does not matched"}'
            logger.info(json)
       
        return json
    
    
    def visibilityChange(self):
        logger.info('visibilityChange')
        attr = ClientDocumentaryFileVisibilityAttribute(self.request)
        logger.info('get_user = ' + str(attr.get_user()))
        logger.info('get_documentary_file_id = ' + str(attr.get_documentary_file_id()))
        logger.info('get_visibility = ' + str(attr.get_visibility()))
        try:
            documentaryfile = Documentaryfile.objects.get(pk=attr.get_documentary_file_id())
        except Documentaryfile.DoesNotExist:
            json = '{"Error": "Invalid documentary id"}'
            logger.info(json)
            return json
        
        logger.info('documentaryfile.user.name = ' + str(documentaryfile.user.username))
        if documentaryfile.user.username == attr.get_user():
            if attr.get_visibility() == 'public':
                visibility_attr = True
            elif attr.get_visibility() == 'private':
                visibility_attr = False
            else:
                json = '{"Error" : "Invalid visibility parameter"}'
                logger.info(json)
                return json
            
            for thecluster in documentaryfile.cluster_set.all():
                for thedocument in thecluster.document.all():
                    for theannotationdoc in thedocument.annotationdocument_set.all():
                        theannotationdoc.visibility = visibility_attr
                        theannotationdoc.save()
                       
            documentaryfile.visibility = visibility_attr
            documentaryfile.save()
            json = '{"visibility": "' + attr.get_visibility() + '"}'
            logger.info(json)
        else:
            json = '{"Error": "User does not matched"}'
            logger.info(json)
       
        return json
        
    def delete(self,docId):
        logger.info('delete DocumentaryFile')
        #attr = ClientDocumentaryFileDeleteAttributes(self.request)
        '''logger.info('get_user = ' + str(attr.get_user()))
        logger.info('get_documentary_file_id = ' + str(attr.get_documentary_file_id()))
        docId = attr.get_documentary_file_id()'''
        if docId == '':
            json= '{"Error": "No documentary_file_id attribute in the http post request"}'
            logger.info(json)
            return json
        
        try:
            documentaryfile = Documentaryfile.objects.get(pk=docId)
        except Documentaryfile.DoesNotExist:
            json= '{"Error": "Invalid documentary_file_id"}'
            logger.info(json)
            return json
        
        logger.info('documentaryfile.user.username = ' + str(documentaryfile.user.username))
        logger.info('self.request.user = ' + str(self.request.user))
        if str(documentaryfile.user.username) == str(self.request.user):
            #verify if the associated documents are associated to another documentaryfile. if not delete the documents
            for thecluster in documentaryfile.cluster_set.all():     
                for thedocument in thecluster.document.all():
                    nb = (Clusterdocumentweight.objects.filter(document_id=thedocument.documentId)).count()
                    logger.info('nb' + str(nb))
                    if nb == 1:
                        thedocument.delete()
           
            documentaryfile.delete()
            json = '{"documentary_file_deleted" :' + str(docId) + '}'
            logger.info(json)
        else:
            json= '{"Error": "User does not match"}'
            logger.info(json)
        return json  
    
    def parseAndSaveValue(self, list_concepts,concepts_with_detailed_documents_list, attr):
        #parse the context
        logger.info('query_context ********** ='+str(self.request.session.items()))
        try:
            #text = str(((attr.get_user()).replace(' ', '')).replace('\n', ''))
            text = str(attr.get_user())
            logger.info('attr.get_user! !!! = '+text)
            tutu = 'cobled'
            logger.info('attr.get_user! !!! = '+text)
            user_attr = User.objects.get(username=tutu)
        except User.DoesNotExist, err:
            logger.info(' Error: '+ str(err))
            json = '{"Error": "User does not existed"}' 
            return json
        visibility_attr = attr.get_visibility()
        if visibility_attr == 'public':
            visibility_bool = True
        else:
            visibility_bool = False
            
        title_attr = attr.get_title()
        description_attr = attr.get_description()
        #query_id_attr = attr.get_query_id()
        #TODO url image
               
        now = datetime.datetime.now()
        mktime(now.timetuple())
        logger.info(mktime(now.timetuple()))
        
        for concept_index, concept_with_detailed_documents_list in enumerate(concepts_with_detailed_documents_list) :
            logger.info('url image first cluster'+list_concepts[concept_index]['url_image'])
            image1 = Image(url=list_concepts[concept_index]['url_image'])
            image1.save()
            break
        if  attr.get_json_streamgraph():
            logger.info('attr.get_json_streamgraph ****'+str(attr.get_json_streamgraph()))
            jsonstreamgraph = attr.get_json_streamgraph()
        else:
            logger.info('request_streamgraph ****'+str(self.request.session['jsonStreamgraph']))
            jsonstreamgraph = self.request.session['jsonStreamgraph']
        
        if attr.get_json_treemap():
            logger.info('attr.get_json_streamgraph ****'+str(attr.get_json_treemap()))
            jsontreemap = attr.get_json_treemap()
        else:
            logger.info('request_streamgraph ****'+str(self.request.session['jsonTreemap']))
            jsontreemap = self.request.session['jsonTreemap']
      
        # create the documentary file
        #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)
        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,)
        dossierDoc1.save()

        data = simplejson.loads(self.request.session['jsonTreemap'])
        logger.info('DATA BEFORE ***'+str(data))
        for cluster in data['clusters']:
            cluster['doc_id'] = int(dossierDoc1.id)
            cluster['user'] = dossierDoc1.user.username
        logger.info('DATA AFTER ***'+str(data))
        jsontreemap = simplejson.dumps(data)
        dossierDoc1.jsontreemap = jsontreemap
        dossierDoc1.save()
        #nb_concept = len(concepts_with_detailed_documents_list)
        
        for concept_index, concept_with_detailed_documents_list in enumerate(concepts_with_detailed_documents_list) :
            imagecluster = Image(url=list_concepts[concept_index]['url_image'])
            imagecluster.save()
            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)
            logger.info('CLUSTERID'+str(cluster1.id))
            for detailed_document in concept_with_detailed_documents_list:
                #Verify if the document exist already in database
                try:
                    doc1 = Document.objects.get(pk=detailed_document['id'])
                except Document.DoesNotExist:
                    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)
                    
                clusterDocWeight1 = Clusterdocumentweight(cluster=cluster1, document=doc1, weight=detailed_document['weight'])
                clusterDocWeight1.save()
        json= '{"documentary_file_created":' + str(dossierDoc1.id) + '}'
        logger.info(json)
        return json