web/ldt/ldt_utils/fileimport.py
author samuel huron <admin@cybunk.com>
Thu, 17 Jun 2010 15:04:36 +0200
changeset 54 24397932219d
parent 10 84e31387a741
child 57 3a3c15c462f8
permissions -rw-r--r--
Merge test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
54
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     1
import tempfile
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     2
import os.path
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     3
import shutil
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     4
from django.core.exceptions import ObjectDoesNotExist
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     5
from ldt.utils import zipfileext
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     6
from django.conf import settings
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     7
from models import Content
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     8
import xml.dom.minidom
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
     9
import xml.dom.ext #@UnresolvedImport
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    10
import xml.xpath #@UnresolvedImport
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    11
import fnmatch
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    12
import uuid
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    13
import urllib
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    14
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    15
class FileImportError(Exception):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    16
    def __init__(self, value):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    17
        self.value = value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    18
    def __str__(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    19
        return repr(self.value)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    20
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    21
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    22
def Property(func):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    23
    return property(**func()) 
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    24
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    25
class IriInfo(object):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    26
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    27
    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    28
    def __init__(self, id, order, titledesc, basepath="", videopath=settings.STREAM_URL, decoupage_blacklist = settings.DECOUPAGE_BLACKLIST, flatten = True):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    29
        self.id = id
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    30
        self.basepath = basepath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    31
        self.order = order
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    32
        self.src = ""
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    33
        self.annotations = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    34
        self.videopath = videopath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    35
        self.videourl = ""
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    36
        self.title = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    37
        self.desc = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    38
        self.duration = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    39
        self.created = False
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    40
        self.content = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    41
        self.decoupage_blacklist = decoupage_blacklist
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    42
        if self.decoupage_blacklist is None:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    43
            self.decoupage_blacklist = ()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    44
        self.flatten = flatten
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    45
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    46
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    47
    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    48
    def processIri(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    49
        # for just import a file ldt and get the title for every media
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    50
        if 'http' in self.src:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    51
            url = urllib.urlopen(self.src)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    52
            doc = xml.dom.minidom.parse(url)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    53
        #for import a zip, get title and copy file .iri in the media directory
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    54
        else:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    55
            path = os.path.join(self.basepath, self.src)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    56
            doc = xml.dom.minidom.parse(path)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    57
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    58
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    59
        doc = Ft.Xml.Domlette.ConvertDocument(doc) 
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    60
        con = xml.xpath.Context.Context(doc, 1, 1, None)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    61
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    62
        res = xml.xpath.Evaluate("/iri/head/meta[@name='title']/@content", context=con)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    63
        self.title = res[0].value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    64
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    65
            
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    66
        res = xml.xpath.Evaluate("/iri/body/ensembles",context=con)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    67
        ensemblesnode = res[0]
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    68
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    69
        ensembleids = []
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    70
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    71
        for node in ensemblesnode.childNodes:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    72
            if node.nodeType == xml.dom.Node.ELEMENT_NODE and node.tagName == "ensemble":
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    73
                id = node.getAttributeNS(None,u"id")
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    74
                if id not in ensembleids:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    75
                    ensembleids.append(id)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    76
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    77
        if self.annotations is not None:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    78
            newEnsemble = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    79
            for cnode in self.annotations.childNodes:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    80
                if cnode.nodeType == xml.dom.Node.ELEMENT_NODE and cnode.tagName == "decoupage":
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    81
                    if newEnsemble is None:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    82
                        newensemble = doc.createElement('ensemble')
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    83
                        ensembleid = self.id+"_"+str(uuid.uuid1())
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    84
                        newensemble.setAttributeNS(None,'id',ensembleid)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    85
            
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    86
                        newensemble.setAttributeNS(None,'title', self.annotations.getAttribute('title'))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    87
                        newensemble.setAttributeNS(None,'author', self.annotations.getAttribute('author'))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    88
                        newensemble.setAttributeNS(None,'date', self.annotations.getAttribute('date'))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    89
                        newensemble.setAttributeNS(None,'abstract', self.annotations.getAttribute('abstract'))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    90
                        ensemblesnode.appendChild(newensemble)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    91
                        ensembleids.append(ensembleid)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    92
                    newDecoupageNode = cnode.cloneNode(True)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    93
                    newensemble.appendChild(newDecoupageNode)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    94
                elif cnode.nodeType == xml.dom.Node.ELEMENT_NODE and cnode.tagName == "ensemble":
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    95
                    ensembleid = cnode.getAttribute(u"id")
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    96
                    cloneNode = cnode.cloneNode(True)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    97
                    if ensembleid in ensembleids:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    98
                        ensembleid = self.id+"_"+str(uuid.uuid1())
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
    99
                        cloneNode.setAttribute(u"id", ensembleid)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   100
                    ensembleids.append(ensembleid)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   101
                    ensemblesnode.appendChild(cloneNode)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   102
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   103
        res = xml.xpath.Evaluate("/iri/body/medias/media[@id='video']/video", context=con)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   104
        if self.flatten:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   105
            src_video = res[0].getAttributeNS(None,'src')
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   106
            self.videourl = os.path.basename(src_video)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   107
            res[0].setAttributeNS(None,'src', self.videourl)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   108
        self.duration = res[0].getAttributeNS(None, u'dur')
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   109
            
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   110
        f = open(path, "w")
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   111
        try:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   112
            xml.dom.ext.Print(doc, stream=f)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   113
        finally:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   114
            f.close()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   115
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   116
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   117
        destPath = os.path.join(os.path.join(os.path.join(settings.MEDIA_ROOT, "media"), "ldt"), self.id);
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   118
        if not os.path.exists(destPath):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   119
            os.makedirs(destPath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   120
        shutil.move(os.path.join(self.basepath, self.src), os.path.join(destPath, os.path.basename(self.src)))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   121
        self.src = self.id + u"/" + os.path.basename(self.src)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   122
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   123
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   124
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   125
    def saveContent(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   126
        #if 'http' in self.src:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   127
        #    url = self.src
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   128
        #else:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   129
        #    url = self.id + u"/" + os.path.basename(self.src)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   130
        content, self.created = Content.objects.get_or_create(iri_id=self.id, defaults = {'src':self.videourl, 'iriurl': self.src, 'title':self.title, 'description':self.desc, 'videopath': self.videopath})
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   131
        if not self.created:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   132
            content.iriurl = self.src
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   133
            content.title = self.title
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   134
            content.description = self.desc
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   135
            content.save()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   136
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   137
        content.iriurl = self.src
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   138
        content.videopath = self.videopath.rstrip("/") + "/"
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   139
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   140
        content.iri = self.id + u"/" + os.path.basename(self.src)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   141
        content.title = self.title
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   142
        content.description = self.desc
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   143
        content.duration = int(self.duration)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   144
        content.save()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   145
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   146
        self.content = content
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   147
            
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   148
    def process(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   149
        self.processIri()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   150
        self.saveContent()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   151
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   152
class BaseFileImport(object):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   153
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   154
    def __init__(self, filepath, videopath):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   155
        self.__filepath = filepath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   156
        self.__tempdir = ""
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   157
        self.__videopath = videopath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   158
        self.__author = None
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   159
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   160
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   161
    def filepath(): #@NoSelf
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   162
        doc = """Docstring""" #@UnusedVariable
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   163
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   164
        def fget(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   165
            return self.__filepath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   166
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   167
        def fset(self, value):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   168
            self.__filepath = value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   169
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   170
        def fdel(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   171
            del self.__filepath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   172
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   173
        return locals()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   174
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   175
    filepath = property(**filepath())
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   176
    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   177
    def videopath(): #@NoSelf
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   178
        doc = """Docstring""" #@UnusedVariable
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   179
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   180
        def fget(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   181
            return self.__videopath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   182
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   183
        def fset(self, value):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   184
            self.__videopath = value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   185
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   186
        def fdel(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   187
            del self.__videopath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   188
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   189
        return locals()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   190
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   191
    videopath = property(**videopath())
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   192
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   193
    def author(): #@NoSelf
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   194
        doc = """Docstring""" #@UnusedVariable
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   195
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   196
        def fget(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   197
            return self.__author
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   198
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   199
        def fset(self, value):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   200
            self.__author = value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   201
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   202
        def fdel(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   203
            del self.__author
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   204
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   205
        return locals()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   206
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   207
    author = property(**author())
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   208
    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   209
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   210
class FileImport(BaseFileImport):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   211
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   212
    def __init__(self, filepath, videopath, flatten):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   213
        BaseFileImport.__init__(self, filepath, videopath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   214
        self.__checkExistingMedia = False
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   215
        self.__flatten = flatten
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   216
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   217
    def checkExistingMedia(): #@NoSelf
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   218
        doc = """Docstring""" #@UnusedVariable
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   219
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   220
        def fget(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   221
            return self.__checkExistingMedia
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   222
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   223
        def fset(self, value):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   224
            self.__checkExistingMedia = value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   225
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   226
        def fdel(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   227
            del self.__checkExistingMedia
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   228
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   229
        return locals()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   230
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   231
    checkExistingMedia = property(**checkExistingMedia())    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   232
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   233
    def flatten(): #@NoSelf
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   234
        doc = """Docstring""" #@UnusedVariable
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   235
       
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   236
        def fget(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   237
            return self.__flatten
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   238
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   239
        def fset(self, value):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   240
            self.__flatten = value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   241
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   242
        def fdel(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   243
            del self.__flatten
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   244
           
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   245
        return locals()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   246
    flatten = property(**flatten())
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   247
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   248
    def processLdt(self, ldtpath=None):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   249
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   250
        # list iri
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   251
        # see if there is some comments
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   252
        # inject comment in iri
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   253
        # copy iri in folder
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   254
        # create or update content
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   255
        contents = {}
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   256
        if ldtpath:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   257
            doc = xml.dom.minidom.parse(ldtpath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   258
        else:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   259
            doc = xml.dom.minidom.parse(self.filepath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   260
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   261
        con = xml.xpath.Context.Context(doc, 1, 1, None)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   262
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   263
        #get author from file ldt
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   264
        result = xml.xpath.Evaluate("/iri/project", context=con)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   265
        for pnode in result:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   266
            author = pnode.getAttributeNS(None,u"user")
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   267
            if author:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   268
                self.author = unicode(author)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   269
                break 
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   270
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   271
        result = xml.xpath.Evaluate("/iri/medias/media", context=con)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   272
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   273
        for i, medianode in  enumerate(result):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   274
        # get iri file's id from file ldt
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   275
            id = medianode.attributes['id'].value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   276
            if self.checkExistingMedia:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   277
                try:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   278
                    Content.objects.get(iri_id=id)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   279
                    do_pass = True
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   280
                except ObjectDoesNotExist: #Content.DoesNotExist
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   281
                    do_pass = False
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   282
            else:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   283
                    do_pass = False
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   284
            if not do_pass:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   285
                if not (contents.has_key(id)):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   286
                    # Create instance iriInfo(id, order, titledesc, basepath="", videopath=settings.STREAM_URL)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   287
                    if ldtpath:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   288
                        contents[id] = IriInfo(id, i, "", os.path.dirname(ldtpath), flatten=self.flatten)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   289
                    else: 
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   290
                        contents[id] = IriInfo(id, i, "", flatten=self.flatten)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   291
                    # Get iri file's url from ldt. This url can be relative path or absolute path.
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   292
                contents[id].src = medianode.attributes['src'].value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   293
                if medianode.attributes['video'].value !="":
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   294
                    contents[id].videopath = medianode.attributes['video'].value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   295
                elif self.videopath !="" or self.videopath:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   296
                    contents[id].videopath = self.videopath
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   297
                else:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   298
                    contents[id].videopath =settings.STREAM_URL
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   299
                    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   300
                
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   301
        #get annotation of file ldt
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   302
        result = xml.xpath.Evaluate("/iri/annotations/content", context=con)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   303
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   304
        for contentnode in result:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   305
            id = contentnode.attributes['id'].value
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   306
            # pocketfilms.utils.log.debug("ID : " + str(id))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   307
            if contents.has_key(id):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   308
                if self.author:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   309
                    contentnode.setAttributeNS(None,"author", unicode(self.author))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   310
                contents[id].annotations = contentnode
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   311
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   312
        #go throught values
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   313
        for iriinfo in contents.values():
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   314
            
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   315
            iriinfo.process()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   316
            
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   317
            # if yes update
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   318
            # if no create
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   319
            # move iri file to the proper place
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   320
            #return list of iriInfo
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   321
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   322
    def processFile(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   323
        if self.filepath.name.endswith(".ldt"):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   324
            self.processLdt()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   325
        elif self.filepath.name.endswith(".zip"):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   326
            self.processZip()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   327
        else:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   328
            raise FileImportError("Bad file type")
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   329
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   330
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   331
    def processZip(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   332
    # """ extraire .zip, pass to method processLdt"""
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   333
        # create temp directory
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   334
        self.__tempdir = tempfile.mkdtemp()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   335
        openfiles = []
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   336
        flvfiles = []
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   337
        processedids = []
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   338
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   339
        try:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   340
            zipfile = zipfileext.ZipFileExt(self.filepath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   341
            zipfile.unzip_into_dir(self.__tempdir)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   342
            #load ldt
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   343
            foldersToProcess = [self.__tempdir]
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   344
            while len(foldersToProcess):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   345
                # pocketfilms.utils.log.debug("folder stack length : "+ str(len(foldersToProcess)))
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   346
                currentFolder = foldersToProcess.pop()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   347
                for entry in os.listdir(currentFolder):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   348
                    if entry in settings.ZIP_BLACKLIST:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   349
                        continue
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   350
                    entryPath = os.path.join(currentFolder, entry)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   351
                    if(os.path.isdir(entryPath)):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   352
                        # pocketfilms.utils.log.debug("Push folder : " + entryPath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   353
                        foldersToProcess.append(entryPath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   354
                    elif fnmatch.fnmatch(entry, "*.ldt"):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   355
                        # pocketfilms.utils.log.debug("Process file : " + entryPath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   356
                        ldtid = self.processLdt(entryPath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   357
                        processedids.append(ldtid)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   358
                    elif fnmatch.fnmatch(entry, "*.flv"):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   359
                        flvfiles.append(entryPath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   360
             
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   361
            if settings.CONTENT_ROOT and os.path.exists(settings.CONTENT_ROOT): 
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   362
                for entry in flvfiles:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   363
                    shutil.copy(entry, settings.CONTENT_ROOT)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   364
                    
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   365
        finally:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   366
            for f in openfiles:
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   367
                f.close()
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   368
            shutil.rmtree(self.__tempdir)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   369
        # delete directory
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   370
        return processedids
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   371
        
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   372
    # def processFileLdt(self):
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   373
        # processedids = []
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   374
        # ldtid = self.processLdt(self.filepath)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   375
        # processedids.append(ldtid)
24397932219d Merge test
samuel huron <admin@cybunk.com>
parents: 10
diff changeset
   376
        # return processedids