version 1.46, 2004/10/28 14:16:00
|
version 1.48, 2004/10/29 13:40:24
|
Line 62 class ZSQLExtendFolder(Folder,Persistent
|
Line 62 class ZSQLExtendFolder(Folder,Persistent
|
for oneclass in classes: |
for oneclass in classes: |
ret[oneclass]=len(self.ZSQLSimpleSearch(statement + " where ("+wherePart+") and "+ relStatement%oneclass)) |
ret[oneclass]=len(self.ZSQLSimpleSearch(statement + " where ("+wherePart+") and "+ relStatement%oneclass)) |
|
|
. return (ret,allRecords) |
return (ret,allRecords) |
|
|
def content_html(self): |
def content_html(self): |
"""template fuer content""" |
"""template fuer content""" |
Line 380 class ZSQLExtendFolder(Folder,Persistent
|
Line 380 class ZSQLExtendFolder(Folder,Persistent
|
self.ZSQLSimpleSearch(queryString) |
self.ZSQLSimpleSearch(queryString) |
return self.REQUEST.RESPONSE.redirect(format) |
return self.REQUEST.RESPONSE.redirect(format) |
|
|
def ZSQLChange_old(self): |
|
"""change entries""" |
|
qs=self.REQUEST['QUERY_STRING'] |
|
#print "CHANGE QS",self.REQUEST |
|
#return self.REQUEST |
|
changeList=[] |
|
for q in qs.split("&"): |
|
name=urllib.unquote(re.sub("r'+'"," ",q.split("=")[0].lower())) |
|
value=q.split("=")[1] |
|
value=re.sub(r'\+'," ",value) |
|
value=urllib.unquote(value) |
|
if name=="-table": |
|
table=urllib.unquote(value) |
|
elif name=="-identify": |
|
identify=urllib.unquote(value) |
|
identify=identify.split("=")[0]+"="+sql_quote(identify.split("=")[1]) |
|
elif name=="-format": |
|
format=urllib.unquote(value) |
|
elif (not name[0]=="-") and (not len(value)==0): |
|
changeList.append("\""+name+"\"="+sql_quote(urllib.unquote(value))) |
|
changeString=string.join(changeList,",") |
|
queryString="UPDATE %s SET %s WHERE %s"%(table,changeString,identify) |
|
self.ZSQLSimpleSearch(queryString) |
|
return self.REQUEST.RESPONSE.redirect(format) |
|
|
|
|
|
|
|
def ZSQLFind2(self,qs="",select="oid,*",storename=None,tableList=['cdli_translit','cdli_cat'],**argv): |
def ZSQLFind2(self,qs="",select="oid,*",storename=None,tableList=['cdli_translit','cdli_cat'],**argv): |
Line 530 class ZSQLExtendFolder(Folder,Persistent
|
Line 505 class ZSQLExtendFolder(Folder,Persistent
|
|
|
return str(min(int(self.REQUEST.SESSION[storename]['rangeEnd']),int(self.REQUEST.SESSION[storename]['count']))) |
return str(min(int(self.REQUEST.SESSION[storename]['rangeEnd']),int(self.REQUEST.SESSION[storename]['count']))) |
|
|
|
def ZSQLNewQuery(self,linkText,storename=None,**argv): |
|
"""suche neu""" |
|
return self.ZSQLNewSearch(linkText,storename,url=self.REQUEST['URL'],args=argv) |
|
|
|
def ZSQLNewSearch(self,linkText,storename=None,url=None,args=None,**argv): |
|
"""suche mit alten parametern bis auf die in argv getauschten""" |
|
|
|
if storename: |
|
"""store""" |
|
else: |
|
storename="foundCount" |
|
qs=self.REQUEST.SESSION[storename]['qs'] |
|
|
|
if args: |
|
argv=args |
|
|
|
querys=qs.split(",") |
|
argList=[] |
|
arg="" |
|
queryList=[x.split("=")[0] for x in querys] |
|
|
|
for argTmp in argv.keys(): |
|
|
|
|
|
arg=argTmp[0:] |
|
if arg[0]=="_":arg="-"+argTmp[1:] # aender _ in - als standard |
|
|
|
if arg not in queryList: # noch nicht drin |
|
querys.append("%s=%s"%(arg,argv[argTmp])) |
|
argList.append(arg) |
|
|
|
|
|
|
|
newquery=[] |
|
for query in querys: |
|
queryArg=query.split("=")[0] |
|
qarg=queryArg[0:] |
|
if qarg[0]=="-":qarg="_"+queryArg[1:] # aender _ in - als standard |
|
|
|
if queryArg in argList: |
|
newquery.append("%s=%s"%(queryArg,argv[qarg])) |
|
else: |
|
newquery.append(query) |
|
|
|
if url: |
|
str=url+"?"+"&".join(newquery) |
|
else: |
|
str="ZSQLSearch?"+"&".join(newquery) |
|
|
|
return """<a href="%s"> %s</a>"""%(str,linkText) |
|
|
def parseQueryString(self,qs,iCT,storemax="no",select=None,nostore=None,storename=None,tableExt=None,NoQuery=None,NoLimit=None,restrictField=None,restrictConnect=None,filter=None): |
def parseQueryString(self,qs,iCT,storemax="no",select=None,nostore=None,storename=None,tableExt=None,NoQuery=None,NoLimit=None,restrictField=None,restrictConnect=None,filter=None): |
"""analysieren den QueryString""" |
"""analysieren den QueryString""" |
#print "NO",nostore |
|
|
|
lop="AND" # standardsuche mit and |
lop="AND" # standardsuche mit and |
max="ALL" #standard alle auswaehlen |
max="ALL" #standard alle auswaehlen |
maxstr="" |
maxstr="" |
Line 553 class ZSQLExtendFolder(Folder,Persistent
|
Line 580 class ZSQLExtendFolder(Folder,Persistent
|
#print "Q",nostore,qs |
#print "Q",nostore,qs |
#check for op |
#check for op |
|
|
|
|
|
|
|
|
splitted=qs.split(",") |
splitted=qs.split(",") |
if tableExt: |
if tableExt: |
table=tableExt |
table=tableExt |
Line 737 class ZSQLExtendFolder(Folder,Persistent
|
Line 767 class ZSQLExtendFolder(Folder,Persistent
|
#print "QUERYSTRING:",self.REQUEST.SESSION[storename]['queryString2'] |
#print "QUERYSTRING:",self.REQUEST.SESSION[storename]['queryString2'] |
if not self.REQUEST.SESSION.has_key(storename): |
if not self.REQUEST.SESSION.has_key(storename): |
self.REQUEST.SESSION[storename]={} |
self.REQUEST.SESSION[storename]={} |
|
|
|
self.REQUEST.SESSION[storename]['qs']=qs #sichere Querystring |
|
|
if self.REQUEST.SESSION[storename].has_key('queryString2'): |
if self.REQUEST.SESSION[storename].has_key('queryString2'): |
|
|
if not self.REQUEST.SESSION[storename]['queryString2']==query2: |
if not self.REQUEST.SESSION[storename]['queryString2']==query2: |
Line 1156 class ZSQLBibliography(Folder,ZSQLExtend
|
Line 1189 class ZSQLBibliography(Folder,ZSQLExtend
|
|
|
def getMetaDataXML(self): |
def getMetaDataXML(self): |
"""crate index meta""" |
"""crate index meta""" |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','record.xml').__of__(self) |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','record.xml')).__of__(self) |
pt.content_type="text/xml" |
pt.content_type="text/xml" |
return pt() |
return pt() |
|
|