annotate documentViewer.py @ 83:ec12a2440daa

My last update Bukhman Andrey
author abukhman
date Mon, 08 Mar 2010 16:02:33 +0100
parents 260078dfd1c4
children a6e4f9b6729a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
1
0
dwinter
parents:
diff changeset
2 from OFS.Folder import Folder
dwinter
parents:
diff changeset
3 from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
4 from Products.PageTemplates.PageTemplateFile import PageTemplateFile
0
dwinter
parents:
diff changeset
5 from AccessControl import ClassSecurityInfo
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
6 from AccessControl import getSecurityManager
0
dwinter
parents:
diff changeset
7 from Globals import package_home
dwinter
parents:
diff changeset
8
dwinter
parents:
diff changeset
9 from Ft.Xml.Domlette import NonvalidatingReader
dwinter
parents:
diff changeset
10 from Ft.Xml.Domlette import PrettyPrint, Print
38
025d3b6cba51 fixes by dirk
casties
parents: 37
diff changeset
11 from Ft.Xml import EMPTY_NAMESPACE, Parse
0
dwinter
parents:
diff changeset
12
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
13
0
dwinter
parents:
diff changeset
14 import Ft.Xml.XPath
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
15 import xmlrpclib
0
dwinter
parents:
diff changeset
16 import os.path
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
17 import sys
0
dwinter
parents:
diff changeset
18 import cgi
dwinter
parents:
diff changeset
19 import urllib
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
20 import logging
61
f3d2f240692c fixed bug in calculation of group numbers
casties
parents: 59
diff changeset
21 import math
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
22
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
23 import urlparse
75
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
24 from types import *
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
25 def logger(txt,method,txt2):
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
26 """logging"""
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
27 logging.info(txt+ txt2)
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
28
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
29
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
30 def getInt(number, default=0):
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
31 """returns always an int (0 in case of problems)"""
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
32 try:
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
33 return int(number)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
34 except:
62
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
35 return int(default)
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
36
0
dwinter
parents:
diff changeset
37 def getTextFromNode(nodename):
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
38 """get the cdata content of a node"""
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
39 if nodename is None:
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
40 return ""
0
dwinter
parents:
diff changeset
41 nodelist=nodename.childNodes
dwinter
parents:
diff changeset
42 rc = ""
dwinter
parents:
diff changeset
43 for node in nodelist:
dwinter
parents:
diff changeset
44 if node.nodeType == node.TEXT_NODE:
dwinter
parents:
diff changeset
45 rc = rc + node.data
dwinter
parents:
diff changeset
46 return rc
dwinter
parents:
diff changeset
47
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
48
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
49 def getParentDir(path):
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
50 """returns pathname shortened by one"""
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
51 return '/'.join(path.split('/')[0:-1])
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
52
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
53
0
dwinter
parents:
diff changeset
54 import socket
dwinter
parents:
diff changeset
55
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
56 def urlopen(url,timeout=2):
0
dwinter
parents:
diff changeset
57 """urlopen mit timeout"""
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
58 socket.setdefaulttimeout(timeout)
0
dwinter
parents:
diff changeset
59 ret=urllib.urlopen(url)
dwinter
parents:
diff changeset
60 socket.setdefaulttimeout(5)
dwinter
parents:
diff changeset
61 return ret
dwinter
parents:
diff changeset
62
dwinter
parents:
diff changeset
63
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
64 ##
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
65 ## documentViewer class
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
66 ##
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
67 class documentViewer(Folder):
0
dwinter
parents:
diff changeset
68 """document viewer"""
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
69 #textViewerUrl="http://127.0.0.1:8080/HFQP/testXSLT/getPage?"
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
70
0
dwinter
parents:
diff changeset
71 meta_type="Document viewer"
dwinter
parents:
diff changeset
72
dwinter
parents:
diff changeset
73 security=ClassSecurityInfo()
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
74 manage_options=Folder.manage_options+(
0
dwinter
parents:
diff changeset
75 {'label':'main config','action':'changeDocumentViewerForm'},
dwinter
parents:
diff changeset
76 )
dwinter
parents:
diff changeset
77
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
78 # templates and forms
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
79 viewer_main = PageTemplateFile('zpt/viewer_main', globals())
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
80 thumbs_main = PageTemplateFile('zpt/thumbs_main', globals())
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
81 image_main = PageTemplateFile('zpt/image_main', globals())
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
82 head_main = PageTemplateFile('zpt/head_main', globals())
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
83 docuviewer_css = PageTemplateFile('css/docuviewer.css', globals())
57
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
84 info_xml = PageTemplateFile('zpt/info_xml', globals())
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
85
68
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
86 thumbs_main_rss = PageTemplateFile('zpt/thumbs_main_rss', globals())
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
87 security.declareProtected('View management screens','changeDocumentViewerForm')
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
88 changeDocumentViewerForm = PageTemplateFile('zpt/changeDocumentViewer', globals())
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
89
0
dwinter
parents:
diff changeset
90
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
91 def __init__(self,id,imageViewerUrl,textViewerUrl=None,title="",digilibBaseUrl=None,thumbcols=2,thumbrows=10,authgroups="mpiwg"):
0
dwinter
parents:
diff changeset
92 """init document viewer"""
dwinter
parents:
diff changeset
93 self.id=id
dwinter
parents:
diff changeset
94 self.title=title
dwinter
parents:
diff changeset
95 self.imageViewerUrl=imageViewerUrl
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
96 self.textViewerUrl=textViewerUrl
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
97
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
98 if not digilibBaseUrl:
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
99 self.digilibBaseUrl = self.findDigilibUrl()
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
100 else:
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
101 self.digilibBaseUrl = digilibBaseUrl
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
102 self.thumbcols = thumbcols
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
103 self.thumbrows = thumbrows
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
104 # authgroups is list of authorized groups (delimited by ,)
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
105 self.authgroups = [s.strip().lower() for s in authgroups.split(',')]
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
106 # add template folder so we can always use template.something
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
107 self.manage_addFolder('template')
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
108
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
109
68
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
110 security.declareProtected('View','thumbs_rss')
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
111 def thumbs_rss(self,mode,url,viewMode="auto",start=None,pn=1):
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
112 '''
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
113 view it
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
114 @param mode: defines how to access the document behind url
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
115 @param url: url which contains display information
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
116 @param viewMode: if images display images, if text display text, default is images (text,images or auto)
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
117
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
118 '''
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
119 logging.info("HHHHHHHHHHHHHH:load the rss")
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
120 logger("documentViewer (index)", logging.INFO, "mode: %s url:%s start:%s pn:%s"%(mode,url,start,pn))
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
121
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
122 if not hasattr(self, 'template'):
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
123 # create template folder if it doesn't exist
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
124 self.manage_addFolder('template')
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
125
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
126 if not self.digilibBaseUrl:
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
127 self.digilibBaseUrl = self.findDigilibUrl() or "http://nausikaa.mpiwg-berlin.mpg.de/digitallibrary"
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
128
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
129 docinfo = self.getDocinfo(mode=mode,url=url)
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
130 pageinfo = self.getPageinfo(start=start,current=pn,docinfo=docinfo)
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
131 pt = getattr(self.template, 'thumbs_main_rss')
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
132
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
133 if viewMode=="auto": # automodus gewaehlt
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
134 if docinfo.get("textURL",'') and self.textViewerUrl: #texturl gesetzt und textViewer konfiguriert
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
135 viewMode="text"
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
136 else:
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
137 viewMode="images"
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
138
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
139 return pt(docinfo=docinfo,pageinfo=pageinfo,viewMode=viewMode)
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
140
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
141 security.declareProtected('View','index_html')
74
dwinter
parents: 73
diff changeset
142 def index_html(self,mode,url,viewMode="auto",start=None,pn=1,mk=None):
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
143 '''
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
144 view it
57
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
145 @param mode: defines how to access the document behind url
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
146 @param url: url which contains display information
57
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
147 @param viewMode: if images display images, if text display text, default is images (text,images or auto)
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
148
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
149 '''
0
dwinter
parents:
diff changeset
150
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
151 logger("documentViewer (index)", logging.INFO, "mode: %s url:%s start:%s pn:%s"%(mode,url,start,pn))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
152
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
153 if not hasattr(self, 'template'):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
154 # create template folder if it doesn't exist
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
155 self.manage_addFolder('template')
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
156
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
157 if not self.digilibBaseUrl:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
158 self.digilibBaseUrl = self.findDigilibUrl() or "http://nausikaa.mpiwg-berlin.mpg.de/digitallibrary"
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
159
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
160 docinfo = self.getDocinfo(mode=mode,url=url)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
161 pageinfo = self.getPageinfo(start=start,current=pn,docinfo=docinfo)
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
162 pt = getattr(self.template, 'viewer_main')
51
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
163
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
164 if viewMode=="auto": # automodus gewaehlt
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
165 if docinfo.get("textURL",'') and self.textViewerUrl: #texturl gesetzt und textViewer konfiguriert
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
166 viewMode="text"
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
167 else:
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
168 viewMode="images"
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
169
75
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
170 return pt(docinfo=docinfo,pageinfo=pageinfo,viewMode=viewMode,mk=self.generateMarks(mk))
0
dwinter
parents:
diff changeset
171
74
dwinter
parents: 73
diff changeset
172 def generateMarks(self,mk):
dwinter
parents: 73
diff changeset
173 ret=""
75
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
174 if mk is None:
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
175 return ""
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
176
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
177 if type(mk) is not ListType:
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
178 mk=[mk]
74
dwinter
parents: 73
diff changeset
179 for m in mk:
75
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
180 ret+="mk=%s"%m
74
dwinter
parents: 73
diff changeset
181 return ret
dwinter
parents: 73
diff changeset
182
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
183 def getLink(self,param=None,val=None):
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
184 """link to documentviewer with parameter param set to val"""
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
185 params=self.REQUEST.form.copy()
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
186 if param is not None:
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
187 if val is None:
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
188 if params.has_key(param):
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
189 del params[param]
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
190 else:
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
191 params[param] = str(val)
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
192 if params["mode"] == "filepath": #wenn beim erst Aufruf filepath gesetzt wurde aendere das nun zu imagepath
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
193 params["mode"] = "imagepath"
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
194 params["url"] = getParentDir(params["url"])
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
195
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
196 # quote values and assemble into query string
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
197 ps = "&".join(["%s=%s"%(k,urllib.quote(v)) for (k, v) in params.items()])
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
198 url=self.REQUEST['URL1']+"?"+ps
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
199 return url
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
200
68
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
201 def getLinkAmp(self,param=None,val=None):
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
202 """link to documentviewer with parameter param set to val"""
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
203 params=self.REQUEST.form.copy()
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
204 if param is not None:
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
205 if val is None:
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
206 if params.has_key(param):
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
207 del params[param]
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
208 else:
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
209 params[param] = str(val)
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
210
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
211 # quote values and assemble into query string
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
212 logging.info("XYXXXXX: %s"%repr(params.items()))
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
213 ps = "&".join(["%s=%s"%(k,urllib.quote(v)) for (k, v) in params.items()])
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
214 url=self.REQUEST['URL1']+"?"+ps
b8457fc33446 piclens rss/support
dwinter
parents: 65
diff changeset
215 return url
81
fae97f071724 fixed problem with info.xml when url without index.meta
casties
parents: 79
diff changeset
216
57
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
217 def getInfo_xml(self,url,mode):
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
218 """returns info about the document as XML"""
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
219
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
220 if not self.digilibBaseUrl:
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
221 self.digilibBaseUrl = self.findDigilibUrl() or "http://nausikaa.mpiwg-berlin.mpg.de/digitallibrary"
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
222
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
223 docinfo = self.getDocinfo(mode=mode,url=url)
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
224 pt = getattr(self.template, 'info_xml')
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
225 return pt(docinfo=docinfo)
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
226
0
dwinter
parents:
diff changeset
227
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
228 def getStyle(self, idx, selected, style=""):
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
229 """returns a string with the given style and append 'sel' if path == selected."""
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
230 #logger("documentViewer (getstyle)", logging.INFO, "idx: %s selected: %s style: %s"%(idx,selected,style))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
231 if idx == selected:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
232 return style + 'sel'
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
233 else:
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
234 return style
57
7cdb0fc34a92 added getInfo_xml method
casties
parents: 55
diff changeset
235
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
236 def getTextLanguage(self,url,docinfo):
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
237 docinfo['lang']=getTextFromNode(dom.xpath("//bib/lang")[0])
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
238 lang = urlencode({'':docinfo['lang']})
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
239 return lang
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
240
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
241
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
242 def isAccessible(self, docinfo):
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
243 """returns if access to the resource is granted"""
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
244 access = docinfo.get('accessType', None)
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
245 logger("documentViewer (accessOK)", logging.INFO, "access type %s"%access)
45
0391fe75aef3 fixed handling of documents with missing access tag
casties
parents: 43
diff changeset
246 if access is not None and access == 'free':
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
247 logger("documentViewer (accessOK)", logging.INFO, "access is free")
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
248 return True
45
0391fe75aef3 fixed handling of documents with missing access tag
casties
parents: 43
diff changeset
249 elif access is None or access in self.authgroups:
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
250 # only local access -- only logged in users
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
251 user = getSecurityManager().getUser()
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
252 if user is not None:
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
253 #print "user: ", user
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
254 return (user.getUserName() != "Anonymous User")
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
255 else:
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
256 return False
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
257
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
258 logger("documentViewer (accessOK)", logging.INFO, "unknown access type %s"%access)
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
259 return False
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
260
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
261
73
dwinter
parents: 71
diff changeset
262 def getDirinfoFromDigilib(self,path,docinfo=None,cut=0):
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
263 """gibt param von dlInfo aus"""
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
264 num_retries = 3
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
265 if docinfo is None:
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
266 docinfo = {}
73
dwinter
parents: 71
diff changeset
267
dwinter
parents: 71
diff changeset
268 for x in range(cut):
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
269
73
dwinter
parents: 71
diff changeset
270 path=getParentDir(path)
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
271
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
272 infoUrl=self.digilibBaseUrl+"/dirInfo-xml.jsp?mo=dir&fn="+path
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
273
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
274 logger("documentViewer (getparamfromdigilib)", logging.INFO, "dirInfo from %s"%(infoUrl))
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
275
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
276 for cnt in range(num_retries):
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
277 try:
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
278 # dom = NonvalidatingReader.parseUri(imageUrl)
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
279 txt=urllib.urlopen(infoUrl).read()
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
280 dom = Parse(txt)
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
281 break
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
282 except:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
283 logger("documentViewer (getdirinfofromdigilib)", logging.ERROR, "error reading %s (try %d)"%(infoUrl,cnt))
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
284 else:
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
285 raise IOError("Unable to get dir-info from %s"%(infoUrl))
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
286
37
ead830ce45d6 better error messages
casties
parents: 35
diff changeset
287 sizes=dom.xpath("//dir/size")
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
288 logger("documentViewer (getparamfromdigilib)", logging.INFO, "dirInfo:size"%sizes)
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
289
37
ead830ce45d6 better error messages
casties
parents: 35
diff changeset
290 if sizes:
ead830ce45d6 better error messages
casties
parents: 35
diff changeset
291 docinfo['numPages'] = int(getTextFromNode(sizes[0]))
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
292 else:
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
293 docinfo['numPages'] = 0
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
294
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
295 return docinfo
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
296
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
297
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
298 def getIndexMeta(self, url):
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
299 """returns dom of index.meta document at url"""
39
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
300 num_retries = 3
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
301 dom = None
39
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
302 metaUrl = None
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
303 if url.startswith("http://"):
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
304 # real URL
39
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
305 metaUrl = url
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
306 else:
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
307 # online path
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
308 server=self.digilibBaseUrl+"/servlet/Texter?fn="
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
309 metaUrl=server+url.replace("/mpiwg/online","")
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
310 if not metaUrl.endswith("index.meta"):
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
311 metaUrl += "/index.meta"
75
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
312 logging.debug("METAURL: %s"%metaUrl)
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
313 for cnt in range(num_retries):
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
314 try:
39
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
315 # patch dirk encoding fehler treten dann nicht mehr auf
38
025d3b6cba51 fixes by dirk
casties
parents: 37
diff changeset
316 # dom = NonvalidatingReader.parseUri(metaUrl)
39
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
317 txt=urllib.urlopen(metaUrl).read()
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
318 dom = Parse(txt)
40
749ee5389892 try to ignore superfluous /mpiwg/online in urls
casties
parents: 39
diff changeset
319 break
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
320 except:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
321 logger("ERROR documentViewer (getIndexMata)", logging.INFO,"%s (%s)"%sys.exc_info()[0:2])
39
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
322
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
323 if dom is None:
1dd90aabd366 added retry when reading index meta from texter applet
casties
parents: 38
diff changeset
324 raise IOError("Unable to read index meta from %s"%(url))
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
325
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
326 return dom
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
327
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
328 def getPresentationInfoXML(self, url):
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
329 """returns dom of info.xml document at url"""
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
330 num_retries = 3
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
331 dom = None
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
332 metaUrl = None
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
333 if url.startswith("http://"):
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
334 # real URL
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
335 metaUrl = url
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
336 else:
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
337 # online path
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
338 server=self.digilibBaseUrl+"/servlet/Texter?fn="
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
339 metaUrl=server+url.replace("/mpiwg/online","")
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
340
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
341
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
342 for cnt in range(num_retries):
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
343 try:
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
344 # patch dirk encoding fehler treten dann nicht mehr auf
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
345 # dom = NonvalidatingReader.parseUri(metaUrl)
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
346 txt=urllib.urlopen(metaUrl).read()
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
347 dom = Parse(txt)
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
348 break
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
349 except:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
350 logger("ERROR documentViewer (getPresentationInfoXML)", logging.INFO,"%s (%s)"%sys.exc_info()[0:2])
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
351
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
352 if dom is None:
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
353 raise IOError("Unable to read infoXMLfrom %s"%(url))
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
354
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
355 return dom
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
356
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
357
70
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
358 def getAuthinfoFromIndexMeta(self,path,docinfo=None,dom=None,cut=0):
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
359 """gets authorization info from the index.meta file at path or given by dom"""
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
360 logger("documentViewer (getauthinfofromindexmeta)", logging.INFO,"path: %s"%(path))
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
361
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
362 access = None
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
363
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
364 if docinfo is None:
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
365 docinfo = {}
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
366
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
367 if dom is None:
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
368 for x in range(cut):
70
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
369 path=getParentDir(path)
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
370 dom = self.getIndexMeta(path)
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
371
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
372 acctype = dom.xpath("//access-conditions/access/@type")
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
373 if acctype and (len(acctype)>0):
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
374 access=acctype[0].value
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
375 if access in ['group', 'institution']:
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
376 access = getTextFromNode(dom.xpath("//access-conditions/access/name")[0]).lower()
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
377
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
378 docinfo['accessType'] = access
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
379 return docinfo
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
380
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
381
70
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
382 def getBibinfoFromIndexMeta(self,path,docinfo=None,dom=None,cut=0):
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
383 """gets bibliographical info from the index.meta file at path or given by dom"""
59
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
384 logging.debug("documentViewer (getbibinfofromindexmeta) path: %s"%(path))
20
9884703dae70 new modi
dwinter
parents: 0
diff changeset
385
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
386 if docinfo is None:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
387 docinfo = {}
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
388
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
389 if dom is None:
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
390 for x in range(cut):
70
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
391 path=getParentDir(path)
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
392 dom = self.getIndexMeta(path)
79
df6952ac93e9 bug in getDocInforFromImagePath, relative lage der index.meta zu path war falsch.
dwinter
parents: 78
diff changeset
393
df6952ac93e9 bug in getDocInforFromImagePath, relative lage der index.meta zu path war falsch.
dwinter
parents: 78
diff changeset
394 logging.debug("documentViewer (getbibinfofromindexmeta cutted) path: %s"%(path))
59
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
395 # put in all raw bib fields as dict "bib"
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
396 bib = dom.xpath("//bib/*")
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
397 if bib and len(bib)>0:
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
398 bibinfo = {}
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
399 for e in bib:
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
400 bibinfo[e.localName] = getTextFromNode(e)
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
401 docinfo['bib'] = bibinfo
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
402
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
403 # extract some fields (author, title, year) according to their mapping
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
404 metaData=self.metadata.main.meta.bib
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
405 bibtype=dom.xpath("//bib/@type")
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
406 if bibtype and (len(bibtype)>0):
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
407 bibtype=bibtype[0].value
20
9884703dae70 new modi
dwinter
parents: 0
diff changeset
408 else:
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
409 bibtype="generic"
59
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
410
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
411 bibtype=bibtype.replace("-"," ") # wrong typesiin index meta "-" instead of " " (not wrong! ROC)
59
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
412 docinfo['bib_type'] = bibtype
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
413 bibmap=metaData.generateMappingForType(bibtype)
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
414 # if there is no mapping bibmap is empty (mapping sometimes has empty fields)
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
415 if len(bibmap) > 0 and len(bibmap['author'][0]) > 0:
63
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
416 try:
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
417 docinfo['author']=getTextFromNode(dom.xpath("//bib/%s"%bibmap['author'][0])[0])
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
418 except: pass
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
419 try:
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
420 docinfo['title']=getTextFromNode(dom.xpath("//bib/%s"%bibmap['title'][0])[0])
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
421 except: pass
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
422 try:
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
423 docinfo['year']=getTextFromNode(dom.xpath("//bib/%s"%bibmap['year'][0])[0])
4a17b755bfc7 added more try/excepts to bib-meta reading code
casties
parents: 62
diff changeset
424 except: pass
59
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
425 logging.debug("documentViewer (getbibinfofromindexmeta) using mapping for %s"%bibtype)
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
426 try:
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
427 docinfo['lang']=getTextFromNode(dom.xpath("//bib/lang")[0])
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
428 except:
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
429 docinfo['lang']=''
59
996b61d71351 added all fields from bib tag to docinfo
casties
parents: 57
diff changeset
430
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
431 return docinfo
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
432
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
433
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
434 def getNumPages(self, xquery, docinfo=None): #New Method 24.02.2010
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
435 text=self.viewerTemplates.query.eval("/mpdl/interface/xquery.xql","document="+ docinfo['textURLPath'] +"&xquery="+str(xquery))
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
436 docinfo['numPages'] = text.count("<pb ")
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
437 return docinfo
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
438
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
439
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
440 def getDocinfoFromTextTool(self,url,dom=None,docinfo=None):
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
441 """parse texttool tag in index meta"""
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
442 logger("documentViewer (getdocinfofromtexttool)", logging.INFO,"url: %s"%(url))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
443 if docinfo is None:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
444 docinfo = {}
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
445
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
446 if docinfo.get('lang',None) is None:
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
447 docinfo['lang']='' # default keine Sprache gesetzt
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
448 if dom is None:
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
449 dom = self.getIndexMeta(url)
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
450
43
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
451 archivePath = None
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
452 archiveName = None
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
453
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
454 archiveNames=dom.xpath("//resource/name")
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
455 if archiveNames and (len(archiveNames)>0):
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
456 archiveName=getTextFromNode(archiveNames[0])
43
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
457 else:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
458 logger("documentViewer (getdocinfofromtexttool)", logging.WARNING,"resource/name missing in: %s"%(url))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
459
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
460 archivePaths=dom.xpath("//resource/archive-path")
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
461 if archivePaths and (len(archivePaths)>0):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
462 archivePath=getTextFromNode(archivePaths[0])
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
463 # clean up archive path
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
464 if archivePath[0] != '/':
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
465 archivePath = '/' + archivePath
43
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
466 if archiveName and (not archivePath.endswith(archiveName)):
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
467 archivePath += "/" + archiveName
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
468 else:
43
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
469 # try to get archive-path from url
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
470 logger("documentViewer (getdocinfofromtexttool)", logging.WARNING,"resource/archive-path missing in: %s"%(url))
43
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
471 if (not url.startswith('http')):
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
472 archivePath = url.replace('index.meta', '')
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
473
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
474 if archivePath is None:
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
475 # we balk without archive-path
f3bc59cf64d9 fixed some problems with bad index.meta files (text-tools mode)
casties
parents: 42
diff changeset
476 raise IOError("Missing archive-path (for text-tool) in %s"%(url))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
477
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
478 imageDirs=dom.xpath("//texttool/image")
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
479 if imageDirs and (len(imageDirs)>0):
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
480 imageDir=getTextFromNode(imageDirs[0])
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
481
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
482 else:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
483 # we balk with no image tag / not necessary anymore because textmode is now standard
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
484 #raise IOError("No text-tool info in %s"%(url))
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
485 imageDir=""
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
486 #xquery="//pb"
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
487 docinfo['imagePath'] = "" # keine Bilder
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
488 docinfo['imageURL'] = ""
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
489
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
490 if imageDir and archivePath:
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
491 #print "image: ", imageDir, " archivepath: ", archivePath
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
492 imageDir=os.path.join(archivePath,imageDir)
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
493 imageDir=imageDir.replace("/mpiwg/online",'')
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
494 docinfo=self.getDirinfoFromDigilib(imageDir,docinfo=docinfo)
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
495 docinfo['imagePath'] = imageDir
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
496
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
497 docinfo['imageURL'] = self.digilibBaseUrl+"/servlet/Scaler?fn="+imageDir
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
498
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
499 viewerUrls=dom.xpath("//texttool/digiliburlprefix")
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
500 if viewerUrls and (len(viewerUrls)>0):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
501 viewerUrl=getTextFromNode(viewerUrls[0])
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
502 docinfo['viewerURL'] = viewerUrl
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
503
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
504 textUrls=dom.xpath("//texttool/text")
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
505 if textUrls and (len(textUrls)>0):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
506 textUrl=getTextFromNode(textUrls[0])
49
a10fff6199b0 verbesserung f?r text unterst?tzung, text kann jetzt aus url kommen, sprache bisher nur deutsch
dwinter
parents: 46
diff changeset
507 if urlparse.urlparse(textUrl)[0]=="": #keine url
a10fff6199b0 verbesserung f?r text unterst?tzung, text kann jetzt aus url kommen, sprache bisher nur deutsch
dwinter
parents: 46
diff changeset
508 textUrl=os.path.join(archivePath,textUrl)
65
c048559460a3 fix problems with full text paths starting with /mpiwg/online
casties
parents: 63
diff changeset
509 # fix URLs starting with /mpiwg/online
c048559460a3 fix problems with full text paths starting with /mpiwg/online
casties
parents: 63
diff changeset
510 if textUrl.startswith("/mpiwg/online"):
c048559460a3 fix problems with full text paths starting with /mpiwg/online
casties
parents: 63
diff changeset
511 textUrl = textUrl.replace("/mpiwg/online",'',1)
c048559460a3 fix problems with full text paths starting with /mpiwg/online
casties
parents: 63
diff changeset
512
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
513 docinfo['textURL'] = textUrl
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
514
82
260078dfd1c4 text-url-path einf?gen
abukhman
parents: 81
diff changeset
515 textUrls=dom.xpath("//texttool/text-url-path")
260078dfd1c4 text-url-path einf?gen
abukhman
parents: 81
diff changeset
516 if textUrls and (len(textUrls)>0):
260078dfd1c4 text-url-path einf?gen
abukhman
parents: 81
diff changeset
517 textUrl=getTextFromNode(textUrls[0])
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
518 docinfo['textURLPath'] = textUrl
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
519
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
520 presentationUrls=dom.xpath("//texttool/presentation")
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
521 docinfo = self.getBibinfoFromIndexMeta(url,docinfo=docinfo,dom=dom) # get info von bib tag
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
522
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
523 if presentationUrls and (len(presentationUrls)>0): # ueberschreibe diese durch presentation informationen
82
260078dfd1c4 text-url-path einf?gen
abukhman
parents: 81
diff changeset
524 # presentation url ergiebt sich ersetzen von index.meta in der url der fuer die Metadaten
260078dfd1c4 text-url-path einf?gen
abukhman
parents: 81
diff changeset
525 # durch den relativen Pfad auf die presentation infos
81
fae97f071724 fixed problem with info.xml when url without index.meta
casties
parents: 79
diff changeset
526 presentationPath = getTextFromNode(presentationUrls[0])
fae97f071724 fixed problem with info.xml when url without index.meta
casties
parents: 79
diff changeset
527 if url.endswith("index.meta"):
fae97f071724 fixed problem with info.xml when url without index.meta
casties
parents: 79
diff changeset
528 presentationUrl=url.replace('index.meta',presentationPath)
fae97f071724 fixed problem with info.xml when url without index.meta
casties
parents: 79
diff changeset
529 else:
fae97f071724 fixed problem with info.xml when url without index.meta
casties
parents: 79
diff changeset
530 presentationUrl=url + "/" + presentationPath
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
531 docinfo=self.getNumPages('//pb', docinfo) #im moment einfach auf eins setzen, navigation ueber die thumbs geht natuerlich nicht
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
532 docinfo = self.getBibinfoFromTextToolPresentation(presentationUrl,docinfo=docinfo,dom=dom)
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
533
55
ba8917b93c84 fixed bug in fix for missing getauthinfo in getdocinfofromtexttool
casties
parents: 54
diff changeset
534 docinfo = self.getAuthinfoFromIndexMeta(url,docinfo=docinfo,dom=dom) # get access info
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
535
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
536 return docinfo
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
537
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
538
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
539 def getBibinfoFromTextToolPresentation(self,url,docinfo=None,dom=None):
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
540 """gets the bibliographical information from the preseantion entry in texttools
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
541 """
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
542 dom=self.getPresentationInfoXML(url)
62
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
543 try:
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
544 docinfo['author']=getTextFromNode(dom.xpath("//author")[0])
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
545 except:
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
546 pass
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
547 try:
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
548 docinfo['title']=getTextFromNode(dom.xpath("//title")[0])
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
549 except:
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
550 pass
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
551 try:
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
552 docinfo['year']=getTextFromNode(dom.xpath("//date")[0])
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
553 except:
8a16ea8db858 fixed bug in getInt
casties
parents: 61
diff changeset
554 pass
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
555 return docinfo
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
556
70
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
557 def getDocinfoFromImagePath(self,path,docinfo=None,cut=0):
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
558 """path ist the path to the images it assumes that the index.meta file is one level higher."""
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
559 logger("documentViewer (getdocinfofromimagepath)", logging.INFO,"path: %s"%(path))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
560 if docinfo is None:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
561 docinfo = {}
29
e1bed068b351 small fixes
casties
parents: 28
diff changeset
562 path=path.replace("/mpiwg/online","")
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
563 docinfo['imagePath'] = path
73
dwinter
parents: 71
diff changeset
564 docinfo=self.getDirinfoFromDigilib(path,docinfo=docinfo,cut=cut)
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
565
79
df6952ac93e9 bug in getDocInforFromImagePath, relative lage der index.meta zu path war falsch.
dwinter
parents: 78
diff changeset
566 pathorig=path
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
567 for x in range(cut):
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
568 path=getParentDir(path)
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
569 logging.error("PATH:"+path)
31
c6451e8d5d23 more small fixes - now version 0.2.2
casties
parents: 29
diff changeset
570 imageUrl=self.digilibBaseUrl+"/servlet/Scaler?fn="+path
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
571 docinfo['imageURL'] = imageUrl
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
572
79
df6952ac93e9 bug in getDocInforFromImagePath, relative lage der index.meta zu path war falsch.
dwinter
parents: 78
diff changeset
573 #path ist the path to the images it assumes that the index.meta file is one level higher.
df6952ac93e9 bug in getDocInforFromImagePath, relative lage der index.meta zu path war falsch.
dwinter
parents: 78
diff changeset
574 docinfo = self.getBibinfoFromIndexMeta(pathorig,docinfo=docinfo,cut=cut+1)
df6952ac93e9 bug in getDocInforFromImagePath, relative lage der index.meta zu path war falsch.
dwinter
parents: 78
diff changeset
575 docinfo = self.getAuthinfoFromIndexMeta(pathorig,docinfo=docinfo,cut=cut+1)
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
576 return docinfo
20
9884703dae70 new modi
dwinter
parents: 0
diff changeset
577
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
578
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
579 def getDocinfo(self, mode, url):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
580 """returns docinfo depending on mode"""
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
581 logger("documentViewer (getdocinfo)", logging.INFO,"mode: %s, url: %s"%(mode,url))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
582 # look for cached docinfo in session
51
c5d3aabbf61b textviewer now integrated, new modus auto introduced as standard for viewing
dwinter
parents: 50
diff changeset
583 if self.REQUEST.SESSION.has_key('docinfo'):
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
584 docinfo = self.REQUEST.SESSION['docinfo']
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
585 # check if its still current
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
586 if docinfo is not None and docinfo.get('mode') == mode and docinfo.get('url') == url:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
587 logger("documentViewer (getdocinfo)", logging.INFO,"docinfo in session: %s"%docinfo)
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
588 return docinfo
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
589 # new docinfo
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
590 docinfo = {'mode': mode, 'url': url}
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
591 if mode=="texttool": #index.meta with texttool information
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
592 docinfo = self.getDocinfoFromTextTool(url, docinfo=docinfo)
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
593 elif mode=="imagepath":
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
594 docinfo = self.getDocinfoFromImagePath(url, docinfo=docinfo)
70
0049d64aa464 filepath introduced
dwinter
parents: 68
diff changeset
595 elif mode=="filepath":
75
9673218e155b minorCVS: ----------------------------------------------------------------------
dwinter
parents: 74
diff changeset
596 docinfo = self.getDocinfoFromImagePath(url, docinfo=docinfo,cut=1)
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
597 else:
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
598 logger("documentViewer (getdocinfo)", logging.ERROR,"unknown mode!")
37
ead830ce45d6 better error messages
casties
parents: 35
diff changeset
599 raise ValueError("Unknown mode %s"%(mode))
ead830ce45d6 better error messages
casties
parents: 35
diff changeset
600
52
92047eaa6272 zLOG exchanged by logging
dwinter
parents: 51
diff changeset
601 logger("documentViewer (getdocinfo)", logging.INFO,"docinfo: %s"%docinfo)
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
602 self.REQUEST.SESSION['docinfo'] = docinfo
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
603 return docinfo
20
9884703dae70 new modi
dwinter
parents: 0
diff changeset
604
9884703dae70 new modi
dwinter
parents: 0
diff changeset
605
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
606 def getPageinfo(self, current, start=None, rows=None, cols=None, docinfo=None):
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
607 """returns pageinfo with the given parameters"""
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
608 pageinfo = {}
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
609 current = getInt(current)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
610 pageinfo['current'] = current
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
611 rows = int(rows or self.thumbrows)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
612 pageinfo['rows'] = rows
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
613 cols = int(cols or self.thumbcols)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
614 pageinfo['cols'] = cols
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
615 grpsize = cols * rows
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
616 pageinfo['groupsize'] = grpsize
61
f3d2f240692c fixed bug in calculation of group numbers
casties
parents: 59
diff changeset
617 start = getInt(start, default=(math.ceil(float(current)/float(grpsize))*grpsize-(grpsize-1)))
f3d2f240692c fixed bug in calculation of group numbers
casties
parents: 59
diff changeset
618 # int(current / grpsize) * grpsize +1))
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
619 pageinfo['start'] = start
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
620 pageinfo['end'] = start + grpsize
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
621 if docinfo is not None:
83
ec12a2440daa My last update Bukhman Andrey
abukhman
parents: 82
diff changeset
622
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
623 np = int(docinfo['numPages'])
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
624 pageinfo['end'] = min(pageinfo['end'], np)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
625 pageinfo['numgroups'] = int(np / grpsize)
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
626 if np % grpsize > 0:
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
627 pageinfo['numgroups'] += 1
78
70ab234a18dc bugs in filepath mode fixes
dwinter
parents: 75
diff changeset
628
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
629 return pageinfo
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
630
0
dwinter
parents:
diff changeset
631 def text(self,mode,url,pn):
dwinter
parents:
diff changeset
632 """give text"""
dwinter
parents:
diff changeset
633 if mode=="texttool": #index.meta with texttool information
dwinter
parents:
diff changeset
634 (viewerUrl,imagepath,textpath)=parseUrlTextTool(url)
dwinter
parents:
diff changeset
635
35
2d9261aea8f3 version 0.2.4
casties
parents: 32
diff changeset
636 #print textpath
0
dwinter
parents:
diff changeset
637 try:
dwinter
parents:
diff changeset
638 dom = NonvalidatingReader.parseUri(textpath)
dwinter
parents:
diff changeset
639 except:
dwinter
parents:
diff changeset
640 return None
dwinter
parents:
diff changeset
641
dwinter
parents:
diff changeset
642 list=[]
dwinter
parents:
diff changeset
643 nodes=dom.xpath("//pb")
dwinter
parents:
diff changeset
644
dwinter
parents:
diff changeset
645 node=nodes[int(pn)-1]
dwinter
parents:
diff changeset
646
dwinter
parents:
diff changeset
647 p=node
dwinter
parents:
diff changeset
648
dwinter
parents:
diff changeset
649 while p.tagName!="p":
dwinter
parents:
diff changeset
650 p=p.parentNode
dwinter
parents:
diff changeset
651
dwinter
parents:
diff changeset
652
dwinter
parents:
diff changeset
653 endNode=nodes[int(pn)]
dwinter
parents:
diff changeset
654
dwinter
parents:
diff changeset
655
dwinter
parents:
diff changeset
656 e=endNode
dwinter
parents:
diff changeset
657
dwinter
parents:
diff changeset
658 while e.tagName!="p":
dwinter
parents:
diff changeset
659 e=e.parentNode
dwinter
parents:
diff changeset
660
dwinter
parents:
diff changeset
661
dwinter
parents:
diff changeset
662 next=node.parentNode
dwinter
parents:
diff changeset
663
dwinter
parents:
diff changeset
664 #sammle s
dwinter
parents:
diff changeset
665 while next and (next!=endNode.parentNode):
dwinter
parents:
diff changeset
666 list.append(next)
dwinter
parents:
diff changeset
667 next=next.nextSibling
dwinter
parents:
diff changeset
668 list.append(endNode.parentNode)
dwinter
parents:
diff changeset
669
dwinter
parents:
diff changeset
670 if p==e:# beide im selben paragraphen
20
9884703dae70 new modi
dwinter
parents: 0
diff changeset
671 pass
9884703dae70 new modi
dwinter
parents: 0
diff changeset
672 # else:
9884703dae70 new modi
dwinter
parents: 0
diff changeset
673 # next=p
9884703dae70 new modi
dwinter
parents: 0
diff changeset
674 # while next!=e:
9884703dae70 new modi
dwinter
parents: 0
diff changeset
675 # print next,e
9884703dae70 new modi
dwinter
parents: 0
diff changeset
676 # list.append(next)
9884703dae70 new modi
dwinter
parents: 0
diff changeset
677 # next=next.nextSibling
9884703dae70 new modi
dwinter
parents: 0
diff changeset
678 #
9884703dae70 new modi
dwinter
parents: 0
diff changeset
679 # for x in list:
9884703dae70 new modi
dwinter
parents: 0
diff changeset
680 # PrettyPrint(x)
9884703dae70 new modi
dwinter
parents: 0
diff changeset
681 #
9884703dae70 new modi
dwinter
parents: 0
diff changeset
682 # return list
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
683 #
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
684
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
685 def findDigilibUrl(self):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
686 """try to get the digilib URL from zogilib"""
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
687 url = self.imageViewerUrl[:-1] + "/getScalerUrl"
50
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
688 #print urlparse.urlparse(url)[0]
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
689 #print urlparse.urljoin(self.absolute_url(),url)
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
690 logging.info("finddigiliburl: %s"%urlparse.urlparse(url)[0])
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
691 logging.info("finddigiliburl: %s"%urlparse.urljoin(self.absolute_url(),url))
6c0f20cecc60 added evaluation of the presentation/info.xml in texttools
dwinter
parents: 49
diff changeset
692
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
693 try:
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
694 if urlparse.urlparse(url)[0]=='': #relative path
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
695 url=urlparse.urljoin(self.absolute_url()+"/",url)
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
696
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
697 scaler = urlopen(url).read()
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
698 return scaler.replace("/servlet/Scaler?", "")
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
699 except:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
700 return None
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
701
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
702 def changeDocumentViewer(self,imageViewerUrl,textViewerUrl,title="",digilibBaseUrl=None,thumbrows=2,thumbcols=10,authgroups='mpiwg',RESPONSE=None):
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
703 """init document viewer"""
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
704 self.title=title
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
705 self.imageViewerUrl=imageViewerUrl
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
706 self.textViewerUrl=textViewerUrl
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
707 self.digilibBaseUrl = digilibBaseUrl
25
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
708 self.thumbrows = thumbrows
e93fb8cadd3a new, less preliminary version 0.2
casties
parents: 22
diff changeset
709 self.thumbcols = thumbcols
32
b25c89d693cf version 0.2.3 - first version with access control!
casties
parents: 31
diff changeset
710 self.authgroups = [s.strip().lower() for s in authgroups.split(',')]
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
711 if RESPONSE is not None:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
712 RESPONSE.redirect('manage_main')
0
dwinter
parents:
diff changeset
713
dwinter
parents:
diff changeset
714
dwinter
parents:
diff changeset
715
dwinter
parents:
diff changeset
716
dwinter
parents:
diff changeset
717 # security.declareProtected('View management screens','renameImageForm')
dwinter
parents:
diff changeset
718
dwinter
parents:
diff changeset
719 def manage_AddDocumentViewerForm(self):
dwinter
parents:
diff changeset
720 """add the viewer form"""
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
721 pt=PageTemplateFile('zpt/addDocumentViewer', globals()).__of__(self)
0
dwinter
parents:
diff changeset
722 return pt()
dwinter
parents:
diff changeset
723
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
724 def manage_AddDocumentViewer(self,id,imageViewerUrl="",textViewerUrl="",title="",RESPONSE=None):
0
dwinter
parents:
diff changeset
725 """add the viewer"""
46
31059e3d9338 has now also a text mode viewMode=text
dwinter
parents: 45
diff changeset
726 newObj=documentViewer(id,imageViewerUrl,title=title,textViewerUrl=textViewerUrl)
0
dwinter
parents:
diff changeset
727 self._setObject(id,newObj)
dwinter
parents:
diff changeset
728
dwinter
parents:
diff changeset
729 if RESPONSE is not None:
dwinter
parents:
diff changeset
730 RESPONSE.redirect('manage_main')
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
731
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
732
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
733 ##
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
734 ## DocumentViewerTemplate class
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
735 ##
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
736 class DocumentViewerTemplate(ZopePageTemplate):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
737 """Template for document viewer"""
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
738 meta_type="DocumentViewer Template"
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
739
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
740
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
741 def manage_addDocumentViewerTemplateForm(self):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
742 """Form for adding"""
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
743 pt=PageTemplateFile('zpt/addDocumentViewerTemplate', globals()).__of__(self)
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
744 return pt()
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
745
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
746 def manage_addDocumentViewerTemplate(self, id='viewer_main', title=None, text=None,
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
747 REQUEST=None, submit=None):
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
748 "Add a Page Template with optional file content."
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
749
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
750 self._setObject(id, DocumentViewerTemplate(id))
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
751 ob = getattr(self, id)
53
f4e0af8c281d NEW - # 44: ECHO - vollst?ndige bibliographische Angabe
dwinter
parents: 52
diff changeset
752 txt=file(os.path.join(package_home(globals()),'zpt/viewer_main.zpt'),'r').read()
f4e0af8c281d NEW - # 44: ECHO - vollst?ndige bibliographische Angabe
dwinter
parents: 52
diff changeset
753 logging.info("txt %s:"%txt)
f4e0af8c281d NEW - # 44: ECHO - vollst?ndige bibliographische Angabe
dwinter
parents: 52
diff changeset
754 ob.pt_edit(txt,"text/html")
22
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
755 if title:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
756 ob.pt_setTitle(title)
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
757 try:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
758 u = self.DestinationURL()
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
759 except AttributeError:
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
760 u = REQUEST['URL1']
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
761
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
762 u = "%s/%s" % (u, urllib.quote(id))
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
763 REQUEST.RESPONSE.redirect(u+'/manage_main')
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
764 return ''
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
765
b139f9937e97 preliminary version 0.2
casties
parents: 20
diff changeset
766
41
0c8ee8fcfd76 some more logging
casties
parents: 40
diff changeset
767