Patch title: Release 90 bulk changes
Abstract:
File: /protocol/http/client.pli
Key:
    Removed line
    Added line
   
# Copyright  Hubert Tonneau  hubert.tonneau@pliant.cx
#
# This program is free software; you can redistribute it and
# modify it under the terms of the GNU General Public Licens
# as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be us
# but WITHOUT ANY WARRANTY; without even the implied warrant
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See 
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public 
# version 2 along with this program; if not, write to the Fr
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 


type HttpStreamDriver
  field Link:Stream tcp
  field CBool direct
  field Intn remain
  field Str filename
  field Link:Stream temp
  field CBool initial_ack
  field Str server path ; field DateTime datetime ; field St
  field DateTime opened_on
  field TraceSession log
# Copyright  Hubert Tonneau  hubert.tonneau@pliant.cx
#
# This program is free software; you can redistribute it and
# modify it under the terms of the GNU General Public Licens
# as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be us
# but WITHOUT ANY WARRANTY; without even the implied warrant
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See 
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public 
# version 2 along with this program; if not, write to the Fr
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 


type HttpStreamDriver
  field Link:Stream tcp
  field CBool direct
  field Intn remain
  field Str filename
  field Link:Stream temp
  field CBool initial_ack
  field Str server path ; field DateTime datetime ; field St
  field DateTime opened_on
  field TraceSession log
  field Str mime
StreamDriver maybe HttpStreamDriver


method http query command stream answer -> status
  arg_rw HttpStreamDriver http ; arg Str command ; arg_rw St
StreamDriver maybe HttpStreamDriver


method http query command stream answer -> status
  arg_rw HttpStreamDriver http ; arg Str command ; arg_rw St
  status := http:tcp:stream_driver query command http:tcp an
  if command="mime"
    answer := http mime ; status := success
  else
    status := http:tcp:stream_driver query command http:tcp answer


method fs open name options flags stream support -> status
  arg_rw HttpFileSystem fs ; arg Str name options ; arg Int 
  if (name eparse "//" any:(var Str server) "/" any:(var Str
    void
  else
    return failure
  if not (options option "no_http_encode")
    path := http_encode path
  var Int port
  if (server eparse any:(var Str server1) ":" port)
    server := server1
  else
    port := 80
  var Str channel := options option "channel" Str
  if channel=""
    channel := "tcp://"+server+"/client/"+string:port
  var Link:Stream tcp :> new Stream
  tcp open channel in+out+safe+cr+lf
  if tcp=failure
    http_trace trace "Failed to connect to " channel
    return (failure "Failed to connect to "+string:server+" 
  var Link:HttpStreamDriver http :> new HttpStreamDriver
  http tcp :> tcp
  http direct := false
  http initial_ack := options option "http_initial_ack"
  http server := server+(shunt port=80 "" ":"+string:port)
  http path := path
  http datetime := options option "datetime" DateTime
  http options := options
  http opened_on := datetime
  http:log bind http_trace
  var Str msg := ""
  if (flags .and. in_out)=in
    var CBool post := options option "form"
    var Str option := options option "option" Str
    tcp writeline (shunt post "POST" "GET")+" /"+path+(shunt
    write_http_options server options tcp http:log
    if post
      tcp writechars (options option "form" Str)
    var Str answer := tcp readline http:log
    if not (answer parse "HTTP/" (var Float protocol_level) 
      return (failure "Unexpected answer "+string:answer+" f
    msg := "http_return_code "+string:retcode
    while { var Str l := tcp readline http:log ; l<>"" }
      msg += " http_answer_option "+string:l


method fs open name options flags stream support -> status
  arg_rw HttpFileSystem fs ; arg Str name options ; arg Int 
  if (name eparse "//" any:(var Str server) "/" any:(var Str
    void
  else
    return failure
  if not (options option "no_http_encode")
    path := http_encode path
  var Int port
  if (server eparse any:(var Str server1) ":" port)
    server := server1
  else
    port := 80
  var Str channel := options option "channel" Str
  if channel=""
    channel := "tcp://"+server+"/client/"+string:port
  var Link:Stream tcp :> new Stream
  tcp open channel in+out+safe+cr+lf
  if tcp=failure
    http_trace trace "Failed to connect to " channel
    return (failure "Failed to connect to "+string:server+" 
  var Link:HttpStreamDriver http :> new HttpStreamDriver
  http tcp :> tcp
  http direct := false
  http initial_ack := options option "http_initial_ack"
  http server := server+(shunt port=80 "" ":"+string:port)
  http path := path
  http datetime := options option "datetime" DateTime
  http options := options
  http opened_on := datetime
  http:log bind http_trace
  var Str msg := ""
  if (flags .and. in_out)=in
    var CBool post := options option "form"
    var Str option := options option "option" Str
    tcp writeline (shunt post "POST" "GET")+" /"+path+(shunt
    write_http_options server options tcp http:log
    if post
      tcp writechars (options option "form" Str)
    var Str answer := tcp readline http:log
    if not (answer parse "HTTP/" (var Float protocol_level) 
      return (failure "Unexpected answer "+string:answer+" f
    msg := "http_return_code "+string:retcode
    while { var Str l := tcp readline http:log ; l<>"" }
      msg += " http_answer_option "+string:l
      void
      if (l parse "Content-Type" ":" any:(var Str value))
        http mime := value
    if retcode>=300
      return failure:msg
  eif (flags .and. in_out)=out
    var Intn size := options option "file_size" Intn
    if size<>undefined
      if debug
        console "upload on the fly "+options eol
      http direct := true
      http remain := size
      status := http write_header size tcp http:log
      if status=failure
        return
    else
      if debug
        console "store then upload" eol
      http filename := file_temporary
      http temp :> new Stream
      http:temp open http:filename out+(flags .and. safe)
  else
    return failure
  stream stream_driver :> http
  status := success ; status message := msg
    
method fs configure name options command -> status
  arg_rw HttpFileSystem fs ; arg Str name options command ; 
  if command="delete"
    if (name eparse "//" any:(var Str server) "/" any:(var S
      void
    else
      return failure
    var Int port
    if (server eparse any:(var Str server1) ":" port)
      server := server1
    else
      port := 80
    var Str channel := options option "channel" Str
    if channel=""
      channel := "tcp://"+server+"/client/"+string:port
    (var Stream tcp) open channel in+out+safe+cr+lf
    if tcp=failure
      http_trace trace "Failed to connect to " channel
      return failure
    (var TraceSession log) bind http_trace
    tcp writeline "DELETE /"+path+" HTTP/1.0" log
    write_http_options server options tcp log
    var Str answer := tcp readline log
    status := shunt (answer parse "HTTP/" (var Float protoco
    if retcode>=300
      return failure:msg
  eif (flags .and. in_out)=out
    var Intn size := options option "file_size" Intn
    if size<>undefined
      if debug
        console "upload on the fly "+options eol
      http direct := true
      http remain := size
      status := http write_header size tcp http:log
      if status=failure
        return
    else
      if debug
        console "store then upload" eol
      http filename := file_temporary
      http temp :> new Stream
      http:temp open http:filename out+(flags .and. safe)
  else
    return failure
  stream stream_driver :> http
  status := success ; status message := msg
    
method fs configure name options command -> status
  arg_rw HttpFileSystem fs ; arg Str name options command ; 
  if command="delete"
    if (name eparse "//" any:(var Str server) "/" any:(var S
      void
    else
      return failure
    var Int port
    if (server eparse any:(var Str server1) ":" port)
      server := server1
    else
      port := 80
    var Str channel := options option "channel" Str
    if channel=""
      channel := "tcp://"+server+"/client/"+string:port
    (var Stream tcp) open channel in+out+safe+cr+lf
    if tcp=failure
      http_trace trace "Failed to connect to " channel
      return failure
    (var TraceSession log) bind http_trace
    tcp writeline "DELETE /"+path+" HTTP/1.0" log
    write_http_options server options tcp log
    var Str answer := tcp readline log
    status := shunt (answer parse "HTTP/" (var Float protoco
  eif false # (command parse word:"datetime" (var DateTime dt))
    console "set date and time to " dt eol
    if (name eparse "//" any:(var Str server) "/" any:(var Str path))
      void
    else
      return failure
    var Int port
    if (server eparse any:(var Str server1) ":" port)
      server := server1
    else
      port := 80
    var Str channel := options option "channel" Str
    if channel=""
      channel := "tcp://"+server+"/client/"+string:port
    (var Stream tcp) open channel in+out+safe+cr+lf
    if tcp=failure
      http_trace trace "Failed to connect to " channel
      return failure

    (var TraceSession log) bind http_trace
    tcp writeline "PROPFIND /"+path+" HTTP/1.0" log
    var Str form := ""
    form += "<?xml version=[dq]1.0[dq] encoding=[dq]utf-8[dq] ?>[lf]"
    form += "<propfind xmlns=[dq]DAV:[dq]>[lf]"
    form += "  <allprop/>[lf]"
    form += "</propfind>[lf]"
    write_http_options server "form "+string:form+" "+options tcp log
    tcp writechars form
    console form
    var Str answer := tcp readline log
    console "answer is " answer eol
    status := shunt (answer parse "HTTP/" (var Float protocol_level) _ (var Int retcode) _ any) and retcode<300 success (failure "HTTP server rejected delete command "+string:answer)
    while not tcp:atend
      console tcp:readline eol

    (var TraceSession log) bind http_trace
    console "PROPPATCH /"+path+" HTTP/1.0" eol
    tcp writeline "PROPPATCH /"+path+" HTTP/1.0" log
    var Str form := ""
    form += "<?xml version=[dq]1.0[dq] encoding=[dq]utf-8[dq] ?>[lf]"
    form += "<D:propertyupdate xmlns:D=[dq]DAV:[dq]>[lf]"
    form += "<D:set>[lf]"
    form += "<D:prop>[lf]"
    form += "<D:getlastmodified>"+rfc1123_date:dt+"</D:getlastmodified>[lf]"
    form += "</D:prop>[lf]"
    form += "</D:set>[lf]"
    form += "</D:propertyupdate>[lf]"
    write_http_options server "form "+string:form+" "+options tcp log
    tcp writechars form
    console form
    var Str answer := tcp readline log
    console "answer is " answer eol
    status := shunt (answer parse "HTTP/" (var Float protocol_level) _ (var Int retcode) _ any) and retcode<300 success (failure "HTTP server rejected delete command "+string:answer)
    while not tcp:atend
      console tcp:readline eol
  else
    status := failure


  else
    status := failure