Sign In to Follow Application
View All Documents & Correspondence

System And Methods For Communication Between Instant Message Users And Short Message Service Users

Abstract: A routing system receives an instant message (I M) from a user via an I M service. The I M contains a source address associated with the I M user and a destination address associated with a contact in the I M user's "buddy" list. A temporary mobile device number is allocated to the I M user. The I M is converted to a text message suitable for delivery to the selected contact's mobile device via a short message service, whereby the temporary mobile device number allocated to the I M user is the source address of the text message. Upon receipt of the text message, the contact may compose and send a reply text message to the I M user via the temporary mobile device number. The reply text message is routed to the I M user via an I M service based on the temporary mobile device number allocated to the I M user.

Get Free WhatsApp Updates!
Notices, Deadlines & Correspondence

Patent Information

Application #
Filing Date
21 February 2011
Publication Number
48/2011
Publication Type
INA
Invention Field
ELECTRONICS
Status
Email
Parent Application
Patent Number
Legal Status
Grant Date
2018-12-14
Renewal Date

Applicants

MICROSOFT CORPORATION
ONE MICROSOFT WAY, REDMOND, WA 98052-6399

Inventors

1. YAHAV, EDO
C/O MICROSOFT CORPORATION, LCA -INTERNATIONAL PATENTS, ONE MICROSOSFT WAY, REDMOND, WA 98052-6399
2. WEISS, YITZHAK
C/O MICROSOFT CORPORATION, LCA -INTERNATIONAL PATENTS, ONE MICROSOSFT WAY, REDMOND, WA 98052-6399
3. SLOUTSKY, ALEZANDER
C/O MICROSOFT CORPORATION, LCA -INTERNATIONAL PATENTS, ONE MICROSOSFT WAY, REDMOND, WA 98052-6399

Specification

BACKGROUND

[1] Instant messaging (I M) applications have become increasingly popular as they allow users to exchange text messages using conventional mobile and stationary computing devices, such as PDAs, cell phones, laptop and desktop computers and the like. Typically, an application running on the computing device allows the user to access a list of contacts to quickly initiate a messaging session with a selected friend, co-worker or other user. Each contact is associated with an identifier that allows the messaging infrastructure to route messages to the designated user. Additionally, the messaging application provides presence information to allow the user to determine which of the contacts are currently on-line.

[2] IM allows a user to send and receive messages nearly instantaneously with other IM service users over a network or collection of networks, such as the Internet. IM services are provided by service providers such as "MICROSOFT" Corporation. A computer connected to the Internet can access the I M service using a client application. The client application can be implemented as a local client or a browser based client. A local client is a program which is stored on the computer and provides an interface allowing a user to access the I M service. A browser based client is a program which is generally provided by a web server. The interface loaded from the server allows the user to access the I M service. I M services are provided to an I M service domain, which is comprised of entities having an account with the I M service.

[3] To use I M, a user establishes an account by providing account information including a user identifier, a password, and a list of messenger contacts. Subsequent login to the service requires the user to provide the user identifier and password. Upon confirmation of the login information with the user's account information, the particular client (either local or browser based) displays an interface indicating the user's presence, messenger contact list and the presence of each contact. Presence is a status indication of whether an entity is online or offline. In another embodiment, a presence can have a state of "busy", "away", "out to lunch", or other states., If the entity, such as the user or a contact on the user's messenger contact list, is logged in to a messenger server within the I M service, than the entity's presence is "online". Otherwise, the presence for the entity is "offline".

[4] The user may select a contact from the messenger contact list displayed in an I M interface to initiate a conversation. Once selected, the client application associated with each conversation member provides a conversation window. In some I M systems, the client applications associated with a conversation receive direct contact information for each other to provide direct communication between them. In other I M services, the client applications for each conversation member are connected to each other through the I M system. When a conversation member sends a message, the I M system receives the message, finds the recipient member's computer location and routes the message to the particular computer. I M services such as "WINDOWS LIVE MESSENGER" use this method. Instant messaging (I M) services are typically limited to interactions between users of a specific messaging service/network, although some services offer inter-connectivity between services/networks.

[5] Short Message Service (SMS) is a service that enables users to exchange short text messages over a communication network. Text messages can originate from various sources, such as by a mobile device (e.g., mobile phone, PDA, etc.) configured to exchange text messages. SMS is a store and forward service, i.e., text messages are not sent directly from sender to recipient, but always via a Short Message Service Center (SMSC). The SMSC handles and manages the text messages by routing text messages between mobile users via each device's Mobile Station International Subscriber Directory Number (MSISDN).

SUMMARY

[6] One aspect of the present technology is to enable communication between users communicating through different messaging services. By way of example only, a first user may select a contact from their "buddy" list, compose an I M and send the I M to the contact. If the "buddy" is offline, he will receive the I M as a text message on his mobile device via an SMS. An instant message includes, among other things, a source address and a destination address. The source address of the I M is an identifier associated with the I M user. The destination address of the I M is an identifier associated with the selected contact. In one embodiment, the source address and destination address comprise I M identifiers (e.g., email addresses, nicknames, etc.).

[7] In order for the contact to receive a text message via an SMS, a routing system converts the I M to a text message. A text message format also includes a source address and a destination address. However, the source address and destination address of a text message comprise mobile device numbers (e.g., MSISDNs). When the routing system receives the I M, the system identifies the selected contact's mobile device number (e.g., MSISDN) based on the destination address contained in the I M. A temporary MSISDN is allocated to the I M user. The I M is converted to a text message, using the temporary MSISDN allocated to the I M user as the source address and the contact's MSISDN as the destination address. The text message is routed to the contact via an SMS. Using a valid MSISDN, rather than a short code, allows the service to work across different mobile networks.

[8] Another aspect of the present technology is to allow the contact that received the text message to deliver a reply text message to the I M user. The text message received by the contact identifies that the message was sent from a certain MSISDN (the MSISDN temporarily allocated to the I M user). Users typically will not reply to a text message from an unfamiliar MSISDN. Thus, in one embodiment, the text message sent to the contact also includes the identifier of the I M user that sent the original I M. When the contact composes and sends a reply text message via an SMS, the reply text message includes a source address and a destination address. The source address is the contact's MSISDN. The destination address is the MSISDN temporarily allocated to the I M user. When the routing system receives the reply text message, the system converts the reply text message to a format suitable for delivery to the I M user via an I M service.

[9] In order to send the reply text message to the I M user, the system determines the identifier of the I M user based on the MSISDN in the destination address of the reply text message, which is the MSISDN temporarily allocated to the I M user. The system also determines the contact's identifier based on the MSISDN contained in the source address of the reply text message, which is the MSISDN of the contact's mobile device. The contact's identifier is placed in the source address of the reply I M and the I M user's identifier is placed in the destination address of the reply I M. The reply I M, containing the text from the reply text message, is then routed to the I M user via an I M service.

[10] Another aspect of the present technology is to re-use the temporarily allocated MSlSDNs across multiple concurrent communication sessions. In one embodiment, the system generates a communication session table for tracking each communication session. Each time a communication session is initiated, the I M identifier of the I M user is associated with a temporary MSISDN. Both are also associated with the I M identifier and MSISDN of the "buddy" the I M user is sending the I M to. The table allows the service to route messages between a large number of subscribers using a relatively small pool of MSISDNs for allocation to I M users.

BRIEF DESCRIPTION OF THE DRAWINGS

[11] Figure 1 provides a block diagram illustrating one embodiment of the network architecture of the present technology.

[12] Figure 2 provides a block diagram of a computer system for performing the methods described herein.

[13] Figures 3A-3B provide block diagrams illustrating several communication connections between I M users and SMS users.

[14] Figure 4 provides an exemplary communication table.

[15] Figure 5 provides a flowchart diagram illustrating delivery of an instant message to a mobile device user via a short message service.

[16] Figure 6 provides a flowchart diagram illustrating additional detail of converting the instant message to a text message.

[17] Figure 7 provides a flowchart diagram illustrating one embodiment of allocating a Session ID to an instant message user.

[18] Figure 8 provides a flowchart diagram illustrating delivery of a text message to an instant message user via an instant message services.

[19] Figure 9 provides a flowchart illustrating one embodiment of converting a text message to an instant message.

[20] Figure 10 provides an exemplary mobile phone and instant message interface.

DETAILED DESCRIPTION

[21] The technology described herein enables bi-directional I M sessions between I M users communicating via an I M service and mobile phone users communicating via an SMS. An MSISDN is temporarily allocated to the I M user so that a routing system can transmit messages across different networks when SMS interconnectivity is involved. In one embodiment, the MSISDN is allocated to the I M user by a cellular network operator. An I M received from an I M user is converted to a text message suitable for delivery to a mobile device user via an SMS. The MSISDN allocated to the I M user is the source address of the text message while the mobile device MSISDN is the destination address. If the mobile device user composes and sends a reply text via an SMS, the reply text message is converted to an I M, and based on the MSISDN allocated to the I M user, is routed back to the I M user as an I M via an I M service.

[22] Fig. 1 illustrates an exemplary network architecture of the present technology. The system 100 enables communication between a user sending instant messages via an I M client 18 and a user sending text messages via a mobile device 12. The I M client 18 shown in Fig. 1 is illustrated as a personal computer for sending and receiving instant messages via a network 108. A user may use other devices such as, but not limited to, laptop computers, cellular phones, PDAs, etc. The network 108 may comprise an I M service (e.g., WINDOWS LIVE, AOL, etc.). The mobile device 12 shown in Fig. 1 is illustrated as a mobile phone to send and receive a text messages via a network 110. A user may use other devices to send/receive text messages such as, but not limited to, a PDA, and the like. The network 110 may comprise any SMS service.

[23] The system 100 generally includes a routing system 102, an instant message gateway (I M GW) 104, a short messaging service center (SMSC) 106, a first network 108 and a second network 110. The routing system 102 includes converters 112, an MSISDN allocator 114 and a database 116. The converters 112 convert messages suitable for delivery via an I M service into a message suitable for delivery via an SMS and vice versa. The MSISDN allocator 114 dynamically allocates MSISDNs to I M users (described in more detail later). As will be described in more detail later, the database 116 maps the user identifiers and MSISDNs involved in each communication session established between an I M user and an SMS user.

[24] With reference to Fig. 2, an exemplary system for implementing an I M - SMS
communication system includes a general purpose computing device in the form of a
computer 210. Components of computer 210 may include, but are not limited to, a processing unit 220, a system memory 230, and a system bus 221 that couples various system components including the system memory to the processing unit 220. The system bus 221 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus.

[25] Computer 210 may include a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 210 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, as well as removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, random access memory (RAM), read only memory (ROM), EEPROM, flash memory or other memory technology, CD-ROMs, digital versatile discs (DVDs) or other optical disc storage, magnetic cassettes, magnetic tapes, magnetic disc storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computer 210. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term "modulated data signal" means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct- wired connection, and wireless media such as RF and other wireless media. Combinations of any of the above are also included within the scope of computer readable media.

[26] The system memory 230 includes computer storage media in the form of volatile and/or nonvolatile memory such as ROM 231 and RAM 232. A basic input/output system (BIOS) 233, containing the basic routines that help to transfer information between elements within computer 910, such as during start-up, is typically stored in ROM 231. RAM 232 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 220. By way of example, and not limitation, Fig. 2 illustrates operating system 234, application programs 235, other program modules 236, and program data 237.

[27] The computer 210 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only, Fig. 2 illustrates a hard disc drive 241 that reads from or writes to non-removable, nonvolatile magnetic media and a magnetic disc drive 951 that reads from or writes to a removable, nonvolatile magnetic disc 252. Computer 210 may further include an optical media reading device 255 to read and/or write to an optical media.

[28] Other removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, DVDs, digital video tapes, solid state RAM, solid state ROM, and the like. The hard disc drive 241 is typically connected to the system bus 221 through a non-removable memory interface such as interface 240. Magnetic disc drive 251 and optical media reading device 255 are typically connected to the system bus 221 by a removable memory interface, such as interface 250.

[29] The drives and their associated computer storage media discussed above and illustrated in Fig. 2, provide storage of computer readable instructions, data structures, program modules and other data for the computer 210. In Fig. 2, for example, hard disc drive 241 is illustrated as storing operating system 244, application programs 245, other program modules 246, and program data 247. These components can either be the same as or different from operating system 234, application programs 235, other program modules 236, and program data 237. Operating system 244, application programs 245, other program modules 246, and program data 247 are given different numbers here to illustrate that, at a min I Mum, they are different copies.

[30] A user may enter commands and information into the computer 210 through input devices such as a keyboard 262 and a pointing device 261, commonly referred to as a mouse, trackball or touch pad. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 220 through a user input interface 260 that is coupled to the system bus 221, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB). A monitor 291 or other type of display device is also connected to the system bus 221 via an interface, such as a video interface 290. In addition to the monitor, computers may also include other peripheral output devices such as speakers 297 and printer 296, which may be connected through an output peripheral interface 295.

[31] The computer 210 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 280. The remote computer 280 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 210, although only a memory storage device 981 has been illustrated in Fig. 2. The logical connections depicted in Fig. 2 include a local window network (LAN) 271 and a wide window network (WAN) 273, but may also include other networks. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet.

[32] When used in a LAN networking environment, the computer 210 is connected to the LAN 271 through a network interface or adapter 270. When used in a WAN networking environment, the computer 210 typically includes a modem 272 or other means for establishing communication over the WAN 273, such as the Internet. The modem 272, which may be internal or external, may be connected to the system bus 221 via the user input interface 260, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 210, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation, Fig. 2 illustrates remote application programs 285 as residing on memory device 281. It will be appreciated that the network connections shown are exemplary and other means of establishing a communication link between the computers may be used.

[33] Fig. 3A illustrates, for the purpose of describing the technology herein only, exemplary communication sessions between I M users 18(1) and 18(2) and SMS users 12(1) and 12(2). In particular, Fig. 3A illustrates three individual communication sessions 120, 122 and 124: a first communication session 120 has been established between I M user 18(1) and SMS user 12(1); a second communication session 122 has been established between I M user 18(1) and SMS user 12(2); and a third communication session 124 has been established between I M user 18(2) and SMS user 12(2). As will be discussed in more detail later, the I M user 18(1) has been temporarily allocated a Session ID X (e.g., an MSISDN) in connection with communication sessions 120 and 122 and I M user 18(2) has been allocated a different Session ID, Session ID Y, in connection with communication session 124. Fig. 3B illustrates the scenario where only communication sessions 120 and 126 have been established. The communication session 120 has been established between I M user 18(1) and SMS user 12(1). The communication session 126 has been established between I M user 18(2) and SMS user 12(2). As will be discussed in more detail later, session ID X has been allocated to both I M user 18(1) and I M user 18(2). The communication sessions and users shown in Figs. 3A-3B will be referred to throughout to describe several aspects the present technology. In one embodiment, the I M users and SMS users are subscribers of the same mobile network operator. Alternatively, the I M users and SMS users are subscribers of different mobile network operators.

[34] Fig. 5 illustrates exemplary steps for routing an I M sent from an I M user to an SMS user as a text message via an SMS. By way of example only, Fig. 5 will be described in the context of I M user 18(1) sending an I M to SMS user 12(1). Fig. 5 is, of course, not limited to these two users. I M services often allow the I M user to maintain a list of people (e.g., "buddy" list or contact list) with whom to interact. For the purpose of describing this technology only, the I M user 18(1) composed an I M by selecting the I M identifier associated with the SMS user 12(1) (e.g., "Bob 123") from his contact list when the I M window 1002 appears (see Fig. 10). The I M user 18(1) composes the message "Bob. R U available to talk right now"

[35] At step 502, the instant message is received by the I M gateway 104 from I M user 18(1). The I M received from the I M user 18(1) contains certain information which, among other things, includes a source address, a destination address and a message. In one embodiment, the source address of the I M is the email address of the I M user 18(1). In alternative embodiments, the source address of the I M may comprise a nickname, "buddy" name, etc. associated with the I M user 18(1) (each referred to as an "identifier"). The destination address of the I M received from the I M user 18(1) is an I M identifier associated with the contact selected from the I M user's 18(1) contact list, which in this case, is the SMS user 12(1). As shown in Fig. 10, SMS user 12(1), shown in the window 1002 as "Bobl23", is offline.

[36] At this point, because SMS user 12(1) is offline, the routing system 102 will deliver the I M to SMS user 12(1) via an SMS. To do so, the routing system 102 generates a text message based on the I M received in step 502 and routes the text message to SMSC 106. In order to have bi-directional communication within an SMS system across networks, both the source address and the destination address of the text message are valid MSISDNs. Otherwise, the message would be limited to routing within a single network because short codes, for example, are network specific.

[37] Here, the originating message was an I M composed by I M user 18(1), and was not sent from a mobile device. Thus, at step 504, the MSISDN allocator 114 of the routing system 102 allocates a Session ID (e.g., MSISDN) to the I M user 18(1). By way of example only, a pool of MSISDNs is controlled by a network operator, and each valid MSISDN in the pool is reserved for use only as a Session ID. One example of valid MSISDN is a telephone number that includes a Country Code + National Destination Code (NDC) + Subscriber Number. For example, the MSISDN 14155551212 comprises the Country Code 1 (United States), NDC 415 (415 area code) and Subscriber Number (555-1212).

[38] One advantage of the present technology is that valid MSISDNs are allocated to the I M user as opposed to short codes, etc. This allows the present technology to send messages between users across different cellular networks (e.g., the SMS user is a subscriber of a different cellular network operator than the I M user). Another advantage is that dynamically allocating MSISDNs to I M users allows the cellular network operator to use a small pool of MSISDNs for the service, eliminating the need to allocate a dedicated MSISDN for each I M user using the service. Of course, it is within the scope of the technology to allocate one MSISDN to each I M user. By way of example only, a cellular network operator could reserve 1,000 MSISDNs for the communication service described herein. Each of these 1,000 MSISDNs is allocated to an I M user when communicating with an SMS user, and may be reallocated to another I M user when returned or released back to the cellular network operator pool. For the purpose of describing the technology only, the MSISDN allocator 114 allocates the MSISDN "14155551212" to I M user 18(1), at step 504.

[39] The database 116 maps and stores each communication session. Each communication session is uniquely identified by a combination of identifiers: the SMS MSISDN of the SMS user's mobile device and the MSISDN temporarily allocated to the I M user.

[40] Fig. 4 provides an example of a table 400 generated and maintained by the database 106. Using the table 400 shown in Fig. 4, the database 106 tracks, for each communication session ID 402, I M user information 404 and SMS user 406. As discussed above, communication session 124 is established between I M user 18(2) and SMS user 12(2). For communication session ID 124 (408), the database 106 stores the following I M user information 404 associated with communication session 124: I M identifier is "BigCharlie" and the temporary MSISDN is 16505551212. The database 106 also stored the following information associated with the SMS user (12(2): I M identifier is "LonelyGuy" and the MSISDN of the SMS user's mobile device is 14085551212. For the communication session 120, the database stores the following I M user information 402 in table 400: I M identifier associated with the I M user 18(1) is "Alice999" and the temporary MSISDN assigned to I M user 18(1) is 14155551212. The table 400 also stores the SMS user information 406 associated with the communication session 120: the I M identifier associated with SMS user 12(1) is "Bob 123" and the MSISN of the SMS user's mobile device is 19175551212.

[41] In order to deliver the I M composed by the I M user 18(1) to the SMS user 12(1) via an SMS, the routing system 102 generates a text message suitable for delivery to SMS user 12(1) via an SMS. A format suitable for delivering text messages via an SMS includes, among other things, a source MSISDN and a destination MSISDN. In this case, the destination MSISDN is the MSISDN of the mobile device of the SMS user 12(1). The source MSISDN is the MSISDN temporarily allocated to the I M user 18(1). At step 506, the routing system 102 determines the MSISDN of the mobile device associated with the identifier contained in the destination address of the I M composed by I M user 18(1). Using the example provided in Fig. 5, the routing system 102 obtains the I M identifier contained in the destination address of the I M, which is the "buddy" name selected by the I M user 18(1) in his contact list ("Bobl23"), and determines the MSISDN of the contact's mobile device. For the purpose of describing this technology only, the MSISDN of the SMS user's 12(1) mobile phone is 19175551212. The system looks up the MSISDN of the SMS user in the I M user's address book that is stored in the I M servers. The MSISDN of each of the I M user's "buddies" may be entered into the I M user's address book in various methods, e.g.: (1) manually entered by the I M user through the I M client, (2) automatically taken from the SMS user's profile on the I M service (in case he also has an I M service account), where it was entered by the SMS user during his service registration to the I M service or later, or (3) synchronized from the I M user's mobile phone address book and matched with the corresponding "buddy" entry, according to the email address field, first and last name etc. The system may look up the MSISDN of the SMS user by other methods.

[42] At step 508, the converter 112 in the routing system 102 converts the I M to a text message suitable for delivery to the SMS user 12(1) via an SMS. Fig. 6 illustrates the detail of step 508 (convert I M to SMS) in Fig. 5. At step 602, a text message is generated that includes, among other things, a source address, a destination address and a text body. At step 604, the source address of the text message is designated as the MSISDN that has been allocated to the I M user 18(1), 14155551212. At step 606, the destination address of the text message is designated as the MSISDN of the mobile device of the SMS user's 12(1), 19175551212.

[43] At step 608, the message contained in the I M is placed into the text body of the text message. At step 610, the I M user's 18(1) user identity is placed in the text body of the text message. For the purpose of describing this technology only, the I M user's I M identifier is "Alice999." Other identifiers associated with the I M user 18(1) may be placed in the text body of the text message. At this point, a text message has been generated based on the I M received from the I M user 18(1), and is ready to be routed to the SMSC 106.

[44] At step 510, the text message generated by the routing system 102 is routed by the SMSC 106 to the MSISDN of the mobile device of the SMS user 12(1). Because the source address of the text message is a valid MSISDN, the text message can be delivered to the SMS user 12(1) across networks, if necessary. The SMS user 12(1) receives the text message "Hi Bob. R U available to talk right now?" on his mobile phone 1004. Fig. 10 shows an exemplary text message received by the SMS user with the I M user's identity inserted into the text body of the text message. Step 610 is not required. The SMS user 12(1) can identify that the text message was sent from "14155551212" (not shown in Fig. 10). Users will often delete text messages received from unknown phone numbers. Here, SMS user 12(1) will not recognize the MSISDN 14155551212 because the MSISDN is not stored in his mobile device address book. Thus, adding the I M user's identifier ("Alice999") in the body of the text message helps the SMS user 12(1) recognize who sent the text message because the SMS user 12(1) will likely recognize the I M identifier.

[45] Fig. 7 illustrates additional detail of one embodiment of step 504 (allocating Session ID) provided in Fig. 5. At step 702, the routing system 102 receives the I M from the I M gateway 104. As discussed above, the I M includes a source address, a destination address and a message. The source address of the I M is the I M identifier of the I M user 18(1) (e.g., "Alice999"). The destination address of the I M is the I M identifier of the SMS user 12(1) (e.g., "Bob 123") shown in the contact list (see Fig. 10).

[46] At step 704, the routing system 102 identifies the MSISDN associated with the I M identifier Bob 123. As described above, the system may look up the MSISDN associated with the I M identifier via several different methods. For the purpose of describing the technology only, the SMS user 12(1) is not currently communicating with any other I M users, and the MSISDN associated with the I M identifier Bob 123 is 19175551212. At step 706, the routing system 102 determines that no other communication sessions are already established that contain the MSISDN of the mobile device of the SMS user 12(1). In one embodiment, the routing system 102 accesses the database 116 to determine if any of the communication sessions contain the MSISDN 19175551212. Thus, at step 714, the MSISDN allocator 114 allocates an available MSISDN to the I M user 18(1) (e.g., 14155551212).

[47] At step 716, the I M received from the I M user 18(1) is converted to a text message (Step 508 in Fig. 5). The MSISDN allocated to the I M user 18(1), 14155551212, is the source address of the text message and the MSISDN of the mobile device of the SMS user 12(1), 19175551212, is the destination address of the text message.

[48] If the destination MSISDN was involved in another communication session with another I M user, steps 708-712 would be performed (discussed later herein). By way of example only, suppose that the communication session 122 between I M user 18(1) and SMS user 12(2) was established prior to the I M user 18(2) composing and sending an I M to SMS user 12(2). In this case, at step 706, the routing system 102 determines that a prior communication session with SMS user 12(2) has been established. At step 708, the routing system 102 identifies that the prior communication session is communication session 122 based on looking up the MSISDN of SMS user 12(2) in the database 116.

[49] At step 710, the routing system 102 identifies that I M user 18(1) has been allocated MSISDN, 14155551212. At step 712, the routing system 102 allocates a different Session ID (e.g., 16505551212) to I M user 18(2). In this scenario, SMS user 12(2) receives text messages from both I M user 18(1) and I M user 18(2). Allocating two different MSISDNs to the two I M users allows SMS user 12(2) to identify that the text messages are being sent from two different users. A text message received from I M user 18(1) will be identified as sent by "14155551212" while text messages received from I M user 18(2) will be identified as sent by "16505551212." The SMS user 12(2) may also reply individually to each I M user 18 by replying to different MSISDNs.

[50] Each I M user 18 is temporarily allocated an MSISDN. The temporary MSISDN allocated to an I M user effectively allows an I M user 18 to deliver an I M to a mobile device via an SMS, regardless of whether the I M user and the SMS user are subscribers of the same network operator. The temporary MSISDN allocated to the I M user 18 also allows a mobile device user to reply to the I M user via an SMS. In one embodiment, each I M user 18 is allocated a dedicated MSISDN. However, MSISDNs are a limited and valuable resource for network operators. Thus, in an alternative embodiment, a network operator will reserve a limited number of MSISDNs, and dynamically allocate the MSISDNs to I M users as necessary for communicating with an SMS user 12. Any number of MSISDNs may be reserved for this use. If, for example, 1,000 MSISDNs were reserved, each SMS user 12 could sI Multaneously receive text message from 1,000 users. If the number of allocated MSISDNs required for communicating with a single SMS user 12 approaches the total number of reserved MSISDNs, the network operator may designate additional MSISDNs for such use.

[51] Fig. 8 illustrates exemplary steps for delivering a reply text message back to the I M user 18 via an I M service. Upon receiving a text message, the SMS user 12 selects "reply" on the mobile device and composes a reply text message. When the SMS user 12 selects "send," the text message is sent from the mobile device 1004 back to the SMSC 106. Using the example provided in Fig. 3A, SMS user 12(1) sends a reply text message "Yes I am. RU?" to I M user 18(1).

[52] At step 802, the routing system 102 receives the reply text message from the SMSC 106. The reply text message includes a source address, a destination address and reply text. The source address of the reply text message is the MSISDN of the mobile device of the SMS user 12(1), 19175551212. The destination address of the reply text message is the MSISDN temporarily allocated to the I M user 18(1), 14155551212, which was the source address of the text message sent to the SMS user 12(1).

[53] In order to deliver the reply text message to the I M user 18(1) via an I M service, the reply text message must first be converted to an I M. An I M requires an I M identifier for both the source address and the destination address. At step 804, the routing system 102 identifies the I M identifier associated with the MSISDN contained in the destination address of the reply text message. For example, the routing system 102 determines that the MSISDN 14155551212 is the destination address in the text message. The system 120 looks in the database 106 for the MSISDN in the table 400 to match the I M identifier "Alice999" with the MSISDN. The I M identifier provides the email address and device location to send the I M.

[54] At step 806, the routing system 102 identifies the MSISDN in the source address of the reply text message. Based on matching the MSISDN in the table 400, the system 102 identifies the I M identifier associated with the MSISDN of the mobile device of the SMS user 12(1), 19175551212. Using the example provided above, the I M identifier associated with the MSISDN 19175551212 is "Bobl23."

[55] At step 808, the routing system 102 converts the reply text message into an I M. At step 810, the routing system 102 routes the I M to the I M gateway 104. The I M gateway 104 transmits the I M to I M user 18(1) via the I M network 108.

[56] Fig. 9 illustrates exemplary steps for converting the reply text message into an I M (step 808). As discussed above, an I M service sends messages between I M users based on source addresses and destination addresses. At step 902, the routing system 102 designates the I M identifier ("Bobl23") associated with the SMS user's 12(1) MSISDN ("Bobl23") as the source address of the I M. BY way of example only, the system 102 looks up the MSISDN obtained in the source address of the reply text message in the database 116, and identifies the I M identifier associated with the MSISDN. At step 904, the routing system 102 designates the I M identifier associated with the I M user 18(1) ("Alice999") as the destination address of the I M. At step 906, the routing system 102 I Mports the text portion of the reply text message into the I M text body (e.g., "Yes I am. R U?"). At this point, the I M gateway 104 is ready to deliver the I M to the destination address designated in the I M (step 810).

[57] Referring back to Fig. 3A, I M user 18(1), now selects the I M identifier ("LonelyGuy") from her "buddy" list and composes an I M. The I M identifier "LonelyGuy" is the identifier of SMS user 12(2). Because SMS user 12(2) is offline, SMS user 12(2) is available only through his mobile device. In order to deliver the I M to the SMS user 12(2), the I M must be converted to a format suitable for delivery via an SMS. An SMS format requires a source MSISDN and a destination MSISDN. At step 502, the routing system 102 receives this second I M from the I M user 18(1) via the I M gateway 104. The routing system 102 recognizes that a temporary MSISDN has already been allocated to I M user 18(1), 14155551212. Thus, step 504 is not necessary, and there is no need to allocate a new or second MSISDN to I M user 18(1). The MSISDN previously allocated to "Alice999" for the communication session 120 with "Bob 123" is reused during the communications session 122 with "LonelyGuy." Accordingly, a new MSISDN is not required every time an I M user sends an instant message to an SMS user. At step 506, the routing system 102 determines the MSISDN of the mobile device of the SMS user 12(2), 14085551212. At step 508, the routing system 102 converts the I M received from I M user 18(1) into a text message suitable for delivery to the mobile device of the SMS user 12(2) via an SMS.

[58] At step 510, the routing system 102 transmits the text message to the SMSC 106. This text message contains a source address comprising the temporary MSISDN allocated to I M user 18(1), a destination address comprising the MSISDN associated with SMS user 12(2), and a text message. In one embodiment, the text message contains the user identifier associated with I M user 18(1) (e.g., "Alice999"). SMS user 12(2) receives a text message on his mobile device, and can identify who sent the text message by either recognizing the MSISDN temporarily allocated to I M user 18(1) or, more likely, recognizing the I M identifier.

[59] Upon receiving the text message, SMS user 12(2) composes and sends a reply text message from his mobile device back to I M user 18(1). The reply text message includes a source address (the MSISDN of the mobile device of SMS user 12(2)), a destination address (the MSISDN temporarily allocated to I M user 18(1)), and reply text. Referring back to Fig. 8, when SMS user 12(2) composes and sends a reply text message to I M user 18(1), the routing system 102 receives the reply text message from the SMSC 106, at step 802. The routing system 102 identifies the I M identifier associated with the MSISDN allocated to I M user 18(1), at step 604.

[60] At step 806, the I M identifier associated with the MSISDN located in the source address of the reply text message is identified. Thus, the routing system 102 determines the I M identifier associated with SMS user 12(2) (e.g., "LonelyGuy"). At step 808, the reply text message is converted to an I M. At step 810, the I M is routed to the I M gateway 104, and ultimately forwarded to I M user 18(1). From the perspective of the I M user 18(1), she is "chatting" with SMS user 12(1) and SMS user 12(2). For example, it appears to I M user 18(1) that SMS user 12(1) and SMS user 12(2) are online and are communicating with her via an I M service. From the perspective of the SMS user 12(1) and the SMS user 12(2), they are each "texting" with I M user 18(1) via an SMS.

[61] Suppose I M user 18(2) now composes and sends an I M to SMS user 12(2) by selecting I M user's 12(2) "buddy" name ("LonelyGuy") in his contact list and typing a message, i.e., "How was the ski trip?". At step 702, the routing system 102 receives the instant message from I M user 18(2). The source address of the I M is the I M identifier associated with I M user 18(2) (e.g., "BigCharlie") and the destination address of the I M is the I M identifier associated with SMS user 12(2), "LonelyGuy." At step 704, the MSISDN of the mobile device of SMS user 12(2) is identified as 14085551212.

[62] At step 706, it is determined whether any active communication sessions include the MSISDN of the mobile device of SMS user 12(2). For the purpose of describing this technology only, the communication session 122 has previously been established and is still active. Thus, at step 708, the communication session 122 is identified as an active session that includes the MSISDN of the mobile device of the SMS user 12(2). At step 710, the MSISDN allocated to the I M user 18(2) is identified. I M users communicating with the same SMS user should not be allocated the same MSISDN so that the SMS user can distinguish who is sending the messages. At step 712, an available MSISDN is allocated to I M user 18(2) that differs from the MSISDN allocated to I M user 18(1).

[63] MSISDNs are temporarily allocated to an I M user and are returned to the pool when the communication session has ended (or some predetermined time after). The routing system 102 attempts to avoid allocating a recently returned MSISDN to a new I M user communicating with an SMS user who was recently receiving text message from the recently returned MSISDN. Otherwise, it will appear to the SMS user that they are receiving new messages from the prior user.

[64] At this point, SMS user 12(2) is receiving text messages from I M user 18(1) and I M user 18(2). SMS user 12(2) is able to differentiate who is sending her text messages because the source address of each text message is the MSISDN temporarily allocated to the I M user 18 sending the message. For example, when SMS user 12(2) receives a text message from I M user 18(1), the text message will contain the message "sent from 14155551212," and optionally contain the I M identifier, "Alice999," in the body of the text message. When SMS user 12(2) receives a text message from I M user 18(2), the text message will contain the message "sent from 16505551212," and optionally contain the I M identifier, "BigCharlie," in the body of the text message.

[65] At step 714, the I M message from I M user 18(2) is converted to a text message suitable for delivery via an SMS. The source address of the text message is the MSISDN allocated to I M user 18(2) for this communication session 124, 16505551212. The destination address of the text message is the MSISDN of the mobile device of SMS user 12(2). The message is inserted into the body of the text message, at step 718. At step 720, the routing system 102 routes the text message to the I M gateway 104, which forwards the text message to the MSISDN of the mobile device of SMS user 12(2). If the SMS user 12(2) composes and sends a reply text message to I M user 18(2), steps 802-810 in Fig. 8 are performed to route the reply text message back to I M user 18(2) via an I M service.

[66] The foregoing detailed description of the technology herein has been presented for purposes of illustration and description. It is not intended to be exhaustive or to Li Mit the technology to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. The described embodiments were chosen in order to best explain the principles of the technology and its practical application to thereby enable others skilled in the art to best utilize the technology in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the technology be defined by the claims appended hereto.

I/We claim;
1. A method of communicating between a first user and a second user using different messaging services, comprising:

(502) receiving a first message from the first user in a first format via a first messaging service, wherein the first message contains a source identifier associated with the first user, a destination identifier associated with the second user and text;

(506) identifying a destination mobile device number based on the destination identifier contained in the first message;

(504) allocating a session identification to the first user;

(508, 602-610) converting the first message received in the first format into a second message in a second format;

(510) routing the second message to a mobile device associated with the destination mobile device number, wherein the second message is routed to the destination mobile device number via a second messaging service.

2. The method as recited in claim 1, wherein the first messaging service comprises an instant message (I M) service.

3. The method as recited in claim 2, wherein the second messaging service comprises a short message service (SMS).

4. The method as recited in claim 3, wherein the step of allocating a session identification to the source identifier comprises the step of:

allocating a Mobile Station International Subscriber Directory Number (MSISDN) to the first user.

5. The method as recited in claim 4, wherein the step of allocating an MSISDN to the first user comprises the steps of:

obtaining an MSISDN from a network owner; and

mapping the MSISDN to the source identifier associated with the first user.

6. The method as recited in claim 3, wherein the step of converting the first message received in the first format into a second message in a second format comprises the steps of:

identifying the source identifier contained in the first message; and

generating a second message in the second format, wherein the second message includes a source address comprising the MSISDN allocated to the first user, a destination address comprising the destination mobile device number and the text from the first message.

7. The method as recited in claim 5, wherein the step of converting the first message in the first format into a second message in a second format further comprises the steps of:

obtaining the source identifier from the first message; and

adding the source identifier to the text in the second message.

8. The method as recited in claim 4, wherein identifying a destination mobile device number comprises the step of identifying the MSISDN of the mobile device of the second user.

9. The method as recited in claim 4, wherein converting the first message into a second message comprises the step of:

generating a text message suitable for delivery via an SMS, wherein the source address of the text message is the MSISDN allocated to the first user and the destination address of the text message is the MSISDN of the mobile device of the second user.

10. A method for sending messages between a first user communicating via an instant message (I M) service operated by a first network operator and a second user communicating via a short messaging service (SMS) operated by a second network operator, comprising:

(502, 702) receiving an I M from the first user, wherein the I M contains a source address and a destination address, the source address is an I M identifier associated with the first user and the destination address is an I M identifier associated with the second user;

(504, 714) allocating a first Mobile Station International Subscriber Directory Number (MSISDN) to the first user;

(506, 704) identifying a second MSISDN associated with the second user based on the destination address contained in the I M;

(508, 602-610, 716) converting the I M received from the first user to a text message suitable for delivery to the second user via an SMS, wherein the text message includes a source address and a destination address, the source address is the first MSISDN allocated to the first user and the destination address is the second MSISDN associated with the second user;

(510, 720) routing the text message to the second user via an SMS.

11. The method as recited in claim 10, wherein the step of converting the I M to a text message further comprises the step of:

placing the I M identifier associated with the first user into a body portion of the text
message.

12. The method as recited in claim 10, wherein the step of allocating a first MSISDN to the first user comprises the steps of:

allocating the first MSISDN to the first user when a communication session is established between the first user and the second user; and

returning the first MSISDN allocated to the first user to a network operator after the communication session between the first user and the second user has ended.

13. The method as recited in 10, further comprising the steps of:

receiving a second I M from the first user, wherein the second I M contains a source address and a destination address, the source address is the I M identifier associated with the first user and the destination address is an I M identifier associated with a third user;

identifying a third MSISDN associated with the third user based on the I M identifier associated in the second I M;

converting the second I M to a second text message suitable for delivery to the third user via an SMS, the text message includes a source address and a destination address, wherein the first MSISDN allocated to the first user is the source address of the text message and a third MSISDN associated with the mobile device of the third user is the destination address of the text message;

routing the second text message to the third user via an SMS.

14. The method as recited in claim 10, further comprising the steps of:

receiving a response text message via an SMS from the third user intended for delivery to the first user, wherein the response text message includes a source address containing the third MSISDN associated with the third user's mobile device and a destination address containing the MSISDN allocated to the first user;

converting the response text message to an I M;

routing the I M to the I M identifier associated with the first user via an I M service.

15. The method as recited in claim 10, wherein the first network operator is different than the second network operator.

16. A method of enabling communications between a first user communicating via an instant message (I M) service and a second user communicating via a short message service (SMS), comprising:

(802) receiving a text message via a first network operator on a mobile device via an SMS, wherein the text message contains a message sent by the first user via an I M service and a source address comprising a Mobile Station International Subscriber Directory Number (MSISDN) that has been temporarily allocated to the first user;

(804, 806, 902-906) generating a response text message on the mobile device, the text message is intended for delivery to the first user, wherein the response text message includes a source address comprising an MSISDN associated with the mobile device, a destination address comprising the MSISDN temporarily allocated to the first user and text; receiving the response text message from the mobile device via the SMS;

(808) converting the response text message to an IM; and

(810) routing the IM to the IM identifier via a second network operator via an IM service.

17. The method as recited in claim 16, wherein the first network operator is different than the second network operator.

18. The method as recited in claim 16, wherein the step of converting the response text message to an I M comprises the steps of:

identifying an IM identifier associated with the MSISDN of the mobile device;

identifying an IM identifier associated with the MSISDN temporarily allocated to the first user;

generating an IM that includes,

a source address comprising the IM identifier associated with the MSISDN of the mobile device;

a destination address comprising the I M identifier associated with the MSISDN temporarily allocated to the first user; and

the text from the response text message.

19. The method recited in claim 16, wherein the text message received via an SMS includes the I M identifier associated with the first user.

20. The method as recited in claim 18, wherein identifying the I M identifier associated with the MSISDN temporarily allocated to the first user comprises the steps of:

identifying a communication session identification stored in a database, wherein the communication session identification includes the MSISDN allocated to the first user, the MSISDN of the mobile device of the second user, and an I M identifier associated with the MSISDN allocated to the first user;

identifying the MSISDN allocated to the first user; and

determining the IM identifier associated with the MSISDN allocated to the first user.

Documents

Application Documents

# Name Date
1 1192-CHENP-2011 POWER OF ATTORNEY 21-02-2011.pdf 2011-02-21
2 1192-CHENP-2011 PCT 21-02-2011.pdf 2011-02-21
3 1192-CHENP-2011 DESCRIPTION(COMPLETE) 21-02-2011.pdf 2011-02-21
4 1192-CHENP-2011 FORM-5 21-02-2011.pdf 2011-02-21
5 1192-CHENP-2011 FORM-3 21-02-2011.pdf 2011-02-21
6 1192-CHENP-2011 FORM-2 21-02-2011.pdf 2011-02-21
7 1192-CHENP-2011 FORM-1 21-02-2011.pdf 2011-02-21
8 1192-CHENP-2011 DRAWINGS 21-02-2011.pdf 2011-02-21
9 1192-CHENP-2011 CORRESPONDENCE OTHERS 21-02-2011.pdf 2011-02-21
10 1192-CHENP-2011 CLAIMS 21-02-2011.pdf 2011-02-21
11 1192-CHENP-2011 ABSTRACT 21-02-2011.pdf 2011-02-21
12 1192-CHENP-2011 FORM-3 29-07-2011.pdf 2011-07-29
13 1192-CHENP-2011 CORRESPONDENCE OTHERS 29-07-2011.pdf 2011-07-29
14 abstract1192-CHENP-2011.jpg 2012-01-03
15 1192-CHENP-2011 CORRESPONDENCE OTHERS 28-08-2012.pdf 2012-08-28
16 1192-CHENP-2011 FORM-18 28-08-2012.pdf 2012-08-28
17 1192-CHENP-2011 FORM-6 02-03-2015.pdf 2015-03-02
18 MTL-GPOA - KONPAL.pdf ONLINE 2015-03-09
19 MS to MTL Assignment.pdf ONLINE 2015-03-09
20 FORM-6-1401-1500(KONPAL).38.pdf ONLINE 2015-03-09
21 MTL-GPOA - KONPAL.pdf 2015-03-13
22 MS to MTL Assignment.pdf 2015-03-13
23 FORM-6-1401-1500(KONPAL).38.pdf 2015-03-13
24 1192-CHENP-2011-FER.pdf 2017-12-14
25 1192-CHENP-2011-OTHERS [11-05-2018(online)].pdf 2018-05-11
26 1192-CHENP-2011-FER_SER_REPLY [11-05-2018(online)].pdf 2018-05-11
27 1192-CHENP-2011-CORRESPONDENCE [11-05-2018(online)].pdf 2018-05-11
28 1192-CHENP-2011-COMPLETE SPECIFICATION [11-05-2018(online)].pdf 2018-05-11
29 1192-CHENP-2011-CLAIMS [11-05-2018(online)].pdf 2018-05-11
30 1192-CHENP-2011-ABSTRACT [11-05-2018(online)].pdf 2018-05-11
31 Correspondence by Agent_General Power of Attorney_12-07-2018.pdf 2018-07-12
32 1192-CHENP-2011-Response to office action (Mandatory) [10-09-2018(online)].pdf 2018-09-10
33 Marked up Claims_Granted 304450_14-12-2018.pdf 2018-12-14
34 Drawings_Granted 304450_14-12-2018.pdf 2018-12-14
35 Description_Granted 304450_14-12-2018.pdf 2018-12-14
36 Claims_Granted 304450_14-12-2018.pdf 2018-12-14
37 Abstract_Granted 304450_14-12-2018.pdf 2018-12-14
38 1192-CHENP-2011-PatentCertificate14-12-2018.pdf 2018-12-14
39 1192-CHENP-2011-IntimationOfGrant14-12-2018.pdf 2018-12-14
40 1192-CHENP-2011-RELEVANT DOCUMENTS [21-03-2019(online)].pdf 2019-03-21
41 1192-CHENP-2011-RELEVANT DOCUMENTS [28-03-2019(online)].pdf 2019-03-28
42 1192-CHENP-2011-RELEVANT DOCUMENTS [29-05-2019(online)].pdf 2019-05-29
43 1192-CHENP-2011-RELEVANT DOCUMENTS [27-03-2020(online)].pdf 2020-03-27
44 1192-CHENP-2011-RELEVANT DOCUMENTS [23-09-2021(online)].pdf 2021-09-23
45 1192-CHENP-2011-RELEVANT DOCUMENTS [26-09-2022(online)].pdf 2022-09-26
46 1192-CHENP-2011-RELEVANT DOCUMENTS [15-09-2023(online)].pdf 2023-09-15

Search Strategy

1 search_23-11-2017.pdf

ERegister / Renewals

3rd: 19 Feb 2019

From 15/09/2011 - To 15/09/2012

4th: 19 Feb 2019

From 15/09/2012 - To 15/09/2013

5th: 19 Feb 2019

From 15/09/2013 - To 15/09/2014

6th: 19 Feb 2019

From 15/09/2014 - To 15/09/2015

7th: 19 Feb 2019

From 15/09/2015 - To 15/09/2016

8th: 19 Feb 2019

From 15/09/2016 - To 15/09/2017

9th: 19 Feb 2019

From 15/09/2017 - To 15/09/2018

10th: 19 Feb 2019

From 15/09/2018 - To 15/09/2019

11th: 19 Feb 2019

From 15/09/2019 - To 15/09/2020

12th: 04 Aug 2020

From 15/09/2020 - To 15/09/2021

13th: 04 Aug 2021

From 15/09/2021 - To 15/09/2022

14th: 03 Aug 2022

From 15/09/2022 - To 15/09/2023

15th: 13 Sep 2023

From 15/09/2023 - To 15/09/2024

16th: 11 Sep 2024

From 15/09/2024 - To 15/09/2025