US20050021667A1 - Arrangement and method for impermanent connectivity - Google Patents

Arrangement and method for impermanent connectivity Download PDF

Info

Publication number
US20050021667A1
US20050021667A1 US10/713,737 US71373703A US2005021667A1 US 20050021667 A1 US20050021667 A1 US 20050021667A1 US 71373703 A US71373703 A US 71373703A US 2005021667 A1 US2005021667 A1 US 2005021667A1
Authority
US
United States
Prior art keywords
client
server
information
client unit
proxy
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US10/713,737
Other versions
US7543038B2 (en
Inventor
David Conway-Jones
Andrew Stanford-Clark
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Assigned to INTERNATION BUSINESS MACHINES CORPORATION reassignment INTERNATION BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: STANFORD-CLARK, ANDREW, CONWAY-JONES, DAVID C.
Publication of US20050021667A1 publication Critical patent/US20050021667A1/en
Application granted granted Critical
Publication of US7543038B2 publication Critical patent/US7543038B2/en
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/58Message adaptation for wireless communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols

Definitions

  • This invention relates to impermanently connected computing environments, and particularly (though not exclusively) to pervasive computing devices such as hand-held or palm-sized portable computing devices.
  • POP3 Post Office Protocol version 3
  • Outlook ExpressTM e.g., in common applications such as Outlook ExpressTM, or Netscape MessengerTM
  • the present applications are not really suitable to work in the unique connectivity environment of pervasive devices. This is because pervasive devices' unique connectivity environment lacks a ubiquitous wireless network with broad coverage which allows an “always connected” mode of operation. Instead, the pervasive devices connect at infrequent intervals to perform “online tasks”, and are disconnected for the rest of the time.
  • Asynchronous messaging products such as IBM's ‘WebSphere MQ’® and ‘WebSphere MQ Everyplace’® seek to insulate application programmers from having to worry about whether they are connected or not at any given time by offering a queuing mechanism which will take the message from the application (so the application can forget about it), and hold it until a later time when connectivity is available and the message can be delivered to its destination on a remote machine.
  • the pervasive device has to be connected to the network when the command is issued in the client application which causes it to make a client-server connection to a remote server
  • a custom application has to be written, which makes explicit use of an asynchronous messaging system and have the flow of interactions with the user redesigned to fit into an asynchronous model where the reply is not likely to come back for a significant time, i.e., make it into a “batch submission” system.
  • This invention enables a variety of standard client-server applications to be used in a “not always connected” environment, without modification to those applications.
  • FIG. 1 shows a block diagram illustrating a networked computing system including pervasive, hand-held computing devices and utilising the present invention
  • FIG. 2 shows a flow chart illustrating steps performed in an SMTP (outgoing mail) process in the system of FIG. 1 ;
  • FIG. 3 shows a flow chart illustrating steps performed in a POP3 (incoming mail) process in the system of FIG. 1 ;
  • FIG. 4 shows a flow chart illustrating steps performed in an FTP (file transfer protocol) file ‘PUT’ process in the system of FIG. 1 ;
  • FIG. 5 shows a flow chart illustrating steps performed in an FTP (file transfer protocol) file ‘GET’ process in the system of FIG. 1 ;
  • FIG. 6 shows a flow chart illustrating steps performed in an HTTP (web page retrieval) process in the system of FIG. 1 .
  • a networked computing system 100 includes a “client” pervasive computing device such as a portable, hand-held computer 110 and a server 120 .
  • the pervasive device 110 and the server 120 are linked by a wired or wireless link 130 , which may typically be impermanent, i.e., “not always on”.
  • the pervasive device 110 runs a software application 112 , which communicates with the server 120 (via a “client proxy” function 114 and a messaging function incorporating an asynchronous, queue-based client messaging function 116 in the pervasive device 110 and via a server messaging function 122 and an “end point proxy” function 124 associated with the server 120 ) as will be explained in greater detail below.
  • the “client proxy” function 114 is typically provided as a software application.
  • the messaging function including the asynchronous (queue-based)messaging function 116 and the server messaging function 122 may conveniently be provided by client and server modules respectively of IBM's ‘WebSphere MQ’® messaging software.
  • the purpose of the “client proxy” function 114 is to give the client application 112 (e.g., an SMTP—Simple Mail Transfer Protocol—email client) the impression that it is connected to a real SMTP server, but because the communication link 130 from the pervasive device may well be down, the “client proxy” function 114 can't simply proxy the data from the client 112 through to the server 120 , as that network path might not be established that time. So instead, the “client proxy” function 114 gives “plausible” responses to the client 112 , to allow the client 112 to complete the operation it intended to perform (e.g., send an email message).
  • client application 112 e.g., an SMTP—Simple Mail Transfer Protocol—email client
  • the “client proxy” function 114 then has the responsibility of completing the action that the client 112 has now been “deceived” into thinking it has successfully performed. This involves queuing one or more messages into the client messaging function 116 , which at some point in the future, when connectivity is established, transfers the message(s) ultimately to the “end point proxy” 124 via server messaging function 122 . Upon receipt of one or more messages which make up a complete action (e.g., the sending of an email), the “end point proxy” 124 establishes a client-server connection to the real destination server 120 (in this example an SMTP server), and delivers the message to it. All handshaking between the “end point proxy” 124 and the server 120 is private to that connection, and does not have to be relayed back to the client 110 , since the client 110 already thinks it has completed the action, so is not expecting any response.
  • the real destination server 120 in this example an SMTP server
  • the client an email client in this example
  • the client would be configured to talk to an SMTP server on “localhost”, i.e., looped back to that pervasive device itself, rather than to a remote SMTP server as would usually be configured.
  • This does not constitute a modification to the client application program, merely a configuration change which can be made very easily.
  • the user of the pervasive device would type in their email message, issue a “send” command, and the client device 110 would display something like “sending . . . ”, then “message sent”.
  • the client (and the user) are led to believe that the message has genuinely been sent.
  • One feature which may be included in the client proxy 114 is a notification service. This is a mechanism whereby, on receipt of a message from the client messaging function 116 from a remote application 124 , via server messaging function 122 , a message can be made visible to the user of the device. This might be a pop-up window alert, or a line added to a scrolling status window on an application which is open on the device screen (not shown). This might be used to notify the user of the pervasive device 110 (rather than the client application 112 ), that the action has been genuinely completed, e.g., that the email that was sent some time ago has, in fact, now been delivered to the remote SMTP server and is on its way. This enables the user to know when the asynchronous actions have completed. This is made use of in various ways in the examples below.
  • an (email) client 112 when told to “send” its message, makes a socket connection to the SMTP server that has been configured, in this case it is a “local” SMTP server, in the form of the client proxy 114 , listening on the SMTP “well known” port ( 25 ).
  • the client proxy 114 has a configuration capability, where the IP (Internet Protocol) address (and optionally port) of the remote (SMTP) server 120 can be configured. As shown at step 220 , the client 112 follows the SMTP protocol, and the client proxy 114 behaves as if it is a real SMTP server, and makes the appropriate responses. The client 112 transfers the email content and other details to the client proxy 114 .
  • IP Internet Protocol
  • the client proxy 114 ensures that the details of the message, including authentication information (as provided by the client 112 ) and the IP address (and optionally port) of the remote (SMTP) server 120 , are safely stored into the client messaging function 116 on the pervasive device 110 , and then the client proxy 114 replies to the SMTP client 112 with the SMTP protocol message which indicates that the message has been sent successfully.
  • authentication information as provided by the client 112
  • IP address and optionally port
  • the client 112 believing it has completed its task then completes the SMTP protocol exchange and closes the socket connection.
  • step 240 at some point in the future, connectivity is established, and the client messaging function 116 transfers its messages to the server messaging function 122 .
  • End point proxy 124 is waiting for such messages to arrive from the server messaging function 122 , and when they arrive, the end point proxy 124 takes them and performs a role very similar to that which the client application 112 performed when it was talking to the client proxy 114 , i.e., it is an SMTP client talking to an (SMTP) server 120 .
  • the end point proxy 124 uses the SMTP protocol to contact a pre-configured SMTP server, and uses SMTP protocol messages to transfer the outgoing message to the server 120 .
  • the server 120 replies that it has sent the message, the end point proxy 124 completes the protocol exchange, and closes the connection.
  • the end point proxy 124 does not need to do anything else, since client the client 112 is already satisfied that it has completed its task; however, the user of the pervasive device may wish to know that the message has really been sent, so in this case, as shown at step 250 , the end point proxy 124 sends a message back to the client proxy, via the messaging system ( 122 then 116 ), which gets to the client messaging function 116 next time the pervasive device establishes connectivity.
  • the client proxy 114 receives the confirmation message, and can either pop up a notification message for the user, or can add it to a status window in an on-screen display, for the user to check at their convenience. It might also “beep” to signal that something has arrived.
  • an email client when asked to “get new messages” uses the ‘POP3’ protocol to connect to a POP3 server, identify itself, using the username and password of the user, and then receive the emails that are awaiting that user on the server.
  • the client application 112 is configured to talk to a POP3 server on “localhost” (the pervasive device). As shown at step 310 , the client application 112 connects to the client proxy 114 , uses the POP3 protocol to authenticate (which is accepted by the client proxy), and then requests new mail messages. The client proxy 114 returns POP3 protocol messages to indicate that there are currently no messages waiting for the client.
  • the client application 112 then completes the protocol exchange and closes the socket.
  • the client proxy 114 has a configuration capability, where the IP address (and optionally port) of the real POP3 server is stored and, as shown at step 330 , this information is sent through the messaging subsystem ( 116 then 122 when the link is established) to the end point proxy, where the end point proxy makes use of this information to connect to the real POP3 server 120 , and uses the login information to retrieve the email for that user. It then sends it back to the client proxy using the messaging subsystem ( 122 then 116 , when the link is established). The information is held in a queue at the client messaging function until next time the POP3 client is used to check for new messages.
  • the client 112 connects to the client proxy 114 , and authenticates, but then the client proxy returns the emails that are waiting in the queue that were retrieved following the previous request.
  • the arrival of mail at the client proxy 114 when the link is established could cause a notification alert to the user to indicate that mail has arrived, thus encouraging the user to “get new messages” again, using the client application 112 , to see the incoming mail.
  • the proxying process is broken into two parts: ‘PUT’ (described below with reference to FIG. 4 ) and ‘GET’ (described below with reference to FIG. 5 ).
  • the client proxy 114 implements a subset of the ftp protocol (certain commands like DIR don't make sense in this environment), and has a configuration capability where the user can set the real ftp server 120 that is to be connected to by end point proxy 124 .
  • the ftp client 112 on the pervasive device connects to the ftp port of the local host, which is where the client proxy 114 is listening.
  • the client proxy 114 then appears to the ftp client 112 as a very receptive ftp site—honouring CD requests to change directory, and PUT requests to transfer files from the local device's storage to the remote location.
  • the client proxy 114 stores all this information into client messaging function 116 as one or more messages, to make an audit trail of the session, including the login details (username and password), and confirms back to the ftp client 112 that each request is successful, using the standard FTP protocol responses.
  • the client proxy 114 ensures that the file contents are safely stored in the underlying client messaging function 116 before confirming successful transfer (even though the file has not yet been transferred in reality).
  • the ftp client 112 completes the protocol exchange and disconnects from the client proxy.
  • the client proxy 114 also adds connection details of the remote ftp server to the messages queued in the client messaging function 116 .
  • the messaging subsystem transfers the data ( 116 to 122 ), and it reaches the end point proxy, where the end point proxy 124 acts as an ftp client and connects to the real ftp server 120 , and attempts to “replay” the sequence of commands that the client issued. Ultimately these will all succeed, though it is possible that because the client was navigating “blind” in the directory tree, over on the pervasive device, or file permissions might not allow the requested operation, or various other exceptional conditions, that the replay could be terminated early.
  • status information is then sent from the end point proxy 124 to the client proxy 114 (via 122 and 116 ) to report the outcome of the session. This would enable the client proxy to alert the user of the outcome of the attempted transfers.
  • a novel solution is employed. Most of this is very similar to the PUT process described above, but when a GET is performed, the ftp client 112 will have started in a certain directory on the local machine, and can then optionally use LCD (Local Change Directory) commands in the client to move to another directory, then when a file GET command is issued, the file content being transferred from the remote ftp server goes into the file in that directory.
  • LCD Local Change Directory
  • the problem is that only the ftp client knows the directory and filename that is being written to.
  • the proposed solution to this is that, as shown at step 510 , when the file GET is issued, the client proxy returns some “bogus” file contents.
  • ftp client 112 writes this into the file specified by the user.
  • signature e.g. an ‘MD5’ (the well-known ‘fingerprinting’ algorithm) signature of the current system ‘timestamp’, or something that gives a string of characters that is substantially guaranteed to be unique.
  • MD5 the well-known ‘fingerprinting’ algorithm
  • the link 130 gets connected, the messages from the client proxy waiting in the client messaging function 116 go to the server messaging function 122 and then on to the end point proxy 124 .
  • the end point proxy 124 acts as an ftp client, and connects out to the real ftp server 120 (as configured by the user in the client proxy 114 ), and gets the requested files. These are transferred from the end point proxy 124 to the client proxy 114 (via the messaging subsystem 122 and 116 ) when the link 130 is connected, and the client proxy 114 now has the real file contents.
  • the client proxy now initiates a search through all the files in the local file system (not shown) of the pervasive device 110 , opening each file and looking to see which one contains that special “signature” that was delivered to the ftp client earlier. When it finds the file, this must be the one to which the ftp client was expecting to write the file contents. So now the client proxy 114 can overwrite that “signature” file with the real file contents, thus completing the operation which the ftp client was led to believe it was performing (i.e., transferring the file contents from FTP server 120 to a particular file in the local storage on the pervasive device).
  • the client proxy 114 can alert the user that the file has been transferred successfully.
  • HTTP HyperText Transfer Protocol
  • URL Uniform Resource Locator
  • the web browser application 112 is configured to talk to an HTTP proxy on localhost.
  • the client proxy 114 emulates an HTTP proxy, accepting the connection from the web browser 112 , and recording the details of the requested URL. It then generates HTML (HyperText Markup Language) content which it sends back to the browser, which the browser will assume came from the remote web site in response to its request.
  • HTML content is a message informing the user that the request has been received, and that the user should perform a ‘reload’ on the page later when the page has been retrieved.
  • step 620 that completes the interaction with the web browser, so the socket is closed.
  • the client proxy 114 stores the request into the client messaging function 116 and eventually, as shown at step 630 , the link 130 is connected, and the request is transferred to the server messaging function 122 , and then on to the end point proxy 124 .
  • the end point proxy 124 acts as an HTTP client, using the server and URL information supplied in the browser's proxy request to go to a remote web site and retrieve the HTML from that URL, and also any embedded images/sounds/applets/etc. which may be referenced in the page (the HTML is parsed for tags such as ‘IMG’, ‘EMBED’, etc.). This content is then tagged with its URL and sent back to the client proxy 114 (via the messaging subsystem 122 and 116 ), next time the link 130 is up.
  • the client proxy 114 then notifies the user that the page has arrived using the alert mechanism described above, and the user clicks the ‘reload’ button on the browser.
  • this causes the browser to re-request the page from the client proxy 114 (which is configured as its HTTP proxy), and this time the client proxy 114 has the requested URL available, and so can feed back to the browser first the HTML, and then the various images, etc., as they are requested during the loading of the page by the browser.
  • the client proxy 114 which is configured as its HTTP proxy
  • HTTP ‘POST’ (generated when a filled-in form is submitted from a web browser) can also be submitted to a remote web site using the same mechanism.
  • impermanent connectivity will typically be carried out in software running on processors (not shown) at the client device and at the server, and that the software may be provided as a computer program element carried on any suitable data carrier (also not shown) such as a magnetic or optical computer disc.

Abstract

A method and arrangement (100) for impermanent connectivity between a client unit (110) and a server (120) in a network, comprising: at the client unit, a client proxy function (114) for receiving information from/for a client application (112), for storing said information, and for relaying said information between the client unit and the server when a connectivity link (130) therebetween is established. The arrangement may further comprise a server proxy function (124), and a messaging subsystem (116, 122). The information may be SMTP, POP3, HTTP or FTP information. An FTP file ‘GET’ command may be performed by, in response to the ‘GET’ command, writing a local file at the client unit having a unique signature, and when the connectivity link is established, obtaining the requested file from the server, finding the file at the client unit having the unique signature, and over-writing the found file with the obtained file. This provides the advantages that: client application code does not have to be modified operation is largely invisible to the client.

Description

    FIELD OF THE INVENTION
  • This invention relates to impermanently connected computing environments, and particularly (though not exclusively) to pervasive computing devices such as hand-held or palm-sized portable computing devices.
  • BACKGROUND OF THE INVENTION
  • With the advent of pervasive computing devices such as hand-held or palm-sized computing devices, and operating systems (e.g., Microsoft PocketPC®) which offer a significant subset of the familiar desktop based computing environment (e.g., Windows 2000®), there is a tendency to make familiar applications available on the pervasive platform.
  • A good example is the ‘POP3’ (Post Office Protocol version 3) mail client (such as found, e.g., in common applications such as Outlook Express™, or Netscape Messenger™), which allows email to be sent and received by the palmtop device. The problem with this is that the present applications are not really suitable to work in the unique connectivity environment of pervasive devices. This is because pervasive devices' unique connectivity environment lacks a ubiquitous wireless network with broad coverage which allows an “always connected” mode of operation. Instead, the pervasive devices connect at infrequent intervals to perform “online tasks”, and are disconnected for the rest of the time.
  • Asynchronous messaging products such as IBM's ‘WebSphere MQ’® and ‘WebSphere MQ Everyplace’® seek to insulate application programmers from having to worry about whether they are connected or not at any given time by offering a queuing mechanism which will take the message from the application (so the application can forget about it), and hold it until a later time when connectivity is available and the message can be delivered to its destination on a remote machine.
  • Unfortunately, the writers of most “user” applications (e.g., POP3 and ‘SMTP’ mail clients, ftp clients, Web browsers, etc.) did not have this model in mind when they wrote the applications, since they assume the existence of a client-server connection at the time the application performs its sending or receiving function.
  • Currently there are two approaches in use: (1) the pervasive device has to be connected to the network when the command is issued in the client application which causes it to make a client-server connection to a remote server, or (2) a custom application has to be written, which makes explicit use of an asynchronous messaging system and have the flow of interactions with the user redesigned to fit into an asynchronous model where the reply is not likely to come back for a significant time, i.e., make it into a “batch submission” system.
  • Neither of these approaches is satisfactory in the pervasive device environment with today's “not always connected” networking infrastructure.
  • A need therefore exists for a method and arrangement for impermanent connectivity wherein the abovementioned disadvantage(s) may be alleviated.
  • STATEMENT OF INVENTION
  • In accordance with a first aspect of the present invention there is provided an arrangement for impermanent connectivity as claimed in claim 1.
  • In accordance with a second aspect of the present invention there is provided a method for impermanent connectivity as claimed in claim 11.
  • This invention enables a variety of standard client-server applications to be used in a “not always connected” environment, without modification to those applications.
  • BRIEF DESCRIPTION OF THE DRAWING(S)
  • One method and arrangement for impermanent connectivity incorporating the present invention will now be described, by way of example only, with reference to the accompanying drawing(s), in which:
  • FIG. 1 shows a block diagram illustrating a networked computing system including pervasive, hand-held computing devices and utilising the present invention;
  • FIG. 2 shows a flow chart illustrating steps performed in an SMTP (outgoing mail) process in the system of FIG. 1;
  • FIG. 3 shows a flow chart illustrating steps performed in a POP3 (incoming mail) process in the system of FIG. 1;
  • FIG. 4 shows a flow chart illustrating steps performed in an FTP (file transfer protocol) file ‘PUT’ process in the system of FIG. 1;
  • FIG. 5 shows a flow chart illustrating steps performed in an FTP (file transfer protocol) file ‘GET’ process in the system of FIG. 1; and
  • FIG. 6 shows a flow chart illustrating steps performed in an HTTP (web page retrieval) process in the system of FIG. 1.
  • DESCRIPTION OF PREFERRED EMBODIMENT(S)
  • Referring firstly to FIG. 1, a networked computing system 100 includes a “client” pervasive computing device such as a portable, hand-held computer 110 and a server 120. The pervasive device 110 and the server 120 are linked by a wired or wireless link 130, which may typically be impermanent, i.e., “not always on”.
  • The pervasive device 110 runs a software application 112, which communicates with the server 120 (via a “client proxy” function 114 and a messaging function incorporating an asynchronous, queue-based client messaging function 116 in the pervasive device 110 and via a server messaging function 122 and an “end point proxy” function 124 associated with the server 120) as will be explained in greater detail below. The “client proxy” function 114 is typically provided as a software application. The messaging function including the asynchronous (queue-based)messaging function 116 and the server messaging function 122 may conveniently be provided by client and server modules respectively of IBM's ‘WebSphere MQ’® messaging software.
  • Simply stated, the purpose of the “client proxy” function 114 is to give the client application 112 (e.g., an SMTP—Simple Mail Transfer Protocol—email client) the impression that it is connected to a real SMTP server, but because the communication link 130 from the pervasive device may well be down, the “client proxy” function 114 can't simply proxy the data from the client 112 through to the server 120, as that network path might not be established that time. So instead, the “client proxy” function 114 gives “plausible” responses to the client 112, to allow the client 112 to complete the operation it intended to perform (e.g., send an email message). The “client proxy” function 114 then has the responsibility of completing the action that the client 112 has now been “deceived” into thinking it has successfully performed. This involves queuing one or more messages into the client messaging function 116, which at some point in the future, when connectivity is established, transfers the message(s) ultimately to the “end point proxy” 124 via server messaging function 122. Upon receipt of one or more messages which make up a complete action (e.g., the sending of an email), the “end point proxy” 124 establishes a client-server connection to the real destination server 120 (in this example an SMTP server), and delivers the message to it. All handshaking between the “end point proxy” 124 and the server 120 is private to that connection, and does not have to be relayed back to the client 110, since the client 110 already thinks it has completed the action, so is not expecting any response.
  • Clearly, the way the “subterfuge” operates will vary from one client application to another, and so a custom module for the “client proxy” 114 will have to be provided for each client-server protocol that is to be supported by this mechanism.
  • With this mechanism in place, the client (an email client in this example) would be configured to talk to an SMTP server on “localhost”, i.e., looped back to that pervasive device itself, rather than to a remote SMTP server as would usually be configured. This does not constitute a modification to the client application program, merely a configuration change which can be made very easily. The user of the pervasive device would type in their email message, issue a “send” command, and the client device 110 would display something like “sending . . . ”, then “message sent”. The client (and the user) are led to believe that the message has genuinely been sent. However the transfer of the email message from the pervasive device (via, for example, ‘WebSphere MQEveryplace’ messaging system 116 and 122 and the endpoint proxy 124) to the SMTP server 120 which can actually process the message for forwarding to its recipients, only happens at some later time when a communication link is established.
  • One feature which may be included in the client proxy 114, is a notification service. This is a mechanism whereby, on receipt of a message from the client messaging function 116 from a remote application 124, via server messaging function 122, a message can be made visible to the user of the device. This might be a pop-up window alert, or a line added to a scrolling status window on an application which is open on the device screen (not shown). This might be used to notify the user of the pervasive device 110 (rather than the client application 112), that the action has been genuinely completed, e.g., that the email that was sent some time ago has, in fact, now been delivered to the remote SMTP server and is on its way. This enables the user to know when the asynchronous actions have completed. This is made use of in various ways in the examples below.
  • Clearly not all client-server applications or protocols are amenable to this treatment, but some of the most commonly used protocols are. Clearly an interactive connection, such as telnet, can not be emulated in this way, since the asynchronous version of this is nonsensical.
  • Four applications which can benefit from this treatment are now described, and the sequence of events is explained which leads to the application client being led to believe it has completed its task, even though no path to the remote server exists. The examples are not exhaustive, and the general principles can be applied to many other client-server protocols. It should be noted that in all the examples the client application code does not have to be modified.
  • SMTP (Outgoing Mail)
  • Referring now also to FIG. 2, this is the example mentioned above, but to be more rigorous it is described here. As shown at step 210, an (email) client 112, when told to “send” its message, makes a socket connection to the SMTP server that has been configured, in this case it is a “local” SMTP server, in the form of the client proxy 114, listening on the SMTP “well known” port (25).
  • The client proxy 114 has a configuration capability, where the IP (Internet Protocol) address (and optionally port) of the remote (SMTP) server 120 can be configured. As shown at step 220, the client 112 follows the SMTP protocol, and the client proxy 114 behaves as if it is a real SMTP server, and makes the appropriate responses. The client 112 transfers the email content and other details to the client proxy 114. The client proxy 114 ensures that the details of the message, including authentication information (as provided by the client 112) and the IP address (and optionally port) of the remote (SMTP) server 120, are safely stored into the client messaging function 116 on the pervasive device 110, and then the client proxy 114 replies to the SMTP client 112 with the SMTP protocol message which indicates that the message has been sent successfully.
  • As shown at step 230, the client 112, believing it has completed its task then completes the SMTP protocol exchange and closes the socket connection.
  • As shown at step 240, at some point in the future, connectivity is established, and the client messaging function 116 transfers its messages to the server messaging function 122. End point proxy 124 is waiting for such messages to arrive from the server messaging function 122, and when they arrive, the end point proxy 124 takes them and performs a role very similar to that which the client application 112 performed when it was talking to the client proxy 114, i.e., it is an SMTP client talking to an (SMTP) server 120. The end point proxy 124 uses the SMTP protocol to contact a pre-configured SMTP server, and uses SMTP protocol messages to transfer the outgoing message to the server 120. The server 120 replies that it has sent the message, the end point proxy 124 completes the protocol exchange, and closes the connection.
  • At this point, the end point proxy 124 does not need to do anything else, since client the client 112 is already satisfied that it has completed its task; however, the user of the pervasive device may wish to know that the message has really been sent, so in this case, as shown at step 250, the end point proxy 124 sends a message back to the client proxy, via the messaging system (122 then 116), which gets to the client messaging function 116 next time the pervasive device establishes connectivity. At that time, the client proxy 114 receives the confirmation message, and can either pop up a notification message for the user, or can add it to a status window in an on-screen display, for the user to check at their convenience. It might also “beep” to signal that something has arrived.
  • POP3 (Incoming Mail)
  • Referring now also to FIG. 3, an email client, when asked to “get new messages” uses the ‘POP3’ protocol to connect to a POP3 server, identify itself, using the username and password of the user, and then receive the emails that are awaiting that user on the server.
  • In this proposed scheme, the client application 112 is configured to talk to a POP3 server on “localhost” (the pervasive device). As shown at step 310, the client application 112 connects to the client proxy 114, uses the POP3 protocol to authenticate (which is accepted by the client proxy), and then requests new mail messages. The client proxy 114 returns POP3 protocol messages to indicate that there are currently no messages waiting for the client.
  • As shown at step 320, the client application 112 then completes the protocol exchange and closes the socket.
  • The client proxy 114 has a configuration capability, where the IP address (and optionally port) of the real POP3 server is stored and, as shown at step 330, this information is sent through the messaging subsystem (116 then 122 when the link is established) to the end point proxy, where the end point proxy makes use of this information to connect to the real POP3 server 120, and uses the login information to retrieve the email for that user. It then sends it back to the client proxy using the messaging subsystem (122 then 116, when the link is established). The information is held in a queue at the client messaging function until next time the POP3 client is used to check for new messages.
  • As shown at step 340, when the POP3 client is next used to check for new messages, again, the client 112 connects to the client proxy 114, and authenticates, but then the client proxy returns the emails that are waiting in the queue that were retrieved following the previous request.
  • Thus the sequence is always “one step behind” what would be seen if the client was connected directly to the real POP3 server, but in practice this is unlikely to be noticeable.
  • The arrival of mail at the client proxy 114 when the link is established could cause a notification alert to the user to indicate that mail has arrived, thus encouraging the user to “get new messages” again, using the client application 112, to see the incoming mail.
  • FTP (File Transfer Protocol)
  • For FTP, the proxying process is broken into two parts: ‘PUT’ (described below with reference to FIG. 4) and ‘GET’ (described below with reference to FIG. 5).
  • Referring now to FIG. 4, the client proxy 114 implements a subset of the ftp protocol (certain commands like DIR don't make sense in this environment), and has a configuration capability where the user can set the real ftp server 120 that is to be connected to by end point proxy 124.
  • For a file PUT, as shown at step 410, the ftp client 112 on the pervasive device connects to the ftp port of the local host, which is where the client proxy 114 is listening.
  • As shown at step 420, the client proxy 114 then appears to the ftp client 112 as a very receptive ftp site—honouring CD requests to change directory, and PUT requests to transfer files from the local device's storage to the remote location. The client proxy 114 stores all this information into client messaging function 116 as one or more messages, to make an audit trail of the session, including the login details (username and password), and confirms back to the ftp client 112 that each request is successful, using the standard FTP protocol responses. When a file is PUT, supposedly to the remote site, the client proxy 114 ensures that the file contents are safely stored in the underlying client messaging function 116 before confirming successful transfer (even though the file has not yet been transferred in reality).
  • As shown at step 430, at the end of the session, the ftp client 112 completes the protocol exchange and disconnects from the client proxy. The client proxy 114 also adds connection details of the remote ftp server to the messages queued in the client messaging function 116.
  • As shown at step 440, at some point in the future, connectivity is established, the messaging subsystem transfers the data (116 to 122), and it reaches the end point proxy, where the end point proxy 124 acts as an ftp client and connects to the real ftp server 120, and attempts to “replay” the sequence of commands that the client issued. Hopefully these will all succeed, though it is possible that because the client was navigating “blind” in the directory tree, over on the pervasive device, or file permissions might not allow the requested operation, or various other exceptional conditions, that the replay could be terminated early.
  • As shown at step 450, status information is then sent from the end point proxy 124 to the client proxy 114 (via 122 and 116) to report the outcome of the session. This would enable the client proxy to alert the user of the outcome of the attempted transfers.
  • Referring now to FIG. 5, for a file GET, a novel solution is employed. Most of this is very similar to the PUT process described above, but when a GET is performed, the ftp client 112 will have started in a certain directory on the local machine, and can then optionally use LCD (Local Change Directory) commands in the client to move to another directory, then when a file GET command is issued, the file content being transferred from the remote ftp server goes into the file in that directory. The problem is that only the ftp client knows the directory and filename that is being written to. The proposed solution to this is that, as shown at step 510, when the file GET is issued, the client proxy returns some “bogus” file contents. This is in fact a special “signature”, e.g. an ‘MD5’ (the well-known ‘fingerprinting’ algorithm) signature of the current system ‘timestamp’, or something that gives a string of characters that is substantially guaranteed to be unique. The ftp client 112 writes this into the file specified by the user.
  • The only thing obviously “wrong” with this file, apart from the requested data not being stored there, is that the number of bytes would not be correct, compared with the size of the real file that was being requested.
  • As shown at step 520, after the ftp session has terminated, at some point in the future, the link 130 gets connected, the messages from the client proxy waiting in the client messaging function 116 go to the server messaging function 122 and then on to the end point proxy 124. The end point proxy 124 acts as an ftp client, and connects out to the real ftp server 120 (as configured by the user in the client proxy 114), and gets the requested files. These are transferred from the end point proxy 124 to the client proxy 114 (via the messaging subsystem 122 and 116) when the link 130 is connected, and the client proxy 114 now has the real file contents.
  • As shown at step 530, the client proxy now initiates a search through all the files in the local file system (not shown) of the pervasive device 110, opening each file and looking to see which one contains that special “signature” that was delivered to the ftp client earlier. When it finds the file, this must be the one to which the ftp client was expecting to write the file contents. So now the client proxy 114 can overwrite that “signature” file with the real file contents, thus completing the operation which the ftp client was led to believe it was performing (i.e., transferring the file contents from FTP server 120 to a particular file in the local storage on the pervasive device).
  • After completing this step, the client proxy 114 can alert the user that the file has been transferred successfully.
  • HTTP (Web Page Retrieval)
  • Referring now to FIG. 6, HTTP (HyperText Transfer Protocol) is likely to be most useful when a user wants to look at a particular URL (Uniform Resource Locator) from a pervasive device, rather than actively ‘surf’ from link to link. The most common example of this is when a user receives a URL link in an email which the user wants to view.
  • The web browser application 112 is configured to talk to an HTTP proxy on localhost. As shown at step 610, the client proxy 114 emulates an HTTP proxy, accepting the connection from the web browser 112, and recording the details of the requested URL. It then generates HTML (HyperText Markup Language) content which it sends back to the browser, which the browser will assume came from the remote web site in response to its request. The HTML content is a message informing the user that the request has been received, and that the user should perform a ‘reload’ on the page later when the page has been retrieved.
  • As shown at step 620, that completes the interaction with the web browser, so the socket is closed.
  • The client proxy 114 stores the request into the client messaging function 116 and eventually, as shown at step 630, the link 130 is connected, and the request is transferred to the server messaging function 122, and then on to the end point proxy 124. The end point proxy 124 acts as an HTTP client, using the server and URL information supplied in the browser's proxy request to go to a remote web site and retrieve the HTML from that URL, and also any embedded images/sounds/applets/etc. which may be referenced in the page (the HTML is parsed for tags such as ‘IMG’, ‘EMBED’, etc.). This content is then tagged with its URL and sent back to the client proxy 114 (via the messaging subsystem 122 and 116), next time the link 130 is up.
  • As shown at step 640, the client proxy 114 then notifies the user that the page has arrived using the alert mechanism described above, and the user clicks the ‘reload’ button on the browser.
  • As shown at step 650, this causes the browser to re-request the page from the client proxy 114 (which is configured as its HTTP proxy), and this time the client proxy 114 has the requested URL available, and so can feed back to the browser first the HTML, and then the various images, etc., as they are requested during the loading of the page by the browser.
  • It will be understood that an HTTP ‘POST’ (generated when a filled-in form is submitted from a web browser) can also be submitted to a remote web site using the same mechanism.
  • Clearly the approach described above can be used for other protocols than those described above which are observed to be the most commonly used ones from pervasive devices at the present time.
  • It will be appreciated that the method described above for impermanent connectivity will typically be carried out in software running on processors (not shown) at the client device and at the server, and that the software may be provided as a computer program element carried on any suitable data carrier (also not shown) such as a magnetic or optical computer disc.
  • It will be understood that the method and arrangement for impermanent connectivity described above provides the following advantages:
      • client application code does not have to be modified
      • operation is largely invisible to the client.

Claims (22)

1. An arrangement for controlling communication between a client application executing on a client unit and an impermanently connected server in a network, comprising:
at least one client proxy, operable when the client unit is not connected for communication with the server, for receiving information from a client application that requires a response from the server for the application to continue operation, for storing said information, for generating a substitute server response and sending the substitute response to the client application to allow the client application to continue operation; and means for relaying the information to the server when a communications link therebetween is established.
2. An arrangement for impermanent connectivity between a client unit and a server in a network, the arrangement comprising:
at the client unit, a client proxy for receiving information, for storing said information, and for relaying said information between the client unit and the server when a connectivity link therebetween is established.
3. The arrangement of claim 1, further comprising server proxy means coupled to the server for cooperating with the client proxy to relay said information between the client unit and the server when connectivity therebetween is established.
4. The arrangement of claim 3 further comprising messaging means coupled between the client unit and the server for relaying said information as messages across the connectivity link.
5. The arrangement of claim 1 wherein a client proxy is arranged to relay SMTP information between the client unit and the server.
6. The arrangement of claim 1 wherein a client proxy is arranged to relay POP3 information between the client unit and the server.
7. The arrangement of claim 1 wherein a client proxy is arranged to relay HTTP information between the client unit and the server.
8. The arrangement of claim 1 wherein a client proxy is arranged to relay FTP information between the client unit and the server.
9. The arrangement of claim 8 wherein the client proxy comprises:
means for, in response to receiving an FTP file ‘GET’ command, writing a local file at the client unit having a substantially unique signature; and
means for, when the connectivity link is established, obtaining the requested file from the server, for finding the file at the client unit having the substantially unique signature, and for over-writing the found file with the obtained file.
10. The arrangement of claim 1 further comprising means for notifying a user of the client unit of an outcome of the relay of information between the client unit and the server.
11. The arrangement of claim 1 wherein the client unit comprises a portable computing device.
12. A method for impermanent connectivity between a client unit and a server in a network, the method comprising:
at the client unit, providing a client proxy means receiving information, storing said information, and relaying said information between the client unit and the server when a connectivity link therebetween is established.
13. The method of claim 12 further comprising providing server proxy means coupled to the server and cooperating with the client proxy means to relay said information between the client unit and the server when connectivity therebetween is established.
14. The method of claim 12 further comprising providing messaging means coupled between the client unit and the server relaying said information as messages across the connectivity link.
15. The method of claim 11 wherein the client proxy means relays SMTP information between the client unit and the server.
16. The method of claim 11 wherein the client proxy means relays POP3 information between the client unit and the server.
17. The method of claim 11 wherein the client proxy means relays HTTP information between the client unit and the server.
18. The method of claim 11 wherein the client proxy means relays FTP information between the client unit and the server.
19. The method of claim 18 wherein the step of receiving, storing and relaying information comprises:
in response to receiving an FTP file ‘GET’ command, writing a local file at the client unit having a substantially unique signature; and
when the connectivity link is established, obtaining the requested file from the server, finding the file at the client unit having the substantially unique signature, and over-writing the found file with the obtained file.
20. The method of claim 11 further comprising notifying a user of the client unit of an outcome of the relay of information between the client unit and the server.
21. The method of claim 11 wherein the client unit comprises a portable computing device.
22. A computer program element comprising computer program means for performing substantially the method of claim 12.
US10/713,737 2003-04-10 2003-11-13 Arrangement and method for impermanent connectivity Expired - Fee Related US7543038B2 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
GB0308277.3 2003-04-10
GBGB0308277.3A GB0308277D0 (en) 2003-04-10 2003-04-10 Arrangement and method for impermanent connectivity

Publications (2)

Publication Number Publication Date
US20050021667A1 true US20050021667A1 (en) 2005-01-27
US7543038B2 US7543038B2 (en) 2009-06-02

Family

ID=9956544

Family Applications (1)

Application Number Title Priority Date Filing Date
US10/713,737 Expired - Fee Related US7543038B2 (en) 2003-04-10 2003-11-13 Arrangement and method for impermanent connectivity

Country Status (2)

Country Link
US (1) US7543038B2 (en)
GB (1) GB0308277D0 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050015462A1 (en) * 2003-03-07 2005-01-20 Samsung Electronics Co., Ltd. Service gateway system and method of using the same
US20080320417A1 (en) * 2005-11-17 2008-12-25 Steven Begley Mail Status Notification System
US20090172395A1 (en) * 2007-12-31 2009-07-02 International Business Machines Corporation System and Method for Service Virtualization Using a MQ Proxy Network
US20090193443A1 (en) * 2008-01-28 2009-07-30 Meenakshi Sundaram Lakshmanan Method and system for enhancing ms exchange (mapi) end user experiences in a split proxy environment
US20110040730A1 (en) * 2007-10-23 2011-02-17 Eugen Adrian Belea System and method for backing up and restoring email data
US20120052842A1 (en) * 2005-12-16 2012-03-01 Research In Motion Limited System And Method For Wireless Messaging In A Wireless Communication System
US20140344475A1 (en) * 2013-05-15 2014-11-20 Media Tek Inc. Enhanced dhcp method
CN114124935A (en) * 2021-11-18 2022-03-01 北京明朝万达科技股份有限公司 Method, system, equipment and storage medium for realizing FTP service

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8281401B2 (en) * 2005-01-25 2012-10-02 Whitehat Security, Inc. System for detecting vulnerabilities in web applications using client-side application interfaces

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6006269A (en) * 1998-03-11 1999-12-21 Hewlett-Packard Company Admission control system with messages admitted or deferred for re-submission at a later time on a priority basis
US6163779A (en) * 1997-09-29 2000-12-19 International Business Machines Corporation Method of saving a web page to a local hard drive to enable client-side browsing
US20030009538A1 (en) * 2000-11-06 2003-01-09 Shah Lacky Vasant Network caching system for streamed applications
US6507867B1 (en) * 1998-12-22 2003-01-14 International Business Machines Corporation Constructing, downloading, and accessing page bundles on a portable client having intermittent network connectivity
US6895425B1 (en) * 2000-10-06 2005-05-17 Microsoft Corporation Using an expert proxy server as an agent for wireless devices
US6996599B1 (en) * 2000-06-21 2006-02-07 Microsoft Corporation System and method providing multi-tier applications architecture
US7188183B1 (en) * 2000-08-04 2007-03-06 Oracle International Corporation Maintaining state information in mobile applications

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6163779A (en) * 1997-09-29 2000-12-19 International Business Machines Corporation Method of saving a web page to a local hard drive to enable client-side browsing
US6006269A (en) * 1998-03-11 1999-12-21 Hewlett-Packard Company Admission control system with messages admitted or deferred for re-submission at a later time on a priority basis
US6507867B1 (en) * 1998-12-22 2003-01-14 International Business Machines Corporation Constructing, downloading, and accessing page bundles on a portable client having intermittent network connectivity
US6996599B1 (en) * 2000-06-21 2006-02-07 Microsoft Corporation System and method providing multi-tier applications architecture
US7188183B1 (en) * 2000-08-04 2007-03-06 Oracle International Corporation Maintaining state information in mobile applications
US6895425B1 (en) * 2000-10-06 2005-05-17 Microsoft Corporation Using an expert proxy server as an agent for wireless devices
US20030009538A1 (en) * 2000-11-06 2003-01-09 Shah Lacky Vasant Network caching system for streamed applications

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050015462A1 (en) * 2003-03-07 2005-01-20 Samsung Electronics Co., Ltd. Service gateway system and method of using the same
US20080320417A1 (en) * 2005-11-17 2008-12-25 Steven Begley Mail Status Notification System
US20120052842A1 (en) * 2005-12-16 2012-03-01 Research In Motion Limited System And Method For Wireless Messaging In A Wireless Communication System
US8380173B2 (en) * 2005-12-16 2013-02-19 Research In Motion Limited System and method for wireless messaging in a wireless communication system
US20110040730A1 (en) * 2007-10-23 2011-02-17 Eugen Adrian Belea System and method for backing up and restoring email data
US20090172395A1 (en) * 2007-12-31 2009-07-02 International Business Machines Corporation System and Method for Service Virtualization Using a MQ Proxy Network
US20090193443A1 (en) * 2008-01-28 2009-07-30 Meenakshi Sundaram Lakshmanan Method and system for enhancing ms exchange (mapi) end user experiences in a split proxy environment
US8505038B2 (en) * 2008-01-28 2013-08-06 Blue Coat Systems, Inc. Method and system for enhancing MS exchange (MAPI) end user experiences in a split proxy environment
US20140344475A1 (en) * 2013-05-15 2014-11-20 Media Tek Inc. Enhanced dhcp method
CN105229972A (en) * 2013-05-15 2016-01-06 联发科技股份有限公司 The DHCP method strengthened
US9537818B2 (en) * 2013-05-15 2017-01-03 Mediatek Inc. Enhanced DHCP method
CN114124935A (en) * 2021-11-18 2022-03-01 北京明朝万达科技股份有限公司 Method, system, equipment and storage medium for realizing FTP service

Also Published As

Publication number Publication date
GB0308277D0 (en) 2003-05-14
US7543038B2 (en) 2009-06-02

Similar Documents

Publication Publication Date Title
US8447821B2 (en) System and method for configuring access to electronic mailboxes
US6785712B1 (en) Airborne e-mail data transfer protocol
US7475115B2 (en) System and method for generating configurations used for accessing electronic mailboxes
US20050038874A1 (en) System and method for downloading data using a proxy
AU2007270872B2 (en) Proxy server
CA2533280C (en) System and method for automatically learning mailbox configuration conventions
US7543038B2 (en) Arrangement and method for impermanent connectivity
US20060155811A1 (en) System and method for mobile e-mail management
EP1380957B1 (en) Method and devices for transferring electronic mail
KR100249494B1 (en) Method for confirming the received of electronic mail on internet
JP4001047B2 (en) Relay device
KR20010081731A (en) Apparatus for and method of reading e-mail from web-based e-mail service server using e-mail program
KR100442550B1 (en) A method for utilizing resources on a client computer of a computer network, and a server thereof
JP2002538524A (en) Electronic parcel distribution system
JP2001318865A (en) Web mail system and web server and web mail access method
JP3709878B2 (en) Communication device
Goh et al. Complete mobile email management
EP1806887A2 (en) Method and device for forwarding e-mail
JP2004086612A (en) Common network interface system
JP2002109246A (en) Device, system, and method for greeting card processing, and recording medium with greeting card processing program recorded thereon
KR20020007596A (en) Method for Transmitting and Receiving E-mail without Limit to Capacity
JP2002314611A (en) Method and program for transferring e-mail and, mail server

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATION BUSINESS MACHINES CORPORATION, NEW YOR

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CONWAY-JONES, DAVID C.;STANFORD-CLARK, ANDREW;REEL/FRAME:014711/0819;SIGNING DATES FROM 20030712 TO 20030716

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

REMI Maintenance fee reminder mailed
FPAY Fee payment

Year of fee payment: 4

SULP Surcharge for late payment
REMI Maintenance fee reminder mailed
LAPS Lapse for failure to pay maintenance fees
STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20170602