The present invention is directed to managing messages between users of electronic devices, and more specifically to identifying related messages communicated via one or more wireless carriers and using a number of identifiers less than the possible number of messages.
Text messages, multimedia messages, and other messages have become an increasingly popular method of communication, especially with mobile devices such as cellular telephones, personal data assistants (PDAs), and the like. Such messages are generally inexpensive to send and receive relative to some voice communications, and can be communicated to multiple electronic devices at the same time. Messages can be exchanged across a variety of protocols, including those for telephones, email systems, web-based message portals, and other network systems. Some exemplary message protocols include short message service—peer to peer (SMS-PP), multimedia service (MMS), simple network paging protocol (SNPP), simple mail transport protocol (SMTP), post office protocol (POP), wireless content transport protocol (WCTP), hypertext transport protocol (HTTP), and the like.
Relationships between messages can be maintained when sending and receiving devices can be uniquely identified. For example, original messages and replies between devices can be associated with each other based on device identifiers, such as telephone numbers and the like. With a large number of sending and receiving devices, a relatively limited number of identifiers may be available for communicating with the devices. The relatively limited number of identifiers may be allocated by a communication carrier, such as a telephone carrier, for a messaging system to manage messages among devices associated with the carrier and/or to manage messages between devices of multiple carriers. If the number of allocated identifiers is insufficient to identify all of the sending and receiving devices, message relationships may be difficult to identify.
The present invention will now be described with reference to the accompanying drawings, which form a part hereof, and which show, by way of illustration, specific exemplary embodiments by which the invention may be practiced. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Among other things, the present invention may be embodied as methods or devices. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. The following detailed description is, therefore, not to be taken in a limiting sense.
Throughout the specification, the term “connected” means a direct connection between the things that are connected, without any intermediary devices or components. The term “coupled,” or “in communication with” means a direct connection between the things that are connected, or an indirect connection through one or more either passive or active intermediary devices or components. The meaning of “a,” “an,” and “the” include plural references. The meaning of “in” includes “in” and “on.” The term “or” is an inclusive “or” operator, and includes the term “and/or,” unless the context clearly dictates otherwise. The phrase “in one embodiment,” as used herein does not necessarily refer to the same embodiment, although it may. Similarly, the phrase “in another embodiment,” as used herein does not necessarily refer to a different embodiment, although it may. The term “based on” is not exclusive and provides for being based on additional factors not described, unless the context clearly dictates otherwise. The term “user” can include a computer user, a mobile device user, an online service subscriber, and/or other person using an electronic device. The term “message” can include a copy of the a message.
Briefly stated, the invention is direct to a method and system for identifying a message as a reply using a relatively limited number of communication identifiers.
The mass memory also includes computer-readable media, such as volatile, nonvolatile, 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. Examples of computer-readable media include RAM, ROM, EEPROM, flash memory, or other memory technology, CD-ROM, digital versatile disks (DVD), or other optical storage, magnetic cassettes, magnetic tape, magnetic disk 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 a computing device.
The mass memory also stores program code and data. One or more applications 24 are loaded into mass memory and run on operating system 20. Examples of application programs include database programs, schedulers, transcoders, calendars, web services, word processing programs, spreadsheet programs, email programs, and so forth. Mass storage may further include applications such as a message routing engine 26 for managing communication to and from clients.
Server 1 also includes input/output interface 18 for communicating with external devices, such as a mouse, keyboard, scanner, or other input device 19. Server 1 can communicate with a local network, the Internet, a telephone network, or some other communications network via network interface units 30a and 30b, which are constructed for use with various communication protocols including transmission control protocol/Internet protocol (TCP/IP), user datagram protocol (UDP), code division multiple access (CDMA), time division multiple access (TDMA), global system for mobile communications (GSM), Institute for Electrical and Electronics Engineers (IEEE) 802.11, IEEE 802.16 (WiMax), SMS, general packet radio service (GPRS), Wireless Application Protocol (WAP), and the like. Network interface units 20a and 20b are sometimes known as transceivers, transceiving devices, network interface cards (NICs), and the like. The network interface units can facilitate communications between computing devices that conform to the same or differing communication protocols. For example, network interface units 30a and 30b are illustrated as communicating with networks 32a and 32b, which may comprise cellular telephone carrier networks, the Internet, and/or other networks. Networks 32a and 32b provide communication services for clients such as clients 40a and 40b.
Mobile device 50 may include many more components than those shown in
Mass memory 60 includes a RAM 62, a ROM 64, and other storage means. Mass memory 60 illustrates another example of computer storage media for storage of information such as computer readable instructions, data structures, program modules or other data. Mass memory 60 stores a basic input/output system (“BIOS”) 70 for controlling low-level operation of mobile device 50. The mass memory also stores an operating system 71 for controlling the operation of mobile device 50. It will be appreciated that this component may include a general purpose operating system such as a version of UNIX, or LINUX™, or a specialized mobile communication operating system such as Windows Mobile™, or the Symbian® operating system. The operating system may include, or interface with a virtual machine module, such as a Java virtual machine module, that enables control of hardware components and/or operating system operations via application programs, such as Java application programs and the like.
Memory 60 further includes one or more data storage units 72, which can be utilized by mobile device 50 to store, among other things, programs 74 and/or other data. Programs 74 may include computer executable instructions which, when executed by processor 52 and/or other components of mobile device 50, transmit, receive, and/or otherwise process data such as text, audio, video, web pages and/or other data. Other examples of application programs include calendars, contact managers, task managers, transcoders, database programs, word processing programs, spreadsheet programs, games, and so forth. In addition, mass memory 60 stores software messaging client 76. Software messaging client 76 may include computer executable instructions, which may be run under control of operating system 71 to enable telecommunication with another user of another mobile or non-mobile device and/or manage SMS, MMS, IM, email, and/or other messaging services for mobile device 50.
Mobile device 50 also includes a power supply 56, one or more wireless interfaces 80, an audio interface 82, a display 84, a keypad 86, an illuminator 88, an input/output interface 90, a haptic interface 92, and an optional global positioning systems (GPS) receiver 94. Power supply 56 provides power to mobile device 50. A rechargeable or non-rechargeable battery may be used to provide power. The power may also be provided by an external power source, such as an AC adapter or a powered docking cradle that supplements and/or recharges a battery.
Mobile device 50 may optionally communicate with a base station (not shown), or directly with another mobile device. Wireless interface 90 includes circuitry for coupling mobile device 50 to one or more wireless networks, and is constructed for use with one or more communication protocols and technologies including, but not limited to, global system for mobile communication (GSM), code division multiple access (CDMA), time division multiple access (TDMA), user datagram protocol (UDP), transmission control protocol/Internet protocol (TCP/IP), SMS, general packet radio service (GPRS), Wireless Application Protocol (WAP), ultra wide band (UWB), IEEE 802.16 Worldwide Interoperability for Microwave Access (WiMax), and the like.
Audio interface 82 is arranged to produce and receive audio signals such as the sound of a human voice. For example, audio interface 82 may be coupled to a speaker and microphone (not shown) to enable telecommunication with others and/or generate an audio acknowledgement for some action. Display 84 may be a liquid crystal display (LCD), gas plasma, light emitting diode (LED), or any other type of display used with a mobile device. Display 84 may also include a touch sensitive screen arranged to receive input from an object such as a stylus or a digit from a human hand.
Keypad 86 may comprise any input device arranged to receive input from a user. For example, keypad 86 may include a push button numeric dial, or a keyboard. Keypad 86 may also include command buttons that are associated with capturing, selecting, and/or sending images and/or other data. Illuminator 88 may provide a status indication and/or provide light. Illuminator 88 may remain active for specific periods of time or in response to events. For example, when illuminator 88 is active, it may backlight the buttons on keypad 86 and stay on while the mobile device is powered. Also, illuminator 88 may backlight these buttons in various patterns when particular actions are performed, such as dialing another mobile device. Illuminator 88 may also cause light sources positioned within a transparent or translucent case of the mobile device to illuminate in response to actions.
Mobile device 50 also comprises input/output interface 90 for communicating with external devices, such as a headset, or other input or output devices not shown in
Optional GPS transceiver 94 can determine the physical coordinates of mobile device 50 on the surface of the Earth, which typically outputs a location as latitude and longitude values. GPS transceiver 94 can also employ other geo-positioning mechanisms, including, but not limited to, triangulation, assisted GPS (AGPS), E-OTD, CI, SAI, ETA, BSS and the like, to further determine the physical location of mobile device 50 on the surface of the Earth. It is understood that under different conditions, GPS transceiver 94 can determine a physical location within millimeters for mobile device 50; and in other cases, the determined physical location may be less precise, such as within a meter or significantly greater distances.
An enterprise client 100 is shown coupled to internet 102, however enterprise client 100 may communicate through other wired or wireless networks, such as an Ethernet network, a telephone network, and the like. Enterprise client 100 may comprise a general purpose computing device associated with a company, an organization, or other enterprise. A user of enterprise client 100 may communicate an original message to a universal message gateways (UMG) 110 for distribution to one or more other users who are associated with the enterprise. UMG 110 may comprise one or more servers and communicate the original message through a gateway network 128 that is coupled one or more communication carriers. For example, gateway network 128 may comprise T3 communication lines coupled to a carrier A short message service center (SMSC) 130 and a carrier B SMSC 131. The original message may then be communicated over a carrier A network 132 to a client 140. Similarly, the original message may be communicated over a carrier B network 133 to a client 141. The carrier networks may comprise wireless and/or wired networks using differing communication protocols, such as those listed above. Each client may return a reply message via UMG 110, which makes the message accessible to, or routes the reply message to enterprise client 100.
Each client device may store the original message in a local inbox. However, UMG 110 also stores the original message in a virtual inbox associate with each client. UMG 110 includes a message routing engine 120 in communication with data stores that comprise carrier A virtual inboxes 122 and carrier B virtual inboxes 123. Carrier A virtual inboxes 122 store messages routed to clients of carrier A. Similarly, Carrier B virtual inboxes 123 store messages routed to clients of carrier B. The original message may also be stored in an enterprise sent folder 114 that is associated with a messaging account for one or more users of enterprise client 100. Conversely, an enterprise inbox 112 can store messages directed to the enterprise messaging account from clients 140 and 141. Messages in enterprise inbox 112 may be replies or unrelated messages from clients 140 and 141.
Clients 140 and 141 can each be identified by a client identifier, such as a telephone number, a mobile identification number (MIN), a short code, an IP address, or other identifier. Similarly, an enterprise messaging account associated with enterprise client 100 can by identified by an enterprise identifier, such as a telephone number, a mobile identification number (MIN), a short code, an IP address, or other identifier. To route messages from the clients to the enterprise accounts, each carrier provides one or more long codes or other enterprise identifiers. In this exemplary embodiment, the clients direct their messages to the long codes, which the carrier SMSCs map to the UMG. If the number of enterprise messaging accounts or enterprise clients becomes large, it may be burdensome for the carriers to provide a unique long code for each enterprise messaging account or enterprise client. The long codes may be in limited supply. Similarly, it may be impractical for the UMG to maintain virtual inboxes for a large number of clients. In this embodiment, each carrier provides a limited number of long codes to UMG 110. Accordingly, UMG 110 stores carrier A long codes 124 and carrier B long codes 125 and makes the long codes available to message routing engine 120. To prevent confusion between duplicate long codes between multiple carriers, each carrier long code may also be associated with a carrier code.
UMG 111 also includes one or more modules. An inbounder 150 receives an original message from message client 76a of enterprise client device 101. Inbounder 150 may perform a number of preliminary actions, including parsing the received original message to determine the enterprise identifier associated with enterprise client device 101 and to determine one or more client identifiers (e.g., telephone numbers) to which the original message is directed. Inbounder 150 may also validate and/or authenticate the identifiers. Inbounder 150 further assigns a message identifier to the original message. This may be dependent on inbounder 150 determining that the enterprise identifier is validated (and optionally dependent on at least on client identifier being validated). For each client identifier, inbounder 150 checks for an existing virtual inbox and creates a virtual inbox (and optionally a virtual sent folder) for each client identifier that does not already have a virtual inbox. Inbounder 150 also associates the original message identifier with the virtual inbox of each client identifier. Inbounder 150 further associates the original message identifier with a sent folder of the enterprise identifier. The associations may be made in a variety of ways. For example, a database may store the associations, copies of the original message may be stored in the corresponding inboxes and/or in the sent folder, or combinations of database and storage can be used.
Inbounder 150 communicates with a message routing engine 120a via a local area network message routing format such as Ethernet or the like. Message routing engine 120a determines a carrier associated with each client identifier to which the original message is directed. Based on the carrier determined, message routing engine 120a selects a long code from those allocated by the determined carrier. For example, a selected long code may be 10101. Message routing engine 120a then assigns the selected long code to the original message. The selected long code is specified as a source identifier for the original message. The source identifier indicates a “from” address of the original message, and correspondingly indicates the address to which any reply should be sent. The client identifier, to which the original message is directed, indicates a “to” address of the message. Since the original message is actually from enterprise client device 101 in this example, message routing engine 120 may also associate a “reply-to” address with the original message. The reply-to address may or may not be added to the original message itself. If not added to the original message, the reply-to address is stored by the message routing engine for later routing a reply to enterprise client device 101.
If all long codes for a determined carrier have already been assigned, message routing engine 12a selects the long code that has been assigned for the longest period and assigns that long code to the receive original message. If the newly assigned long code is not associated with the same client identifier, a reply can still be associated with an earlier message. If the newly assigned long code is associated with the same client identifier, the prior association can be deleted, so that a reply to the recent original message is not routed as a reply to the earlier message.
Message routing engine 120 is also in communication with a carrier interaction application 154, using a LAN message format (such as Ethernet) and/or a database communication format (such as SQL). Carrier interaction application 154 reformats, applies headers, or otherwise prepares the original message as necessary for routing to those carriers that are associated with the client identifiers to which the original message is directed. Communication between carrier interaction application 154 and a carrier interface 160 may utilize an SMS-PP protocol or other carrier protocol or format.
Message routing engine 120 further communicates with a message status and reply monitoring application 156 using a database communication format. Message status and reply monitoring application 156 provides status information on sent messages, newly received messages, and reply messages associated with enterprise messaging accounts. Message status and reply monitoring application 156 may validate enterprise client 101 before enabling access to the status information via status check application 104. Similarly, message routing engine 120 communicates with a customer service toolkit 158 using a database communication format. Customer service toolkit 158 enables a user of enterprise client 101 to manage settings via customer provisioning application 106. If customer provisioning application 106 is implemented as a browser based application, it may communicate with customer service toolkit 158 using HTTP. A data store 159 is in communication with one or more of the other modules of UMG 111, using a database communication format. Data store 159 stores long codes, associations among identifiers, inboxes, sent folders, status information, settings, and/or other information.
If an original message is sent as an SMS message to carrier interface 160 (e.g., SMSC), the SMS message is generally forwarded as soon as possible to those clients to which the original message is addressed. Carrier interface 160 would generally not maintain a copy of the original message. If the original message is sent as another type of message, such as an email message to an additional carrier, the corresponding carrier interface may be implemented as a POP3 email server and may maintain a copy of the original message. If the original message is sent to multiple clients via the same carrier, each client identifier is associated with the original message. For example, short codes 555 and 560 may be associated with the original message to identify client 1162 and client 2164, respectively. Carrier interface 160 uses the short codes to deliver the original message to the clients using a signaling system 7 (SS7) or other carrier format.
If one or more of the clients return a client message, it is treated in similar manner as the original message. However, message routing engine 120 checks the virtual inbox of the sending client to determine whether it includes a message (e.g., the original message) indicating the long code as a source identifier to which the client message is directed.
Further detail is provided below with regard to exemplary logic flow diagrams shown in
At an operation 204, the UMG receives an original message from an originating enterprise user. The UMG assigns a message identifier to the original message. A transaction identifier may also be assigned to reference information on the direction of communication, targeted client identifiers, or other data. The UMG may optionally store a “reply-to” identifier at an operation 206. The reply-to identifier may be used as an additional address or an alternative address. If only the reply-to identifier is used, return messages or other messages from the other clients may be routed directly to an enterprise client device without storing the return messages in the enterprise inbox. This bypass may reduce storage costs and/or free up space in the enterprise inbox. In either case, the reply-to address may be used to notify the enterprise user of a message before the enterprise user next logs into the UMG to check for messages.
At an operation 208, the UMG evaluates a header or other addressing portion of the original message and determines which carriers are associated with those clients to which the original message is directed. For each carrier, the UMG selects a long code to which messages can be routed back from the clients. The same long code can be used for routing the original message to multiple clients served by one carrier. At an operation 210, the UMG stores a relationship between the original message and the virtual inbox of each client to which the original message is directed. The virtual inboxes may not be known to, or accessible by the clients. If storage space is not a concern, the original message may be stored in each virtual inbox. The original message is further associated with the sent folder of the enterprise user that originated the message. A pointer to the enterprise sent folder and/or other header or envelope information may be applied to the original message to make the original message content available to each client. The UMG sends the original message to the identified carriers, at an operation 212, for delivery to each client identified by a client identifier in the original message.
The UMG also accesses the virtual inbox associated with the client identifier that indicates the source of the client message. The UMG searches the virtual inbox, at an operation 224, for a message that was directed to the client identifier and includes the same long code to which the client message was directed. If no matching message is found at a decision operation 226, the UMG stores the client message in the inbox of the enterprise client as a new, independent message. Conversely, if a matching message is found, the UMG associates the client message with the original message found in the client inbox. More specifically, at an operation 230, the UMG sets a transaction identifier of the client message to the message identifier of the original message. The UMG also adds a header for the client message, providing a pointer to the original message in the enterprise user's sent folder. The UMG further adds a header for the client message, providing a pointer to the original message in the virtual inbox of the client that received the original message and returned the client message.
The UMG also stores the client message, at an operation 232, and an association with the enterprise user's inbox, identifying the client message as a reply. The UMG may apply an arrow icon or other reply indicator, so that the enterprise user will recognize the client message as a reply. The UMG may optionally also route the client message (the reply) to the enterprise client device associated with the enterprise client identifier. The enterprise client identifier may be provided by the reply-to identifier. The enterprise client identifier may also be predefined, so that all replies are routed to a predefined enterprise client device.
The above specification, examples, and data provide a complete description of the manufacture and use of the composition of the invention. Since many embodiments of the invention can be made without departing from the spirit and scope of the invention, the invention resides in the claims hereinafter appended.