home *** CD-ROM | disk | FTP | other *** search
/ Kosovo Orphans' Appeal Charity CD / KosovoOrphansAppeal.iso / internet / browsers / _webster / docs / protocol < prev    next >
Text File  |  1995-12-05  |  37KB  |  792 lines

  1. /*
  2.  * ArcWeb Standard Protcol Definition
  3.  *
  4.  * Copyright (C) Stewart Brodie, 1994, 1995
  5.  *
  6.  * This product is supplied under the terms laid down in the `Terms' file.
  7.  *
  8.  * This file: Protocol
  9.  *
  10.  *   Paragraphs prefixed by '+' have been added by Andrew Pullan
  11.  *   and relate specifically to Webster.
  12.  *
  13.  *   + Added info on the WebBrowser protocol.
  14.  *   + Added the FetchInProgress Messages. These are not yet part of the
  15.  *   +  official Protcol Definition
  16.  *
  17.  *   For ArcWeb versions 0.28 and later (until superceded)
  18.  *
  19.  *   Changes from protocol in version 0.26
  20.  *      'reload' and 'fast images' bits have been switched
  21.  *      the ExternalLaunch can accept non-extended URLs, although such use is
  22.  *      deprecated.
  23.  *
  24.  *   Changes from protocol in version 0.25
  25.  *      Message_ArcwebExternalLaunch added
  26.  *      Message_ArcwebConfigure added
  27.  *      Notes on both of the above added.
  28.  *
  29.  *   Changes from protocol in version 0.20
  30.  *      More flags added to FetchRequest & PostRequest messages.  These are
  31.  *      for the information of the fetcher only and do not need to be preserved
  32. ***     From version 0.25, the use on non-extended URLs is deprecated
  33.  *
  34.  *   Changes from protocol in version 0.19
  35.  *      Comments about bit 27 handling (arcweb_FLAGS_url_changed) changed
  36.  *      Comments in several other sections changed
  37.  *      Whole document should be reread by those implementing any part of
  38.  *      any of the ArcWeb protocols
  39.  *
  40.  *   Changes from protocol in version 0.12
  41.  *      Extensions to the Message_ArcwebRenderDone buffer.  The image renderer
  42.  *      must insert the X and Y pixel size of a graphical image (to enable
  43.  *      ArcWeb to calculate URLs for imagemaps unless the information is not
  44.  *      available or not applicable (eg. for sound)
  45.  *
  46.  *   Changes from protocol in version 0.11
  47.  *      Extended URL protocol defined
  48.  *      - in *Request message blocks
  49.  *      - notes about ownership of file handles
  50.  *      - in comments about the Flags word
  51.  *      - comments about how to handle Location: header from HTTP servers
  52.  *      Message_ArcwebEMailRequest/Done added
  53.  *      Handling of bit 27 in non-extended URL messages
  54.  *      In Other Notes: comment about expiry dates updated
  55.  *      Warning about setting type bits in Done messages
  56.  *      Renderer protocol warnings added
  57.  *      Sender protocol renamed to Poster protocol
  58.  *      EMail protocol added (uses a new bit in flags)
  59.  *      Suggestion about intelligent HTTP fetchers prefetching images
  60.  *      Message_ArcwebAbortRequest added   + description
  61.  *      Message_ArcwebTransferStatus added + description
  62.  *
  63.  */
  64.  
  65. This file describes the protocols used by ArcWeb.  There are nine protocols
  66. planned, although only the first eight are fully implemented so far.
  67.  
  68. + This file also describes the protocols used by Webster. Again only the first
  69.   eight are implemented and the 'Renderer Protocol' is only used for files
  70.   that are not HTML and is not used for inline Images (These are configured
  71.   separately).
  72.  
  73.   * Fetcher Protocol
  74.   * Renderer Protocol
  75.   * Quit Protocol
  76.   * Extended URL Protocol
  77.   * Poster Protocol
  78.   * Email Protocol
  79.   * External Launch Protocol
  80.   * Configuration Protocol
  81.   * Expire Protocol
  82.  
  83.  
  84. Programmers supporting these protocols must be extremely careful with their
  85. memory, message and protocol management.  The protocols are allowed to be
  86. concurrent and nested.
  87.  
  88. The obvious example is that a renderer may find an inline image in a
  89. document, and will hence want to issue a request to fetch it.  A not so
  90. obvious example is an intelligent HTTP fetcher which tries to intelligently
  91. scan the returned document (if it was HTML) to pick out <img> tags and kick
  92. off requests for these in-lined images so that when ArcWeb comes to ask for
  93. them, a swifter reply can be made.  The impact of such a system would be
  94. more noticable, the more images there are inlined in a document.
  95.  
  96.  
  97. General
  98. =======
  99.  
  100.   Each protocol consists of 2 messages, a "Request" and a "Done". The
  101. Request is sent with event code 18 to force an acknowledgement.  The
  102. fetcher/renderer should acknowledge with the Done message to prevent the
  103. Wimp returning the message to the originator.  Should the fetcher/renderer
  104. wish to call Wimp_Poll before it is ready to send the Done reply, it MUST ack
  105. the message (ie. fill in the ref fields and reply with event type 19 to
  106. prevent the Wimp returning it to the originator), and then send the Done
  107. message when it is ready (having remembered to fill in the your_ref field
  108. from the my_ref of the original Request).
  109.  
  110.   Instead of sending a Wimp acknowledgement with event type 19 to prevent
  111. delivery failure, as mentioned above, it would be much better to actually
  112. reply with a Message_ArcwebTransferStatus, which doubles both as the ack and
  113. as a useful message.  Further Message_ArcwebTransferStatus messages can be
  114. sent periodically (use event type 17 and zero the ref field for these)
  115.  
  116.   C programmers will want to use requester.h to define the structures used. 
  117. The types have been divorced from any Wimp library, only char, void and int
  118. types have been used.
  119.  
  120. For an example of a Fetcher, see !ArcwebLcl application supplied.  For an
  121. example of a Renderer, see !ArcWebImg application supplied.  ArcWeb
  122. broadcasts a RenderRequest even for HTML and plain text files, as it listens
  123. for RenderRequest messages itself (and this allows it to be overridden).
  124.  
  125. + Webster does not broadcast RenderRequests for HTML files or inline images,
  126.   as these are dealt with by Webster it's self. It can however be configured
  127.   to broadcast this message for any other kind of file.
  128.  
  129. Messages
  130. ========
  131.  
  132. buf is the buffer returned from Wimp_Poll (&e->data in Risc_OSlib).  The
  133. obvious fields have been omitted (ie. buf+0 to buf+12).
  134. The 'Private ArcWeb handle' must always be preserved, as this is the only
  135. way ArcWeb can deliver replies to the request originator.
  136.  
  137. The types of each entry are given:  str0 = zero terminated string.  strN = 
  138. string whose length is defined elsewhere.  str0/N = string zero terminated
  139. unless it is maximum length (defined elsewhere) in which case the terminator
  140. is missing; date5 = 5 byte date string (in UTC) as returned by OS_Word 14,3
  141.  
  142. The buffers are all defined together and then explained below.  requester.h
  143. contains C structures for these messages.
  144.  
  145.  
  146.  
  147.  
  148. Message_ArcwebFetchRequest      (msg_Arcweb__base +  0)
  149.  
  150.         buf+16  int     Message_ArcwebFetchRequest      (0x4A240)
  151.         buf+20  void*   Private ArcWeb handle
  152.         buf+24  int     Flags
  153.         buf+28  int     RISC OS file handle (source)
  154.  
  155. EITHER  buf+32  str0    Uniform Resource Locator (fully qualified)
  156.  
  157.     OR  buf+32  int     RISC OS file handle (URL) (if flags bit 22 set)
  158.  
  159.  
  160. Message_ArcwebFetchDone         (msg_Arcweb__base +  1)
  161.  
  162.         buf+12  int     my_ref from Message_ArcwebFetchRequest
  163.         buf+16  int     Message_ArcwebFetchDone         (0x4A241)
  164.         buf+20  void*   Private ArcWeb handle
  165.         buf+24  int     Flags
  166.  
  167.  EITHER buf+28  str0    Error message
  168.  
  169.      OR buf+28  int     Zero=this item has an expiry date
  170.         buf+32  int     Non-zero=use default expiry delay
  171.         buf+36  date5   Expiry date in UTC (if buf+32 zero, and buf+28 zero)
  172.  
  173.  
  174. Message_ArcwebRenderRequest     (msg_Arcweb__base +  2)
  175.  
  176.         buf+16  int     Message_ArcwebRenderRequest     (0x4A242)
  177.         buf+20  void*   Private ArcWeb handle
  178.         buf+24  int     flags
  179.         buf+28  int     RISC OS file handle (source)
  180.         buf+32  int     RISC OS file handle (temporary)
  181.         buf+36  int     RISC OS file handle (diagram)
  182.         buf+40  int     RISC OS file handle (link)
  183.         buf+44  int     size of data following
  184.         buf+48  ---     (contents of buf+44) bytes of source file
  185.  
  186. Message_ArcwebRenderDone        (msg_Arcweb__base +  3)
  187.  
  188.         buf+16  int     Message_ArcwebRenderDone        (0x4A243)
  189.         buf+20  void*   Private ArcWeb handle
  190.         buf+24  int     flags
  191.  
  192. EITHER  buf+28  int     size of image in x pixels (0 if N/A)
  193.         buf+32  int     size of image in y pixesl (0 if N/A)
  194.  
  195. OR      buf+28  str0    error message
  196.  
  197.  
  198. Message_ArcwebPostRequest       (msg_Arcweb__base +  4)
  199.  
  200.         buf+16  int     Message_ArcwebPostRequest       (0x4A244)
  201.         buf+20  void*   Private ArcWeb handle
  202.         buf+24  int     flags
  203.         buf+28  int     RISC OS file handle (source)
  204.         buf+32  int     RISC OS file handle (form)
  205.  
  206. EITHER  buf+36  str0    Uniform Resource Locator (if flags bit 22 clear)
  207.  
  208.     OR  buf+36  int     RISC OS file handle (URL) (if flags bit 22 set)
  209.  
  210. Message_ArcwebPostDone          (msg_Arcweb__base +  5)
  211.  
  212.         buf+12  int     my_ref from Message_ArcwebPostRequest
  213.         buf+16  int     Message_ArcwebPostDone          (0x4A245)
  214.         buf+20  void*   Private ArcWeb handle
  215.         buf+24  int     flags
  216.  
  217.  EITHER buf+28  str0    Error message
  218.  
  219.      OR buf+28  int     Zero=this item has an expiry date
  220.         buf+32  int     Non-zero=use default expiry delay
  221.         buf+36  date5   Expiry date in UTC (if buf+32 zero, and buf+28 zero)
  222.  
  223. Message_ArcwebEMailRequest      (msg_Arcweb__base +  6)
  224.  
  225.         buf+16  int     Message_ArcwebEMailRequest      (0x4A246)
  226.         buf+20  void*   Private ArcWeb handle
  227.         buf+24  int     flags
  228.         buf+28  int     RISC OS file handle (form file containing e-mail)
  229.  
  230. Message_ArcwebEMailDone         (msg_Arcweb__base +  7)
  231.  
  232.         buf+12  int     my_ref from Message_ArcwebEMailRequest
  233.         buf+16  int     Message_ArcwebEMailDone         (0x4A247)
  234.         buf+20  void*   Private ArcWeb handle
  235.         buf+24  int     flags
  236.  
  237.  
  238. Message_ArcwebQuit              (msg_Arcweb__base + 32)
  239.  
  240.         buf+16  int     Message_ArcwebQuit              (0x4A260)
  241.  
  242.  
  243. Message_ArcwebExpire            (msg_Arcweb__base + 33)
  244.  
  245.         buf+16  int     Message_ArcwebExpire            (0x4A261)
  246.         buf+20  void*   Private ArcWeb handle
  247.         buf+24  int     flags
  248.         buf+28  int     RISC OS file handle (source)
  249.  
  250. Message_ArcwebAbortRequest      (msg_Arcweb__base + 34)
  251.  
  252.         buf+16  int     Message_ArcwebAbortRequest      (0x4A262)
  253.         buf+20  void*   Private ArcWeb handle
  254.         buf+24  int     reserved
  255.         buf+28  str0    reason for abort (could log this)
  256.  
  257. Message_ArcwebTransferStatus    (msg_Arcweb__base + 35)
  258.  
  259.         buf+16  int     Message_ArcwebTransferStatus    (0x4A263)
  260.         buf+20  void*   Private ArcWeb handle from ..Request
  261.         buf+24  int     reserved, must be zero
  262.         buf+28  int     status flags
  263.         buf+32  int     total size of data to be transmitted
  264.         buf+36  int     size of data transmitted so far
  265.         buf+40  int     total size of data to be received (if known)
  266.         buf+44  int     size of data received so far
  267.         buf+48  str0    current status of communication
  268.  
  269. Message_ArcwebConfigure         (msg_Arcweb__base + 36)
  270.  
  271.         buf+16  int     Message_ArcwebConfigure         (0x4A264)
  272.         buf+20  void*   Unused
  273.         buf+24  int     Unused
  274.         buf+28  str0    Application to be configured
  275.         
  276. Message_ArcwebExternalLaunch    (msg_Arcweb__base + 37)
  277.  
  278.         buf+16  int     Message_ArcwebExternalLaunch    (0x4A265)
  279.         buf+20  void*   Sender's private handle (not ArcWeb's)
  280.         buf+24  int     Flags (see notes on this Message)
  281.         buf+28  int     RISC OS file handle (URL)
  282.  
  283. Message_ArcwebLaunchDone        (msg_Arcweb__base + 38)
  284.  
  285.         buf+12  int     my_ref from Message_ArcwebExternalLaunch
  286.         buf+16  int     Message_ArcwebLaunchDone        (0x4A266)
  287.         buf+20  void*   Preserved from the Launch message
  288.         buf+24  int     Flags (will have bit 31 set on an error)
  289.         buf+28  str0    Error message
  290.  
  291. Message_ArcwebWebBrowser        (msg_Arcweb__base +  39)
  292.  
  293.         buf+16  int     Message_ArcwebWebBrowser      (0x4A267)
  294.         buf+20          Unused
  295.         buf+24          Unused
  296.         buf+28  str0    Browser name (Zero terminated)
  297.  
  298. +Message_ArcwebFetchInProgress      (msg_Arcweb__base +  40)
  299. +
  300. +        buf+16  int     Message_ArcwebFetchInProgress (0x4A268)
  301. +        buf+20  void*   Private ArcWeb handle
  302. +        buf+24  int     Flags
  303. +        buf+28  int     RISC OS file handle (source)
  304. +        buf+32  int     RISC OS file handle (URL) (if flags bit 22 set)
  305.  
  306.  
  307. Ownership of File Handles
  308. =========================
  309.  
  310. Some people have expressed concern at the apparent capability to lose track
  311. of which task 'owns' the RISC OS file handles passed in the messages.  There
  312. is never any ambiguity, and this section will clarify this.
  313.  
  314. The task which sends the FetchRequest/RenderRequest/PostRequest message will
  315. have called OS_Find to open the file, and this task (normally ArcWeb itself)
  316. owns the returned file handle UNTIL it calls Wimp_Poll.  At this point, the
  317. Wimp will start delivering the Request message to each task in turn.  While
  318. the Wimp is doing this the file handle is in limbo (in effect, it is
  319. 'lost').
  320.  
  321. There are two possible continuations:
  322.  
  323. i) As soon as a task receives the Request message and decides that it wishes
  324. to reply to the Request message, it will either send the corresponding Done
  325. message, OR just ack it with the intention on replying properly later.  It
  326. is upon the sending of this Done message, or Ack, (the call to
  327. Wimp_SendMessage) that the task becomes the owner of the file handle, and
  328. hence responsible for closing the file handle when it is finished with.
  329.  
  330. ii) The other scenario is when *no* task wants to reply to the Request
  331. message. In this case, the Wimp will deliver an event code 19 copy of the
  332. message to the originator.  The originator now regains ownership of the file
  333. handle and is responsible for it (ArcWeb closes the file(s) and generates
  334. an error if this is sensible).
  335.  
  336. In general, for any task, if it receives a Request message, it is guaranteed
  337. to have exclusive use of the file handle until it next calls Wimp_Poll.
  338.  
  339. This system ensures that ownership of the file is guaranteed to be allocated
  340. to one particular task in the system at any time, and that a task has to
  341. 'claim' ownership explicitly, as shown in (i) above.
  342.  
  343. + There is one Complicated Situation. That is when the Fetcher sends the
  344. + Message_ArcWebFetchInProgress message. With this message the ownership of
  345. + file handles reverts back to the Browser after the InProgress message is
  346. + sent. If message should only ever be sent when the Browser allows it.
  347.  
  348. Flags
  349. =====
  350.  
  351. The Flags word contains several useful bits of information:
  352.  
  353.    On ..Request messages:
  354.    
  355.         bit  0          Now unused (was reload bit in previous versions)
  356.         bit  1          If set, the previous page was a local: URL
  357.         bit  2          If set, fast images are being used - not implemented
  358.         bit  3          If set, the POST request should be sent as a PUT
  359.         bit  4          If set, the user has disabled image fetching
  360. +       bit  5          If set, the Browser supports InProgress messages
  361. +                       for this fetch. May not support it on the next fetch!   
  362.  
  363.    On ..Done and InProgress messages
  364.    
  365.         bits 0-15       RISC OS file type/ArcWeb file type (see bits 16,30)
  366.         bit  16         If set, bits 0-15 are ArcWeb file type, else RISC OS
  367.  
  368.    In both types of message:
  369.  
  370.         bits 17 and 18  Reserved (must preserve in replies)
  371.         bit  19         If set, user requested a 'save to disc'
  372.         bit  20         If set, user requested a reload on this document
  373.         bit  21         If set, the email message is already complete
  374.         bit  22         If set, an extended URL is in use
  375.         bit  23         If set, ArcWeb will not display the results of the render
  376.         bit  24         If set (+bit 31 set), ArcWeb will not raise an error
  377.         bit  25         If clear, this is a 'page' fetch, else inline data
  378.         bit  26         If set, ArcWeb will close the window which issued request
  379.         bit  27         If set, extended URL has changed
  380.         bit  28         If set, symbolic link request/confirm
  381.         bit  29         If set, ArcWeb will not attempt to render the file
  382.         bit  30         If set, bits 0-16 are valid, else they are invalid
  383.         bit  31         If set, buffer contains an error message
  384.  
  385. + Webster ignores bits 23,26 and 29 as for Webster they make no sense.
  386.  
  387. The error bit (31) determines which of the options in two of the messages
  388. above, is in force.  If the error bit is set, ArcWeb will raise an error to
  389. the user UNLESS bit 24 is also set (indicating that the other application
  390. has already handled this - this is the preferred way of doing it).
  391.  
  392. When a request to fetch a new page is issued, ArcWeb remembers which window
  393. (if any) launched the request.  Once a successful RenderDone has been
  394. delivered to the window, it will self-destruct if bit 26 is set.  ArcWeb
  395. will set this bit itself according to the user's choice, and so this bit
  396. should always be preserved, unless you absolutely want to set it (see bit 23
  397. below).  That window is not allowed to launch further requests until the
  398. whole transaction is completed.  This blocked state is indicated to the user
  399. by the web animation in the information window for a busy page.
  400.  
  401. If you find that bit 22 is set upon receipt of a Request involving a URL,
  402. then the buffer will not contain a URL, but a file handle of a file that
  403. does.  The file will have been opened in R/W mode with OS_Find.  You should
  404. read the whole of the file to obtain the URL.  It may be terminated by a
  405. whitespace character, or by EOF.  The same rules about responsibility for
  406. closing the file apply as for the other handles in ..Request messages.
  407.  
  408. If, during a conversation with an HTTP server, you receive a Location:
  409. directive indicating a document relocation, then you should amend the
  410. contents of the extended URL file to represent the new target URL.  You must
  411. set flag bit 27 in the Done message (which you don't send immediately - you
  412. pretend as though you had received the new URL from the Request message). 
  413. The transparent obedience to Location: directives is not strictly required
  414. (and the change cannot be signalled to ArcWeb if the extended URL protocol
  415. is not being used), but is MOST HIGHLY ENCOURAGED.  At some point in the
  416. future, only extended URLs will be used at all.
  417.  
  418. *** From version 0.25, the use on non-extended URLs is deprecated
  419.  
  420. If bit 19 was set, then the user did a SHIFT-click on the link to force it
  421. to be loaded to disc only.
  422.  
  423. If bit 23 is set in RenderDone, ArcWeb will not display the results of the
  424. render.  This is to allow applications such as image renderers to open their
  425. own window to display the picture.  This must NOT be done if bit 25 is set
  426. (as someone else is trying to render an inline image).  If bit 25 is set,
  427. the application must convert the image into a sprite file and store it in
  428. the 'diagram' file.  If you set bit 23, it is a good idea to clear bit 26 in
  429. order not to confuse the user.  Make sure that you set the size of the image
  430. in pixels (if appropriate) in the RenderDone message, as this will enable
  431. image maps to work correctly.
  432.  
  433. Upon receipt of a FetchRequest message, the application should check bit 28. 
  434. If bit 28 is set, then the application may opt to retrieve the file to its
  435. own private directory and store the name of the file in the 'source' file. 
  436. If it declines to do this (or bit 28 is clear anyway), bit 28 should be
  437. cleared on the response and the fetched file placed in 'source'.  This
  438. facility is provided mainly for the benefit of ArcWebLcl to avoid copying
  439. files around the locally available filesystems.
  440.  
  441. If bit 21 is set on receipt of a EMailRequest message, then this indicates
  442. that the form file contains a complete e-mail message ready to be mailed
  443. off (excluding From: header).  If bit 21 is clear, then this indicates that
  444. the helper application needs to open some kind of editor to allow the user
  445. to complete the e-mail.  The editor should be initialised with the contents
  446. of the form file.  If it is going to do anything at all, then the helper
  447. application must reply with a EMailDone message.
  448.  
  449. Bit 20 is used by ArcWeb to indicate to fetchers that the user has
  450. specifically requested that images are not fetched and rendered.  This
  451. allows 'intelligent' HTTP fetchers mentioned at the start of this document,
  452. to parse the HTML responses to its fetches and immediately kick off the
  453. transfers for these images before the render of the document begins.  If bit
  454. 20 is set, then the fetcher should not do this.
  455.  
  456.  
  457.  
  458. Message_ArcwebAbortRequest
  459. ==========================
  460.  
  461. Upon receipt of this message, the fetcher application retrieving a URL under
  462. the given ArcWeb Private handle, should terminate the fetch with an error. 
  463. It should acknowledge this message with Message_ArcwebFetchDone, after
  464. setting the flags correctly indicating some kind of error.  All active
  465. fetches associated with the handle should be stopped.  This allows
  466. intelligent fetchers to stop any automatic fetches that they might have
  467. issued, to fetch inlined images.
  468.  
  469. At the choice of the FETCHER, it may decide to ignore the AbortRequest and
  470. continue fetching data.  The most obvious situation in which this is useful
  471. is if the fetch is large and nearly complete anyway - say less than 1 second
  472. estimated to completion.  You must acknowledge the AbortRequest with a
  473. FetchDone, in the usual manner (ie. you can acknowledge the message first,
  474. then send a reply later).  The amount of time may be configurable in the
  475. fetcher, but should not exceed a few seconds as this may confuse the user.
  476.  
  477.  
  478.  
  479. Message_ArcwebTransferStatus
  480. ============================
  481.  
  482. A fetcher which wishes to inform the user of the status of the communication
  483. between itself and the remote information server (FTP, HTTP, Gopher, etc..)
  484. may use this message to inform the browser of its progress.  The 4 size
  485. elements in the message may be used by the browser to create a graphical
  486. representation of the communication status.  Values of -1 should be known
  487. for unknown quantities (0 is reserved for indicating no bytes yet
  488. transferred or expected).  The browser may choose to ignore these values and
  489. rely on the description string, which should say something like:
  490.  
  491. 1000 bytes out of 2000 byte document read
  492. 0 bytes out of 16384 bytes of inlined image read
  493. Looking up louis.ecs.soton.ac.uk ...
  494.  
  495. or whatever it feels is appropriate.  Fetcher writers must recognise that
  496. the browser may attempt to display these messages in an icon, and will hence
  497. be issuing redraw requests (even if only via Wimp_SetIconState) for each
  498. message received.  The fetcher should provide a facility for disabling these
  499. messages, and not send them too frequently - two or three times per second
  500. is quite enough.
  501.  
  502.  
  503. If you are going to provide byte counts as in the examples above, I HIGHLY
  504. RECOMMEND using OS_Convert(Fixed)FileSize to give a useful display.  It
  505. isn't terribly useful to know that 65539 bytes out of 268435456 bytes have
  506. been received.  Far better, even if slightly inaccurate, to say '64K out of
  507. 256M' and maybe show the percentage that represents.
  508.  
  509. Returned messages should typically be less than about 64 characters long.
  510.  
  511. The browser may ignore these messages, and so the fetcher should not send
  512. them recorded delivery (Wimp event type 18).
  513.  
  514. The flags for Message_ArcwebTransferStatus:
  515.  
  516.         bit   0         If set, transmission is in progress
  517.         bit   1         If set, reception is in progress
  518.         bit   2         If set, transmission is complete
  519.         bit   3         If set, reception is complete
  520.         bit   4         If set, other comms. are in progress eg. DNS lookup
  521.         bits  5 - 31    Reserved
  522.  
  523.  
  524.  
  525. Other Notes
  526. ===========
  527.  
  528. You must preserve the ArcWeb Private Handle.  This is a private pointer to a
  529. part of ArcWeb's application memory used to distribute the replies which
  530. ArcWeb receives.
  531.  
  532. When specifying an expiry date in FetchDone messages, if you intend to
  533. specify a date rather than allow the default to be used, then you must
  534. specify this as an exact date.  ie. not relative to the current time, you
  535. must add it up yourself.  HTTP servers may supply expiry dates on documents
  536. which they return.  These should be honoured (see documentation of the
  537. Territory module's handling of Time & Date).
  538.  
  539. The 'source', 'temporary', 'diagram' and 'link' words in the FetchRequest
  540. and RenderRequest messages are RISC OS file handles to the appropriate files
  541. in ArcWeb's cache.  If you acknowledge either of the Request messages, YOU
  542. are responsible for closing the files (ie. passing the handle to OS_Find 0).
  543. You must close ALL the file handles in the message even if you don't use
  544. them all.  The reason for passing handles around is that filenames  won't
  545. necessarily fit in the message buffer (particularly when you want to pass 5
  546. of them).  If just having the handle is inconvenient, you should use OS_Args
  547. 7 to convert the handle into a filename (as !ArcWebLcl does), close the file
  548. and reopen it how you want to do it.  BUT BEWARE: only do this if you are
  549. going to acknowledge the message (otherwise other recipients of the message
  550. will find that they have an illegal file handle in the message).  For
  551. FetchRequest, 'source' is opened as read/write (OS_Find 0x83 - [I always
  552. thought that was for output only, but my RO3 PRMs say otherwise]).  For
  553. RenderRequest, 'source' is opened read only (OS_Find 0x43), and the others
  554. are read/write (OS_Find 0x83).  For PostRequests, the source is as for
  555. FetchRequests, and the form file is read only.  For EMailRequests, the form
  556. file is read-only.
  557.  
  558. [An example of using OS_Args 7 in BASIC is in !ArcWebLcl which uses OS_CLI
  559. to issue a straight *COPY command when the symlink bit is clear]
  560.  
  561.  
  562. You do not need to fill in the file type bits (0-15,16 and 30) when sending
  563. the Fetch Done message, but it will assist the renderers in deciding what to
  564. do with the document if you do.  The most common types returned are plain
  565. text (&FFF), HTML (&FAF), GIF (&695), JPEG (&C85) and XBM (&10104).
  566.  
  567. WARNING: Most HTTP servers are configured with a default type to return in
  568. the case that it cannot work out the type of a file from its name or a
  569. specific directive telling it the file type.  This default type is usually
  570. text/plain.  This is a problem when you wish to store binary files (eg.
  571. arcweb.arc) on HTTP servers, as louis.ecs.soton.ac.uk's server will tell you
  572. that this is a text/plain file, when obviously it isn't.  ArcWeb 0.12 and
  573. later will examine the data in the RenderRequest message* to ensure that it
  574. does not contain non-printable characters before attempting to render it.
  575.  
  576. * see renderer protocol discussion below
  577.  
  578.  
  579. Renderer Protocol
  580. =================
  581.  
  582. + All rendering of HTML and inline XBM, GIF and JPEG files is controlled
  583.   internally in Webster via the 'Inline Viewers' section of the 'Choices'
  584.   windows.
  585.  
  586. + Fetched files can be rendered if configured using the 'External Viewers'
  587.   section of the 'Choices' windows.
  588.  
  589.   The Renderer Protocol is used to transform a file into something which can
  590. be viewed in the ArcWeb window.  ArcWeb generates a DrawFile (type &AFF)
  591. to represent the HTML document.  I have written my own parser to read the
  592. HTML file (conforms with the HTML 2.0 specification, 13 June 1994) and
  593. display it.  Renderers should convert images into sprites and store them in
  594. the 'diagram' file (but only if it is an inline data fetch - see discussion
  595. of bits 23 and 25 above).  ArcWeb will be expecting a sprite file to be
  596. there which it can then import.  It will take the first sprite out of the
  597. file.  ArcWeb will handle RISC OS sprite files (&FF9) itself (although it
  598. will broadcast the message with the expectation of receiving it back).  You
  599. should not acknowledge render requests for files of type &FF9
  600.  
  601.   Renderers should inspect the file type bits in the RenderRequest to see
  602. whether the file is of a type which they can handle.  If the type is not
  603. known* (bit 30 is clear), then the renderer may inspect the first few bytes
  604. of the file.  Before sending the RenderRequest message, ArcWeb will have
  605. loaded in as much of the file as possible to the message (to fill it up to
  606. 256 bytes).  The amount of data in the message is in buf+44, and the data
  607. starts at buf+48.  Thus up to 208 bytes of data will be present (currently
  608. it is 208 unless the file is not that long, in which case the whole file is
  609. there).  If 208 bytes is not enough, the renderer may use the file handle
  610. given in the message to read more of the file in.  The file pointer should
  611. be reset to zero if it decides that it can't handle it.  As a safeguard,
  612. Renderers MUST NOT assume that the file pointer will be zero, and should set
  613. it explicitly.
  614.  
  615. * The renderer may decide that it doesn't 'trust' the given file type.  If
  616. that is the case, then it is allowed to ignore bit 30 and attempt to
  617. recognise the file type from the data in the message buffer and act on that
  618. alone.
  619.  
  620.  
  621.  
  622. Quit Protocol
  623. =============
  624.  
  625.   Fetchers and Renderers should have a configurable option to allow them to
  626. quit when ArcWeb dies.  This provides a clean way of shutting ArcWeb and all
  627. its related programs down in one go.  Upon receipt of a Message_ArcwebQuit
  628. message, store the task handle (in buf+4) and wait for the Wimp task
  629. closedown message (Message_TaskCloseDown 0x400C3) to arrive with the given
  630. task handle.  [To prevent ArcWeb closing down, acknowledge the
  631. Message_ArcwebQuit message - not in version 0.08.  ArcWeb will exit anyway.]
  632.  
  633.   By using an extra message, this avoids the need for the auxiliary apps to
  634. lookup the task name from the handle to check whether it was ArcWeb or not,
  635. and this also guards against the task name changing.
  636.  
  637.   Do not acknowledge Message_ArcwebQuit unless you wish to prevent the
  638. shutdown (treat it like you would treat Message_PreQuit)
  639.  
  640.  
  641. Expire Protocol
  642. ===============
  643.  
  644.   If a fetcher has used a symbolic link when fetching a file then that file
  645. should be expired upon receipt of Message_ArcwebExpire.  ArcWeb will pass you
  646. a handle to the file in the cache.  If the symbolic link bit (bit 28) is set
  647. in the flags, then the file to be removed is really the file whose name is
  648. in the file whose handle you have been given.  !ArcwebLcl ignores this
  649. message completely (as it should).  This protocol is not fixed and should
  650. not yet be used (there is a particular problem with extended URLs), but
  651. fetcher authors should be aware of its future existence.  ArcWeb does not
  652. currently send Message_ArcwebExpire messages.
  653.  
  654.  
  655. Poster Protocol
  656. ===============
  657.  
  658. This protocol will be used when ArcWeb wants to send information to a URL
  659. rather than retrieve it, ie. when an HTML form with a method of POST has
  660. been completed and the SUBMIT button has been pressed.  If the form did not
  661. override the default (GET) or chooses the GET method, the the FetchRequest
  662. protocol is used, and the fetcher is not aware of the fact that the data
  663. transfer has happened (an extended URL will have been used).
  664.  
  665. PostRequest should be treated exactly like Message_ArcwebFetchRequest,
  666. except that the 'form' file handle is a RISC OS file handle pointing to a
  667. read-only file containing data to tag onto the end of the request. 
  668. Obviously, the fetcher should issue a POST command to the HTTP server
  669. instead of a GET.  The data in the form file will be suitable for tacking on
  670. IMMEDIATELY after the POST and other usual headers, as it will contain a
  671. Content-Length: header followed by a blank line, followed by the form data
  672. with all the appropriate escape characters already substituted in.  This
  673. data should be passed transparently to the HTTP server.  The fetcher should
  674. respond to ArcWeb with a Message_ArcwebPostDone in exactly the same format
  675. as a response to Message_ArcwebFetchRequest.  The buffer for PostDone is the
  676. same as the buffer for FetchDone.  This is because the target script on the
  677. server responds with a new virtual document, usually confirming that the
  678. data entry was successful/failed etc.
  679.  
  680. EMail Protocol
  681. ==============
  682.  
  683. This protocol will be used when ArcWeb wants to send some e-mail.  ArcWeb
  684. will send this message when the users attempts to follow a mailto: hypertext
  685. link, or when a form with a mailto: method is submitted.  In the former
  686. case, the message remains to be constructed, so the contents of the form
  687. file should be taken as the initial text to be placed in the editor.  ArcWeb
  688. guarantees to make the first line of the file the To: header.  Furthermore,
  689. bit 21 will be clear indicating that the message is not yet complete.  In
  690. the latter case (the invoked form), bit 21 will be set, indicating a
  691. complete message is in the buffer and ready for mailing.  ArcWeb will still
  692. guarantee that the first line in the form file is the To: header, but will
  693. also add an X-Mailer: header, a Date: header and any other headers as
  694. directed by MH tags in the form (eg. Subject: headers)
  695.  
  696. Upon receipt of the EMailRequest, the e-mail application should take over
  697. the process of sending e-mail and return an EMailDone, after taking a copy
  698. of the form file contents and closing the form file.  ArcWeb is not
  699. concerned with what happens to the e-mail next, as far as it is concerned,
  700. the email is sent.
  701.  
  702. There is no virtual document returned from an EMailRequest.  The e-mail
  703. application may flag an error in the usual way (and choose whether to report
  704. the error itself of not).  ArcWeb will open a dialogue box indicating the
  705. status of the e-mail, rather than generating a complete new page.
  706.  
  707. ArcWebTCP will provide the email facility only if it is configured to do so.
  708. To configure it, you must give it your email address and SMTP gateway name.
  709.  
  710.  
  711. Configuration Protocol
  712. ======================
  713.  
  714. This protocol is used when the user invokes an option off the Configure menu
  715. on ArcWeb's icon bar menu.  It allows the configuration windows of the
  716. helper applications to be accessed even when no icon bar icon is installed.
  717. The name of the application (case insensitive) will be in the message.
  718. The name may also be a string of length 1, that character being * which
  719. indicates that all applications are to open their configuration windows.
  720. There is no acknowledgement required for this protocol.
  721.  
  722.  
  723. External Launch Protocol
  724. ========================
  725.  
  726. This protocol is used when an external application, such as a mail reader,
  727. wishes to launch a URL fetch.  The 'Private handle' field will be
  728. preserved in any response from ArcWeb allowing the client to have
  729. multiple outstanding requests, although ArcWeb does not guarantee to be
  730. able to support multiple concurrent external requests at this time. The flags
  731. field corresponds to the usual flags specified for ..Request messages with
  732. the following exceptions:  It should have bit 22 set indicating that a file
  733. handle is present which contains a fully qualified URL.  It should have no
  734. other flags may be set except for arcweb_FLAGS_reload,
  735. arcweb_FLAGS_load_to_disc, or arcweb_FLAGS_images_disabled
  736.  
  737. This message should be sent recorded delivery (ie. Wimp event type 18) and
  738. upon receipt of a failure (Wimp returns a Wimp event type 19) the external
  739. application must close the URL file and issue its own error.  It must
  740. assume that ArcWeb was not loaded or was otherwise unable to respond. 
  741. ArcWeb will respond with a Message_ArcwebLaunchDone message if it can (and
  742. thus assume full responsibility for the URL file handle).  The error status
  743. is indicated by the error bit in the flags, and if this is set, then the
  744. buffer contains an error message, otherwise the buffer contents are
  745. indeterminate.
  746.  
  747.  
  748. Browser Identification
  749. ======================
  750.  
  751. This message should be sent before fetching any pages. It allows fetchers
  752. to include a line of the form:
  753.  
  754. User-Agent: <BrowserName> (Acorn RISC OS; ARM) <FetcherName>
  755.  
  756. Both <BrowserName> and <FetcherName> follow the style 'Name/Version'. The
  757. <FetcherName> part is of course filled in by the fetcher it's self.
  758.  
  759. +Fetch in progress messages
  760. +==========================
  761. +
  762. + To be sent by the Fetcher when it has received part of the fetched file.
  763. + This should be done after receiving any MIME headers and after changing the
  764. + files URL if required. It should only ever be done on any fetch if that
  765. + fetch has the flag set saying the InProgress message is supported.
  766. +
  767. + After this message the ownership of file handles reverts back to the Browser
  768. +
  769. + After sending this message and having it accepted by the browser, the fetcher
  770. + must then preserve the file position pointers of the files. i.e. it can
  771. + append to the file, but it must put the file pointer back where it was before
  772. + appending to the file. This is so the Browser can carry on reading from the
  773. + file as if nothing has changed.
  774. +  
  775. + On completing the fetch the Fetcher must send the FetchDone message as before,
  776. + but it should only close the files it used IF the FetchInProgress message was
  777. + *NOT* sent.
  778. + On receiving the FetchInProgress message the Browser should store the two file
  779. + handles and then it can start decoding the data in the part of the file that
  780. + has been received. On getting to the end of the file it should check if a
  781. + FetchDone message has been received for this file. If so then this is the real
  782. + end of file. If the FetchDone message has not been received, then the browser
  783. + should wait until there is more of the file to decode OR the Fetch Done message
  784. + is received. In either case when the FetchDone is received and the decoding is
  785. + complete the two files should be closed by the Browser.
  786. +
  787. + All errors should be returned using the FetchDone message NOT the
  788. + FetchInProgress message.
  789.  
  790. ==END==
  791.