X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=www%2Fquery.egw;h=e922e297507073e831d16a3d3cc93d438010575f;hb=c6ea088406ba64e6ed5ea833e1c2ae516552e18e;hp=e188c71d361d56e2dd4449fbf84700da32e4d6b4;hpb=a6f3beb071fe8c894ee6c846c86296c84f48e3d4;p=egate.git diff --git a/www/query.egw b/www/query.egw index e188c71..e922e29 100644 --- a/www/query.egw +++ b/www/query.egw @@ -1,105 +1,212 @@ + + WWW/Z39.50 Gateway Query Form + + { -# $Id: query.egw,v 1.2 1995/10/27 15:12:04 adam Exp $ -proc init-response {} { +# $Id: query.egw,v 1.19 1995/12/20 16:31:31 adam Exp $ + + if {[info commands saveState] == ""} { + source z39util.tcl + } + +proc fail-response {} { global sessionWait - htmlr {Init ok
} - htmlr {} - htmlr {} - set sessionWait 0 + set sessionWait -1 } - set t $sessionParms - set databases [lindex $targets($t) 1] - ir z39 +proc ok-response {} { + global sessionWait set sessionWait 1 - z39 connect $t - z39 callback init-response - z39 init } - - WWW/Z39.50 Gateway Query Form - - -

Search in databases

-

Not Functional Yet

-{ - html {
} + + 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 {

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

\n" + + z39 callback ok-response + z39 failback fail-response + 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 30}]} { + 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 {$setNo > 1 && $hist([expr $setNo - 1],host) == $host} { + set oSetNo [expr $setNo - 1] + set databaseDefault $hist($oSetNo,database) + } else { + set databaseDefault [lindex $databases 0] + set oSetNo 0 + } + + 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 {} + html {} +} +
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}
+ + +