WO2006130238A1 - Method for poc server to handle poc caller preferences - Google Patents

Method for poc server to handle poc caller preferences Download PDF

Info

Publication number
WO2006130238A1
WO2006130238A1 PCT/US2006/013177 US2006013177W WO2006130238A1 WO 2006130238 A1 WO2006130238 A1 WO 2006130238A1 US 2006013177 W US2006013177 W US 2006013177W WO 2006130238 A1 WO2006130238 A1 WO 2006130238A1
Authority
WO
WIPO (PCT)
Prior art keywords
server
message
poc
mobile device
user
Prior art date
Application number
PCT/US2006/013177
Other languages
French (fr)
Inventor
John E. Emrich
Balakumar Jagadesan
Original Assignee
Motorola, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Motorola, Inc. filed Critical Motorola, Inc.
Priority to EP06740769.2A priority Critical patent/EP1889441B1/en
Publication of WO2006130238A1 publication Critical patent/WO2006130238A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/50Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
    • H04M3/53Centralised arrangements for recording incoming messages, i.e. mailbox systems
    • H04M3/533Voice mail systems
    • H04M3/53308Message originator indirectly connected to the message centre, e.g. after detection of busy or absent state of a called party
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1069Session establishment or de-establishment
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1083In-session procedures
    • H04L65/1094Inter-user-equipment sessions transfer or sharing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/40Support for services or applications
    • H04L65/4061Push-to services, e.g. push-to-talk or push-to-video
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/2866Architectures; Arrangements
    • H04L67/30Profiles
    • H04L67/306User profiles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/06Selective distribution of broadcast services, e.g. multimedia broadcast multicast service [MBMS]; Services to user groups; One-way selective calling services
    • H04W4/10Push-to-Talk [PTT] or Push-On-Call services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W76/00Connection management
    • H04W76/40Connection management for selective distribution or broadcast
    • H04W76/45Connection management for selective distribution or broadcast for Push-to-Talk [PTT] or Push-to-Talk over cellular [PoC] services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W84/00Network topologies
    • H04W84/02Hierarchically pre-organised networks, e.g. paging networks, cellular networks, WLAN [Wireless Local Area Network] or WLL [Wireless Local Loop]
    • H04W84/04Large scale networks; Deep hierarchical networks
    • H04W84/08Trunked mobile radio systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/10Architectures or entities
    • H04L65/1016IP multimedia subsystem [IMS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1101Session protocols
    • H04L65/1104Session initiation protocol [SIP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/20Technology dependant metering
    • H04M2215/2093Push to talk
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/12Messaging; Mailboxes; Announcements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/16Communication-related supplementary services, e.g. call-transfer or call-hold

Definitions

  • This disclosure relates generally to cellular communication systems, in particular the provision of push-to-X (PTX) services in a cellular communication system.
  • PTX push-to-X
  • Push-to-talk refers to a half-duplex mode of communication during which a single user has mutually exclusive use of a wireless communication channel for the transmission of voice information to another user or group of users.
  • originating party User A presses a PTT switch on a mobile device, possibly awaits a "ready” tone, speaks into a microphone of the mobile device, and then releases the PTT switch.
  • a former called party User B can press a PTT switch, possibly await a "ready” tone, speak into the microphone, and release the PTT switch. This procedure is repeated with different parties becoming the originating user and transmitting to one or more called parties in the group call until the conversation has completed.
  • PTX over Cellular (PoC) services are starting to address the merging of PTX and other telephony services — such as the merging of PTT with voicemail services.
  • PoC PTX over Cellular
  • a called party User B forwards a PoC call to a voicemail server
  • the outgoing message of the voicemail may grab the "floor" and thus have mutually exclusive use of the communication channel for the duration of the outgoing message.
  • originating party User A and other group call participants such as User C may have to endure the outgoing message of User B's voicemail when User A would rather have avoided User B's voicemail system entirely.
  • FIG. 1 shows a push-to-talk over cellular (PoC) system architecture according to an embodiment.
  • FIG. 2 shows a block diagram of a mobile device according to an embodiment.
  • FIG. 3 shows a sample signal flow diagram for a push-to-talk system according to an embodiment.
  • FIG. 4 shows a flow chart to be implemented in a PTT server for handling a calling device's priority list according to a second embodiment.
  • FIG. 5 shows a flow chart to be implemented in a PTT server for handling a calling device's priority list according to a first embodiment.
  • a Push-to-X over Cellular (PoC) server receives a server registration for a first device from a second server.
  • the PoC server receives a PoC invitation message with PoC preferences and a message from an originating device.
  • the PoC preferences determine what device to call first (e.g., a mobile device) and how many hops the call can be forwarded (e.g., to a voicemail server) if the first- attempted device is not available, before discontinuing the connection. If a trigger, such as time elapsed, occurs for the first-attempted device and the PoC preferences permit, the PoC server sends an invitation message to the second server. If the second server is a recording server, the invitation message includes a message from the originating device that is compatible with the capabilities of the recording server.
  • FIG. 1 shows a push-to-X over cellular (PoC) system architecture 100 according to an embodiment.
  • PoC systems both terrestrial and satellite, generally utilize a network component (e.g., a PTT server 151) to (a) set up and control required radio resources and (b) establish and manage the switching of voice data.
  • a network component e.g., a PTT server 151
  • this system architecture can be expanded to include not only push-to- talk services, but also push-to-message, push-to-video, and other extensions of the push-to-talk concept into other forms of communication and services.
  • an originating mobile device 111 wirelessly communicates with a radio access network 121.
  • This radio access network 121 connects to a packet data core network 131 which in turn connects to a PTT radio resource manager 141 and a PTT server 151 (sometimes called a PTT data switch) through the Internet 161, SIP proxy servers, or other data network elements.
  • the PTT radio resource controller 141 (sometimes called a PTT radio resource manager) communicates with the PTT server 151.
  • Other elements such as recording servers 191 are also coupled to the network.
  • Other packet data core networks 135, 137 are connected to the Internet 161, while other radio access networks 125, 127 are connected to the packet data core networks.
  • Called mobile devices 115, 117, 119 are wirelessly connected to one or more of the available radio access networks 121, 125, 127.
  • any two or more of these mobile devices 111, 115, 117, 119 can establish a group call by one mobile device (such as originating mobile device 111) requesting a PoC call with one or more other mobile devices (such as called mobile device 115) in accordance with an agreed-upon protocol such as Session Initiation Protocol (SIP).
  • SIP Session Initiation Protocol
  • the PoC system architecture 100 is implemented as part of a Global System for Mobile communications (GSM) system, with the radio access networks being GSM General Packet Radio Service (GPRS) radio access networks and the packet data core networks 131, 135, 137 being Gateway GPRS Support Nodes (GGSNs) and Serving GPRS Support Nodes (SGSNs).
  • GSM Global System for Mobile communications
  • GPRS General Packet Radio Service
  • GGSNs Gateway GPRS Support Nodes
  • SGSNs Serving GPRS Support Nodes
  • the PoC system architecture 100 can be implemented as part of a CDMA system, with the radio access networks 121, 125, 127 being CDMA Ix radio access networks and the packet data core networks 131, 135, 137 being Packet Data
  • an originating mobile device 111 wirelessly communicates with a radio access network 121.
  • the originating mobile device 111 is a GSM device and the radio access network 121 is a GSM GPRS radio access network; however, alternate radio access networks are applicable as mentioned previously.
  • the radio access network 125 connects to a packet data core network 135, implemented as an SGSN and GGSN, which in turn uses an Internet Protocol (IP) and Session Initiation Protocol (SIP) to connect to the PTT radio resource controller 141 and PTT server 151 through the Internet 161.
  • IP Internet Protocol
  • SIP Session Initiation Protocol
  • a called mobile device 115 wirelessly communicates with a different radio access network 125, which is also a GSM GPRS radio access network in this example.
  • the radio access network 125 connects to a packet data core network 135, implemented as another SGSN and GGSN, which in turn uses an Internet Protocol (IP) and Session Initiation Protocol (SIP) to connect to the PTT radio resource controller 141 and PTT server 151 through the Internet 161.
  • IP Internet Protocol
  • SIP Session Initiation Protocol
  • the radio access network 127 connects to a packet data core network 137, which in turn connects to the PTT radio resource controller 141 and PTT server 151 through the Internet 161.
  • the mobile devices 111, 115, 117, 119 are shown as wireless telephones and a personal digital assistant, one or more mobile devices could be implemented as other types of wireless device such as pocket personal computers or laptop computers.
  • a signal goes from the mobile device 111 through the radio access network 121 and packet data core network 131 to the PTT radio resource controller 141, which sets up the path for communication data.
  • the PTT radio resource controller 141 sets up the path for communication data.
  • User A's communication data is sent from the mobile device 111 to the radio access network 121, to the packet data core network 131, and to the PTT server 151.
  • the PTT server 151 forwards User A's communication data to the packet data core networks 135, 137 of the called parties, which in turn go to the radio access networks 125, 127 of the called parties and then the mobile devices 115, 117, 119 of the called parties.
  • Called party User B may have the mobile device 115 forwarded to a recording server 191 (such as a voicemail system) because User B's mobile device 115 is not being answered, is powered down, or is roaming in a network that does not support PoC services.
  • a recording server 191 such as a voicemail system
  • User B may unintentionally participate in the call through User B's outgoing message on the voicemail server.
  • the outgoing message may grab the "floor" and maintain the floor throughout the duration of the outgoing message. At this point, all the other participants on the call are forced to listen to User B's outgoing voicemail message.
  • the originating user may hang up or interact with the voicemail server by leaving a message and /or working with the voicemail menu system.
  • the recording server 191 can also be implemented as an electronic mail server or another type of server used for disseminating outgoing messages or storing incoming messages.
  • an electronic mail server might be implemented as a component in a text messaging or paging system.
  • a further complication occurs when more than one user, such as User B with mobile device 115 and User D with mobile device 119, has calls forwarded to their voicemail server(s).
  • two outgoing messages may attempt to grab the floor at approximately the same time. The result might be that one outgoing message grabs the floor and the other outgoing message is at least partially blocked because it does not have the floor.
  • the voice mail servers may need to be addressed one after another, which would take up additional time during the beginning of the group call. It is also possible that a voicemail server that does not have the floor may terminate the call due to inactivity.
  • FIG. 2 shows a block diagram of a mobile device 200 according to an embodiment.
  • the mobile device 200 can be any of the mobile device 111, 115, 117, 119 shown in FIG. 1.
  • the mobile device 200 includes a user interface 202 coupled to a processor 206, such as one or more microprocessors, microcontrollers, digital signal processors (DSPs), or equivalents or combinations thereof.
  • the mobile device 200 further includes at least one memory device 208 associated with a processor 206, such as random access memory (RAM), dynamic random access memory (DRAM), and /or read only memory (ROM) or equivalents thereof, that maintain data and programs that may be executed by the processor 206 and that allow the mobile device 200 to perform all the functions necessary to operate in a compatible communication system such as the one shown in FIG. 1.
  • the user interface 202 provides a user of the mobile device 200 with the capability of interacting with the mobile device 200, including entering instructions into the mobile device 200.
  • the user interface 202 includes a display screen 204 and a keypad with multiple keys, including a PoC key.
  • the PoC key is implemented as a "soft key" or a region on a touchscreen rather than a discrete key.
  • the memory device 208 maintains a Mobile ID and a PoC Address that are uniquely associated with the mobile device 200.
  • a PoC Address can be implemented as an e-mail address or a canonical telephone number.
  • a PoC Address may be a Session Initiation Protocol (SIP) Universal Resource Identifier or Locator (URI or URL) such as "someone@example.com.”
  • a PoC Address may be a Telephone (TEL) URI or URL, such as international number TEL: +1-888-555-1212, or a local number that uses a local dialing plan and prefix.
  • TEL Telephone
  • the memory device 208 maintains a phone book listing of identifiers associated with one or more other devices.
  • An identifier can be a PoC Address uniquely associated with a mobile device, a PoC Address of a voicemail or email server of a home network serving the mobile device 200, such as the recording server 191 shown in FIG. 1, or a talkgroup ID uniquely associated with multiple unique PoC Addresses.
  • the identifiers may be pre-programmed into the memory device 208 or may be added to the memory device 208 by a user of the mobile device 200.
  • the memory device 208 further allows for PoC preferences regarding each entry in its phone book listing.
  • the PoC preferences include the originating mobile device's prioritized list of preferred forwarding actions for a PoC call. Examples of a prioritized list are shown in memory element 215 for User B and memory element 217 for User C.
  • an originating mobile device such as User A's mobile device 115 shown in FIG. 1
  • a prioritized list such as that shown in memory elements 215
  • 217 seeks to establish a PoC call with User B, it will first call User B's mobile device (such as mobile device 115 shown in FIG. 1).
  • memory element 215 shows that it is acceptable for the PoC call to be forwarded to a recording server such as recording server 191 shown in FIG. 1 or a different PoC Address.
  • a further variable indicates how many forwarding hops are acceptable to the originating user, User A. For example, memory element 215 indicates that two hops are acceptable, which could be one hop to an alternate telephone number and a second hop to a recording server. If no alternate PoC Address is available or the hop count is exceeded, the memory element 215 indicates that the PoC call should discontinue the connection.
  • Another memory element 217 is established for User Cs mobile device 117 shown in FIG. 1.
  • User Cs mobile device such as mobile device 117 shown in FIG. 1. If the PoC call is unable to connect because User Cs mobile device 117 is not being answered, out of range, turned off, set to "do not disturb," or the like, memory element 217 indicates that the PoC call should end.
  • memory element 217 establishes that, even though User C may have a recording server available, originating User A's preference is to not forward the PoC call to the recording server or any other PoC Address. In this situation, either originating User A will reach called party User C at User Cs mobile phone or User A will not reach User C at all.
  • this prioritized list can be set and modified by the originating caller on a per-call basis or less frequently. For example, if an originating user only wants to reach called users at their primary mobile device for a particular PoC call, then, prior to originating that PoC call, the originating user can set the prioritized lists to "(1) call mobile device and (2) discontinue connection" for each of the mobile devices to be called.
  • the originating user wants to leave a message for one called party and try to reach all other called parties directly, the originating user can modify the prioritized list for that one party to be "(1) call mobile device, (2) allow forwarding a specified number of hops, and (3) discontinue connection" while leaving the other prioritized lists as "(1) call mobile device and (2) discontinue connection.” Allowing forwarding 0 hops is another way to implement not allowing forwarding. Although it is theoretically possible to allow forwarding an unlimited number of hops, each hop generally causes delay and increases the risk of a loop where a hop returns the call to a server that has already been hopped-through.
  • PoC preference lists can keep track of the originating user's preferences and allow the caller to maintain some control over where the call is being forwarded and prevent unwanted effects, such as a voicemail outgoing message grabbing the floor.
  • FIG. 3 shows a sample signal flow diagram 300 for a push-to-talk system according to an embodiment.
  • Vertical line 311 represents signaling to and from an originating mobile device A, such as mobile device 111 shown in FIG. 1.
  • Vertical line 351 represents signaling to and from a PTT server, such as PTT server 151 shown in FIG. 1.
  • Vertical line 315 represents signaling to and from a called mobile device B, such as mobile device 115 shown in FIG. 1.
  • Vertical line 317 represents signaling to and from a called mobile device C, such as mobile device 117 shown in FIG. 1.
  • Vertical line 391 represents signaling to and from a recording server, such as recording server 191 shown in FIG. 1. Note that there may be other servers involved in this communication session.
  • PTT server 351 may serve User A while another PTT server (not shown) serves User B and yet another PTT server (not shown) serves User C. Additionally, there may be intermediate servers that route messages but are not directly associated with any of the call participants. For the purposes of this explanation, no additional PTT servers are shown; however, additional servers affect the situation in that they increase the hop count and may introduce delay into the system.
  • the recording server 391 sends a recording server registration message 301 indicating the PoC Address of the recording server and its association with a mobile device.
  • the recording server is a voicemail server for mobile device B.
  • the recording server registration message 301 indicates the preference of mobile device B relative to the recording server.
  • the message 301 indicates that mobile device B should first be contacted and then, should contacting mobile device B be unsuccessful, the recording server 391 should be contacted.
  • the originating mobile device A 311 sends a SIP OPTIONS message 303 to query the PTT server 351 regarding any recording server registrations for the group call's participant list.
  • the PTT server 351 returns a 200 OK message 306 with information regarding any recording servers registered to the participants, including the capabilities of the recording servers.
  • the originating mobile device 311 constructs a message that can be sent (with or without modifications) to one or more registered recording servers.
  • a participant's recording server accepts multimedia messages
  • a photo of a watch and an audio recording of "It's meeting time!” plus the text "IT'S MEETING TIME” can be forwarded.
  • a text message TFS MEETING TTME can be constructed by stripping out non-text layers of the message 313 described earlier or by receiving and selecting a text-only message 313 from the originating mobile device.
  • an audio recording of "It's meeting time!” can be made by stripping out non-audio layers of the multimedia message 313 described earlier or by receiving and selecting an audio-only message 313 from the originating mobile device.
  • the originating mobile device 311 can tailor messages to the capabilities of the available recording devices, which improves the user experience and reduces wasted bandwidth when, for example, a multimedia message is constructed at the originating device but no participant's recording server can accept a multimedia message. Additionally, the information in 200 OK message 306 can be used by User A to create personalized messages for called users rather than grouping the message by recording server type (e.g., text, audio, multimedia, etc.).
  • the originating mobile device A 311 sends one or more messages to the PTT server 351 containing a SIP BSTVITE message 310 identifying target mobile devices.
  • the identifier of the target mobile devices can be a PoC Address such as a telephone number or email address.
  • a single SIP INVITE message can include a single PoC Address or multiple PoC Addresses.
  • the initial set of INVITE- related messages includes an audio, visual, or multimedia message 313 such as "It's Meeting Time” in the recorded voice of the user A, a text message "It's Meeting Time,” a graphic icon of an alarm clock, or more than one of the messages above.
  • the initial set of ENTVITE-related messages can include originating mobile device PoC preferences 316.
  • user A may have determined that the PTT server 351 should, for all called mobile devices, first attempt a connection with the target mobile device, then any recording server associated with the target mobile device, and hang up if neither the target mobile device nor its recording server can be reached.
  • the PTT server 351 sends an INVITE message 320 to User B and an
  • INVITE message 323to User C These secondary INVITE messages 320, 330 occur in parallel.
  • Mobile device B 315 responds to the SIP INVITE message 320 with a SIP 180 RINGING message 330.
  • Mobile device C 317 responds to the SIP INVITE message 323 with a SIP 180 RINGING message 333.
  • the PPT server 351 processes these SIP 180 RINGING messages normally and sends a SIP 180 RINGING message 336 to the originating mobile device A 311.
  • a SIP 200 OK message 340 goes from the mobile device C 317 to the PTT server 351, which sends a SIP 200 OK message 343 to the mobile device A 311.
  • the originating mobile device 311 and PTT server 351 set up a Real Time Protocol (RTP) media session 370 from the originating mobile device 311 to the PTT server 351 and another RTP media session 373 from the PTT server 351 to the mobile device 315 that has accepted the call.
  • RTP Real Time Protocol
  • RTP media session 370 will be established with the PTT server 351, and the information in RTP media session 370 will be sent to the additional mobile devices as they answer the group call.
  • mobile device B 315 has not been answered and the PTT server 351 awaits a trigger indicating that the PTT should no longer continue to wait.
  • the trigger can be implemented as a ring count (e.g., wait no longer than six rings), a timer (e.g., wait no longer than 30 seconds), or another triggering mechanism.
  • the PTT server 351 sends a SIP BYE message 353 to the mobile device B 315 to cancel the previous SIP INVlTJi message 320 to User B.
  • the PTT server 351 sends a SIP INVITE message 360 to User B at the second-choice PoC Address in accordance with the PoC preference list 316 expressed in the initial set of messages from the originating mobile device A 311.
  • the second-choice is a recording server 391, whose PoC Address is determined from the recording server registration message 301 sent earlier to the PTT server 351.
  • the PTT server 351 can also forward a message 363 to the recording server 391 reflecting the message 313 from the originating mobile device A 311.
  • the message 313 can have more than one layer or part (e.g., voice, text, photo, video, etc.), and the appropriate layers of the message 313 can be sent to the recording server 391 depending on the recording server's capability. For example, only the voice layer of the message 313 will be forwarded to a voicemail server and only the text layer of the message 313 will be forwarded to a text server, but multiple layers of the message 313 will be forwarded to a multimedia messaging server.
  • Additional layers of the message 313 can include flags for "urgent” or data such as location information of the calling party.
  • the recording server 391 responds with a SIP 200 OK message 366 for User B, and the PTT Server 351 closes the session with a SIP BYE message 369 to the recording server 391. Because only User C is available for the group call at mobile device C 317, when mobile device A 311 has the floor, it sends an RTP media message 370 to the PTT server 351, which forwards it to mobile device C 317.
  • the originating User A and any available called parties can have a group call without being forced to listen to an outgoing message from non-available called parties (User B).
  • the originating User A would like to leave a message, it can be pre-recorded and sent to a called party's recording server without interrupting the real-time group call. If the originating User A would not like to leave a message with a called party (User B), then the PTT Server 351 can disconnect the call if the called party is not available directly. Other variations of called party preferences are possible, as shown in FIGs.4-5.
  • FIGs. 4-5 show a flow chart 400, 500 to be implemented in a PTT server for handling an originating party's PoC preference list according to an embodiment.
  • a PTT server such as PTT server 151 shown in FIG. 1 can implement the flow chart 400.
  • Memory element 215 of FIG. 2 can store the PoC preference list of the originating user.
  • step 410 receives an INVITE message for a group call for N called parties and, optionally, messages for the called parties, where N is a natural number.
  • step 415 checks each called party's server registration.
  • Step 420 forks an INVlTJi message to each of the N called parties so that each of the N called parties is being sent an individual INVITE message. Forking can be implemented in a PTT server using separate state machines for each called party operating in parallel.
  • Step 430 resets individual triggers for each called party. As stated earlier, triggers can be timers, ring counts or other mechanisms.
  • Step 440 determines if a particular called party's trigger has tripped. If the trigger has expired, then the flow goes to step 520 in FIG. 5.
  • step 450 determines that an OK message has been received from the called party related to that trigger, then step 454 cancels that called party's trigger and step 457 continues with a normal PoC call set-up for that called party.
  • step 455 handles any message received (such as a RINGING or TRYING message) normally and returns to step 440.
  • step 520 checks whether the originating user's PoC preference list shows a preference for the call to be forwarded. If there is no preference for the call to be forwarded, step 525 discontinues the connection for that called party. If there is a preference for the call to be forwarded, step 530 determines if the called party has implemented call forwarding to another PoC Address. If not, step 525 discontinues the connection.
  • step 535 determines if forwarding the call would exceed the allowable hop count set by the originating user. If the hop count is not exceeded, then the connection is forwarded in step 550. [0046] If step 460 determines that the connection is forwarded to a recording server, the originating user can leave a pre-recorded message without interrupting the other parties on the group call in step 465. Otherwise, the flow returns to step 430 in FIG. 4 to reset the trigger for that particular called party. [0047] Returning to step 535, if the hop count is exceeded, than step 525 discontinues the connection. Note that the originating user may set a maximum hop count for a number of reasons. One is to limit delay in the PoC communications.
  • Two is to limit the potential for a circular call- forwarding loop.
  • One called party's phone may be forwarded to a secretary and that secretary's phone may be forwarded to a receptionist. If the receptionist's phone is forwarded back to the secretary, the originating user may become stuck in a call-forwarding loop.
  • Three is to limit the potential for being forwarded to someone who is only peripherally related to the subject of the PoC call.
  • the first hop may be from the called party's primary telephone (mobile device) to the called party's secondary telephone (office telephone), the second hop may be to the called party's secretary who is aware of the called party's availability, but a third hop may be to a company receptionist who is not aware of the called party's availability.
  • a PTT server implementing this flow chart can adhere to an originating party's PoC preferences for reaching a called party for a PoC call.
  • an originating user can leave messages with called parties without interrupting the real-time PoC call, can avoid recording servers as desired, and can limit the number of server hops in a PoC call.
  • processor 206 includes a processor that executes computer program code to implement the methods described herein.
  • Embodiments include computer program code containing instructions embodied in tangible media, such as floppy diskettes, CD-ROMs, hard drives, or any other computer-readable storage medium, wherein, when the computer program code is loaded into and executed by a processor, the processor becomes an apparatus for practicing the invention.
  • Embodiments include computer program code, for example, whether stored in a storage medium, loaded into and /or executed by a computer, or transmitted over some transmission medium, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein, when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing the invention.
  • the computer program code segments configure the microprocessor to create specific logic circuits.

Abstract

A Push-to-X over Cellular (PoC) server (351) receives a server registration message (301) for a first called device from a second server. The PoC server (351) receives a PoC invitation message (310) with PoC preferences and a message (313) from an originating device (311). The PoC preferences determine what device to call first (e.g., a mobile device 315, 317) and how many hops the call can be forwarded (e.g., to a voicemail server) if the first-attempted device is not available, before discontinuing the connection. If a trigger, such as time elapsed, occurs for the first-attempted device (350) and the PoC preferences permit, the PoC server (351) sends an invitation message (360) to the second server (391). If the second server (391) is a recording server, the invitation message (360) includes a message (363) from the originating device that is compatible with the capabilities of the recording server (391).

Description

METHOD FOR POC SERVER TO HANDLE POC CALLER PREFERENCES
FIELD OF THE DISCLOSURE
[0001] This disclosure relates generally to cellular communication systems, in particular the provision of push-to-X (PTX) services in a cellular communication system.
BACKGROUND OF THE DISCLOSURE
[0002] Push-to-talk (PTT) refers to a half-duplex mode of communication during which a single user has mutually exclusive use of a wireless communication channel for the transmission of voice information to another user or group of users. From an operational viewpoint, originating party User A presses a PTT switch on a mobile device, possibly awaits a "ready" tone, speaks into a microphone of the mobile device, and then releases the PTT switch. At this point, a former called party User B can press a PTT switch, possibly await a "ready" tone, speak into the microphone, and release the PTT switch. This procedure is repeated with different parties becoming the originating user and transmitting to one or more called parties in the group call until the conversation has completed.
[0003] With PTT and other PTT-related (PTX) services being available over a cellular communication network, PTX over Cellular (PoC) services are starting to address the merging of PTX and other telephony services — such as the merging of PTT with voicemail services. If a called party User B forwards a PoC call to a voicemail server, the outgoing message of the voicemail may grab the "floor" and thus have mutually exclusive use of the communication channel for the duration of the outgoing message. Meanwhile, originating party User A and other group call participants such as User C may have to endure the outgoing message of User B's voicemail when User A would rather have avoided User B's voicemail system entirely.
[0004] Thus, there is an opportunity to improve a user's experience in situations where a PoC call is forwarded to a voicemail server. The various aspects, features and advantages of the disclosure will become more fully apparent to those having ordinary skill in the art upon careful consideration of the following Drawings and accompanying Detailed Description.
BRIEF DESCRIPTION OF THE DRAWINGS
[0005] FIG. 1 shows a push-to-talk over cellular (PoC) system architecture according to an embodiment.
[0006] FIG. 2 shows a block diagram of a mobile device according to an embodiment.
[0007] FIG. 3 shows a sample signal flow diagram for a push-to-talk system according to an embodiment.
[0008] FIG. 4 shows a flow chart to be implemented in a PTT server for handling a calling device's priority list according to a second embodiment. [0009] FIG. 5 shows a flow chart to be implemented in a PTT server for handling a calling device's priority list according to a first embodiment.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
[0010] A Push-to-X over Cellular (PoC) server receives a server registration for a first device from a second server. The PoC server receives a PoC invitation message with PoC preferences and a message from an originating device. The PoC preferences determine what device to call first (e.g., a mobile device) and how many hops the call can be forwarded (e.g., to a voicemail server) if the first- attempted device is not available, before discontinuing the connection. If a trigger, such as time elapsed, occurs for the first-attempted device and the PoC preferences permit, the PoC server sends an invitation message to the second server. If the second server is a recording server, the invitation message includes a message from the originating device that is compatible with the capabilities of the recording server.
[0011] If no hops are allowed, the connection to a particular called party will be discontinued if the first-attempted device is not available. This is useful when an originating user only wants to reach a person immediately. If one or more hops are allowed, the connection to a particular called party can be forward to additional servers, including recording servers. If the connection is forwarded to a recording server, a recorded message from the originating user can be sent to the recording server without interrupting the group call. A recorded message from the originating user can be selected or modified depending on the capabilities of the recording server. [0012] FIG. 1 shows a push-to-X over cellular (PoC) system architecture 100 according to an embodiment. PoC systems, both terrestrial and satellite, generally utilize a network component (e.g., a PTT server 151) to (a) set up and control required radio resources and (b) establish and manage the switching of voice data. Note that this system architecture can be expanded to include not only push-to- talk services, but also push-to-message, push-to-video, and other extensions of the push-to-talk concept into other forms of communication and services. [0013] In this PoC system architecture 100, an originating mobile device 111 wirelessly communicates with a radio access network 121. This radio access network 121 connects to a packet data core network 131 which in turn connects to a PTT radio resource manager 141 and a PTT server 151 (sometimes called a PTT data switch) through the Internet 161, SIP proxy servers, or other data network elements. The PTT radio resource controller 141 (sometimes called a PTT radio resource manager) communicates with the PTT server 151. Other elements , such as recording servers 191 are also coupled to the network. Other packet data core networks 135, 137 are connected to the Internet 161, while other radio access networks 125, 127 are connected to the packet data core networks. Called mobile devices 115, 117, 119 are wirelessly connected to one or more of the available radio access networks 121, 125, 127. Any two or more of these mobile devices 111, 115, 117, 119 can establish a group call by one mobile device (such as originating mobile device 111) requesting a PoC call with one or more other mobile devices (such as called mobile device 115) in accordance with an agreed-upon protocol such as Session Initiation Protocol (SIP).
[0014] In this embodiment, the PoC system architecture 100 is implemented as part of a Global System for Mobile communications (GSM) system, with the radio access networks being GSM General Packet Radio Service (GPRS) radio access networks and the packet data core networks 131, 135, 137 being Gateway GPRS Support Nodes (GGSNs) and Serving GPRS Support Nodes (SGSNs). Alternately, the PoC system architecture 100 can be implemented as part of a CDMA system, with the radio access networks 121, 125, 127 being CDMA Ix radio access networks and the packet data core networks 131, 135, 137 being Packet Data
Switching Networks (PDSNs). The PoC system architecture can have additional or alternate radio access networks and core networks, including combinations and hybrids that develop as technology progresses. [0015] In this example, an originating mobile device 111 wirelessly communicates with a radio access network 121. For the purposes of providing detail for this preferred embodiment, the originating mobile device 111 is a GSM device and the radio access network 121 is a GSM GPRS radio access network; however, alternate radio access networks are applicable as mentioned previously. The radio access network 125 connects to a packet data core network 135, implemented as an SGSN and GGSN, which in turn uses an Internet Protocol (IP) and Session Initiation Protocol (SIP) to connect to the PTT radio resource controller 141 and PTT server 151 through the Internet 161. [0016] A called mobile device 115 wirelessly communicates with a different radio access network 125, which is also a GSM GPRS radio access network in this example. The radio access network 125 connects to a packet data core network 135, implemented as another SGSN and GGSN, which in turn uses an Internet Protocol (IP) and Session Initiation Protocol (SIP) to connect to the PTT radio resource controller 141 and PTT server 151 through the Internet 161. Further called mobile devices 117, 119 wirelessly communicate with yet another radio access network 127. The radio access network 127 connects to a packet data core network 137, which in turn connects to the PTT radio resource controller 141 and PTT server 151 through the Internet 161.
[0017] Although the mobile devices 111, 115, 117, 119 are shown as wireless telephones and a personal digital assistant, one or more mobile devices could be implemented as other types of wireless device such as pocket personal computers or laptop computers.
[0018] If the mobile device 111 is operated by an originating party (User A), a signal goes from the mobile device 111 through the radio access network 121 and packet data core network 131 to the PTT radio resource controller 141, which sets up the path for communication data. Once the PoC circuit is set up, User A's communication data is sent from the mobile device 111 to the radio access network 121, to the packet data core network 131, and to the PTT server 151. The PTT server 151 forwards User A's communication data to the packet data core networks 135, 137 of the called parties, which in turn go to the radio access networks 125, 127 of the called parties and then the mobile devices 115, 117, 119 of the called parties.
[0019] Called party User B may have the mobile device 115 forwarded to a recording server 191 (such as a voicemail system) because User B's mobile device 115 is not being answered, is powered down, or is roaming in a network that does not support PoC services. In such an instance, User B may unintentionally participate in the call through User B's outgoing message on the voicemail server. The outgoing message may grab the "floor" and maintain the floor throughout the duration of the outgoing message. At this point, all the other participants on the call are forced to listen to User B's outgoing voicemail message. Once User B's voicemail server releases the floor, the originating user (User A) may hang up or interact with the voicemail server by leaving a message and /or working with the voicemail menu system. Note that the recording server 191 can also be implemented as an electronic mail server or another type of server used for disseminating outgoing messages or storing incoming messages. In the case of an electronic mail server, note that an electronic mail server might be implemented as a component in a text messaging or paging system.
[0020] A further complication occurs when more than one user, such as User B with mobile device 115 and User D with mobile device 119, has calls forwarded to their voicemail server(s). In this situation, two outgoing messages may attempt to grab the floor at approximately the same time. The result might be that one outgoing message grabs the floor and the other outgoing message is at least partially blocked because it does not have the floor. Alternately, the voice mail servers may need to be addressed one after another, which would take up additional time during the beginning of the group call. It is also possible that a voicemail server that does not have the floor may terminate the call due to inactivity.
[0021] By equipping at least an originating mobile device with PoC caller preferences, the originating mobile device can avoid situations where outgoing messages of a recording server compete with each other or actual users for the floor. PoC caller preferences enable an originating user to specify whether PoC calls should be forwarded to a recording server (or another server) and allow the originating user to leave a message on a recording server without interrupting the PoC conversation. [0022] FIG. 2 shows a block diagram of a mobile device 200 according to an embodiment. The mobile device 200 can be any of the mobile device 111, 115, 117, 119 shown in FIG. 1. The mobile device 200 includes a user interface 202 coupled to a processor 206, such as one or more microprocessors, microcontrollers, digital signal processors (DSPs), or equivalents or combinations thereof. The mobile device 200 further includes at least one memory device 208 associated with a processor 206, such as random access memory (RAM), dynamic random access memory (DRAM), and /or read only memory (ROM) or equivalents thereof, that maintain data and programs that may be executed by the processor 206 and that allow the mobile device 200 to perform all the functions necessary to operate in a compatible communication system such as the one shown in FIG. 1. [0023] The user interface 202 provides a user of the mobile device 200 with the capability of interacting with the mobile device 200, including entering instructions into the mobile device 200. In one embodiment, the user interface 202 includes a display screen 204 and a keypad with multiple keys, including a PoC key. In alternate embodiments, the PoC key is implemented as a "soft key" or a region on a touchscreen rather than a discrete key.
[0024] The memory device 208 maintains a Mobile ID and a PoC Address that are uniquely associated with the mobile device 200. A PoC Address can be implemented as an e-mail address or a canonical telephone number. For example, a PoC Address may be a Session Initiation Protocol (SIP) Universal Resource Identifier or Locator (URI or URL) such as "someone@example.com." As another example, a PoC Address may be a Telephone (TEL) URI or URL, such as international number TEL: +1-888-555-1212, or a local number that uses a local dialing plan and prefix. [0025] Additionally, the memory device 208 maintains a phone book listing of identifiers associated with one or more other devices. An identifier can be a PoC Address uniquely associated with a mobile device, a PoC Address of a voicemail or email server of a home network serving the mobile device 200, such as the recording server 191 shown in FIG. 1, or a talkgroup ID uniquely associated with multiple unique PoC Addresses. The identifiers may be pre-programmed into the memory device 208 or may be added to the memory device 208 by a user of the mobile device 200.
[0026] The memory device 208 further allows for PoC preferences regarding each entry in its phone book listing. The PoC preferences include the originating mobile device's prioritized list of preferred forwarding actions for a PoC call. Examples of a prioritized list are shown in memory element 215 for User B and memory element 217 for User C. When an originating mobile device (such as User A's mobile device 115 shown in FIG. 1) with a prioritized list such as that shown in memory elements 215, 217 seeks to establish a PoC call with User B, it will first call User B's mobile device (such as mobile device 115 shown in FIG. 1). If the PoC call is unable to connect because User B's mobile device 115 is not being answered, out of range, turned off, set to "do not disturb," or the like, memory element 215 shows that it is acceptable for the PoC call to be forwarded to a recording server such as recording server 191 shown in FIG. 1 or a different PoC Address. A further variable indicates how many forwarding hops are acceptable to the originating user, User A. For example, memory element 215 indicates that two hops are acceptable, which could be one hop to an alternate telephone number and a second hop to a recording server. If no alternate PoC Address is available or the hop count is exceeded, the memory element 215 indicates that the PoC call should discontinue the connection. [0027] Another memory element 217 is established for User Cs mobile device 117 shown in FIG. 1. In this situation, when User A's mobile device seeks to establish a PoC call with User C, it will first try to contact User Cs mobile device (such as mobile device 117 shown in FIG. 1). If the PoC call is unable to connect because User Cs mobile device 117 is not being answered, out of range, turned off, set to "do not disturb," or the like, memory element 217 indicates that the PoC call should end. Thus, memory element 217 establishes that, even though User C may have a recording server available, originating User A's preference is to not forward the PoC call to the recording server or any other PoC Address. In this situation, either originating User A will reach called party User C at User Cs mobile phone or User A will not reach User C at all.
[0028] Note that this prioritized list can be set and modified by the originating caller on a per-call basis or less frequently. For example, if an originating user only wants to reach called users at their primary mobile device for a particular PoC call, then, prior to originating that PoC call, the originating user can set the prioritized lists to "(1) call mobile device and (2) discontinue connection" for each of the mobile devices to be called. If, however, the originating user wants to leave a message for one called party and try to reach all other called parties directly, the originating user can modify the prioritized list for that one party to be "(1) call mobile device, (2) allow forwarding a specified number of hops, and (3) discontinue connection" while leaving the other prioritized lists as "(1) call mobile device and (2) discontinue connection." Allowing forwarding 0 hops is another way to implement not allowing forwarding. Although it is theoretically possible to allow forwarding an unlimited number of hops, each hop generally causes delay and increases the risk of a loop where a hop returns the call to a server that has already been hopped-through.
[0029] As telephony services evolve and merge with other services such as presence, instant messaging, location-based services, electronic mail, and the like, the list of options for PoC preference lists will grow. PoC preference lists can keep track of the originating user's preferences and allow the caller to maintain some control over where the call is being forwarded and prevent unwanted effects, such as a voicemail outgoing message grabbing the floor.
[0030] FIG. 3 shows a sample signal flow diagram 300 for a push-to-talk system according to an embodiment. Vertical line 311 represents signaling to and from an originating mobile device A, such as mobile device 111 shown in FIG. 1. Vertical line 351 represents signaling to and from a PTT server, such as PTT server 151 shown in FIG. 1. Vertical line 315 represents signaling to and from a called mobile device B, such as mobile device 115 shown in FIG. 1. Vertical line 317 represents signaling to and from a called mobile device C, such as mobile device 117 shown in FIG. 1. Vertical line 391 represents signaling to and from a recording server, such as recording server 191 shown in FIG. 1. Note that there may be other servers involved in this communication session. For example, PTT server 351 may serve User A while another PTT server (not shown) serves User B and yet another PTT server (not shown) serves User C. Additionally, there may be intermediate servers that route messages but are not directly associated with any of the call participants. For the purposes of this explanation, no additional PTT servers are shown; however, additional servers affect the situation in that they increase the hop count and may introduce delay into the system.
[0031] Initially, the recording server 391 sends a recording server registration message 301 indicating the PoC Address of the recording server and its association with a mobile device. In this example, the recording server is a voicemail server for mobile device B. The recording server registration message 301 indicates the preference of mobile device B relative to the recording server. In this example, the message 301 indicates that mobile device B should first be contacted and then, should contacting mobile device B be unsuccessful, the recording server 391 should be contacted.
[0032] When User A desires to make a group call, the originating mobile device A 311 sends a SIP OPTIONS message 303 to query the PTT server 351 regarding any recording server registrations for the group call's participant list. The PTT server 351 returns a 200 OK message 306 with information regarding any recording servers registered to the participants, including the capabilities of the recording servers. Based on whether any participants have registered recording servers, and the capabilities of the recording servers, the originating mobile device 311 constructs a message that can be sent (with or without modifications) to one or more registered recording servers. For example, if a participant's recording server accepts multimedia messages, a photo of a watch and an audio recording of "It's meeting time!" plus the text "IT'S MEETING TIME" can be forwarded. If the recording server only accepts text messages then a text message TFS MEETING TTME" can be constructed by stripping out non-text layers of the message 313 described earlier or by receiving and selecting a text-only message 313 from the originating mobile device. If a participant's recording server accepts audio messages, then an audio recording of "It's meeting time!" can be made by stripping out non-audio layers of the multimedia message 313 described earlier or by receiving and selecting an audio-only message 313 from the originating mobile device. [0033] By querying the existence and capability of participants' recording servers, the originating mobile device 311 can tailor messages to the capabilities of the available recording devices, which improves the user experience and reduces wasted bandwidth when, for example, a multimedia message is constructed at the originating device but no participant's recording server can accept a multimedia message. Additionally, the information in 200 OK message 306 can be used by User A to create personalized messages for called users rather than grouping the message by recording server type (e.g., text, audio, multimedia, etc.). [0034] To initiate a PoC communication session, the originating mobile device A 311 sends one or more messages to the PTT server 351 containing a SIP BSTVITE message 310 identifying target mobile devices. The identifier of the target mobile devices can be a PoC Address such as a telephone number or email address. Depending on implementation, a single SIP INVITE message can include a single PoC Address or multiple PoC Addresses. Optionally, the initial set of INVITE- related messages includes an audio, visual, or multimedia message 313 such as "It's Meeting Time" in the recorded voice of the user A, a text message "It's Meeting Time," a graphic icon of an alarm clock, or more than one of the messages above. Also, the initial set of ENTVITE-related messages can include originating mobile device PoC preferences 316. For example, user A may have determined that the PTT server 351 should, for all called mobile devices, first attempt a connection with the target mobile device, then any recording server associated with the target mobile device, and hang up if neither the target mobile device nor its recording server can be reached. [0035] In response to the SIP INVIiE message 310 from the originating mobile device 311, the PTT server 351 sends an INVITE message 320 to User B and an
INVITE message 323to User C. These secondary INVITE messages 320, 330 occur in parallel. Mobile device B 315 responds to the SIP INVITE message 320 with a SIP 180 RINGING message 330. Mobile device C 317 responds to the SIP INVITE message 323 with a SIP 180 RINGING message 333. The PPT server 351 processes these SIP 180 RINGING messages normally and sends a SIP 180 RINGING message 336 to the originating mobile device A 311.
[0036] Shortly after, in this example, mobile device C 317 is answered either automatically or manually, and a SIP 200 OK message 340 goes from the mobile device C 317 to the PTT server 351, which sends a SIP 200 OK message 343 to the mobile device A 311. At this point, the originating mobile device 311 and PTT server 351 set up a Real Time Protocol (RTP) media session 370 from the originating mobile device 311 to the PTT server 351 and another RTP media session 373 from the PTT server 351 to the mobile device 315 that has accepted the call. Now, User A can communicate from mobile device 311 to mobile device 315. If additional mobile devices (not shown) are participating in the group call, further secondary RTP media sessions, similar to RTP media session 373, can be established with the PTT server 351, and the information in RTP media session 370 will be sent to the additional mobile devices as they answer the group call. [0037] Meanwhile, mobile device B 315 has not been answered and the PTT server 351 awaits a trigger indicating that the PTT should no longer continue to wait. The trigger can be implemented as a ring count (e.g., wait no longer than six rings), a timer (e.g., wait no longer than 30 seconds), or another triggering mechanism. One the trigger has occurred 350, the PTT server 351 sends a SIP BYE message 353 to the mobile device B 315 to cancel the previous SIP INVlTJi message 320 to User B. Next, the PTT server 351 sends a SIP INVITE message 360 to User B at the second-choice PoC Address in accordance with the PoC preference list 316 expressed in the initial set of messages from the originating mobile device A 311. In this situation, the second-choice is a recording server 391, whose PoC Address is determined from the recording server registration message 301 sent earlier to the PTT server 351. Based up the PTT server's knowledge of the capabilities of the recording server, the PTT server 351 can also forward a message 363 to the recording server 391 reflecting the message 313 from the originating mobile device A 311. [0038] Note that the message 313 can have more than one layer or part (e.g., voice, text, photo, video, etc.), and the appropriate layers of the message 313 can be sent to the recording server 391 depending on the recording server's capability. For example, only the voice layer of the message 313 will be forwarded to a voicemail server and only the text layer of the message 313 will be forwarded to a text server, but multiple layers of the message 313 will be forwarded to a multimedia messaging server. Additional layers of the message 313 can include flags for "urgent" or data such as location information of the calling party. [0039] The recording server 391 responds with a SIP 200 OK message 366 for User B, and the PTT Server 351 closes the session with a SIP BYE message 369 to the recording server 391. Because only User C is available for the group call at mobile device C 317, when mobile device A 311 has the floor, it sends an RTP media message 370 to the PTT server 351, which forwards it to mobile device C 317. [0040] Thus, the originating User A and any available called parties (User C) can have a group call without being forced to listen to an outgoing message from non-available called parties (User B). If the originating User A would like to leave a message, it can be pre-recorded and sent to a called party's recording server without interrupting the real-time group call. If the originating User A would not like to leave a message with a called party (User B), then the PTT Server 351 can disconnect the call if the called party is not available directly. Other variations of called party preferences are possible, as shown in FIGs.4-5.
[0041] FIGs. 4-5 show a flow chart 400, 500 to be implemented in a PTT server for handling an originating party's PoC preference list according to an embodiment. A PTT server such as PTT server 151 shown in FIG. 1 can implement the flow chart 400. Memory element 215 of FIG. 2 can store the PoC preference list of the originating user.
[0042] Initially, step 410 receives an INVITE message for a group call for N called parties and, optionally, messages for the called parties, where N is a natural number. Step 415 checks each called party's server registration. Step 420 forks an INVlTJi message to each of the N called parties so that each of the N called parties is being sent an individual INVITE message. Forking can be implemented in a PTT server using separate state machines for each called party operating in parallel. Step 430 resets individual triggers for each called party. As stated earlier, triggers can be timers, ring counts or other mechanisms. Step 440 determines if a particular called party's trigger has tripped. If the trigger has expired, then the flow goes to step 520 in FIG. 5.
[0043] If the trigger has not tripped and step 450 determines that an OK message has been received from the called party related to that trigger, then step 454 cancels that called party's trigger and step 457 continues with a normal PoC call set-up for that called party.
[0044] If the trigger has not tripped and step 450 determines that no OK message has yet been received, then step 455 handles any message received (such as a RINGING or TRYING message) normally and returns to step 440. [0045] Turning to FIG. 5, step 520 checks whether the originating user's PoC preference list shows a preference for the call to be forwarded. If there is no preference for the call to be forwarded, step 525 discontinues the connection for that called party. If there is a preference for the call to be forwarded, step 530 determines if the called party has implemented call forwarding to another PoC Address. If not, step 525 discontinues the connection. If the called party has a forwarding PoC Address, step 535 determines if forwarding the call would exceed the allowable hop count set by the originating user. If the hop count is not exceeded, then the connection is forwarded in step 550. [0046] If step 460 determines that the connection is forwarded to a recording server, the originating user can leave a pre-recorded message without interrupting the other parties on the group call in step 465. Otherwise, the flow returns to step 430 in FIG. 4 to reset the trigger for that particular called party. [0047] Returning to step 535, if the hop count is exceeded, than step 525 discontinues the connection. Note that the originating user may set a maximum hop count for a number of reasons. One is to limit delay in the PoC communications. As the hop count increases, the time delay for a PoC communication generally increases. Two is to limit the potential for a circular call- forwarding loop. One called party's phone may be forwarded to a secretary and that secretary's phone may be forwarded to a receptionist. If the receptionist's phone is forwarded back to the secretary, the originating user may become stuck in a call-forwarding loop. Three is to limit the potential for being forwarded to someone who is only peripherally related to the subject of the PoC call. The first hop may be from the called party's primary telephone (mobile device) to the called party's secondary telephone (office telephone), the second hop may be to the called party's secretary who is aware of the called party's availability, but a third hop may be to a company receptionist who is not aware of the called party's availability.
[0048] Thus, a PTT server implementing this flow chart can adhere to an originating party's PoC preferences for reaching a called party for a PoC call. By enabling PoC preferences, an originating user can leave messages with called parties without interrupting the real-time PoC call, can avoid recording servers as desired, and can limit the number of server hops in a PoC call. [0049] While this disclosure includes what are considered presently to be the preferred embodiments and best modes of the invention described in a manner that establishes possession thereof by the inventors and that enables those of ordinary skill in the art to make and use the invention, it will be understood and appreciated that there are many equivalents to the preferred embodiments disclosed herein and that modifications and variations may be made without departing from the scope and spirit of the invention, which are to be limited not by the preferred embodiments but by the appended claims, including any amendments made during the pendency of this application and all equivalents of those claims as issued.
[0050] It is further understood that the use of relational terms such as first and second, top and bottom, and the like, if any, are used solely to distinguish one from another entity, item, or action without necessarily requiring or implying any actual such relationship or order between such entities, items or actions. Much of the inventive functionality and many of the inventive principles are best implemented with or in software programs or instructions. It is expected that one of ordinary skill, notwithstanding possibly significant effort and many design choices motivated by, for example, available time, current technology, and economic considerations, when guided by the concepts and principles disclosed herein will be readily capable of generating such software instructions and programs with minimal experimentation. Therefore, further discussion of such software, if any, will be limited in the interest of brevity and minimization of any risk of obscuring the principles and concepts according to the present invention. [0051] As understood by those in the art, processor 206 includes a processor that executes computer program code to implement the methods described herein. Embodiments include computer program code containing instructions embodied in tangible media, such as floppy diskettes, CD-ROMs, hard drives, or any other computer-readable storage medium, wherein, when the computer program code is loaded into and executed by a processor, the processor becomes an apparatus for practicing the invention. Embodiments include computer program code, for example, whether stored in a storage medium, loaded into and /or executed by a computer, or transmitted over some transmission medium, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein, when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing the invention. When implemented on a general-purpose microprocessor, the computer program code segments configure the microprocessor to create specific logic circuits. [0052] We claim:

Claims

1. A method for a Push-to-X over Cellular (PoC) server comprising: receiving a server registration for a first called device from a second server; receiving a PoC invitation message with PoC preferences from an originating device; and sending an invitation message to the second server, if a trigger occurs for the first called device and the PoC preferences permit.
2. A method according to claim 1 further comprising, before sending an invitation message to the second server: receiving PoC addresses for one or more called parties from the originating device; and sending invitation messages to the one or more called parties.
3. A method according to claim 1 further comprising: sending a "BYE" message to the first called device, if the trigger occurs for the first called device.
4. A method according to claim 1 further comprising: receiving at least one recorded message from the originating device.
5. A method according to claim 4 wherein the at least one recorded message is at least one of: a text message, an audio message, a picture message, and a video message.
6. A method according to claim 4 further comprising: forwarding the at least one recorded message to the second server, if the trigger occurs for the first called device and the PoC preferences permit.
7. A method according to claim.6 further comprising: sending a "BYE" message to the second server.
8. A method according to claim 6 further comprising, before forwarding the at least one recorded message to the second server: determining messaging capabilities of the second server; and modifying the at least one recorded message based on the messaging capabilities of the second server.
9. A method according to claim 4 further comprising: determining messaging capabilities of the second server; selecting one message of the at least one recorded message based on the messaging capabilities of the second server; and forwarding the one message to the second server, if the trigger occurs for the first called device and the PoC preferences permit.
10. A method according to claim 4 further comprising: determining messaging capabilities of the second server; selecting one message of the at least one recorded message based on the messaging capabilities of the second server and a message preference of the originating device; and forwarding the one message to the second server, if the trigger occurs for the first called device and the PoC preferences permit.
11. A method according to claim 4 further comprising: selecting one message of the at least one recorded message that is compatible with messaging capabilities of the second server; and forwarding the one message to the second server, if the trigger occurs for the first called device and the PoC preferences permit.
12. A method according to claim 11 further comprising: sending a "BYE" message to the second server.
13. A method according to claim 1 further comprising: sending a Real Time Protocol media message from the originating device.
14. A method according to claim 13 further comprising: sending the Real Time Protocol media message to a second called device.
15. A method according to claim 1 wherein the server registration includes a PoC address for the second server.
16. A method according to claim 1 wherein the second server is a voicemail server.
17. A method according to claim 1 wherein the second server is an electronic mail server.
18. A method according to claim 1 wherein the second server is a multimedia messaging server.
19. A method according to claim 1 wherein the trigger is an elapsed timer.
20. A method according to claim 1 wherein the PoC preferences include a hop count limit.
PCT/US2006/013177 2005-05-27 2006-04-07 Method for poc server to handle poc caller preferences WO2006130238A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP06740769.2A EP1889441B1 (en) 2005-05-27 2006-04-07 Method for poc server to handle poc caller preferences

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/139,719 2005-05-27
US11/139,719 US7801494B2 (en) 2005-05-27 2005-05-27 Method for PoC server to handle PoC caller preferences

Publications (1)

Publication Number Publication Date
WO2006130238A1 true WO2006130238A1 (en) 2006-12-07

Family

ID=36655075

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2006/013177 WO2006130238A1 (en) 2005-05-27 2006-04-07 Method for poc server to handle poc caller preferences

Country Status (3)

Country Link
US (1) US7801494B2 (en)
EP (1) EP1889441B1 (en)
WO (1) WO2006130238A1 (en)

Families Citing this family (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7801953B1 (en) * 2001-02-12 2010-09-21 Nortel Networks Limited Push-to-talk wireless telecommunications system utilizing an voice-over-IP network
CN100450222C (en) * 2005-07-15 2009-01-07 华为技术有限公司 Method and apparatus for invited user in conversation obtaining group information
US20070101019A1 (en) * 2005-11-03 2007-05-03 Cromer Daryl C Apparatus, system, and method for managing response latency
EP1956818A4 (en) * 2005-11-04 2011-10-12 Sharp Kk PoC SERVER AUTOMATIC-SEARCH METHOD, QUALITY ADJUSTING METHOD, AND COMMUNICATION SYSTEM USING THESE METHODS
KR101002572B1 (en) * 2006-01-12 2010-12-17 엘지전자 주식회사 Method and termimal for establishing pt session using pt box
EP1814337A1 (en) * 2006-01-27 2007-08-01 Hewlett-Packard Development Company, L.P. Improvements in or relating to group communications
KR100850573B1 (en) 2007-04-04 2008-08-06 삼성전자주식회사 Mobile terminal for ptt and method for executing missed ptt call information thereof
US8363657B2 (en) 2007-05-23 2013-01-29 Apple Inc. SIP-enabled framework for multi-domain roaming control plane in a WiMAX access network
US8184558B2 (en) * 2007-05-31 2012-05-22 Telecom Italia S.P.A. Method, gateway and system for providing a push-to-x service to a user of a data terminal
CN101137231B (en) * 2007-07-31 2010-11-10 中兴通讯股份有限公司 Terminal registering method and device based on CDMA cluster system
US8135124B2 (en) 2008-03-21 2012-03-13 Microsoft Corporation Communicating information pertaining to cancelling of forked call requests
US8817697B2 (en) * 2008-06-05 2014-08-26 Qualcomm Incorporated System and method for minimizing call setup latency in a group communication among wireless communication devices
CN102057700B (en) * 2008-06-09 2015-01-14 爱立信电话股份有限公司 Private communication in a push to talk over cellular network
KR20100033613A (en) * 2008-09-22 2010-03-31 삼성전자주식회사 Method, system and mobile terminal for notifying absence in ptt service
US20100115613A1 (en) * 2008-10-31 2010-05-06 Google Inc. Cacheable Mesh Browsers
US9832319B2 (en) 2014-06-13 2017-11-28 Genesys Telecommunications Laboratories, Inc. System and method for transferee controlled protocol transfers
GB2533330B (en) * 2014-12-16 2017-05-17 Motorola Solutions Inc Methods and systems for provisioning mobile radios to talkgroups
US10051442B2 (en) * 2016-12-27 2018-08-14 Motorola Solutions, Inc. System and method for determining timing of response in a group communication using artificial intelligence
US9961516B1 (en) * 2016-12-27 2018-05-01 Motorola Solutions, Inc. System and method for obtaining supplemental information in group communication using artificial intelligence
US20190149959A1 (en) 2017-11-16 2019-05-16 Motorola Solutions, Inc Method for controlling a virtual talk group memeber to perform an assignment

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020169776A1 (en) * 2000-09-01 2002-11-14 Nokia Corporation Network architecture and methods for service script execution and management

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1133116A3 (en) * 2000-03-11 2003-07-23 Hewlett-Packard Company Message diffusion between mobile devices
US6501739B1 (en) * 2000-05-25 2002-12-31 Remoteability, Inc. Participant-controlled conference calling system
US6996414B2 (en) * 2001-04-30 2006-02-07 Motorola, Inc. System and method of group calling in mobile communications
US20040203752A1 (en) * 2002-11-18 2004-10-14 Toshiba America Information Systems, Inc. Mobility communications system
US20040264410A1 (en) * 2003-06-30 2004-12-30 Motorola, Inc. Method and apparatus for providing a communication unit with a handoff between networks
US7395057B2 (en) * 2003-09-30 2008-07-01 Avaya Technology Corp. System and method for reconnecting dropped cellular phone calls
EP1560368A1 (en) * 2004-01-30 2005-08-03 France Telecom Method and system for establishing a multimedia session between a calling equipment and a called equipment in a IP Multimedia Subsystem (IMS) type network
JP2008507217A (en) * 2004-07-16 2008-03-06 ブリッジポート ネットワークス, インコーポレイテッド Presence detection and handoff for cellular and Internet protocol telephony
US20060046758A1 (en) * 2004-09-02 2006-03-02 Mohsen Emami-Nouri Methods of retrieving a message from a message server in a push-to-talk network
US7529845B2 (en) * 2004-09-15 2009-05-05 Nokia Corporation Compressing, filtering, and transmitting of protocol messages via a protocol-aware intermediary node
FI20041377A0 (en) * 2004-10-25 2004-10-25 Nokia Corp Delivery of services in a telecommunications system

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020169776A1 (en) * 2000-09-01 2002-11-14 Nokia Corporation Network architecture and methods for service script execution and management

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
"Digital cellular telecommunications system (Phase 2+); Universal Mobile Telecommunications System (UMTS); Internet Protocol (IP) multimedia call control protocol based on Session Initiation Protocol (SIP) and Session Description Protocol (SDP); Stage 3 (3GPP TS 24.229 version 5.12.0 Release 5); ETSI", ETSI STANDARDS, EUROPEAN TELECOMMUNICATIONS STANDARDS INSTITUTE, SOPHIA-ANTIPO, FR, vol. 3-CN1, no. V5120, March 2005 (2005-03-01), pages 1 - 263, XP014027590, ISSN: 0000-0001 *
"Digital cellular telecommunications system (Phase 2+); Universal Mobile Telecommunications System (UMTS); IP Multimedia (IM) session handling; IM call model; Stage 2 (3GPP TS 23.218 version 6.2.0 Release 6); ETSI TS 123 218", ETSI STANDARDS, EUROPEAN TELECOMMUNICATIONS STANDARDS INSTITUTE, SOPHIA-ANTIPO, FR, vol. 3-CN1, no. V620, September 2004 (2004-09-01), pages 1 - 59, XP014027526, ISSN: 0000-0001 *
"Universal Mobile Telecommunications System (UMTS); 3GPP enablers for Open Mobile Alliance (OMA) Push-to-talk over Cellular (PoC) services; Stage 2 (3GPP TR 23.979 version 6.1.0 Release 6); ETSI TR 123 979", ETSI STANDARDS, EUROPEAN TELECOMMUNICATIONS STANDARDS INSTITUTE, SOPHIA-ANTIPO, FR, vol. 3-SA2, no. V610, March 2005 (2005-03-01), pages 1 - 38, XP014027165, ISSN: 0000-0001 *
LENNOX X WU H SCHULZRINNE COLUMBIA UNIVERSITY J: "Call Processing Language (CPL): A Language for User Control of Internet Telephony Services; rfc3880.txt;", IETF STANDARD, INTERNET ENGINEERING TASK FORCE, IETF, CH, October 2004 (2004-10-01), pages 1 - 74, XP015009658, ISSN: 0000-0003 *

Also Published As

Publication number Publication date
EP1889441A1 (en) 2008-02-20
US20060270362A1 (en) 2006-11-30
EP1889441B1 (en) 2015-09-09
US7801494B2 (en) 2010-09-21

Similar Documents

Publication Publication Date Title
US7801494B2 (en) Method for PoC server to handle PoC caller preferences
US9787733B2 (en) Group details of group services
EP1747692B1 (en) Handling an audio conference related to a text-based message
US7756537B2 (en) Group details of group services
US7751848B2 (en) Systems and methods for providing concurrent mobile applications to mobile communication devices
US7986775B2 (en) Method for realizing ring back tone in communication system
US9253319B1 (en) Methods and systems for call connecting calls
US20040006623A1 (en) Service providing mechanism
EP1747660A1 (en) Managing a conference session
CN101112071A (en) Image exchange for image-based push-to-talk user interface
KR100738532B1 (en) IP Network and Communication Method Therein
US8391908B2 (en) Communication systems
US20150222753A1 (en) Method for Handling a Call from a Calling Subscriber Towards a Called Subscriber
KR100929059B1 (en) System and method for providing multimedia contents in communication system
US8150003B1 (en) Caller initiated undivert from voicemail
US20070288600A1 (en) Telecommunications system and method of initiating file transfers from voice endpoints
WO2007045274A1 (en) Method and apparatus for handling redirection of sip messages
CN100440998C (en) Method for realizing consummation of civility call business characteristic
JP2004260728A (en) Exchange system and mobile terminal used for automatic answering telephone service, and automatic answering telephone service method
KR20060056515A (en) A method for poc call service and im chatting service in mobile network
WO2008067757A1 (en) A service processing method, system and application server

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application
NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2006740769

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: RU