X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=www%2Fquery.egw;h=0c4832d4ce52cbcc0fc6457fe35542ff68176e40;hb=df7b985601de6c729147a6fd6588adba6f905480;hp=3f0d25f5d2d6723af1225c2e7053813f4d8ef948;hpb=c1c09b4242df9a16cd11477deea2e35f8ff57fec;p=egate.git diff --git a/www/query.egw b/www/query.egw index 3f0d25f..0c4832d 100644 --- a/www/query.egw +++ b/www/query.egw @@ -1,112 +1,212 @@ + + WWW/Z39.50 Gateway Query Form + + { -# $Id: query.egw,v 1.3 1995/10/27 17:30:15 adam Exp $ +# $Id: query.egw,v 1.21 1996/01/02 10:52:26 adam Exp $ + + if {[info commands saveState] == ""} { + source z39util.tcl + } + proc fail-response {} { global sessionWait - htmlr {Init fail
} - set sessionWait 0 + set sessionWait -1 } -proc init-response {} { +proc ok-response {} { global sessionWait - htmlr {Init ok
} - htmlr {} - htmlr {} - set sessionWait 0 + set sessionWait 1 } - set t $sessionParms - set databases [lindex $targets($t) 1] - set sessionWait 1 - ir z39 + global setNo + global nextSetNo + global hist + + set host [lindex $sessionParms 0] + + if {[catch {set setNo $nextSetNo}]} { + set nextSetNo 1 + set setNo 1 + } + if {[catch {set oldHost [z39 connect]}]} { + set oldHost "" + } + + set hist($setNo,host) $host + set hist($setNo,idAuthentication) [lindex $targets($host) 3] + + if {[catch {z39 failback fail-response}]} { + ir z39 + } + + html "

Search in " [lindex $targets($host) 0] "

\n" + + z39 callback ok-response z39 failback fail-response - z39 connect $t - z39 callback init-response - z39 init -} - - WWW/Z39.50 Gateway Query Form - - -

Search in databases

-

Not Functional Yet

-{ - html {
} + if {$host != $oldHost} { + catch {z39 disconnect} + + set sessionWait 0 + if {[catch {z39 connect $host}]} { + displayError "Cannot connect to target ${host}" {} + html "\n" + z39 disconnect + wabort + } elseif {$sessionWait == 0} { + if {[catch {zwait sessionWait 35}]} { + displayError "Cannot connect to target ${host}" {} + html "\n" + z39 disconnect + wabort + } + if {$sessionWait != 1} { + displayError "Cannot connect to target ${host}" {} + html "\n" + z39 disconnect + wabort + } + } + set sessionWait 0 + z39 idAuthentication $hist($setNo,idAuthentication) + if {[catch {z39 init}]} { + displayError "Cannot initialize target ${host}" {} + html "\n" + wabort + } + if {[catch {zwait sessionWait 60}]} { + displayError "Cannot initialize target ${host}" {} + html "\n" + wabort + } + if {$sessionWait != "1"} { + displayError "Cannot initialize target ${host}" {} + htmlr "\n" + wabort + } + if {![z39 initResult]} { + displayError "Connection rejected by target ${host}" \ + [z39 userInformationField] + z39 disconnect + htmlr "" + wabort + } + } + set databases [lindex $targets($host) 1] + + if {[catch {set prevHost $hist([expr $setNo - 1],host)}]} { + set databaseDefault [lindex $databases 0] + set oSetNo 0 + } else { + set oSetNo [expr $setNo - 1] + set databaseDefault $hist($oSetNo,database) + } + html {} \n set nodb [llength $databases] if {$nodb > 1} { if {$nodb > 2} { - htmlr {The chosen target supports searching in several databases.
} - htmlr {Choose the bases you want to search:
} + html "The chosen target supports searching in " + html "several databases.
\n" + html "Choose the bases you want to search:
\n" } set i 0 foreach d $databases { html { } $d + if {[lsearch $databaseDefault $d] == -1} { + html {"> } $d \n } else { - htmlr {" checked> } $d + html {" checked> } $d \n } } - htmlr {
} + html "
\n" if {$nodb > 2} { - html { All
} + html { All
} \n } + html "Input your search criteria:
\n" } } -
-Input your search criteria:
{ - set fields [lindex $targets($t) 2] + set fields [lindex $targets($host) 2] for {set no 1} {$no < 4} {incr no} { - htmlr {} \n + if {$oSetNo > 0} { + html {
+

+ +{ + html {Europagate} + html {New Target} +} +


This page is maintained by Peter Wad Hansen . Last modified 29. september 1995.
- This and the following pages are under construction and will continue to be so -until the end of December 1995. -
-sessionId: {html $sessionId}
-sessionParms: {html $sessionParms}
+ This and the following pages are under construction +and will continue to be so until the end of December 1995. + { + html "
\n" + html "

Debug information

\n" + html "sessionId: $sessionId
\n" + html "sessionParms: $sessionParms
\n" foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} { - htmlr $e {: } $env($e) {
} + html $e {: } $env($e) {
} \n } + html "form: " [wform] "
\n" + html "target: " $host "
\n" + html "databases: " $databases "
\n" + html "setNo: " $setNo "
\n" + html "nextSetNo: " $nextSetNo "
\n" } -form: {html [form]}
-target: {html $t}
-databases: {html $databases}
+ + +