# -*- coding: utf-8
# Copyright 2004-2009 by Vahur Rebas
"""This is a container for documents."""
import Globals
from Globals import Acquisition, Persistent
from AccessControl import ClassSecurityInfo
from Products.BTreeFolder2.BTreeFolder2 import BTreeFolder2
from Acquisition import aq_base, aq_inner, aq_parent, Implicit
from zope.interface import implements
from interfaces import IDocuments
from permissions import *
NEW_DOC = """
"""
class Documents(Persistent,BTreeFolder2,Implicit):
""" Container holding documents. """
meta_type = 'Korpus Documents'
security = ClassSecurityInfo()
security.declareObjectPublic()
id = 'Documents'
implements(IDocuments)
def __init__(self):
""" init method """
BTreeFolder2.__init__(self,'Documents')
security.declareProtected(perm_list_documents, 'index_html')
def index_html(self):
""" index html """
return self.documents_index()
security.declareProtected(perm_del_documents, 'docs_index_handler')
def docs_index_handler(self, REQUEST, del_button='', del_docs=''):
""" Documents/ form handler. Deletes documents and marks them ready for marking """
if del_button:
for x in del_docs:
doc = getattr(self, x, None)
if doc is None:
continue
doc._updateProperty('is_deleted', 1)
doc.reindex_object()
return REQUEST.RESPONSE.redirect('index_html')
security.declareProtected(perm_list_documents, 'getDocuments')
def getDocuments(self, REQUEST=None, as_objects = False):
""" return a list of document objects """
if REQUEST:
is_deleted = REQUEST.get('del', 0)
doc_stat = REQUEST.get('stat', -1)
texttype = REQUEST.get('texttype', '')
sort_on = REQUEST.get('sort_on', '')
title = REQUEST.get('title', '')
else:
is_deleted = 0
doc_stat = -1
texttype = sort_on = title = ''
if doc_stat == -1:
doc_stat = ''
query = { 'is_deleted' : is_deleted,
'document_status' : doc_stat,
'texttype' : texttype,
'getTitle' : title,
'sort_on' : sort_on,
}
if REQUEST:
if REQUEST.get('corpus', None): query['getCorpus'] = REQUEST.get('corpus')
try:
REQUEST.SESSION.set('stat', doc_stat)
REQUEST.SESSION.set('texttype', texttype)
REQUEST.SESSION.set('sort_on', sort_on)
REQUEST.SESSION.set('title', title)
except AttributeError:
pass
res = self.zcatalog(query, sort_on=sort_on, sort_order='descending')
if as_objects:
return [ x.getObject() for x in res ]
return res
security.declareProtected(perm_add_documents, 'newDocument')
def newDocument(self, REQUEST):
""" source for a new document """
REQUEST.RESPONSE.setHeader('Content-Type', 'text/html')
return NEW_DOC
security.declareProtected(perm_edit_document, 'saveDocument')
def saveDocument(self, REQUEST):
""" save document """
id = self.generateId(prefix='doc_', suffix='_item', rand_ceiling=999999999999)
from Document import Document
new = Document(id, REQUEST.kupu)
self._setObject(id, new)
new = getattr(self, id)
return REQUEST.RESPONSE.redirect(id)
def getStatus(self):
return 0
security.declareProtected(perm_add_documents, 'newDocFromParams')
def newDocFromParams(self, REQUEST, schema=None, corpus=None):
""" new document from parameters """
id = self.generateId(prefix='doc_', suffix='_item', rand_ceiling=999999999999)
from Document import Document
new = Document(id, NEW_DOC, schema)
new.setCorpus(corpus)
self._setObject(id, new)
new = getattr(self, id)
return REQUEST.RESPONSE.redirect(id+'/edit.html')
security.declareProtected(perm_manage, 'migr_errors')
def migr_errors(self):
""" migrate errors """
for x in self.objectValues('Document'):
if x.getId() in ['doc_491521501702_item', 'doc_491521501711_item']:
continue
print x
x.convertErrorsNG()
return "ok"
security.declareProtected(perm_manage, 'fixDocStatus')
def fixDocStatus(self):
""" if n_of_errors == 0 and doc_status== 1 --> doc_status->0 """
tot = 0
for x in self.objectValues('Document'):
if x.getStatus() != 1: continue
if x.get_n_of_errors() > 0: continue
print x.getId(), x.getStatus(), x.get_n_of_errors(), x.getTitle()
tot += 1
x._updateProperty('document_status', 0)
x.reindex_object()
print "total:", tot
return "ok"
security.declareProtected(perm_list_documents, 'batch_previous')
def batch_previous(self, batch):
""" generate links to next and previous pages """
result = []
while batch.previous:
batch = batch.previous
result.append(batch.start-1)
result.reverse()
return result
security.declareProtected(perm_list_documents, 'batch_next')
def batch_next(self, batch):
""" generate links to next and previous pages """
result = []
while batch.next:
batch = batch.next
result.append(batch.start-1)
return result
security.declareProtected(perm_manage, 'gen_text2')
def gen_text2(self, REQUEST):
""" asd """
for x in self.objectValues():
x.another_txt()
return "ok"
security.declareProtected(perm_manage, 'export_all')
def export_all(self, REQUEST):
""" export all documents to text """
path = "/tmp/korpus/"
msg = "exporting\n"
for x in self.objectValues():
f = open(path+x.getId()+'.txt', "wb")
con = x.getProperty('textdoc') #.replace('\n', '\r\n')
try:
#f.write(x.getProperty('textdoc').decode('utf-8').encode('windows-1257'))
#f.write(x.getProperty('textdoc').decode('utf-8').encode('latin1').replace('\n', '\r\n'))
con = con.decode('utf-8').encode('windows-1257')
except UnicodeEncodeError:
msg += "failed... "+x.getId()+"\n"
f.write(con)
f.close()
return msg
Globals.InitializeClass(Documents)
# EOF