Method for sending messages to a mobile telephone

Information

  • Patent Application
  • 20080005299
  • Publication Number
    20080005299
  • Date Filed
    June 28, 2006
    18 years ago
  • Date Published
    January 03, 2008
    17 years ago
Abstract
A method is described for providing a user of a telephone device with a capability to receive an indication that a message has been sent to that user via an Internet-based application, irrespective whether the user is currently actively connected to that application or not. The method comprises the steps of receiving a message addressed to said user at a second server associated with the Internet-based application, forwarding the message towards a first server at which a virtual client entity was previously created to allow conducting a communication session that was held between the user and the Internet-based application, determining whether the user is currently connected to the Internet-based application, storing the message if the user is not currently connected to that Internet application and providing the user with an indication that at least one message addressed to him/her has been stored.
Description

BRIEF DESCRIPTION OF THE DRAWINGS

FIGS. 1 to 3—present block diagrams of systems construed in accordance with different embodiments of the present invention;


FIGS. 4 and 5—demonstrate an example of carrying out the method according to an embodiment of the present invention. FIG. 4 demonstrates a method according to an embodiment of the invention by which a user communicates with an Internet-based application, while FIG. 5 exemplifies a method by which the user is notified of messages received at times when he/she was not connected to the respective Internet-based application.





DETAILED DESCRIPTION OF THE INVENTION

A better understanding of the present invention is obtained when the following non-limiting detailed description is considered in conjunction with the following drawings.


Let us consider now FIG. 1 which is a schematic block diagram of a system 2 according to an embodiment of the present invention. The system shown comprises and user 4 who wishes to conduct through his/her telephone device a session while using a certain application such as ICQ, AIM, MSN etc. The end user communicates with the provider's server (e.g. Tjat™ server) which is shown in this FIG. for illustration purposes only as being comprised of two entities, server 6 and virtual client 8. In reality such a server comprises some or all of the following functions: web application, web server, database. Java engine and Tjat application, which is operative to provide the connectivity between the user and the provider of the requested application.


At its other end, the provider's server is connected to the appropriate application server, 10. It should be noted that one of the advantages of the solution provided by the present invention is, that there is no need for the telephone device to be configured in any way to communicate with the virtual client entity, because the provider's server which receives the request is able to recognize the resources available for the telephone device making the request on the one hand, and the requirements set for communicating with the requested application's server, so that the virtual client which is constructed by the provider's server is constructed in a way that takes into account these various constrains.



FIG. 2 shows another example of a system 22 in accordance with an embodiment of the present invention. By this example each of the three end users 24′, 24″ and 24″′ communicate with the provider's server 26, requesting to use of a different application. User 24′ wishes to use the ICQ application, user 24″ the MSN application and user 24″′—the AIM application. In server 26, three corresponding virtual clients are constructed, 28′, 28″ and 28″′, respectively. Each of these virtual clients' entities is constructed in a way that it can communicate with the requested application's server. For example, the language used to communicate with the application server by one of these virtual clients can be Java while the virtual client constructed to meet the request of communicating with a different application can use a different language such as Brew, C#, or any other language applicable to mobile telephone devices.



FIG. 3 presents yet another schematic illustration of an embodiment of system 42 construed according to the present invention. In this FIG., three telephone users, 44′, 44″ and 44″′ are in communication with provider's server 45. However, by this example only one of the users, 44″′, requests to communication with the application server 54, while the others is engaged with a voice over IP call (user 44′) and user 44″ to MIM (Mobile Instant Messaging. Server 45 with which all the users communicate, is capable of differentiating between the various requirement, so that after constructing the appropriate virtual client entities (48′, 48″ and 48″′, respectively), directs the communications to the appropriate addresses. This way, the VOIP session held with user 44′ is routed via VOIP server 46, the session with user 44″ via MIM server 50, while the session with user 44″′ is directed to application server 52.



FIG. 4 presents a flow chart of an example demonstrating the method by which the user communicates with an Internet-based application, MSN. The user opens the browser at his/her cellular device and establishes Internet connection such as GPRS/3 G (or any other method supported by his/her current cellular operator) in order to conduct a communication session (step 100). Once the connection has been established, the cellular operator will authenticate the user (step 110) by applying any method known in the art per se for authenticating a mobile user in order to provide Internet connectivity and billing the user.


Next, the user specifies a web site (step 120), using his/her cellular telephone, e.g. the page wap.tjat.com. Once this page is loaded, the user receives a menu from which he/she should choose the application to use (e.g. MSN). This request is then sent (step 130) to wap.tjat.com server, and the user receives in response a login page. At this stage, a virtual client (a “terminal service” like) is created (step 150) for the user by creating a phase java emulation thread between tjat server and the telephone user (the end user). This path will remain active until the user logs off. Preferably, the user receives all the WML/JSP/HTML (or in any other applicable format) pages from the tjat server, which will serve that end user as his/her “Application interface” (e.g. the “terminal service” based on that “java emulation” thread) so that no software shall be required to be installed for the telephone device. Now, the tjat system has established the tunnel based on pre-defined icq.com protocol where the tunnel extends between the server operative under the address icq.com to the server operative under the address tjat.com, and thereafter between the server tjat.com and the telephone user. Once the telephone user receives the login page, he/she may navigate with the aid of the telephone keys in order to select the requested application (i.e. the requested link). Upon selecting the requested link, the telephone device shall transmit a WML message with the selected application to the virtual client, which translates the information into a command in the language that is suitable to communicate with the tjat.com server (e.g. Java). Since the tjat.com server is the entity responsible to create the virtual client, there is no need to pre-defined a language for the operation of the virtual client. Following the above steps, the server opens a communication channel with the application server. In the case that the telephone's operating system is capable of translating the characters types by the user on his/her phone into symbols, the symbols will be communicated to the tjat.com server, otherwise, when the session is created, the characters will be transmitted to the tjat.com server, the telephone device will receive a WML page and the link can be selected therefrom.


On the login page, the user may now enter his/her user information associated with the application chosen, e.g. MSN user ID and password. For a first time user, a user ID and password will be selected during that first session, and the user ID will be stored at the tjat server


Upon clicking on “connect”, a new session is created (step 160) for that specific user between the tjat.com server and the msn.com server. The information provided by the user is then transferred to msn.com server in order for the MSN provider to authenticate the user, by running an AUTH query with icq.com validation servers (step 170). Once the user has been authenticated, he/she may login. Following the logging in of the user, he/she will receive all the WML/JSP/HTML (or in any other applicable format) files, depending on the end user requests, like “Contact list”, “History”, “User info” and/or any other page requested by the user. All thee files will be received by the user as emulation, and not locally (application) on the mobile device (step 180).


During the period at which the user is in communication with wap.tjat.com he/she may be engaged in a variety of activities, such as sending/receiving messages, retrieving history files associated with other users included in his/her contact list, receiving information related to other users, adding/removing contacts, changing connection status, changing settings (e.g. encoding, certain interface features, not including the settings which are stored at the tjat.com associated database, and the like.



FIG. 5 presents a flow chart of another example demonstrating the present invention. In this example, a cellular telephone user wishes to be connected to the MSN application and receive messages including at times when he/she is off-line (i.e. not actively connected to the MSN application). According to this example the user has to be registered with the MSN application via the tjat server, and the establishment of that first communication session may be carried as described for example in FIG. 4.


When the user subscribes to the internet-based application, e.g. the MSN service, his/her user ID for that application is stored at the application's server (step 200). When a message received at the application server and destined to the user, it shall be forwarded (step 210) towards the tjat server. At the tjat server it is determined whether the user is currently connected to that Internet-based application (step 220), If it is determined that the user is indeed currently connected to the application server, the message will be forwarded to the user (step 230), otherwise, the message is stored at the tjat server (240). Next, the user is provided with an indication (step 250) that one or more messages are awaiting him/her. The indication preferably also includes an identification of the application through which that the message has been received.


There are a number of ways to carry out this step 250, all of which should be understood to be encompassed by the present invention. It may be carried out following the receipt of the user's request to be connected to that Internet-based application at any time after the message has been stored at the tjat server. Alternatively, the indication is provided to the user following the establishment of a communication session between the user and the Internet-based application at any time after the message has been stored at the first server. By yet another alternative, the indication is sent to the user's telephone device once storage of the message at the tjat server has been successfully completed, irrespective if the user has initiated a request to be connected that Internet-based application, or not, so that the user may receive the indication while being for example in a telephone mode (as opposed to being in communication with an Internet-based application).


As will be appreciated by those skilled in the art, the examples provided illustrate some ways of establishing a communication tunnel between the telephone user and the application server, via an intermediate server and a virtual client application operative at that server. However, similar methods may be used to open and maintain that tunnel, without departing from the scope of the present invention.


It is to be understood that the above description only includes some embodiments of the invention and serves for its illustration. Numerous other ways of carrying out the methods provided by the present invention may be devised by a person skilled in the art without departing from the scope of the invention, and are thus encompassed by the present invention.

Claims
  • 1. A method to allow providing a user of a mobile telephone device with an indication that a message was sent to him/her via an Internet-based application, irrespective of whether said user is currently actively connected to said Internet-based application, which method comprises the steps of: (i) at a second server associated with said Internet-based application, receiving a message addressed to said user;(ii) forwarding said message towards a first server at which a virtual client entity had been created to enable establishing a communication session previously held between said user of the mobile telephone device and said Internet-based application;(iii) determining whether said user is currently actively connected to the Internet-based application;(iv) storing the message if said user is not currently actively connected to said Internet-based application; and(v) providing said user with an indication that at least one message addressed to him/her has been stored.
  • 2. A method according to claim 1, further comprising carrying out the following steps when a user that had never been registered to said Internet-based application, wishes to register thereto: transmitting a message towards said first server by said mobile telephone device, denoting the user's request to be connected to said Internet-based application;establishing a communication path extending between said mobile telephone device and said second server via said first server;at said first server, creating a virtual client entity adapted to communicate with said mobile telephone device and with said Internet-based application;associating a user ID and a password with said user in order to allow him/her to use said Internet-based application in the future; andstoring an identification of said user at a database associated with said first server.
  • 3. A method according to claim 2, further comprising a step of authenticating the user by a service provider associated with said first server.
  • 4. A method according to claim 2, further comprising a step of providing said user with a menu from which the user selects a requested application prior to carrying out the step of establishing said communication path.
  • 5. A method according to claim 2, further comprising a step of providing said mobile telephone device with a plurality of WML/JSP/HTML pages transmitted from said first server.
  • 6. A method according to claim 1, further comprising providing said mobile telephone device with an emulation to allow the user to communicate with said Internet-based application, when a communication session takes place.
  • 7. A method according to claim 1, further comprising a step of establishing an Internet connection between said mobile telephone device and said first server prior to transmitting said indication.
  • 8. A method according to claim 1, wherein said step of providing the user with said indication is carried out following receipt of a request generated at said mobile telephone device, to connect its user with any Internet-based application via said first server.
  • 9. A method according to claim 1, wherein said step of providing the user with said indication is carried out following the establishment of a communication session between said mobile telephone device and said Internet-based application.
  • 10. A method according to claim 1, wherein said step of providing the user with said indication is carried out by sending said indication to the mobile telephone device following storage of the message at said first server, irrespective of whether a request to connect said user with said Internet-based application has already been initiated.
  • 11. A computer program product encoding a computer program for executing on a computer system a process for creating a virtual client entity adapted to communicate with a mobile telephone device and with an Internet-based application associated with a remote server, storing an identification of a user of said mobile telephone device for communicating with said Internet-based application, storing messages forwarded towards a server associated with said computer program product from the remote server, and sending an indication towards said mobile telephone device, indicating that there is/are stored messages addressed to the user of said mobile telephone device.
  • 12. A computer program product according to claim 11, wherein messages addressed to said user are forwarded towards said server associated with said computer program product following a positive response made by said server to an interrogation initiated by said Internet-based application to determine whether said user's identification is stored at said server associated with said computer program product.
  • 13. A computer program product according to claim 11, further adapted to carry out an authentication procedure of the user.
  • 14. A computer program product according to claim 11, wherein said virtual client entity is constructed to match at least one protocol used by the Internet-based application and at least one protocol by which the mobile telephone device is adapted to communicate.
  • 15. A computer program product according to claim 11, wherein said at least one protocol used by said Internet-based application is different from said at least one protocol by which the mobile telephone device is adapted to communicate.
  • 16. A computer program product encoding a computer program for executing on a computer system a process for receiving one or more messages transmitted to a user of a mobile telephone device via an Internet-based application associated with a remote server while said mobile telephone user is not actively connected to said Internet-based application, enabling storage of said message received and providing said user with an indication that said message has been stored.