WO2008134207A1 - Procédés et appareils pour connecter des personnes pour des communications en temps réel par voip - Google Patents
Procédés et appareils pour connecter des personnes pour des communications en temps réel par voip Download PDFInfo
- Publication number
- WO2008134207A1 WO2008134207A1 PCT/US2008/059687 US2008059687W WO2008134207A1 WO 2008134207 A1 WO2008134207 A1 WO 2008134207A1 US 2008059687 W US2008059687 W US 2008059687W WO 2008134207 A1 WO2008134207 A1 WO 2008134207A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- telephonic
- query
- advertisement
- listing
- connection
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1069—Session establishment or de-establishment
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/10—Office automation; Time management
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
Definitions
- At least some embodiments of the disclosure relate to communication connections in general and more particularly but not limited to connecting people for real time communications via Voice over Internet Protocol (VoIP).
- VoIP Voice over Internet Protocol
- VoIP Voice over Internet Protocol
- IP Internet Protocol
- PSTN public switched telephone network
- Cellular communication networks allow a cellular phone to connect to a nearby cellular base station through an air interface for wireless access to a telephone network.
- Recent developments in wireless telephone systems allow not only voice communications but also data communications.
- cellular phones can now receive and send messages through a Short Message Service (SMS), a Multimedia Message Service (MMS), or data communication connections.
- SMS Short Message Service
- MMS Multimedia Message Service
- web pages can be retrieved through wireless cellular links and displayed on cellular phones.
- WAP Wireless Application Protocol
- Telephone systems are frequently used in conducting business. Telephone numbers are typically provided in advertisements, web sites, directories, etc., as a type of contact information to reach businesses, experts, persons, etc.
- the Internet provides another communication media that can also be used as an advertisement media to reach globally populated web users.
- advertisements can be included in a web page that is frequently visited by web users.
- advertisements included in web pages contain only a limited amount of information (e.g., a small paragraph, an icon, etc.); and links in the advertisements are used to direct the visitors to the web sites of the advertisers for further detailed information.
- the advertisers pay for the advertisements based on the number of visits directed to their web sites by the links in the advertisements, or based on the number of presentations of the advertisements.
- Performance based advertising generally refers to a type of advertising in which an advertiser pays only for a measurable event that is a direct result of an advertisement being viewed by a consumer.
- an advertisement is included within a result page of a keyword search.
- Each selection ("click") of the advertisement from the results page is the measurable event for which the advertiser pays. In other words, payment by the advertiser is on a per click basis in such advertising.
- Figure IA illustrates a system to associate query information used to search for a listing with a telephonic connection resulted from a presentation of the listing on a telephonic apparatus according to one embodiment.
- Figure IB illustrates a system to track query information via a telephonic reference of a connection server that contains the query information according to one embodiment.
- Figure 1C illustrates a system to track query information via a call signaling message to a connection server that contains the query information according to one embodiment.
- Figure ID illustrates a system to track query information via a report message from the telephonic apparatus that associates the call with the query information according to one embodiment.
- Figure IE illustrates a system to track query information via a request message to resolve a telephonic reference of the callee according to one embodiment.
- Figure IF illustrates a system to track query information via a callback message that contains the query information according to one embodiment.
- Figure IG illustrates a system to connect a caller to a callee via advertisements according to one embodiment.
- Figure 2 illustrates a VoIP application for accessing an advertiser according to one embodiment.
- Figures 3 A - 3B illustrate examples of a VoIP application for accessing an advisor according to one embodiment.
- Figure 4 illustrates a user interface of a VoIP application for managing advertisements according to one embodiment.
- Figure 5 illustrates a user interface for the creation of an advertisement according to one embodiment.
- Figure 6 shows a method to establish connections for real time communications according to one embodiment.
- Figure 7 illustrates an example of a user interface to manage availability for receiving phone calls according to one embodiment.
- Figure 8 shows a diagram illustrating a method to select a type of tracking mechanism with a corresponding reference for embedding in an advertisement according to one embodiment.
- Figure 9 illustrates an example of telephone call tracking mechanisms which can be selected according to one embodiment.
- Figure 10 shows a diagram of a system to make and track phone connections according to one embodiment.
- Figure 11 shows a system including a connection server configured on a packet switched network according to one embodiment.
- Figure 12 shows a connection server according to one embodiment.
- Figure 13 shows a block diagram example of a data processing system which may be used in various embodiments.
- Figure 14 illustrates a system to display and manage advertisements according to one embodiment.
- Figure 15 illustrates a method to display advertisements according to one embodiment.
- Figure 16 illustrates a further method to display advertisements according to one embodiment.
- Figure 17 shows a method to manage an advertisement according to one embodiment.
- Figure 18 shows a method to manage telephonic contact information according to one embodiment.
- Figures 19 - 20 illustrate application programming interfaces according to one embodiment.
- Figure 21 illustrates data objects for application programming interfaces according to one embodiment.
- Figure 22 illustrates an application programming interface to provide advertisements according to one embodiment.
- Figure 23 illustrates a method to connect a telephonic apparatus to an advertiser and to track parameters associated with the telephonic call via a telephonic reference of a connection server that includes the parameters to be tracked according to one embodiment.
- Figure 24 illustrates a method to track parameters associated with a call via a call signaling message to a connection server that contains the parameters to be tracked according to one embodiment.
- Figure 25 illustrates a method to track parameters associated with a call via a report message from the telephonic apparatus that associates the call with the parameters to be tracked according to one embodiment.
- Figure 26 illustrates a method to track parameters associated with a call via a request message that contains the parameters to be tracked to resolve a telephonic reference of the callee according to one embodiment.
- Figure 27 illustrates a method to track parameters associated with a call via a callback message that contains the parameters to be tracked according to one embodiment.
- references in this specification to "one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the disclosure.
- the appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments.
- various features are described which may be exhibited by some embodiments and not by others.
- various requirements are described which may be requirements for some embodiments but not other embodiments.
- an advertisement may refer to various different forms of presentations to attract attention or patronage.
- An advertisement may be simply a listing of identity and contact information (e.g., in a web page, a print media, a telephonic listing service, etc.), or a passage including one or more statements about business offering, etc., or a banner with graphical content and/or animation embedded in a web page, or a voice message presented in a voice channel (e.g., radio broadcasting, a voice portal with Interactive Voice Response (IVR), which may accept user input through voice recognition or through keypad input generated Dual Tone Multi-Frequency (DTMF) signals), or others.
- IVR Interactive Voice Response
- a listing may or may not be provided on behalf of an advertiser.
- a community of users may create listings of businesses, sellers, etc. based on the recommendation of the users.
- a directory service provider may compile listings of some businesses or sellers without the businesses or sellers explicitly request the directory service provider to advertise for them.
- a business or seller presented by a listing may or may not pay an advertisement fee for the presentation of the listing and/or for the lead to the customers resulting from the presentation of the listing.
- an advertiser of an advertisement is charged an advertisement fee based on the performance of the advertisement (e.g., a telephonic connection to a customer, a lead for real time communication with a customer, a deal completed with the customer as a result of the performance, a subscription fee for a number of bundled leads or deals, etc.).
- the performance of the advertisement e.g., a telephonic connection to a customer, a lead for real time communication with a customer, a deal completed with the customer as a result of the performance, a subscription fee for a number of bundled leads or deals, etc.
- Figure IA illustrates a system to associate query information used to search for a listing with a telephonic connection resulted from a presentation of the listing on a telephonic apparatus according to one embodiment.
- the telephonic apparatus (11) has the data communication capability. After a query is submitted from the telephonic apparatus (11) over a data communication network (13), a listing is received with embedded information about the query. The information about the query may be received in clear text, in an encoded format, or in encrypted text.
- the listing may be an advertisement received from a server, a community listing received from a peer to peer network, a directory listing (e.g., a telephone book listing, a directory assistance listing, etc.).
- the listing can include other information received with the query from the telephonic apparatus, such as the identity of the telephonic apparatus or the identity of the user of the telephonic apparatus, the identity of an operator of the telephonic apparatus, a reference link that causes the telephonic apparatus to submit the query, etc.
- the listing can include information generated or identified after the query is received from the telephonic apparatus. For example, the listing may include discount or electronic coupon information, the identity of parties who contributed to the delivering of the listing to the telephonic apparatus, the bid price of an advertiser for the advertisement, date and time of a search performed to locate the listing, etc.
- the listing received at the telephonic apparatus may or may not include a telephonic reference of the callee of the listing.
- a telephonic reference is used to identify an "end point" on a telephonic network for a telephonic connection to the "end point".
- the telephonic network may be a circuit switched network, or a packet switched network, or a combination of one or more circuit switched networks and one or more packet switched networks.
- the telephonic reference may be a telephone number with an extension, a telephone number without an extension, a session initiation protocol (SIP) uniform resource identifier (URI), a user identifier of an instant messaging network, a user identifier of a Voice over Internet Protocol (VoIP) network, or a user identifier of a peer to peer VoIP network, etc.
- SIP session initiation protocol
- URI uniform resource identifier
- VoIP Voice over Internet Protocol
- the telephonic apparatus can establish a telephonic call to the callee of the listing in response to a user request; and the telephonic apparatus can cause the telephonic call to be associated with the information about the query and/or other parameters to be tracked. Telephonic apparatus may or may not initiate the call; and the telephonic apparatus may transmit the information about the query in various ways in the process of establishing the call, or report the association between the information about the query and the telephonic call without transmitting the information about the query via messages for call signaling. Various detailed embodiments are discussed bellow.
- the query information related to a search for a listing e.g., search terms of a user, and/or the parameters characterizing the circumstances that lead the user to the listing, such as the hierarchy of directories browsed by the user to reach the listing, a predefined query, a link to the listing, etc.
- the listing is presented to the user, the user may want to talk to the entity presented by the listing.
- the query information which was provided with the listing to the user terminal/telephonic apparatus, is received from the user terminal/telephonic apparatus to correlate the query information with the telephonic connection.
- the query information is correlated with the telephonic connection by the telephonic apparatus; and information identifying the correlation between the query information and the telephonic connection can be submitted from the telephonic apparatus (e.g., to the listing provider or other parties who are interested in the information) during or after the telephonic connection.
- the query information is provided from the user in an automated way via the telephonic apparatus to avoid burdening the user.
- the telephonic apparatus is configured to receive the query information together with the listing and transmit the query information to a connection provider during the process of initiating a telephonic connection between the user and the entity.
- Figure IB illustrates a system to track query information via a telephonic reference of a connection server that contains the query information according to one embodiment.
- a telephonic apparatus (11) is configured to have the capability to query for advertisements/listings over the data communication network (13) and then initiate calls to a connection provider (15) using telephonic references provided with the advertisements/listing; and the connection provider is configured to connect the calls to the respective callee (17) (e.g., advertisers) based on the telephonic references that are used by the telephonic apparatus to call the connection provider.
- a telephonic apparatus (11) is configured to have the capability to query for advertisements/listings over the data communication network (13) and then initiate calls to a connection provider (15) using telephonic references provided with the advertisements/listing; and the connection provider is configured to connect the calls to the respective callee (17) (e.g., advertisers) based on the telephonic references that are used by the telephonic apparatus to call the connection provider.
- a communication method is designed to track various parameters about the process from the query for advertisements/listings to the initiation of the calls to allow improved visibility of the process at the time the calls are received from the connection provider point of view.
- the communication method includes using a Session Initiation Protocol (SIP) Uniform Resource Identifiers (URI) that contains the encrypted information about the parameters to facilitate the tracking of the parameters.
- SIP Session Initiation Protocol
- URI Uniform Resource Identifiers
- the parameters to be tracked can be provided as an encoded or concatenated string of part of the SIP URI.
- the SIP URI is used to initiate the call to the connection provider, the parameters can be extracted or decoded from the SIP URI of the received call.
- some or all the parameters can be transmitted, in clear text, encoded text or encrypted text, in the header and/or body of one or more call signaling messages, such as INVITE, ACK, and/or OPTIONS messages according to a Session Initiation Protocol (SIP) or call signaling messages according other protocols. Other messages can also be used to identify the relation between the telephonic call and the parameters.
- the parameters to be tracked can be provided separately from the SIP URI of the connection, as illustrated in Figure 1C.
- Figure 1C illustrates a system to track query information via a call signaling message to a connection server that contains the query information according to one embodiment.
- the information about the query can be transmitted from the telephonic apparatus (11) to the connection server (15) in a field of the call signaling message (e.g., SIP INVITE, ACK, or OPTIONS) other than the address information (e.g., request URI) of the message.
- the information about the query can be provided in the header or body of the call signaling message (e.g., a call initiation message, a call termination message, etc.).
- the information about the callee can be embedded in the address information of the call signaling message; and the connection server (15) can identify the telephonic reference of the callee based on the address information of the call signaling message, through decoding or decrypting the address information to obtain the telephonic reference of the callee or through looking up the telephonic reference of the callee from a database using the address information of the call signaling message.
- the connection server (15) can use the telephonic reference of the callee to further connection the call to the callee (17).
- the telephonic apparatus can be configured to call the connection server at a pre-configured telephonic reference or send call signaling messages to a pre-configured telephonic reference, with parameters embedded in the header or body of a call signaling message to identify the callee and/or the telephonic reference of the callee and to identify the parameters related to the telephonic call.
- a fixed telephonic reference of the connection server can be specified in the listing.
- different telephonic references of the connection server can be provided for different listings to identify different aspects of the listings.
- the advertisement/listing and the parameters can be provided to the telephonic apparatus in an XML message, in which the parameters can be in clear text, in an encoded format, or as encrypted information; and the telephonic apparatus can submit the parameters with the call to the connection provider using a SIP INVITE message (e.g., in clear text, in the encoded format, or as the encrypted information) to initiate the call to the connection server.
- a SIP INVITE message e.g., in clear text, in the encoded format, or as the encrypted information
- the parameters can be embedded in a request URI, one or more headers and/or the body of a SIP message (e.g., INVITE, ACK, OPTIONS).
- SIP message may be sent directly from the telephonic apparatus, or via a gateway which constructs the SIP message after obtaining the parameters from the telephonic apparatus.
- the gateway can construct the SIP URI to include the parameters after receiving the telephonic reference and the parameters from the telephonic apparatus.
- the gateway can construct the SIP INVITE message to include the parameters in the message body without modifying the SIP URI.
- the telephonic apparatus may directly construct the SIP INVITE message from the telephonic reference and the parameters to be tracked.
- the telephonic apparatus may use the constructed SIP INVITE message to make a call to the connection server directly, or via a gateway.
- communication protocols other than SIP can be used to call the connection provider.
- the connection provider can be called via a traditional telephone; and the parameters can be provided as an encoded or encrypted extension.
- a proprietary communication protocol may be used to initiate the call; and the communication protocol may be bridged to the connection server and/or the callee in a different protocol via a gateway.
- an HTTP message may be used to initiate the call.
- the parameters to be tracked are partially or completed contained in the addressing information (e.g., request URI) that is used to make the call. In one embodiment, the parameters to be tracked are partially or completed contained in the body of the message that is used to initiate the call.
- addressing information e.g., request URI
- no centralized connection server is used to track the connection via being on the calling path from the telephonic apparatus and the callee, as illustrated in Figure ID.
- Figure ID illustrates a system to track query information via a report message from the telephonic apparatus that associates the call with the query information according to one embodiment.
- the listing the telephonic apparatus (11) received from the data communication network (13) includes the information about the query and the telephonic reference of the callee.
- the telephonic apparatus (11) associates the call to the callee (17) with the information about the query (and/or other parameters received with the listing) and reports the association information to the server (21).
- the server can use the reported information to charge the advertisers, to compensate various partners who contributed to the delivery of the telephonic lead to the callee, and/or to improve future searches, etc.
- the telephonic reference provided in the listing/apparatus can be a reference for connecting to the callee (e.g., via a peer to peer network, or via a connection server, or via a telecommunication carrier); and the telephonic apparatus can be configured to correlate the parameters to be tracked with the telephonic connect made via the telephonic apparatus.
- the telephonic apparatus can be configured to report the correlation to a listing provider during or after the telephonic connect.
- a centralized server or a peer to peer network, is used to resolve a telephonic reference into a format that is usable to call the callee, as illustrated in Figure IE.
- Figure IE illustrates a system to track query information via a request message to resolve a telephonic reference of the callee according to one embodiment.
- the listing received by the telephonic apparatus (11) from the data communication network (13) includes the information about the query and a reference which cannot be used directly by the telephonic apparatus to call the callee.
- the telephonic apparatus is configured to request the server to resolve the telephonic reference of the callee based on the reference received in the listing.
- the request message sent from the message includes the information about the query and the reference.
- the received reference can be an encrypted or encoded telephonic reference which is to be decrypted or decoded by the server (23).
- the received reference may be an index for looking up the telephonic reference from a database by the server (23). Since the telephonic apparatus is configured to send the request message in response to a user request to call the callee (17), the request message is a reliable indicator that a telephonic call to the callee (17) will occur; and the server (23) can associate the call with the information about the query.
- a callee identifier can be provided as the telephonic reference (or part of the telephonic reference) received in the listing; and the telephonic apparatus is configured to obtain a telephone number of the callee, or an identifier of the callee in a VoIP network, to initiate the call to the callee.
- the telephonic apparatus can be configured to query the centralized server, or the peer to peer network, to find out the identifier of the callee in the VoIP network (or an Internet address of the callee for a peer to peer connection) using the callee identifier (or the telephonic reference provided as in the listing).
- the parameters to tracked and the connection to be established can be correlated.
- the telephonic apparatus and the centralized server exchange one or more rounds of messages to resolve the telephonic reference and/or to establish the correlation between the telephonic connection and the parameters to be tracked.
- the telephonic apparatus can provide the parameters in the message, or as part of the address that is used to send the message.
- the telephonic apparatus sends a message to a connection server to request a call back from the connection server to connect the telephonic apparatus to the callee, as illustrated in Figure IF.
- Figure IF illustrates a system to track query information via a callback message that contains the query information according to one embodiment.
- the telephonic apparatus (11) sends a message (e.g., an HTTP message, an instant message, an email message, an SMS message, a SIP message, or a message according to a custom protocol, etc.) to the connection server (25) to request a callback.
- the parameters to be tracked can be provided in various fields of the message, such as the header, the subject line, the message body, etc.
- the parameters can also be provided in the address information of the messages.
- the request also identifies the telephonic reference of the telephonic apparatus.
- the connection server can call back the telephonic apparatus, call the callee and bridge the calls to connect the telephonic apparatus to the callee.
- the telephonic reference of the callee is received with the listing at the telephonic apparatus (in clear text, in an encoded format, or in encrypted text).
- the connection server (25) can used the telephonic reference to call the callee (17) (e.g., after extracting/decoding/decrypting the telephonic reference of the callee from the message received from telephonic apparatus).
- the telephonic reference of the callee is looked up from a database based on a reference to the callee provided in the listing.
- the communication method is designed to capture various information about the query, such as information about the customer who made the query, the time when the query was made, the query terms and/or the geographic locations for the query, the demand partner who helped in reaching the customer to generate the query, the domain/category on which the advertisement/listing is to be served, an identification of the advertisement/listing that is being returned as the result of the query, a supply partner who helped in introducing the advertiser into the network, the ordering position of the advertisement/listing in the sorted result set returned as a response to the query request, the keyword/category of the advertisement/listing that matches the query terms, the bid price of the advertiser for an advertisement fee at the time of the query, etc.
- Such information to be tracked for the call is provided with the advertisement as the response (e.g., in a XML format) to the query and received at the connection provider at the time the telephonic apparatus calls the connection provider to identify the details about the query that leads to the call.
- such information is contained or encrypted in the telephonic references provided in the advertisements to allow the connection provider to extract or decrypt the information at the time the connection provider receives the calls made via the telephonic references.
- the telephonic references are SIP URIs.
- the telephonic references can be other VoIP user identifiers, or telephone numbers with or without extensions.
- the telephonic references can be user IDs of a peer to peer VoIP network, user IDs of an instant messaging network, etc.
- Other references that can be used on a telephonic apparatus to initiate a telephonic call can also be used as the telephonic references, such as click-to-assign references, click-to-callback references, click-to-resolve references, click- to-dial references, etc. Further details are provided below.
- such information to be tracked for the call is transmitted by the telephonic apparatus over a data communication channel to request a call back to the telephonic apparatus.
- such information is transmitted by the telephonic apparatus over a data communication channel while the telephonic apparatus is calling or is connected to the connection provider (or after the call).
- a connection reference that is assigned to identify the connection can be used to identify the association between the information to be tracked and the telephonic connection.
- the telephonic apparatus may report the association during the initiation of the call, during the call, or after the call.
- At least part of the information can be stored in a database; and the index pointing to the stored information can be transmitted to the telephonic apparatus with the advertisement.
- the index can be an encrypted/encoded part of the telephonic reference, which can be used to locate the information in the database at the time the connection provider is called using the telephonic reference.
- the information to be tracked is transmitted in the messages for setting up the call; and one or more entities on the message transmission path of setting up the call can access the information during the set up phase of the call.
- the information transmitted in the message during the set up phase of the call is encrypted to prevent unauthorized access to the information.
- the telephonic reference and/or the gateway and/or the connection server can be configured to report the association between the tracked information and the telephonic connection to one or more entities during or after the call.
- Figure IG illustrates a system to connect a caller to a callee via advertisements according to one embodiment.
- a telephonic apparatus (103) that supports data communication is used to query for advertisements via a web service server (109) of a connection provider which has an advertisement database (111) and a connection server (113).
- the telephonic apparatus (103) may query the web service server (109) directly or via a listing server (105), which may have a separate listing database (107).
- the listing server (105) may selectively serve listings/advertisements obtained from the listing database (107) and/or the advertisement database (111).
- the advertisements retrieved from the web service server (109) contain telephonic references, which can be used by the telephonic apparatus (103) to call the connection server (113).
- the connection server (113) identifies the telephone contact information of the corresponding advertisers based on the telephonic references called by the telephonic apparatus and further connects the call to the advertisers (e.g., 119).
- the telephonic apparatus (103) is a softphone implemented at least in part via software, such as an instant messenger, a VoIP client application running on a computer, an applet embedded in a web page, a built-in or plug-in module of a web browser, a handheld device, a personal digital assistant (PDA), a cellular phone, a cordless phone, a Bluetooth phone, a WiFi phone, etc.
- the telephonic apparatus (103) may be designed to make a connection based on Internet Protocol, based on a peer to peer network, based on software, and/or based on a connection to a server or a host computer, etc.
- the telephonic apparatus (103) is implemented via hardwire circuitry, such Application-Specific Integrated Circuit (ASIC); in some embodiments, the telephonic apparatus (103) is implemented partially via special purpose hardwire circuitry and partially via software, such as Application- Specific Integrated Circuit (ASIC) or Field-Programmable Gate Array (FPGA) with software/firmware; and in some embodiments, the telephonic apparatus are implemented using a set of general purpose hardwire components that are under the control of software.
- ASIC Application-Specific Integrated Circuit
- FPGA Field-Programmable Gate Array
- the telephonic references in the advertisements that are retrieved directly or indirectly via the web service server (109) are SIP URIs which contain encrypted information, such as the telephone number of the advertiser, an identifier of the caller, information about the query, the geographic area of the service of the advertisement, and/or the position of the advertisement in the sorted list of the search result, etc.
- the connection server (113) decrypts the SIP URI that is used to call the connection server (113) to further connect the call to the advertiser.
- the information to be tracked can be provided in the advertisement separately from the SIP URI of the connection server (or other types of telephonic reference of the connection server).
- the information can be provided in an XML message/document.
- the telephonic apparatus (103) can construct a new SIP URI that includes the parameters to be tracked to call the connection server, or include the parameters in a field of the SIP message to initiate the call to the connection server, or provide the parameters to the connection server in a separate message during or after the initiation of the call.
- the telephonic apparatus (103) is configured to call the telephone number of the advertiser directly and report the association between the call to the telephone number of the advertiser and the parameters to be tracked to the listing server (105) and/or the web service server (109).
- the telephonic apparatus (103) is configured to send a message, including the parameters to be tracked, to the web service server ( 109) to request the connection server to call back to the telephonic apparatus (103) and to further connect the call to the advertiser (119).
- the telephonic apparatus (103) is configured to send a message to the web service server (109) to decrypt the telephone number of the advertiser (101) and then call the telephone number of the advertiser (101) directly without going though the connection server (113).
- the message sent to request the web service server (109) to decrypt the telephone number of the advertiser (101) includes the parameters to be tracked; and decrypting of the telephone number of the advertiser (101) for the telephonic apparatus (103) can be considered as an initiation of a call to the advertiser (119).
- the telephonic apparatus (103) receives the information to be tracked but not the telephone number of the advertiser (101).
- a reference is provided to represent the telephone number of the advertiser (101).
- the telephonic apparatus (103) is configured to send a message to the web service server (109) to obtain the telephone number of the advertiser (101) via the provided reference and then call the telephone number of the advertiser (101) directly without calling though the connection server (113).
- the query of the telephonic apparatus (103) is submitted to the web service server (109) with an identifier of the caller, such as a telephone number of the caller, a user identifier of a telephonic apparatus, an internet address of the telephonic apparatus, a softphone user ID, a number unique to the softphone user ID among different softphone user IDs, etc.
- the identifier of the caller is encrypted in the SIP URI.
- connection provider may prevent other telephonic apparatuses that did not perform the query from calling the advertiser (119) using the result of the query.
- the connection provider can also use the identifier information of the caller to determine whether a query is generated by a machine in an automated fashion and to determine whether the query and/or the calls from the caller should be blocked. For example, after an advertiser complains about a call from a caller, the connection server can block the queries and/or calls from the caller (e.g., for a period of time).
- the telephonic apparatus is capable of making a VoIP call but using a different protocol different from SIP; and a gateway (115) is used to interface the telephonic apparatus and the connection server (113).
- the telephonic apparatus is capable of making a SIP call using the SIP URI to reach the connection server (113) without the gateway (115).
- the telephonic apparatus makes a call over a Public Switch Telephone Network (PSTN); and a telecommunication carrier bridges the call from the PSTN to the connection provider on a data network.
- PSTN Public Switch Telephone Network
- the advertiser (119) uses a telephone that is connected on the Public Switch Telephone Network (PSTN); and the connection server (113) uses the gateway (117) to reach advertiser (119).
- the gateway (117) is operated by a telecommunication carrier of the connection provider.
- the connection server (113) uses the gateways (115 and 117) to set up the call and direct the gateways (115 and 117) to make a direct media connection that does not go through the connection server (113) to provide the telephonic connection between the caller (101) and the advertiser (119).
- the advertiser (119) uses a telephone that is connected on a data network; and the gateway (117) is used to bridge the protocol used by the telephone of the advertiser (119) and the protocol used by the connection server (113).
- the telephone of the advertiser (119) and the connection server (113) may use the same protocol; and the connection server (113) can call the telephone of the advertiser (119) directly (e.g., via SIP) without a gateway (117).
- the connection provider charges the caller on behalf of the advertiser for services provided by the advertiser over the telephonic connection established via the advertisement.
- the connection provider charges the advertiser an advertisement fee per connection made via the advertisement.
- the advertiser may place a bid price for the advertisement fee; and the bid price can be used in ranking the advertisements in the set of search results that match with the query.
- the bid price can be in the form of a maximum bid; and the actual bid is determined based on the bid price that is ranked next to the advertisement in the ranked search results.
- the telephonic apparatus (103) obtains listings directly or indirectly via a web service server (109) of the connection provider.
- the telephonic apparatus may also obtain listings from other sources (e.g., listing database 107) and selectively present the listings in response to a search request from the caller.
- the listings from the database (107) are provided without an advertisement fee; and the advertisement fee generated from the advertisements from the advertisement database (111) are shared between the operator of the listing server (105) and the connection provider.
- the listing server (105) is used as a channel of a demand partner of the connection provider for distributing advertisements to the callers.
- the connection provider encrypts information related to the search, the advertiser's telephonic contact information, the caller's identification information, the ID of the listing server (105), etc. in the SIP URI which can be called by the telephonic apparatus (103) to reach the connection server (103).
- telephonic references can be used, such as telephone numbers with extensions, VoIP user identifiers, etc.
- the information can be encrypted/encoded in the telephonic references provided in the advertisements.
- the telephonic references can be used in a database to look up the associated information such as the advertiser's telephonic contact information, the keywords used in the search, caller's identification information, the ID of the listing server (105), promotions/electronic coupons provided with the advertisement, etc.
- the SIP URI provided in the advertisement via the web service server (109) can be used to call the connection server (113) for a telephonic connection to the advertiser (119).
- the SIP URI contains information in an encrypted string (e.g., sip: ⁇ Encrypted String>@sip.
- ingenio.com such as information about the advertiser, information about the user who performed the query, information about the demand partner who distributes the hardware and/or the software of the telephonic apparatus and/or who distributes the advertisements to the telephonic apparatus (103), and information about the query, such as a search term used in the query, the timestamp of the search, the order number of the advertisement in the result set, an identification of the advertisement, promotions/electronic coupons provided with the advertisement, etc.
- the telephonic apparatus (103) is connected to the connection server (113) at the SIP "end point,” before being further connected by the connection server (113) to the advertiser (119).
- the telephonic apparatus (103) is configured to have the capability to store or bookmark the SIP URI provided in the advertisement.
- the SIP URI can be stored in association with the advertisement or advertiser in a contact book maintained on the telephonic apparatus.
- a gateway (115) is used to bridge the call from the telephonic apparatus (103) that is in one VoIP domain (e.g., based on a proprietary protocol for VoIP) and the connection server (113) that is in another VoIP domain (e.g., based on an open standard VoIP protocol).
- the SIP URI is provided as a communication reference which can be used directly by the telephonic apparatus (103) to call the gateway (115) which further connects the call to the connection server (113).
- the telephonic apparatus can be configured to treat the SIP URI as a VoIP user ID associated with the gateway.
- a portion of the SIP URI e.g., the encrypted string
- the listing server (105) is used to provide advertisements/listings to the telephonic apparatus (103).
- the listing server (105) is configured to obtain advertisements/listings from the web service server (109) of the connection provider and/or other sources.
- the listing server can be further configured to dynamically assign VoIP user IDs to the SIP URIs such that when the assigned VoIP user IDs are called by the telephonic apparatus (103), the call is routed to the gateway (115) for further connection to the connection server (113) of the connection provider via the SIP URI.
- the listing server may dynamically generate the VoIP user IDs based on the SIP URIs such that the SIP URIs can be computed based on the dynamically assigned VoIP user IDs.
- the dynamically assigned VoIP user IDs may be associated with the SIP URIs via a database.
- the web service server (109) provides the advertisement with a traditional telephone number instead of the SIP URI.
- the traditional telephone number may or may not include an extension.
- the telephonic apparatus (103) uses the gateway (115) to access PSTN and reach the connection server (113) via a telecommunication carrier which bridges the call from the PSTN to the connection server (113).
- the telecommunication carrier may provide the call to the connection server (113) via a SIP call.
- the extension is to be dialed by the telephonic apparatus after the telephonic connection between the telephonic apparatus (103) and the connection server (113) is established.
- the extension is to be dialed by the gateway (115).
- the gateway (115) places a SIP call to the connection server (113), bypassing the telecommunication carrier of the connection provider; and the extension is used to construct the SIP URI of the call (or be included in the SIP INVITE message sent from the gateway (115).
- the gateway (115) used to bridge the call to the PSTN may prevent the connection server (113) from identifying the caller via ANI (Automatic Number Identification (ANI) service.
- the gateway (115) can be further configured to provide the information about the caller to the connection provider via call ID information or via extension.
- the gateway (115) may bypass the telecommunication carrier and connect the call to the connection provider via a SIP call and provide the information about the caller in the FROM header of the SIP INVITE message.
- a gateway when a gateway (115) is used to bridge one protocol used by the telephonic apparatus (e.g., a proprietary protocol) and another protocol used by the connection server (e.g., SIP), the telephone network is configured to selectively route the call to the gateway to reduce latency or balance load.
- the telephonic apparatus (103) can use other gateways (not shown in Figure IG) to reach other callees.
- the telephonic apparatus (103) is configured to identify the geographic area of the telephonic apparatus to the connection provider; and the connection provider can return advertisements/listings based on the geographic area of the telephonic apparatus and/or selectively block the calls from customers who are outside the service area of the advertisers.
- the listing server (105) and the listing database (107) can be implemented via a peer to peer network.
- the listing server (105) is not used.
- the web service server (109) is not used.
- the advertisement database (111) may include free listings.
- the listing database (107) may include advertisements for which the advertisers are charged based on the telephonic connections provided via the advertisements.
- the methods to track the correlation between the query information and the resulting telephonic connections to callees of the listings of the listing database (107) can also be used in similar ways described above for tracking the correlation between the query information and the resulting telephonic connections to the advertiser (119).
- encrypted tracking information can be provided to the telephonic apparatus (103) for listings retrieved from the listing database (107); and the correlation information determined at the connection server (113) can be transmitted to the listing server (106) for decrypting/decoding.
- the telephonic apparatus (103) can be configured to report the correlation to the listing server (105).
- the gateway (115) is configured to report the correlation to the listing server (105).
- Figure 2 illustrates a VoIP application for accessing an advertiser according to one embodiment.
- the interface as illustrated in Figure 2 may be presented as a standalone application or as an applet running inside a web browser.
- a telephonic apparatus that has data communication and processing capabilities and the capability to dial a call via a connection to PSTN or a cellular communication network can also be designed to have the user interface similar to that illustrated in Figure 2.
- a user may select a "Search" tab to search for listings.
- the search result may include advertisements retrieved from the web service server (109) and/or the listings retrieved from database (107).
- the listing server (105) performs the integration of the listings obtained from the listing database (107) and the listings obtained from the advertisement database (111) for presentation on the telephonic apparatus (103).
- the listings maintained in the listing database (107) are created and edited by the community of users of telephonic apparatuses similar to the telephonic apparatus (103).
- the users can provide, edit, and/or modify a description, comments, ratings, etc., about a business or service provider that is identified by a telephonic reference, such as a telephone number of the business or service provider.
- the listings may have a portion of description that can be edited by the respective advertiser but not by other users.
- the listings maintained in the advertisement database (111) is created by the advertisers.
- the connection provider can also maintain information about customer feedbacks and ratings for the services and/or products offered by the advertisers.
- the listing server (107) may also collect users' description, comments and ratings for the services and/or products offered by the advertisers of the advertisements of the database (111).
- the listing server (105) further maintains data that represents a social network among members of the community of users of the telephonic apparatuses; and the listing server (105) may selectively present the listings based on a trustworthy indicator determined based on the social network and/or present the comments, recommendations, feedbacks, ratings, etc., based on the social distance between the caller (101) and the users who made the comments, recommendations, feedbacks, ratings.
- a user can select the "Contacts" tab in Figure 2 to manage contact information.
- the user can use the contact management interface to store/edit a set of telephonic references which can be used to call friends and family using the telephonic apparatus without going through the connection server (113).
- the user may also select the "Contacts" tab to specify friends of the user as the direct social connections in the social network and/or a trustworthiness indicator
- a trustworthiness indicator can be computed for users who are indirectly connected in the social network (e.g., the largest product of the trustworthiness indicators along any social connection path between the two users).
- the trustworthiness indicator can be used to select advertisements, comments, recommendations, ratings from the point of view of the user of the telephonic apparatus.
- the contact information is maintained for the user of the VoIP terminal (e.g., telephonic apparatus 103).
- a contact information entry can include a phone number or a user ID for the VoIP application or a SIP URI.
- the VoIP application on the computing/communication device (e.g., a personal computer, a palm top computer, a notebook computer, a personal digital assistant (PDA), or a special purpose device, such as a VoIP compatible phone, etc.)
- the user can make a telephonic connection to a remote user.
- the remote user may use a landline phone, a mobile phone, or a VoIP application (e.g., a personal computer, a palm top computer, a notebook computer, a personal digital assistant (PDA), or a special purpose device).
- the user may select a "Dial" tab in Figure 2 to directly enter the information (e.g., the ID of the remote user for the VoIP application, or the phone number of the remote user) for "dialing" the VoIP call and select the "Call List” tab to view a history of calls placed or received via the telephonic apparatus.
- the information e.g., the ID of the remote user for the VoIP application, or the phone number of the remote user
- the user can select the "My Profile” in Figure 2 to indicate the geographic location and/or other preferences of the user and select the "My Listings" to create an advertisement or listing of the user.
- the user can select the "Review" tab in Figure 2 to edit the description of a listing from the listing database (107), to provide recommendations, comments, ratings, etc. for listings from the listing database (107) or from the advertisement database (111).
- the user can also select the "Review" tab (or link 139) to provide comments, recommendations, feedbacks, ratings on an advertisement obtained from the advertisement database (111).
- the graphical user interface includes a "Search” tab which can be selected to perform a search of people, advisor, business or predefined categories of services, such as taxi, pizza, florist, electrician, plumber, etc.
- the user can input key words (e.g., "Mortgage brokers") in the entry box (121) under the label "search for” to perform a search for a specific category.
- the user can input the information about the specific geographic area (e.g., "Dallas, TX"). For example, a keyword to category algorithm queried with service area returns relevant advertisers, such as "Mortgage
- some of the advertisements/listings in the search result are retrieved from the advertisement database (111) (e.g., top one or three or five of the search results are from the advertisement database (111)) and some are from the listing database (107).
- separate areas are used to show the listings retrieved from the advertisement database (111) and the listings retrieved from the listing database (107).
- the advertisers are served based on the amount of bids the advertisers placed on the advertisements. For example, the highest bidders matching the search criteria are displayed above and/or before other bidders matching the search criteria are displayed.
- one or more advertisements retrieved from the advertisement database (111) are presented above a set of matching listings retrieved from the listing database
- the expanded entry includes a phone icon (129) which can be selected to initiate a
- VoIP telephonic connection with the advertiser using the VoIP application.
- the user may also use the main phone icon (137) to initiate the call to the phone number associated with the selected, expanded entry.
- the VoIP telephonic connection may be made to a regular landline phone, or a mobile phone, or VoIP terminal.
- the VoIP telephonic connection may be made through a VoIP application to a phone over a landline, over a cellular communication line to a cellular phone, or over a data communication link (e.g., Internet) to another VoIP application.
- the phone icon (129) includes a SIP URI assigned to the advertisement, which when selected causes the VoIP terminal to call the connection provider using the SIP URI directly, or indirectly via a gateway (e.g., 115).
- the advertisement (131) also includes a telephone number assigned by the connection provider to the advertisement (131).
- the telephone number may include an extension, which is to be dialed by the VoIP terminal after being connected to the connection provider.
- a gateway (115) may provide the extension number in the SIP INVITE message without actually dialing the extension.
- the telephone number is included in an icon (e.g., 129) without being displayed to the user.
- the telephone number is to be used by the VoIP application to construct a SIP URI for a direct SIP call to the connection server (113) (or a SIP gateway 115).
- the VoIP application displays the call duration and other information about the advertiser, such as the logo of the advertiser, the pricing information of the advertiser, etc.
- the advertiser charges the user of the VoIP application with a per minute price, which is displayed during the phone call.
- the advertiser pays the operator of the VoIP application and/or the advertisement provider (distributor) based on a pay per call price bid.
- the user interface displays the balance of an account which can be used to pay for the charges related to the call.
- the user/consumer calls the advertiser using the VoIP application.
- the phone call is connected to a phone connection server (e.g., of an advertisement provider, which may be the same as, or different from, the service provider of the VoIP application).
- the phone connection server further connects the phone call to the advertiser.
- a separate phone call is placed to the advertiser; and the phone call from the consumer is connected with the phone call with the advertiser.
- the consumer's request to call the advertiser is transmitted to a phone connection server, which makes separate calls to the consumer and the advertiser and joins the separate calls to connect the consumer and the advertiser.
- the VoIP application system determines the communication parameters for the devices of the caller and the callee. Using the communication parameters, the VoIP application on the caller's device and the VoIP application on the callee's device can directly make a communication connection for the VoIP call.
- at least one of the VoIP applications is programmed to report the duration of the call to a server which records the call duration.
- the online presence information/availability status of the VoIP applications on the network is relayed on a distributed, decentralized network to avoid the use of a central server. Alternatively, a centralized server may be used to facilitate the connections.
- the phone connection server prevents the consumer and the advertiser from gaining information about the other party from the phone connection.
- the advertiser is not provided with the telephonic information about the consumer (e.g., the VoIP user ID of the consumer, a phone number of the consumer) in making the phone connection; and the consumer is not provided with the telephonic information about the advertiser (e.g., the VoIP user ID of the advertiser, a phone number of the advertiser).
- anonymity of the call is maintained (if the advertiser and the consumer do not reveal their telephonic information during the conversation).
- the advertisement provider/distributor charges the advertiser based on the advertiser's current bid for the phone lead in the category and service area that matches the search submitted by the user of the VoIP application.
- a caller algorithm of the advertisement provider prevents multiple charges. For example, if calls to the advertisement provider from the user of the VoIP application is within a certain time window, such as an hour, a day or a week, these calls may be considered as providing the same phone lead to the advertiser; and the advertiser is charged for only one phone lead.
- a fraud detection system is deployed for the advertisement provider to detect the abuse of the system.
- the system may detect and stop the use of pay per call advertisement bids as a way to obtain long distance phone calls to a landline phone or a mobile phone.
- the telephonic information about the advertiser is provided to the VoIP application indirectly.
- the advertisement provider embeds in the advertisement a phone number, or a reference to the phone number (e.g., a user ID of the VoIP application system) that can be used to reach the phone connection center of the advertisement provider.
- the VoIP application connects to the call connection server, which looks up the contact information of the advertiser and further connects the call to the advertiser.
- the call connection server may obtain the phone number of a landline phone or a mobile phone, make a call to the phone number of the advertiser (e.g., partially through a VoIP connection, or through a traditional telephonic connection), and join the call to the advertiser and the call from the user to make the connection.
- the call connection server may obtain a VoIP user ID of the advertiser, make a VoIP connection to the advertiser, and join the VoIP connections to connect the advertiser and the user.
- the advertisement provider assigns different phone numbers, or VoIP user IDs, to different advertisements and/or different advertisers for the connection center so that the connection center can look up the telephonic contact information for the corresponding advertisements and/or advertisers.
- the differences in the phone numbers for different advertisements and/or different advertisers may be in the main phone number (dialed before a connection to the connection center is made), or in the extension of the phone number (dialed after a connection to the connection center is made).
- the connection server of the advertisement provider is integrated with the server of VoIP application.
- the advertisement contains an ID similar to, or corresponding to, a VoIP user ID.
- the server of the VoIP application receives the ID of the advertisement in response to the user's request to telephonically connect to the advertiser (e.g., when a button or a link is selected by the user, the request for a connection is generated; and the ID of the advertisement embedded in the advertisement is automatically transmitted to the server by the VoIP application)
- the server of the VoIP application looks up the contact information (e.g., the phone number, or the VoIP user ID of the advertiser, etc.) from the advertisement database to connect the phone call to the advertiser in a way similar to that the connection center connects the caller and the advertiser.
- the VoIP user ID of the user (or the equivalent information for making a VoIP connection to the user) is transmitted to the connection center together with a reference to the advertiser and/or the advertisement.
- the connection center then starts the VoIP connection to the VoIP application of the user and a separate connection to the advertiser.
- the connections are joined to connect the user and the advertiser.
- the separate connection to the advertiser may be via VoIP, or via regular circuit switched call, or via VoIP for part of the transmission path and via a circuit switched network for the remaining part of the transmission path.
- the expanded entry further includes an information icon (e.g., 127 in Figure 2), which can be selected to provide a profile page about the advertiser.
- the profile page may include the business hours of the advertiser, a description of the advertiser, payment methods accepted by the advertiser for purchasing products/services, categories under which the advertiser is listed, a map showing the location near the advertiser, and/or a link to view map details about the location near the advertiser, etc.
- the advertiser can specify the schedule to receive calls from customers.
- the advertisement includes an indication whether the advertiser is currently scheduled to receive calls at the time the advertisement is presented. For example, different icons can be presented to indicate the availability. For example, the text "Call Now" or "Schedule a Call” can be used to indicate the availability according to the schedule.
- Figure 3A illustrates a VoIP application for accessing an advisor according to one embodiment.
- a user of the VoIP may also search advisors using the VoIP application.
- the user may enter one or more key words (e.g., "Excel") in the search box under the heading "search for" to indicate the requirement for the desired advisors.
- the advisors set their own rates for providing services, such as advice, entertainment, celebrity conversations or other types of paid access, over the telephone link.
- the search result of the advisors may include entries of advisors.
- an advisor entry shows a photo image (141) of the advisor, a description (143) of the expertise of the advisor, the rating (145) based on the experience of prior activity of the advisor, the price (147), etc.
- the expanded entry further includes an information icon (149), which can be selected to provide a profile page about the advisor.
- the profile page may include the expertise of the advisor, the rate, a detailed description, and previous consumer feedback information, such as rating, comments, recommendations, etc.
- the VoIP application displays the rate for the advisor (e.g., $15.00 for 15 min), the duration of the call, the remaining minutes (when applicable), etc. In one embodiment, the VoIP application also displays the balance amount available in an account which is designated for paying for the call.
- the entry of the advisor can be added to the contact collection of the user of the VoIP application in a way similar to those described for an advertiser entry (e.g., automatically add the advisor into the contact list after the advisor is called).
- Figure 3A shows an example of a user interface in which a telephone number (142) with an extension is displayed for the advisor.
- the user can call the advisor via selecting the "call now" link (146) or the telephone icon (144) of the listing, or selecting the call button (148) while the listing is being selected/highlighted.
- the user may use a different telephonic apparatus (e.g., a cellular phone, a landline phone, a plain old telephone set) to dial the telephone number (142) to reach the advisor.
- a different telephonic apparatus e.g., a cellular phone, a landline phone, a plain old telephone set
- Figure 3B shows an example of a user interface in which the telephonic reference of the advertiser is not explicitly displayed. The user is encouraged to call the advisor via selecting the "call now" link (146) or the telephone icon (144) of the listing, or selecting the call button (148) while the listing is being selected/highlighted.
- Figure 4 illustrates a user interface of a VoIP application for managing advertisements according to one embodiment.
- the user of the VoIP application can also be an advisor in the advisor providing system.
- the user can be presented as an advisor.
- the user can enter the information about the user as an advisor for the network.
- the advisor information is collected to present in listings and on profile page.
- the advisor information includes title (e.g., a name) (153), description (155), rate (e.g., prices) (157), photo (159), categories (151) of the advice service.
- the listing created via the interface as illustrated in Figure 4 is maintained by the listing server (105).
- the created listing can be submitted to the advertisement database (111) via the web service server (109).
- the user is charged an advertisement fee when a customer is connected to the user via the listing.
- the user is charged a percentage of the service fees the user charges the customer as a commission fee for connecting the customer and the user.
- the VoIP application uses the application program interface (API) of the advisor listing provider (e.g., Ingenio) to create listings within the VoIP application.
- an extensive reporting suite provides the VoIP application and the advertiser the tools to see how their listings are performing and make adjustments to maximize their Return on Investment (ROI).
- ROI Return on Investment
- Figure 5 illustrates a user interface for the creation of an advertisement according to one embodiment.
- the user interface may be presented via web in a web browser or in the VoIP terminal.
- the telephonic apparatus (103) is configured to communicate with the web service server (109) to generate and/or edit the advertisement in the database (111) using the interface (161).
- the telephonic apparatus (103) may communicate with the web service server (109) via the listing server (105).
- an interface (161) allows the advertiser to describe an offer (or a switch pitch, or a cross sell, or some advertising content).
- the advertiser can specify the business contact information for the advertisement, including the business name, street/mailing address, phone number and fax number.
- the advertiser/seller is encouraged to tell customers via concise marketing messages what is being offered and why the customers should call the advertiser/seller. For example, the advertiser is encouraged to include promotional offers in the marketing messages to get buyers to call the advertiser.
- an audio and/or visual advertisement is generated based at least in part on the information submitted by the advertiser via the user interface (161) (e.g., for presentation via virtual realty, directory assistance service, search result, etc.)
- a short audio advertisement is generated based on the concise marketing message (e.g., two sentences, each having a length limit, such as 35 characters). The concise marketing message can be read by a human to generated a recorded audio file for a short audio advertisement, or be converted into an audio message via a text-to-speech synthesizer.
- the audio advertisement also includes the business name.
- a visual presentation of the advertisement may be used to supplement the audio advertisement.
- the address of the advertisement can be presented in a visual advertisement, together with additional information that is specified in the business profile page of the advertisement.
- the visual component of the advertisement can be sent to the customer via an SMS message, via an email, via a custom application, via a web/WAP page, etc.
- the advertisement is sent to a user device in text according to a pre-determined format (e.g., in XML or a custom designed format) to allow a client application running on the user device to present the advertisement in a custom format.
- the client application may present the short marketing advertisement in an audio form via a text-to- speech synthesize and the present a selected portion of the advertisement as an animation (e.g., present an electronic coupon via an animation).
- an animation e.g., present an electronic coupon via an animation
- a Java applet can be downloaded into the browser of the user to facilitate Vo IP -based phone communication and perform at least part of the text-to-speech operations to enable improved compression in transmitting audio advertisements.
- the short audio advertisement when an advertisement is presented to the user via a web or a virtual reality environment, the short audio advertisement can also be included; and the audio advertisement can be played automatically or after the user selects the advertisement.
- the interface (161) may be implemented as a web page.
- an advertisement may submit the advertising content via a custom client application, or via a message gateway (e.g., an instant message, an email, an SMS message, etc.).
- a message gateway e.g., an instant message, an email, an SMS message, etc.
- one or more advertisements can be uploaded into a server via a spreadsheet, or via a web service interface.
- the system converts the text input received from the advertiser into an audio advertisement.
- the audio file for the advertisement is stored in the advertisement database; alternatively, the text input can be converted into the audio advertisement (e.g., via a text-to-speech synthesizer, or a human announcer) when the audio advertisement is needed.
- the machine synthesized audio recording can be stored in the database for a period of time and deleted if not used after a predetermined period of time, or when the usage of the audio advertisement is lower than a threshold.
- Figure 6 shows a method to establish connections for real time communications according to one embodiment.
- user A (171) provides a contact for real time communication, such as a telephonic reference of the user A.
- the contact can be used to establish a connection with user A (171) through a communication network.
- the contact can be a telephone number of a landline, traditional analog telephone, a cellular phone number, a phone number with an extension, a Universal Resource Identifier (URI) such as a URI.
- URI Universal Resource Identifier
- Session Initiation Protocol SIP
- URI Session Initiation Protocol
- VoIP Voice over IP
- a user identifier of a VoIP application a user identifier of an instant messaging system, etc.
- the contact of the user A (171) is stored in the database (175); and a reference is assigned to represent the contact. Instead of providing the contact to customers, the reference representing the contact is provided through the media (177) to user B (179). Thus, when the user B (179) uses the reference to request a connection with the user A (171), the connections resulted from the advertisement can be tracked to evaluate the performance.
- advertisements can be distributed via a number of media channels operated by a number of demand partners.
- the reference can also be assigned to identify the demand partners and/or the media channels used to distribute the advertisements.
- the information obtained from tracking the demand partners who are responsible for the delivery of a communication lead is used to compensate the demand partner for each delivered communication lead.
- the demand partners may be compensated according to the advertisement presentations made for the advertiser; and tracked information can be used to determine the performance and/or the cost effectiveness of the media channels.
- the reference can be presented via a variety of media channels, such as a virtual reality environment, newspaper, magazine, telephone directory, web search results, VoIP user terminals, interactive maps, banners, directory assistance service, online marketplace, mobile communication devices, radio, cable/satellite television, interactive television, web television, voice portal, web portal, online auction site, blog, email, bulletin board, refrigerate magnet, brochure, etc.
- the user B (179) can use the reference obtained from media (177) to request the connection provider (173) to establish a connection or facilitate a communication channel for real time communications between the user A (171) and the user B (179).
- the connection provider uses the database (175) to determine the contact of the user A (171) and then make a connection between the user A (171) and user B (179) using the contact of the user A (171).
- the reference may include an encoded/encrypted version of the contact of the user A (171) which can be decoded/decrypted without relying upon the database (175).
- the connection provider (173) may establish two separate connections to the user A (171) and the user B (179) and then bridge the two connections to connect the user A (171) and user B (179). For example, the connection provider (173) may determine the reference from a connection established between the user B (179) and connection provider (173) and then further bridge the connection to the user A (171). [00164] In one embodiment, the connection provider (173) may provide a separate reference to represent the user B (179) and allow the user A (171) to subsequently callback to the user B (179) via the reference that represents the user B (179), if the user A (171) is not currently available for real time communications. The connection provider (173) may schedule an appointment for the user A (171) and user B (179) for a real time communication session. The connection provider (173) may send a notification to the user A (171) to inform the user A (171) about the request for a real time communication.
- connection provider (173) tracks the connections made via the reference for billing for the advertisement. For example, the connection provider (173) may charge the advertiser for each communication lead deliver to the user A (171).
- a communication lead may be limited to a distinct, separate customer such that repeated calls from the same customer within a predefined time period may not be counted as separate communication leads.
- the communication lead may also be limited by the duration of a communication session, such that a short session having a duration shorter than a predefined time period may not be counted as a communication lead, and/or a long session having a duration longer than a predefined time period may be counted as more than one communication lead.
- a number of communication leads may be bundled as a package for a subscription fee, or a bid price. Further, the delivery of communication leads may be bundled with an offer of a telecommunication service package. Alternatively, the advertiser may specify a bid price that is to be charged for each communication lead delivered, or a bid limit (e.g., maximum bid) which is to be resolved into an actual bid based on the bid prices of competitors in a category for a specific geographic service area.
- a bid limit e.g., maximum bid
- Figure 7 illustrates an example of a user interface to manage availability for receiving phone calls according to one embodiment.
- An advertiser may specify the day and time of availability for accepting the calls for real time communications. Based on the availability, the system may schedule the presentation of the advertisements/communication references more effectively and block unwanted calls.
- the system can store multiple phone numbers of the seller.
- the system can intelligent route a call to the seller according to the preference of the seller. For example, in Figure 7, the advertiser/seller may choose a preferred phone number from a set of phone numbers of the seller to receive incoming calls using the option group (191) in the user interface (181). The seller may indicate whether the seller is currently available to take calls or is to be taken "off call" (e.g., using the check box (189)).
- the system allows the seller to specify the schedule to receive calls; and the schedule (183) is displayed to the seller in a graphical way to help the seller to manage calls.
- the user interface (181) includes a link (193) which can be selected to display a user interface (not shown in Figure 7) to manage the schedule (183).
- the system can decrease the priority of the advertisement for this advertiser, or stop temporarily the presentation of advertisements for this advertiser.
- the system can block the call, or direct the call into a voice mail for the advertiser, or arrange a call at an alternative time, or obtain a callback number to allow the advertiser to initiate a callback to the customer.
- the user interface (181) also includes a summary of call activities. Buttons (187 and 185) can be selected to show graphical representation of the call activities and further details of the call activities.
- a wide array of information can be collected and tracked, including day/date/time of calls, duration of calls, call status (answered, no answer, busy), inbound phone numbers, etc.
- Such tracked information can be used in counting communication leads generated from advertisements. For example, when multiple calls are made from the same user to the same seller within a period of time (e.g., a day or a week), or in connection with the same offered or auctioned item, these multiple calls can be considered as one qualified call or a single lead.
- a communication reference used to represent the contact of an advertiser may be a traditional phone number with or without an extension, a click-to-call reference, a SIP address for VoIP call, a click-to-reveal reference, etc.
- the communication reference can be embedded into an advertisement to count the communication leads generated from advertisements, to track the contributions of demand partners who operate media channels to present the advertisements to customers, and/or to track other aspects of advertising, such as partners who bring the advertisers/sellers to the system and the keywords responsible for the selection of the advertisement for presentation.
- the tracking mechanism used for a particular version of a particular advertisement is selected from a number of available mechanisms, based on one or more considerations such as the volume or frequency of calls generated from the advertisement, the conversion rate of the advertisement (e.g., the ratio between a count of presentations of the advertisement and a count of communication leads generated from the presentations), the price per communication lead that the advertiser is willing to pay for the advertisement according to a price bid specified by the advertiser, a potential revenue for a particular party in the advertising activity, a classification or category of the advertisement (e.g., the category of service or product advertised in the advertisement), a geographical area served by the advertisement, the demand partner who is going to present the advertisement (e.g., the success rate of the demand partner in reaching viable customers in comparison with other demand partners), etc.
- the conversion rate of the advertisement e.g., the ratio between a count of presentations of the advertisement and a count of communication leads generated from the presentations
- Figure 8 shows a diagram illustrating a method to select a type of tracking mechanism with a corresponding reference for embedding in an advertisement according to one embodiment.
- multiple types of tracking mechanisms are used in the system.
- the tracking mechanism used for an advertisement or a version of the advertisement can be dynamically selected and changed. For example, different versions of an advertisement can be generated for delivery by different demand partners.
- a pool (319) of different types of references are maintained, such as local phone numbers (301), 800-numbers (303), 888-numbers (305), 877-numbers (307), 866-numbers (309).
- Some of the references can be dynamically generated and used, such as extensions (311), SIP addresses (313), click-to-assign references (315) and click-to-callback references (317).
- one or more of the references are selected and used as the assigned reference (323) that is embedded in the advertisement (321).
- the assignment is based at least partially on factors related to the advertisement, such as call volume, conversion rate, revenue potential, category, geography, demand partner, etc.
- the reference of a particular type is selected and assigned to the advertisement when the advertisement is being requested for delivery.
- the previously assigned reference can be used.
- a different reference of a re-selected type can be selected and assigned to the advertisement, based on the considerations such as the call volume in a past time period, conversion rate, price bid, etc.
- the previous reference can be assigned to a different advertisement.
- a new reference can be assigned to the advertisement for delivery by the same demand partner.
- references can be associated with a same set of parameters in a time period. Further, since some of the references can be re-assigned to a different advertisement, one reference may be associated with multiple sets of parameters (e.g., for different advertisements). In one embodiment, when a reference is associated multiple sets of parameters, the parameter set that is most recently assigned to and associated with an advertisement has the highest priority; and when the reference is used to request a communication connection with an advertiser, the customer can be prompted to confirm the set of parameters (directly or indirectly) before the set of parameters are used to connect the customer to the advertiser.
- a communication reference that is specific to a selected tracking mechanism is allocated or selected or generated for a particular advertisement.
- the communication reference is embedded into the advertisement to generate a particular version of the advertisement.
- the tracking mechanism is selected at a time when the particular version of the advertisement is needed for presentation (e.g., when the version of the advertisement is to be delivered to a media channel, a demand partner, or to a web browser of a customer).
- the corresponding communication reference is allocated or selected or generated when the tracking mechanism is selected.
- the selected tracking mechanism can be dynamically changed at a time when the particular version of the advertisement is needed for presentation (e.g., when the version of the advertisement is to be delivered to a demand partner, or to a web browser of a customer).
- the tracking mechanism used in an advertisement that is to be presented via a particular demand partner can be upgraded or downgraded based on the statistical data collected from the past activities related to the advertisement.
- a version of an advertisement can have multiple assigned references corresponding to different types of tracking mechanisms.
- a version of an advertisement may include a SIP address, a reference to arrange a callback and a reference to request an assigned phone number.
- the SIP address may be presented in a click-to-call format via a VoIP application.
- the customer may choose to make the phone call via the SIP address without requesting for a traditional telephone number.
- the reference to arrange a callback can be implemented as a link or a button labeled as "Request a phone connection through calling me back".
- a form to take the callback number is presented with the link or button.
- a further interface e.g., a web page, a dialog box, etc.
- the reference to request an assigned phone number can be implemented as a link or a button labeled as "Show me a phone number", which when selected, causes a phone number to be assigned to the version of the advertisement. After a phone number is assigned to the version of the advertisement, the advertisement can be subsequently displayed with the assigned phone number without showing the reference to request an assigned phone number.
- the "Show me a phone number" link or button is selected, the complete phone number of the advertiser can be shown to allow the customer to call the advertiser directly. In such an implementation, the number of times that the advertiser's phone number is clicked to reveal can be used as a performance indicator, based on which the advertisement is charged for.
- statistical data related to consumer responses to the advertisement can be collected and used to adjust the tracking mechanisms for the advertisement. For example, if it is determined that the majority of the phone calls in response to the advertisement is via the SIP address, other tracking mechanisms may be de-allocated from the advertisement, or re-allocated for a different advertisement. Alternatively, the reference may be phased out from the advertisement while the reference is allocated to a different advertisement.
- an advertisement may be upgraded for a more expensive method of tracking.
- An advertisement with an extension may be upgraded to a local phone number without an extension, or even a vanity toll-free number, if the performance of the advertisement is above a threshold (e.g., when its conversion rate or call volume is high).
- advertisements that perform poorly may be downgraded in tracking methods used. For example, an advertisement tracked by a toll-free number without an extension may be downgraded to have a number with an extension, a click- to-call connection mechanism.
- the tracking mechanism of an advertisement can be determined not only by the performance of an advertisement, but also by the quality of the demand partner or the quality of the customer viewing the advertisement.
- one advertisement may use an expensive tracking mechanism on one demand partner but may be assigned a different, inexpensive tracking mechanism on a second demand partner who tends to have lower quality customers (e.g., customers who response less frequently to advertisements).
- the quality of a demand partner may be reflected upon on the difference in the conversion rate of a same advertisement presented via different demand partners, in the numbers of the potential customers the demand partners can reach, the quality of the customers of the demand partners, etc.
- the tracking mechanism is directly determined by the quality of the customer himself/herself.
- information can be collected about the customer interacting with the advertisements; if the customer is a frequent buyer, an expensive tracking mechanism can be used for the customer.
- the quality of a customer may also reflected upon the preferences of the customer, the spending habit of the customer, the response rate of the customer to advertisements, the need of the customer, etc. In this case, different customers of different buying tendencies may see the advertisement using different tracking mechanisms at the same demand partners.
- the likelihood of an advertisement being called is estimated based on the type of media channels used to present the advertisement, the demand partner responsible to deliver the advertisement, and/or the customer who views the advertisement. Any characteristics in advertising that have an impact on the likelihood of an advertisement of being called and thus the expected revenue/profit generated from the presentation of the advertisement can be used in selecting a tracking mechanism for the particular instance of the advertisement.
- the assigned phone number may be reallocated to another advertisement.
- the tracking mechanism used for the advertisement may be promoted to a phone number with a short or vanity extension, a phone number without an extension, a vanity phone number, a toll free phone number, a vanity toll free number, a local phone number, or a vanity local phone number. If the number of communication leads generated from the advertisement is lower than a threshold, the tracking mechanism may be downgraded, freeing up tracking resources for other advertisements.
- this demand partner when advertisements are provided to a demand partner that has a lower success rate in reaching viable customers than other demand partners, this demand partner may be represented using a long extension, leaving short extensions for other demand partners.
- the advertisements for presentation by the demand partner may be tracked using references for callback or SIP addresses.
- the system may promote the advertisement activities in one geographic area; and the advertisements served in that geographic area receive upgrades in tracking mechanism.
- the advertisements in certain categories of products and services use upgraded tracking mechanisms.
- the advertisements with a pay per communication lead price bid higher than a threshold receives an upgrade in tracking mechanism.
- the system determines weighting factors in various types of communication references (e.g., in terms of cost and benefit in promoting the advertisement), the success rate of the advertisement in various communication channel/demand partner, and the price bids of the advertisers. Based on the collected information, the system can select tracking mechanisms to optimize the potential revenue that can be generated from advertising. In one embodiment, the potential revenue includes the advertisement revenue and/or other revenue that can be generated from the advertisement.
- the potential revenue can include the expected commission from the presentation of the advertisement; and in such a case the system may further use the statistical data related to the successful rate of a call converting into a transaction, an average value of a transaction, the possibility of a repeated call, the average value of a repeated call, etc., in the determination of the potential revenue.
- advertisements may qualify for better tracking mechanisms when their pay-per-call bid price reaches a certain value.
- advertisements may qualify for better tracking mechanisms when their overall value reaches a certain threshold. Their overall value can be a function of their bid price, ordinal position, conversion rate, demand source, customer quality, etc.
- Figure 9 illustrates an example of telephone call tracking mechanisms which can be selected according to one embodiment.
- a phone number (207) without an extension is assigned for the generation a particular version (213) of an advertisement (209).
- the assigned phone number (207) is associated with the media channel (203) and the advertiser's phone number (205) (and/or other parameters to be tracked).
- the parameters to be tracked can be identified based at least partially on the assigned phone number (207).
- the particular version (213) of the advertisement (209) that has the assigned phone number (207) is provided to the customer (217) via the media channel (215).
- the advertisement may instruct or suggest the customer to call the assigned phone number (207) to reach the advertiser.
- the customer may call the assigned phone number (207).
- connection provider (221) When the connection provider (221) is called at the assigned phone number via a telephone carrier, the connection provider (221) can identify the assigned phone number (e.g., via a Dialed Number Identification Service (DNIS)) and determine the advertiser's phone number (205) based at least partially on the assigned phone number (207). Further, using the assigned phone number, it can also be determined that the phone call from the customer is a response to an advertisement that is delivered via the media channel (215) based on the association between the assigned phone number (207) and the media channel (203) in the database (201).
- DNIS Dialed Number Identification Service
- the connection provider (221) after determining the advertiser's phone number from the assigned phone number that is dialed by the customer (217), the connection provider (221) makes a separate call to the advertiser (225) via a telephone carrier.
- the connection provider (221) can bridge or conference the calls to connect the customer (217) and the advertiser (225).
- the connection provider (221) may forward the calls from the customer (217) to the advertiser (225) after determining the advertiser's phone number.
- the assigned phone number can be a phone number that is local to the area to be served by the advertisement.
- the assigned phone number can be a toll free phone number, such as an 800- (888-, 877, or 866-) number.
- the assigned phone number is a vanity number that spells one or more words on a dial pad on a phone, such as 1-800-PLUMBER for the advertisement of a plumber.
- the assigned phone number can be a plain phone number.
- a local phone number is easy to dial manually, a vanity number is easy to remember, and an 800- number is easier to remember than other toll free numbers.
- an 800- number is easier to remember than other toll free numbers.
- another type of tracking mechanism uses different extensions to differentiate tracked parameters.
- different root phone numbers can be used to represent different media channels; and different extensions can be used to represent different advertisers.
- different root phone numbers are used to represent different advertisers; and different extensions are used to represent different media channels.
- the entire assigned phone number, including the root phone number and the extension is used as a key to look up the media channel and the advertiser's phone number.
- the root phone numbers are not used to differentiate tracked parameters; and the tracked parameters are represented by the extensions, which may be implemented as keys to look up the parameters or as encoded/encrypted version of the parameters.
- the customer dials the root number
- the customer is connected to an IVR system or a human operator of the connection provider/tracker.
- the tracked parameters such as the media channel and/or the advertiser's phone number, can be determined.
- the IVR system or the human operator can prompt the customer for the extension that is provided in the advertisement.
- the IVR system or the human operator may customize the prompt to include the information of the media channel and ask the customer to further provide the extension to reach the desired advertiser.
- the IVR system or the human operator may customize the prompt to include the information of the advertiser and ask the customer to further provide the extension to reach the desired advertiser.
- the extension can be a plain extension or a vanity extension that spells one or more words on a dial pad on a phone, such as extension PLUMBER for the advertisement of a plumber.
- extensions used in the system can have different lengths. A shorter extension is easy to dial; and a vanity extension is easy to remember.
- the extension includes an encoded/encrypted version of the associated parameter to allow an authorized data system to decode/decrypt at least some of the parameters without having to query the database.
- different types of extensions can have different values in advertising.
- the tracking methods described can have different costs.
- a toll-free number with many extensions for instance, is much cheaper than many vanity toll-free numbers. Therefore, the system uses the more expensive methods when it's worthwhile to do so. For instance, if an advertisement receives many calls, it may be selected for a more expensive method of tracking.
- An advertisement with an extension may in the future be upgraded to a local phone number without an extension, or even a vanity toll-free number.
- an advertisement may qualify for a more expensive method of tracking if its conversion rate is high (e.g., if it has a high ratio of the number of calls it receives to the number of times it is displayed).
- advertisements that perform poorly may be downgraded in tracking methods used. For example, an advertisement tracked by a toll-free number may be downgraded to have a less expensive, click-to-call connection mechanism.
- the connection provider calls the customer instead of providing a phone number to receive a phone call from the customer.
- the reference assigned to represent the contact of the advertiser may not be used to make a call via a traditional telephone carrier.
- the reference can be submitted to the connection provider via a data communication, such as an email, an SMS message, a web request, or other types of data communication.
- the reference can be used as a key in the database to look up the associated parameters, such as the media channel and the advertiser's phone number.
- the reference is an encoded/encrypted version of the associated parameters, such that an authorized data system can decode/decrypt the information without having to look up from the database.
- the connection provider can callback to the customer to establish the connection between the customer and the advertiser.
- the request may include a callback phone number of the customer.
- a customer may be prompted to provide the callback phone number in response to the request.
- the connection provider can connect the customer and the advertiser by calling the customer and the advertiser separately and bridge/conferences the calls, or by forwarding one call (e.g., the call to the customer) to another (e.g., to the advertiser).
- a telephone number assigned to a version of an advertisement includes a SIP address for the initiation of a Vo IP -based telephone call.
- the SIP address can be used for a manually dialed call on a SIP-enabled phone, or be used in a click to call format.
- the SIP address includes an encoded/encrypted version of the contact of the advertiser such that the connection provider can decode/decrypt the contact of the advertiser from the SIP address without having to look up from database.
- the allocation of a telephone number to an advertisement is deferred to a stage when a customer is interested in the advertisement and ready to make a phone call.
- a reference embedded in the advertisement can be used to specifically request for the telephone number that is assigned to the advertiser by the connection provider.
- the request can be sent as a web request in response to a click on a link, or as an email, an SMS message, or an instant message.
- the assigned telephone number may be a toll free phone number without extension, a local phone number with an extension, a SIP URL, etc.
- the reference can be used to request the actual phone number of the advertiser.
- Figure 10 shows a diagram of a system to make and track phone connections according to one embodiment.
- a database may contain the phone numbers of target phone A (261), target phone B (263), ..., target phone X (269), etc.
- the target phones belong to the institutions, businesses, individuals, etc, which seek for publicity through various media channels, such as media channel A (231) (e.g., web server), media channel B (232) (e.g., WAP server), media channel C (233) (e.g., short messaging service center), media channel D (234) (e.g., custom server), media channel E (237) (e.g., cable television), media channel E (238) (e.g., news press), media channel G (239) (e.g., radio station), and others such as virtual reality, directory assistance service, interactive maps, etc.
- the phone numbers of the target phones are not directly publicized over the media channels. Instead, encoded target phone numbers (253) are used.
- the encoded target phone numbers allow the association of additional information with the target phone numbers, such as the media channels used, special promotions, etc.
- the encoded target phone numbers are delivered with content information (e.g., web page, WAP page, short message, television programs, news articles, virtual reality, etc.) to user devices, such as user device A (241) (e.g., cellular phone), user device B (242) (e.g., personal digital assistant (PDA)), user device C (243) (e.g., computer), user device D (246) (e.g., receiver), user device E (248) (e.g., newspaper).
- user device A e.g., cellular phone
- user device B 242
- user device C 243
- user device D 246)
- user device E e.g., receiver
- user device E e.g., newspaper
- a user device can include a USB phone, a Bluetooth wireless phone, or one or more speakers or headphones with one or microphones for the implementation of a software based phone (softphone).
- the user devices/phones support one or more real time communication capabilities, such as VoIP using Session Initiation Protocol (SIP) which may support video and instant-messaging applications, IP phone, regular phone over VoIP service, Bluetooth wireless phone, USB phone, software based phone, and other forms of IP telephony.
- SIP Session Initiation Protocol
- the user devices/phones support the display of virtual reality.
- the user device can include a television set to receive the advertisement. Further, the television set may have the capability to accept user input so that the television content may be changed according to the user input (e.g., interactive television, web television, internet television, etc.), or be coupled with a set top box which has such capability.
- the user input may be provided to the content provider through the same communication channel in which the television content/programs are delivered (e.g., a cable system of a cable television system), or a separate channel (e.g., a phone line, an Internet connection, etc.).
- the user input may include a request to make a connection to an advertiser featured in an advertisement presented in a television program, such as a request for a telephonic connection to the advertiser.
- the user devices are mobile devices, such as PDA, cellular phone, etc.
- the user devices obtain content information, including advertisements, through wireless communication connections, such as cellular communication links, wireless access points for wireless local area network, etc.
- a user device e.g., a cellular phone, a computer, a PDA
- can receive content information from multiple types of media channels e.g., a web server, a WAP server, an SMSC, CHTML, etc.
- a user device is capable to dial a phone call (e.g., automatically according to the encoded phone number embedded in the content information when a user selects the number).
- a user may manually dial a phone call using a separate phone, such as user phone S (247) or user phone T (249).
- dialing at least a portion of an encoded target phone number connects the phone call to a connection server (255) first.
- the connection server (255) determines the corresponding target phone number using the database (251) and connects the phone call to the corresponding target phone (e.g., one of target phones 261 - 269) through the communication network (257).
- the communication network (257) may be circuit switched, packet switched, or partially circuit switched and partially packet switched.
- the telephone network may partially use the Internet to carry the phone call (e.g., through VoIP).
- the connection between the user phone/device and the connection server (255) may be carried using
- connection server (255) may be carried using a land-line based, circuit switched telephone network.
- the information associated with the encoded target phone number such as the media channel used to provide the encoded target phone number to the users, is also decoded/retrieved using the database (251).
- the information associated with the encoded target phone number can be tracked/stored.
- connection server (255) also determines the phone number of the user through Automatic Number Identification (ANI).
- ANI is a phone system feature that provides the billing phone number of the person making the phone call.
- the information about the caller, target phone number, the media channel used for delivering the contact information to the user can be used to bill the caller and/or the target phone number, and provide credit/compensation for the corresponding media channel.
- the advertisements for target phone numbers can be paid for on a pay per call basis. Monitoring and tracking the calls can be used for billing the advertisers.
- the users may be seeking the contact information on a pay per call basis.
- Monitoring and tracking the calls can be used for billing the users.
- the additional information associated with the encoded target phone number is used to provide credit/compensation to the operators of the corresponding media channels that are responsible for leading the users to the phone calls to the target phones.
- the system can further track the time and duration of the phone calls and other information, such as conditional promotions, electronic coupons, etc.
- the information about the media channels that are responsible for leading the users to the phone calls to the target phones can also be useful for the advertisers.
- the advertisers may wish to know which media channel is more effective in reaching users. For example, using the statistic information about the media channels which successfully bring in phone calls, the advertisers may fine tune advertisement strategies. Further, different media channels may charge differently for the advertisements; and the advertisers may bid differently on different media channels for their advertisements.
- an encoded target phone number has the same number of digits as a standard phone number (e.g., a typical telephone number assigned by a telephone company).
- dialing the encoded target phone number is as easy as dialing the target phone number; and dialing the target phone number reaches the connection server (255).
- a large number of encoded phone numbers are generally required to differentiate the different target phones and different media channels.
- an encoded target phone number has more digits than a standard phone number.
- a first portion of the encoded target phone number has the same number of digits as a standard phone number to reach the connection server (255) through the communication network (257); and a second portion of the encoded target phone number is to be decoded by the connection server (255).
- the Dual Tone Multi-Frequency (DTMF) decoder can be installed in the connection server (255) to detect the second portion of the encoded target phone number dialed at the user phone. The detected phone number can then be used to recover the target phone number.
- a human operator or an interactive voice response (IVR) system can be used to receive the second portion of the encoded target phone number for decoding.
- an encoded target phone number When an encoded target phone number has more digits than a standard phone number, the additional digits can be implemented as a telephone extension, or as input to an IVR system.
- an encoded target phone number includes a Session Initiation Protocol (SIP) address for the initiation of a VoIP call to the system.
- SIP Session Initiation Protocol
- a single telephone number is used to reach the connection server (255) for different target phone numbers; and the portion of the encoded target phone number that is used to reach the connection server (255) is not used in determining the information associated with the encoded target phone number.
- connection server 255
- the entire encoded target phone number can be used to determine the information associated with the encoded target phone number.
- the encoded target phone numbers can have different numbers of digits. The advertisers may be arranged to bid for shorter encoded target phone numbers.
- the encoded target phone numbers are assigned only when needed for use in a media channel. For example, when a query is received at the server of the system, the system assigns phone numbers for the advertisements that satisfy the query.
- a look-up table approach is used to encode the information. For example, the database (251) keeps track of the information about the media channel and the target phone number (and other information, if any) for the encoded target phone number so that the encoded target phone number can be used as a key to retrieve the corresponding information. Thus, it is not necessary to have a predetermined structure to encode the information about the media channels and the target phone number.
- algorithms can be used to generate and encode target phone number and associated information.
- a predetermined algorithm may be used to encode different information in the target phone number.
- the target phone number may include a number of fields separated by "*" or "#". Each of the fields can be decoded separately (e.g., from a separate look up table or a mapping algorithm) to determine the target phone number, identity of the media channel, etc.
- a set of parameters can be mapped from a string of characters to a string of numerical digits as a part of the encoded target phone number; and the string of numbers can be mapped back into the string of characters at the connection server (255).
- a mapping scheme is used, a look up table is not necessary.
- an encoded target phone number may include a first portion that is the phone number of the connection server (255), a second portion that is the target phone number appended with a number mapped from an identifier of the media channel.
- an encryption/scrambling scheme can be used to encode the second portion, which is decoded at the connection server (255).
- connection server (255) determines the target phone number from the encoded target phone number dialed by the user and then dials the target phone number for the user and joins/bridges the phone calls so that the user can talk to the target phone.
- users dial the encoded target phone numbers manually.
- a user can dial the encoded target phone number regardless of the user device used and the media channel used.
- user devices can automatically dial the encoded target phone numbers.
- a cellular phone, a computer or a PDA can dial a phone number using a Dual Tone Multi-Frequency (DTMF) generator.
- the encoded target phone numbers are presented in the content information in a format such that when the user selects the phone number the user device (e.g., a cellular phone or a computer) dials the encoded target phone number for the user.
- the user selection may be in the form of an keyboard/keypad input, a touch pad input, a track ball input, a mouse input, a voice command, etc.
- the user device initiates the phone call through a VoIP system when the user selects the encoded target phone number.
- the user device dials the phone number for the user without the user manually pressing the sequence of the encoded target phone numbers. This greatly simplifies the process of make the phone call. Since a user device can dial a long sequence of number easily, a large number of digits can be used to encode the information without presenting any difficulties for the users.
- the encoded target phone numbers are formatted so that the user device dials a first portion of the encoded target phone numbers to access the connection server
- the user device initiates the phone call.
- a connection server may be used to initiate phone calls both to the user device (or a separate user phone) and the target phone and then join/bridge the phone calls to connect the user to the target phone.
- the selection of the target phone number is transmitted to the connection server with the user phone number.
- the user phone number can be automatically determined through ANI, or through a user preference setting, or through an entry submitted with the selection of the encoded target phone number.
- the selection of the encoded target phone number is transmitted to the corresponding media channel, which forwards the request for making the phone call to a server (e.g., a web server) connected to the connection server.
- a server e.g., a web server
- the content information can be formatted so that the selection is sent directly to the connection server.
- the encoded target phone number can also include alphabetic characters (and/or other characters).
- the connection server can decode the encoded target phone number to recover/retrieve the target phone number and other associated information, such as the identity of the media channel that is creditable for providing the encoded target phone number to user.
- an advertisement is presented to end users around the globe without geographical area limitations.
- an advertiser may provide services and/or products to customers around the globe.
- the advertisement may be delivered to the worldwide users of the Internet.
- the intended audience of an advertisement is the population in a particular geographical area or people interested in a particular geographical area.
- an advertiser may limit its service area within a geographical area, where the advertiser can provide services and/or products to the customers more effectively.
- a business may better serve the customers within a convenient walking/driving distance to the site of the business.
- a business may limit the service area within a city, a county, a state, a country, or other types of regional areas.
- a large business entity having offices around the world may want to attract customers in different geographical regions to different offices for better services.
- a target geographic area is specified for publicizing a phone number which can be used to reach an advertiser. The target geographic area information can be used to effectively reach potential customers and connect the customers to the corresponding phones of the advertisers.
- the advertiser can specify a geographic service area corresponding to a phone number.
- the service area may be specified in terms of radius, city, region, state or national boundary, etc.
- the service area can be used to limit the delivery of the advertisement to customers seeking information in the corresponding geographic area.
- the service area can be used to stream information into a mobile device when the mobile device enters the service area, with or without explicit request from the user of the mobile device.
- the service area information can also be used to route the phone to the corresponding one of the offices of the advertiser, based on the location of the caller, if the advertiser has more than one office.
- an advertisement presented in a media channel is for a single advertiser.
- the end user selects an advertiser according to the advertisements presented on behalf of individual advertisers; and the connection server connects the end user and the selected advertiser according to the encoded target phone number individually publicized in the advertisement for the advertiser.
- the selection of the advertiser is based on the online information.
- an advertisement is presented in a media channel for a group of advertisers, such as a group of mortgage brokers.
- the advertisement contains an encoded target phone number which is reachable to the group of mortgage brokers.
- the encoded target phone number is selected or used, the selection of a particular advertiser is performed at the connection server.
- a toll-free number is published to advertise mortgage brokers in a particular geographic area.
- the call is routed to the highest bidding mortgage broker who is available in that market.
- the connection server may select the target advertiser according to the bidding of the advertisers for the advertisement.
- the advertiser who places the highest bid is the winner for the call.
- other types of selection criteria can also be used.
- the user may be interested in advertisers in a particular geographical region; and the geographical area of interest to the caller can be determined and used in selecting the target advertiser. Further, the user may be interested in a connection without excessive waiting time.
- the status of the availability of the advertisers to answer the call can be used in ranking the candidates for routing the call.
- an indicator used to rank the candidates may be a function of a number of parameters, such as the bid for the advertisement, the projected waiting time, an indicator showing a degree of matching to one or more user requirements (e.g., geographic area, service type, etc.), advertisement budget, and others.
- a connection provider uses a connection server configured on a packet switched network to provide telephonic connections between callers (e.g., customers) and callees (e.g., advertisers), as illustrated in Figure 11.
- the connection server (277) receives and/or places telephone calls via the telecommunication carrier (275) over the packet switched network (279).
- the telecommunication carrier (275) further routes the telephone communications towards the caller (271) and the callee (273).
- the connection server (277) can use one type of communication connection with the telephone carrier (275) to facilitate the communication connections with variety of devices used by the customers (e.g., callers and callees).
- the connection server (277) can also place and/or receive direct VoIP calls to/from the caller (or callee).
- the connection server can place separate VoIP calls, via the telecommunication carrier (275), to the caller (271) (e.g., the requester of the click-to-call) and the callee (273) (e.g., the destination of the click-to-call request).
- the caller e.g., the requester of the click-to-call
- the callee e.g., the destination of the click-to-call request
- the telecommunication carrier (275) bridges the packet switched the network and the public switched telephone network (PSTN).
- the telecommunication carrier (275) routes the call from the packet switched network (279) to the caller (271) (or the callee 273) on the circuit switched network.
- POTS Plain Old Telephone Service
- the connection server (277) joins the separate calls that are placed via the packet switched network (279) to connect the callee (273) and the caller (271).
- call signaling and media content may use different network paths. While call signaling is arranged to go through the packet switched network (279) and the connection server (277), the media stream does not have to go through the connection server (277). For example, when the calls are joined, the media content may be redirected to flow over the communication carrier (275) without going through the packet switched network (279) to the connection server (277) for improved performance and efficiency.
- the connection server (277) can release the control over the media stream to allow the media stream to flow through the shortest path, without going through the connection server, while maintaining control to the connection for the call by staying on the path for call signaling.
- the telecommunication carrier (275) converts the call for the packet switched network (279) for the connection server (277).
- virtual softphones on the telecommunication carrier (275) are assigned to the caller (271) and the callee (273) for interfacing with the connection server (277) over the packet switched network (279).
- the virtual softphones encapsulates the devices and networks used by the caller (271) and callee (273) to access the connection server (277); and the telecommunication carrier (275) shields the connection server (277) from the implementation details of the user devices and networks used by the caller (271) and the callee (273).
- the connection server (277) calls (or receives calls from) and connects the virtual softphones on the telecommunication carrier (275) to connect the caller (271) and the callee (273).
- connection server (277) the telephonic connection between the telecommunication carrier (275) and the connection server (277) is facilitated via a packet switched network (279).
- the connection server (277) can operate efficiently in a digital domain.
- the connection server (277) interfaces with the telecommunication carrier (275) using one type of Internet Telephony systems (e.g., SIP-based Internet telephony).
- a connection server may include some or all of the functionality of the telecommunication carrier (275).
- the connection server may be configured to bridge a packet switched network and a circuit switched network.
- the connection server may support multiple, different types of Internet Telephony systems.
- connection server (277) and the telecommunication carrier (275) are operated by different, separate entities.
- the connection server (277) and the telecommunication carrier (275) may be operated by the same entity.
- the telecommunication carrier (275) includes a set of facilities operated by a number of separate entities.
- the caller (271) and/or the callee (273) may also place/receive calls via a packet switched network.
- the telecommunication carrier (275) may route the calls between the caller (271) and the callee (273) without using a PSTN.
- caller (271) and/or the callee (273) may place calls to or receive calls from the connection server (277) via Internet.
- connection server (355) is configured to place and/or receive VoIP calls using Session Initiation Protocol (SIP).
- SIP Session Initiation Protocol
- a session border controller (351) is used to interface with the packet switched network (353) and control the types of network traffic related to VoIP calls that might go into the connection server (355).
- the session border controller (351) is configured to control the signaling and media stream during the setting up, conducting and tearing down of VoIP calls to or from the connection server (355).
- the session border controller (351) may pick up the call that comes to the session border controller (351), places a separate call from the session border controller (351), and joins the received call and the placed call to control both the signaling and media stream.
- the session border controller (351) may perform signaling/encoding translation to allow the connection server (355) to process the VoIP calls in one standard, while receiving VoIP calls in a variety of standards (e.g., SIP, H.323, etc.).
- the session border controller (351) is configured to perform one or more firewall functionalities, such as denial of service protection, call filtering, bandwidth management, etc.
- the session border controller (351) is configured to perform media releasing operation.
- the session border controller (351) determines that the source and destination of a media stream is on the same side of the session border controller (351) (e.g., both the source and the destination of the media stream is outside the connection server 355), the session border controller (351) can release the hairpinning of the media stream and allow the media stream to flow without going through the session border controller (351).
- a set of SIP servers e.g., 361, 363, ..., 369 are networked to the session border controller (351) to receive messages for incoming calls and to initiate outgoing calls.
- the session border controller (351) is configured to evenly distribute the calls for processing by the SIP servers.
- the session border controller (351) may route it to a SIP server (e.g., 361) for processing.
- the INVITE message includes the phone number dialed by the caller and the contact information about the caller (e.g., the phone number of the caller 271 and/or the identity of the virtual SIP phone at the telecommunication carrier 275).
- the SIP server may determine whether the phone number dialed by the caller (273) is sufficient to determine the phone number of the callee (e.g., 273). If the phone number of the callee (e.g., 273) can be determined from the phone number dialed by the caller (273) (e.g., via decoding the phone number dialed by the callee, or looking up the phone number of the callee from a table using the phone number dialed by the caller as a key), the SIP server can place a separate SIP call to the callee via the packet switched network (353) and then connect the caller and the callee.
- the phone number of the callee e.g., 273
- the SIP server can place a separate SIP call to the callee via the packet switched network (353) and then connect the caller and the callee.
- the SIP server can further route the SIP INVITE message (e.g., to the telecommunication carrier (275) to direct the call to the callee.
- the SIP server may modify the INVITE message by replacing the destination with the determined phone number of the callee.
- the SIP server can modify the INVITE message by removing the phone number of the caller (or replacing the phone number of the caller with a phone number of the connection server).
- the modified INVITE message identifies the virtual softphone corresponding to the caller on the telecommunication carrier as the SIP phone initiated the call; thus, the virtual softphone corresponding to the callee on the telecommunication carrier can establish media connection with the virtual softphone corresponding to the caller on the telecommunication carrier directly.
- the modified INVITE message may identifies a media server (371) (or a virtual softphone on SIP server) as the initiator for a separate call. The SIP server then connects the calls for the media stream.
- the caller is first connected to a media server (e.g., 371 , 373, or 379).
- the SIP server may forward the SIP INVITE message to one or more of the media servers for answering the call.
- a media server e.g., 371
- a prompt is played to the caller by the media server.
- the media server may include an Interactive Voice Response (IVR) system, or be connected to an IVR system, to obtain input from the caller.
- IVR Interactive Voice Response
- the media server may prompt the caller to enter the extension assigned to the callee, such that the phone number of the callee can be determined based on the phone number including the extension dialed by the caller.
- the extension dialed by the caller is sufficient to determine the phone number of the callee.
- the SIP server can further connect the call to the callee.
- the media server can send a message to the SIP server.
- the message identifies the call and the extension obtained from the caller.
- the SIP server determines the callee' s phone number based at least on the extension received from the media server and initiates a SIP call via the packet switched network (353) (e.g., by sending a SIP INVITE message to the telecommunication carrier 275, which further bridges the call to the callee 273).
- the SIP server disconnects the media server from the call and reconnects the call to the callee.
- the SIP server can send a SIP BYE message to the media server to disconnect the media server from the call (e.g., by sending a "BYE" message to the media server for the call) and send a re-INVITE message towards the caller to connect the caller and the callee.
- the media server may send a SIP BYE message to the SIP server for the call; the BYE message may include the extension obtained from the caller; in response to the BYE message that contains the extension, the SIP server determines the phone number of the callee and further connects the caller to the callee.
- the SIP server can direct the caller and the callee to connect to each other for the media stream without having the media stream going through the session border controller (351) into the connection server (355).
- the media stream can go through the telecommunication carrier (275) in Figure 11 without going to the connection server (277) after the SIP server connects the caller and the callee.
- the SIP server stays on the signaling path to monitor the progress and termination of the call.
- the SIP server can also break the connection between the caller and the callee, or force the media stream to come through the connection serve (355).
- the SIP server may selectively conference a media server into the call to monitor and/or record the communication of the call between the caller and the callee.
- the SIP server may reconnect the caller and the callee to separate media servers for interaction with an IVR system or a human operator to confirm a deal or transaction.
- the SIP server may initiate a callback to a caller via a SIP call over the packet switched network (353) for a connection to the caller.
- the SIP call may be bridged onto a circuit switched network (e.g., by a telecommunication carrier 275).
- the SIP server can then reconnect the call to a media server for sending a prompt to the caller before reconnect the call to the callee.
- the callback can be initiated from a media server; and the call signaling (e.g., the INVITE message from the media server) goes through the SIP server for call control.
- the SIP server sends out the INVITE message on behalf of the media server.
- the SIP servers (361, 363, ..., 369) and media servers (371, 373, ..., 379) are implemented on separate computers connected via a local area network (and/or intranet or Internet). Alternatively, at least the some of the servers can be implemented on a same computer.
- the SIP servers and the media servers are also integrated with the session border controller (351) on a same data process system having multiple processors coupled with a data bus.
- the SIP servers are coupled to the media servers via a network; and a SIP server may use any of the available media server for interaction with the caller (or callee).
- a SIP server may be configured to use one or more of media servers that are not shared by other SIP server.
- a SIP server may be implemented on a same data processing system with one or more media servers which are reserved for the SIP server.
- connection server (355) may further include a database server (355) to storing records related to the calls, data mapping between the communication references assigned to the callees and the actual phone numbers of the callees, etc.
- contact mapping are cached in the local memory (e.g., RAM) of the servers for improved performance; and the cached mapping is updated when the database is updated.
- Figure 13 shows a block diagram example of a data processing system which may be used in various embodiments. While Figure 13 illustrates various components of a computer system, it is not intended to represent any particular architecture or manner of interconnecting the components. Other systems that have fewer or more components may also be used.
- the communication device (331) is a form of a data processing system.
- the system (331) includes an inter-connect (332) (e.g., bus and system core logic), which interconnects a microprocessor(s) (333) and memory (338).
- the microprocessor (333) is coupled to cache memory (334) in the example of Figure 13.
- the inter-connect (332) interconnects the microprocessor(s) (333) and the memory
- Typical I/O devices include mice, keyboards, modems, network interfaces, printers, scanners, video cameras and other devices which are well known in the art.
- the inter-connect (332) may include one or more buses connected to one another through various bridges, controllers and/or adapters.
- the I/O controller (336) includes a USB (Universal Serial Bus) adapter for controlling USB peripherals, and/or an IEEE-
- the memory (338) may include ROM (Read Only Memory), and volatile RAM
- Random Access Memory Random Access Memory
- non-volatile memory such as hard drive, flash memory, etc.
- Volatile RAM is typically implemented as dynamic RAM (DRAM) which requires power continually in order to refresh or maintain the data in the memory.
- DRAM dynamic RAM
- Non-volatile memory is typically a magnetic hard drive, a magnetic optical drive, or an optical drive (e.g., a DVD
- RAM random access memory
- the non-volatile memory can be a local device coupled directly to the rest of the components in the data processing system.
- a non-volatile memory that is remote from the system such as a network storage device coupled to the data processing system through a network interface such as a modem or Ethernet interface, can also be used.
- a server data processing system as illustrated in Figure 13 is used as one of the communication server(s), virtual reality server(s), connection server(s), database server(s), media server(s), controller(s), router(s), gateway(s), etc.
- one or more servers of the system can be replaced with the service of a peer to peer network of a plurality of data processing systems, or a network of distributed computing system.
- the peer to peer network, or a distributed computing system can be collectively viewed as a server data processing system.
- a web server or a file server is used to provide computer instructions for implement the methods to user terminals.
- the user terminals perform methods according various embodiments of the disclosure.
- a peer to peer network is used in providing to user terminals the computer instructions for implement the methods.
- a user terminal as a client system can be a data processing system similar to the system of Figure 13.
- a client system can be in the form of a PDA, a cellular phone, a notebook computer or a personal desktop computer.
- the I/O devices of the user device may include a USB phone, a Bluetooth wireless phone, or one or more speakers or headphones with one or microphones for the implementation of a software based phone.
- a user devices/phones support one or more real time communication capabilities, such as VoIP using Session Initiation Protocol (SIP) which may support video and instant-messaging applications, IP phone, regular phone over VoIP service, Bluetooth wireless phone, USB phone, software based phone, and other forms of IP telephony.
- SIP Session Initiation Protocol
- IP phone IP phone
- regular phone over VoIP service IP phone
- Bluetooth wireless phone IP phone
- USB phone software based phone
- FIG. 14 illustrates a system to display and manage advertisements according to one embodiment.
- a telephonic apparatus (401) is capable to place and/or receive a VoIP call through the connection to the communication network (403).
- the communication network may include a telephone network (e.g., for providing an Internet connection), a computer network, a wireless communication network, etc.
- the telephonic apparatus (401) includes a VoIP module (413) coupled with a user interface module (411) and a communication module (417) to provide the VoIP telephonic function.
- the telephonic apparatus (401) can operate to make VoIP calls to other telephonic apparatuses (e.g., 409) without activating the remote API access module (415) and communicating with the advertisement server (405).
- the telephonic apparatus (401) further includes a remote API access module (415) coupled with the user interface module (411) and the communication module (417) to provide access to advertisements.
- the access to the advertisements such as yellow page information and telephonic based service listings, can be conveniently obtained from the user interface of the telephonic apparatus (401).
- the advertisement server (405) provides services access to a search engine (423), a bidding service (425) and an advertisement database (427) through an API gateway (421).
- the search engine (423) can perform a search on the advertisement database
- the bidding service (425) can provide competitive bidding information on similar advertisements/service listings.
- the API gateway (421 ) may be implemented using a hypertext transfer protocol
- HTTP HyperText Transfer Protocol
- the data may be transferred in a Hypertext Markup Language (HTML) format, or an Extensible
- XML Markup Language
- the telephonic apparatus (401) uses the remote API access module (415) to submit search requests to the search engine (423) over the communication network (403), retrieve the search results from the API gateway (421), and display the search results in the user interface of the telephonic apparatus.
- the telephonic apparatus displays the advertisements but not the telephonic contact information.
- Telephonic contact information is when the user requests to call the advertiser of the advertisement.
- no telephonic contact information is transmitted to the telephonic apparatus with the advertisements. Instead, the telephonic contact information for calling the advertiser is retrieved from the advertisement server in a just- in-time fashion after the user requests to call the advertiser who is identified by an identifier embedded in the advertisement or the corresponding identification of the advertisement.
- no telephonic contact information is transmitted to the telephonic apparatus for the advertisements.
- the user requests to call the advertiser, the telephonic contact information of the telephonic apparatus is transmitted to the API gateway (421) together with an identifier of the advertiser or an identifier of the advertisement.
- the advertisement server (405) then arranges a call back to the telephonic apparatus to connect the telephonic apparatus (401) to a telephonic apparatus of the advertiser.
- VoIP module may be implemented partially using a software program which is to be executed in a microprocessor to assemble/dissemble data packets, to perform data compression/ decompression, etc.
- these functions can be implemented using an Application- Specific Integrated Circuit (ASIC) or a Field-Programmable Gate Array (FPGA).
- ASIC Application- Specific Integrated Circuit
- FPGA Field-Programmable Gate Array
- Figure 15 illustrates a method to display advertisements according to one embodiment.
- an advertisement is presented (501) on a VoIP phone terminal (e.g., in response to one or more search terms submitted from the phone terminal, such as a search term for service category and another search term for a geographic area of the services).
- the advertisement includes a reference to a phone contact of an advertiser of the advertisement.
- the reference may be a direct phone number of the advertiser, or an indirect phone number of a routing server which is assigned to the advertiser, or a VoIP application user ID of the advertiser, or an indirect VoIP application user ID of a routing server which is assigned to the advertiser, or an identifier of the advertiser, or an identifier of the advertisement, etc.
- the reference to the phone contact of the advertiser of the advertisement is transmitted (505) to a server; and a VoIP phone connection with the server is established (507).
- the VoIP phone connection between the server and the VoIP terminal may be initiated by the VoIP terminal or the server.
- the reference to the phone contact may be transmitted through initiate the VoIP phone connection or through a separate data transmission from the VoIP terminal to the server.
- the server further connects the VoIP phone connection to a phone of the advertiser according to the reference.
- the phone connection between the VoIP terminal and the phone of the advertiser is monitored (509) at the server.
- an amount for the phone connection according to a price specified by the advertiser is charged (511). For example, the advertiser is charged for the advertisement on a per call basis; or a portion of fee collected for the advertiser who charges the caller for rendering a service over the phone connection is deducted as the fee to provide the service to make the phone connection.
- Figure 16 illustrates a further method to display advertisements according to one embodiment.
- an advertisement is retrieved (521) from a server (e.g., in response to a user submitting one or more keywords to initiate a search for contact information, such as searching a phone directory or service listings) and presented (523) on a VoIP phone terminal.
- the advertisement includes a reference to a phone contact of an advertiser of the advertisement, such as a direct phone number of the advertiser, or an indirect phone number of a routing server which is assigned to the advertiser, or a VoIP application user ID of the advertiser, or an indirect
- a VoIP phone call is initiated (527) to a phone of the advertiser according to the reference.
- the phone connection between the VoIP terminal and the phone of the advertiser is monitored (529) at the VoIP phone terminal.
- the call information about the phone connection is transmitted (531) from the VoIP phone terminal to the server.
- the call information may include time, duration, advertiser, and/or a reference associated with the advertisement, etc.
- an amount for the phone connection is charged (533) according to a price specified by the advertiser (e.g., charge the advertiser for the advertisement on a per phone lead basis, and/or deduct a portion of fee collected for the advertiser who charges the caller for rendering a service over the phone connection).
- Figure 17 shows a method to manage an advertisement according to one embodiment.
- a user interface is presented (541) on a VoIP phone terminal to manage an advertisement.
- An identify of the VoIP phone terminal is provide (543) to a server to identify an account of advertisement on the server.
- the identify of the VoIP phone terminal (e.g., a phone number of the VoIP phone terminal or a user ID of the VoIP Phone terminal) is provided (549) (e.g., automatically) to the server as the phone contact information associated with the advertisement.
- Figure 18 shows a method to manage telephonic contact information according to one embodiment.
- an advertisement retrieved from a server is presented (551) in a user interface (e.g., on a VoIP terminal).
- a user input is received in the user interface to save the contact information of the advertisement (e.g., selecting a link or button designed to be selected to at least save the phone contact of the advertisement)
- a reference to the advertisement is stored (e.g., in the contact list of the VoIP terminal) as at least part of contact information of the advertiser.
- a list of contact entries can be displayed (557) for a plurality of persons including an entry for the advertiser.
- a current version of the advertisement is retrieved (559) from the server and displayed (561) in the user interface.
- the actual phone contact information of the advertiser is not displayed, stored, or even transmitted to the VoIP terminal.
- the current version of the advertisement provides the means for the VoIP terminal to start the telephonic connection, as in certain embodiments described above.
- the user devices/phones support one or more real time communication capabilities, such as VoIP using Session Initiation Protocol (SIP) which may support video and instant-messaging applications, IP phone, regular phone over VoIP service, Bluetooth wireless phone, USB phone, software based phone, and other forms of IP telephony.
- SIP Session Initiation Protocol
- the API for the management of Pay Per Call advertisements includes a number of methods which an application may invoke to manage the advertisements/listings (e.g., through a web service).
- a web service using Simple Object Access Protocol (SOAP), Representational State Transfer (REST), remote procedure call (RPC) via HyperText Transfer Protocol (HTTP) or binary access is used to invoke one or more of the methods of the API.
- SOAP Simple Object Access Protocol
- REST Representational State Transfer
- RPC remote procedure call
- HTTP HyperText Transfer Protocol
- a custom designed communication protocol can also be used.
- Figures 19 - 20 illustrate application programming interfaces according to one embodiment.
- Figure 21 illustrates data objects for application programming interfaces according to one embodiment.
- a method for example, CreateListing (e.g., Create Listing 601) can be used to create a new listing when the user provides the detailed information about the listing (e.g., Listing 655) together with the identification of the advertiser (e.g., User Specification 651).
- the server system provides the calling application with an internal listing identifier (e.g., Listing ID 631) generated by the system.
- the internal listing identifier can be subsequently used to identify this listing.
- the user may further include an external identifier (e.g., External Listing ID 653) to identify the listing when making the request to create the listing.
- an object e.g., Listing Specification 803 for the identification of a listing may include a field for specifying the internal listing identifier (e.g., Listing ID 835) and a field for specifying the external identifier (e.g., External Listing ID 837).
- an object used to define the specification of an advertisement includes a number of fields, such as Business Info (841) specifying the contact information of the advertiser, Description (843) specifying a short advertisement message (e.g., less than 80 characters), Service Area (844) of the product and/or service advertised by the listing, Category Specification (845) specifying one or more categories of services and/or products of the advertisement, Price Per Call (847) specifying the bids for the communication leads (e.g., telephone calls) generated by the advertisement, and Advanced Details (849).
- Business Info 841
- Description 843
- Service Area 844
- Category Specification specifying one or more categories of services and/or products of the advertisement
- Price Per Call specifying the bids for the communication leads (e.g., telephone calls) generated by the advertisement
- Advanced Details 849.
- an object Business Info (815) includes a number of fields, such as Business Name (881), address (883) of the business/advertiser, phone number (887) of the business/advertiser, and fax (889) of the business/advertiser.
- a phone number or a fax number may include the country code, area code, and/or an extension code.
- a field e.g., Is Address Displayed 885) allows the user to indicate whether or not the specified address (883) is to be displayed with the advertisement.
- an advertisement can have Advanced Details (811), such as Logo (861), Hours of Operation (863), Payment Options (865) (e.g., cash, Visa, MasterCard, American Express, discover, debit, personal check, PayPal, etc), Coupon (867), and Ad Details (869) which describes for further details of the advertisement.
- Advanced Details such as Logo (861), Hours of Operation (863), Payment Options (865) (e.g., cash, Visa, MasterCard, American Express, discover, debit, personal check, PayPal, etc), Coupon (867), and Ad Details (869) which describes for further details of the advertisement.
- a Logo (807) can be specified by a Universal Resource Locator (URL) (855) which points to a downloadable image of the logo, and the dimensions of the logo, such as Height (851) and Width (853).
- URL Universal Resource Locator
- an object for Hours of Operation specifies the day of the week (e.g., Day 871), the start time (e.g., 873) and the end time (e.g., 875) of the specified day.
- a number of objects for Hours of Operation (813) can be used to specify a schedule during which the advertiser is to be in operation (e.g., to take calls generated from the advertisement).
- an electronic coupon can be attached to an advertisement.
- a coupon (817) may include Headline (891), Description (893) specifying the offer of the coupon, Expiration Date (895) of the coupon, and Instructions (897) for the redemption of the coupon.
- UpdateListing e.g., Update Listing 603
- the listing may be identified using the internal identifier generated by the system when the listing is created, and/or the external identifier provided to the system when the creation of the listing is requested.
- an object e.g., Listing Specification 657 is used to identify an listing for access; and such an object (e.g., 803) may include the internal listing identifier (e.g., Listing ID 835) that is returned by the system during the creating of the listing and the external listing identifier (e.g., External Listing ID 837) that is specified by the user during the creating of the listing.
- an object e.g., Listing Specification 657
- a method for example, DeleteListing (e.g., Delete Listing 605) can be used to delete an existing listing.
- the listing can be identified using the internal identifier generated by the system when the listing is created, or the external identifier provided to the system when the creation of the listing is requested (e.g., using Listing Specification 661).
- a number of listings can be deleted in a batch mode when a list of objects specifying that listings is provided.
- a method for example, GetUserListings (e.g., Get User Listings 607) can be used to get the listings associated with a specified user (e.g., via an object User Specification 663).
- the user may be specified using an internal user ID that is assigned to the user during the creation of the user in the system, and/or be specified using an external user ID that is provided by the user when the creation of the user in the system is requested.
- an object (801) is used to represent a user; and such an object may include the internal user ID (e.g., User ID 831) and/or the external user ID (e.g., External User ID 833).
- the internal user ID is created by the system when an account for the user is create using a graphical user interface (e.g., a web based user interface) or an application programming interface.
- the external user ID is provided by the user when the account is created for the user.
- a list of objects e.g., 633 specifying the listings of the user is retrieved when the method GetUserListings (e.g., Get User Listings 607) is invoked.
- a method for example, GetListinglnfo (e.g., Get Listing Info 609) can be used to retrieve the details of an existing listing.
- the listing can be specified using the internal and/or external identifiers (e.g., via Listing Specification 665).
- a number of listings can be retrieved in a batch mode.
- the system In response to receiving a list of objects identifying the listings, the system returns a list of objects, each containing the identification of one listing (e.g., Listing Specification 635) and the details of the listing (e.g., Listing 637).
- a method for example, GetListingPricePerCall (e.g., Get Listing Price 621) can be used to retrieve the current price per call (bid) stored in the system for the specified listing (e.g., specified using the internal and/or external identifier via Listing Specification 667).
- the prices for a number of listings can be retrieved in a batch mode.
- the system In response to receiving a list of objects identifying the listings, the system returns a list of objects, each containing the identification of one listing (e.g., Listing Specification 641) and its price (e.g., Price 643).
- a method for example, UpdateListingPricePerCall (e.g., Update Listing Price 623) can be used to update/submit the price per call bid in the system for the specified listing (e.g., specified using the internal and/or external identifier via Listing Specification 671).
- the price for a number of listings can be updated in a batch mode.
- the system In response to receiving a list of objects identifying the listings (e.g., Listing Specification 671) and the price (e.g., Price 673), the system returns a list of objects, each containing the identification of one listing (e.g., Listing Specification 645), its price before the update (e.g., Previous Price 647) and its updated price (e.g., Current Price 649).
- a list of objects identifying the listings e.g., Listing Specification 671
- the price e.g., Price 673
- the system In response to receiving a list of objects identifying the listings (e.g., Listing Specification 671) and the price (e.g., Price 673), the system returns a list of objects, each containing the identification of one listing (e.g., Listing Specification 645), its price before the update (e.g., Previous Price 647) and its updated price (e.g., Current Price 649).
- a method for example, GetListingStatus (e.g., Get Listing Status 701) can be used to retrieve the status information about a specified listing.
- the user may specify the status of a listing as active or paused. When active, the listing is available for selection for presentation to the consumers (e.g., users of a search engine, etc.). When paused, the listing will not be presented even if there is a matching opportunity for presenting the listing.
- the system may specify the status of a listing as Active or Paused.
- the system may further specify the reason for the Paused status, such as Invoice Approval Pending, Invoice Not Approved, Not Accepted, Budget Limit Reached, Monthly Limit Reached, Credit Card Failed, Credit Card Expired, Credit Limit Reached, Low Funds, No Payment Info, Pending Acceptance, No Payment Plan, etc.
- the method can be used to retrieve such status information about a listing.
- the status information for a number of listings can be retrieved in a batch mode.
- the system In response to receiving a list of objects identifying the listings (e.g., Listing Specification 751), the system returns a list of objects, each containing the user specified status (e.g., User Display Status 711) and the system specified status (e.g., System Display Status 713) for one listing.
- the user specified status e.g., User Display Status 711
- the system specified status e.g., System Display Status 713
- a method for example, UpdateListingStatus (e.g., Update Listing Status 703) can be used to update/submit the user defined status of a specified listing.
- the method can be used to receive user input that indicates whether the status of the listing should be active or paused.
- the status of a number of listings can be specified in a batch mode.
- the system In response to receiving a list of objects identifying the listings (e.g., Listing Specification 753) and the user specified status (e.g., Listing User Status 755), the system updates the status of the listings accordingly.
- a method for example, GetListingCategories (e.g., Get Listing Categories 705) can be used to retrieve from the system the current categories under which a specified listing is listed.
- a listing can be listed in one or more different categories. When a search matches any of the specified categories, the listing may be selected for presentation.
- the category information for a number of listings can be retrieved in a batch mode.
- the system In response to receiving a list of objects identifying the listings (e.g., Listing Specification 757), the system returns a list of objects, each containing the identification of one listing (e.g., Listing Specification 715) and its category information (e.g., Category Specification 717) that contains one or more categories under which the listing is listed.
- a method for example, UpdateListingCategories (e.g., Update Listing Categories 707) can be used to update/submit to the system the categories under which a specified listing is listed.
- the listing can be specified using an object (e.g., Listing Specification 761) and category information of the listing can be specified using another object (e.g., Category Specification 763) which contains one or more categories under which the listing is listed.
- a method for example, GetCategoryFromSearchTerm (e.g., Get Category From Search Term 709) can be used to retrieve the categories of listings that match and/or are related to the specified key words of a search.
- the API may accept a string of characters as one or more key words (e.g., Search Term 771).
- a method can be used to search categories of listings.
- the search may be related to a specific address (e.g., a street address specified via object Search Address 773).
- the search may be limited to the categories of listings that have a service area within a specified geographic area, such as within the city region of the specified address, within the state or nation of the specified address, or a number of units (e.g., miles, street blocks, etc) within the radius of the specified address, etc.
- the search may specify that the requirement for the search area is unknown, in which case the server will attempt to determine a geographic area for the search.
- the search area is specified via an object (Search Area 775).
- the API in the request for key word based search of categories, the API further receives an indication (e.g., Spell Check 777) of whether or not spell checking is to be performed on the string of search term.
- an indication e.g., Spell Check 777
- the system can update the search term to indicate the corrected spelling.
- the spelling-corrected search term is provided in an object (e.g., Search Term 721).
- an indication e.g., Spell Check behaved 723 of whether a correction has been made to the search term is also provided.
- the categories that match the search terms are returned to the calling application after the search (e.g., via an object for Matched Categories 725).
- the search result may further include a number of top price bids for the listings in the corresponding categories (e.g., the top 5 prices).
- an object for describing a matched category e.g., Category Details 809) includes the category (e.g., 857) and a number of top price bids (e.g., BidPrices 859) in the category.
- the related categories that may fit the search terms are also suggested (e.g., via an object for Related Categories 727).
- a method for example, GetListingStatistics (e.g., Get Listing Statistics 719) can be used to retrieve the statistics related to a given listing (e.g., specified using an object Listing Specification 284) during a specified time period (e.g., Time Period 286). Examples of time periods include today, yesterday, week to date, month to date, quarter to date, year to date, etc.
- the statistics includes total number of calls (e.g., Total Calls 281), total number of charged calls (e.g., Total Charged Calls 733), overage (e.g., 735, the number of minutes over a predetermined "free connection time" allowed per call, beyond which the communication time may be charged at a predetermined per minute rate), total impressions (e.g., 737, the number of times an advertisement is viewed, which can be estimated based on the number of times the advertisement is being requested or can be tracked based on the number of times the advertisement is loaded into browsers for presentation), total number of unique callers (e.g., Total Unique Callers 739), call through rate (e.g., 741), average bid position (e.g., 743), total amount spent on the listing for advertisement (e.g., Total Spend 745), average price per call (e.g., 747), etc.
- total number of calls e.g., Total Calls 281
- total number of charged calls e.g., Total Charged
- the API is provided through a web service (e.g., using a web server).
- a web service e.g., using a web server.
- servers such as a server with a custom designed communication protocol can also be used.
- Figure 22 illustrates an application programming interface to provide advertisements according to one embodiment.
- an application programming interface is provided to facilitate the development of client applications (not shown in Figure 22).
- the client applications can access the server(s) (945) to query the advertisement database (947).
- the server(s) (945) includes web service servers, listing (advertisement) servers, and reference allocation servers.
- the web service servers are used to receive request from client applications via web and to provide listing information via web.
- the advertisement information e.g., 951-867, ...) can be provided via an XML data document that is generated in response to the received web request.
- the listing (advertisement) servers are used to determine or identify the requested listing information in response to the requests that are received via the web service servers; and the reference allocation servers are used to allocate the communication references (e.g., assigned telephone numbers or click-to-call references) for the listing information that is to be provided via the web as a response.
- the advertisement database (947) is stored on one or more database servers and cached in the memory of the listing (advertisement) servers.
- the listing (advertisement) servers communicate with the database servers to obtain the current advertisement data.
- the advertisement database (947) may be implemented using a non-volatile file system, a volatile random access memory system, or a combination of non-volatile and volatile memory systems.
- the server(s) (945) can be implemented as one combined server, or as multiple cooperating servers hosted on one or more data processing systems. Using the server(s) (945), client applications can query the advertisement database (947) through an application programming interface.
- a client application can specify one or more fields/parameters using the application programming interface, such as category (931), search terms (933), geographic location (935), affiliate identifier (937), filter (939), customer identification (941), etc.
- a client application can specify values for a subset of the fields/parameters illustrated in Figure 22.
- An alternative embodiment may include more or less fields/parameters.
- the application programming interface can be an interface for a remote procedure call (RPC) implemented via a web service (e.g., based on Simple Object Access Protocol (SOAP) or the GET method of Hypertext Transfer Protocol (HTTP)).
- RPC remote procedure call
- SOAP Simple Object Access Protocol
- HTTP Hypertext Transfer Protocol
- the server(s) (945) searches advertisement database (947) and returns a list of one or more advertisements.
- the advertisement database (947) is hosted on a database management server, which can be searched using a standard language (e.g., a Structured Query Language (SQL)).
- SQL Structured Query Language
- the server(s) (945) may query an SQL server to obtain a list of one or more advertisements.
- the advertisement database (947) is loaded in the random access memory of one or more of the servers (945), which can perform a search using the data loaded in the random access memory without querying a database management server (e.g., an SQL server).
- a database management server e.g., an SQL server
- the advertisement database (947) is loaded into a volatile memory from a non-volatile storage facility (e.g., an SQL server) and synchronized in changes with the non-volatile storage facility.
- the category field (931) can be used to specify a category of products or services that is being requested by a customer.
- the request is received from a customer via a demand partner; the category (931 ) is characterized by the demand partner based on the demand partner's understanding of the need of the customer; and the search terms (933) are the original keywords used by the customer in their request, without being interpreted or mapped by the demand partner.
- the application programming interface allows the client application to specify the geographic location (935) from which the customer is seeking a product or service.
- the geographic location (935) can be specified as a country, a state, a city, a postal code, coordinates (e.g., latitude and longitude).
- the search terms (933) are parsed to look for indication of the target service area; and when no geographic location can be identified from the input fields, the advertisement server may filter out the advertisements for specific local areas in the search.
- an affiliate identifier (937) can be used to track the source of the request.
- the affiliate identifier (937) can be used to identify a demand partner such that the phone number (957) is assigned accordingly to track the contribution of the demand partner.
- the source of the request can be identified based on a communication address used to make the remote procedure call.
- the affiliate identifier (937) can also be used to track a number of parameters for the demand partner.
- the demand partner can use the affiliate identifier to associate a number of parameters with the request; and when the customer responds to the advertisement by calling the advertiser, the call can be associated with the affiliate identifier and thus the parameters of the demand partner.
- the demand partner's parameters can be provided as an encrypted string in the extension part of the affiliate identifier; or the extension part of the affiliate identifier may include a key that can be used by the demand partner to look up the parameters in its database.
- the filter (939) allows the client application to filter outs certain types of advertisements from the search.
- a filter may be requested to filter out advertisements that advertise adult services or products.
- a filter may be requested to filter out local advertisers, or national advertisers.
- a filter may be requested to filter out advertisements from a specific company, or a specific category, or a specific product or service, or a specific advertisement.
- the search is for pitch switching or cross selling; and a filter can be requested to filter out advertisements that are on different economical levels or different quality levels.
- the advertisement server filters out the advertisements by the same corporation mentioned in the directory assistance request and filters out the advertisements that are not in the same economical and/or quality level of that corporation.
- the request includes an identifier of the requesting client application (e.g., an Internet Protocol (IP) address of the requesting client application, an telephone number of the requester determined via ANI, a hardware serial number of the requester, etc.); and the advertisement server performs security check (e.g., trust and safety verification) using the identifier of the requesting client application (e.g., the IP address, telephone number, hardware serial number).
- IP Internet Protocol
- the server(s) (945) returns one or more components of the advertisement that is in the resulting list according to the application programming interface.
- the server(s) (945) may return the business name (951), business address (953), business description (955), phone number (957), web URL (959), price per call, (961), default display (963), audio file URL (965), and/or video file URL (967), etc.
- one or more components of the advertisements are returned in a text format (e.g., in separate fields in an XML format); and thus, the client application can be programmed to present the advertisement in a way independent from the advertisement server.
- the client application can be programmed to selectively use some of the components to assemble a particular presentation.
- the client application can selectively convert some of the returned text fields into an audio message (e.g., via a text-to- speech synthesizer).
- the client application may apply a formatting template (e.g., font, font size, font effect, etc.) to the text components to provide a uniform appearance of advertisements.
- the business name (951) is used to present the name of the advertising party (e.g., seller, adviser, advertiser, service provider); the business address (953) is used to present the street address of the advertiser; the business description (955) provides a few sentences of marketing message for the advertiser, which may include a promotional offer to convince/persuade the customer to call the advertising party.
- the advertising party e.g., seller, adviser, advertiser, service provider
- the business address (953) is used to present the street address of the advertiser
- the business description (955) provides a few sentences of marketing message for the advertiser, which may include a promotional offer to convince/persuade the customer to call the advertising party.
- the phone number (957) is a phone reference that is assigned by the system to track the customer responses to the advertisement.
- the phone number (957) can be a telephone number with or without an extension, or a phone reference for the initiation of a VoIP call, such as a session initiation protocol (SIP) uniform resource identifier (URI).
- SIP session initiation protocol
- URI uniform resource identifier
- the phone number (957) is associated with a set of parameters in the database, such as the advertiser's phone number, the demand partner, the supply partner, etc.
- the phone number can include an encoded/encrypted set of parameters, which can be decoded/decrypted without having to look up the parameters from a database.
- the parameters can be encoded/encrypted in the extension part of the phone number; or the user identifier portion of the SIP address can contain an encrypted string that can be decrypted into the parameters.
- one of the parameters decrypted from the string may be used to look up other parameters; or the encrypted phone number can be used as a key to look up other parameters.
- the advertisement server can further associate the phone number (957) with parameters such as an identifier of a supply partner who is creditable for bringing in the advertiser, information of the customer who is going to receive the advertisement (e.g., the IP address of the customer, the phone number of the customer, a user ID of the customer), the search terms used by the customer, the categories characterized by the demand partner, the date of the search that results in the delivery of the advertisement, the keywords that cause the advertisement to be selected in the search, the product or service specific to the request, the position of the advertisement in the ordered list of advertisements that are returned as the result of the search, etc.
- the tracked information can be used to improve the selection of advertisements in response to search requests.
- the tracked information can be used to correlate queries from demand partners with calls made from customers.
- a click-to-call reference can be used in the place of the telephone number to track the communication leads generated from the advertisements.
- a customer is presented with a button or icon or link, which when selected causes a message to be sent to a connection provider/tracker.
- the click-to-call reference identifies advertiser's phone number; and the customer provides the phone number to call back the customer.
- the connection provider/tracker can make the connection for the customer and track the communication leads delivered to the advertiser.
- a click-to-assign reference can be used in the place of the telephone number.
- the reference is associated with the advertiser; and a button or icon or link with the click-to assign reference is selected, the reference is transmitted to the server to request for the telephone number that is assigned to the advertiser.
- This arrangement can postpone the need for a separate telephone number for the tracking of the communication lead until the explicit request from the customer.
- a communication between a customer and an advertiser is facilitated via the phone number (957)
- at least a portion of the communication goes through a tracker such that the communication leads generated by the advertisement for the advertiser can be tracked (e.g., to determine the performance of the advertisement and/or to bill the advertiser based on the count of communication leads).
- the web URL (959) is used to point to a web page that can provide further details about the advertiser and/or the advertisement.
- a web page hosted on the server(s) (945) can be used to provide further details on the advertisement, such as the detailed specifications of the products or services offered, user feedback, etc.
- a combined server is used to identify the advertisement and to provide the web page.
- separate, distinct servers are used to identify the advertisement and to provide the web page.
- the web URL (959) may point to a web page that is maintained by the advertiser.
- the advertisement is at least charged for according to a price per call (961) which is specified by the advertiser.
- the price per call (961) can be used by a demand partner to selectively present or prioritize the returned advertisements.
- the server(s) (945) also provides a default display (963) of the advertisement.
- the default display (963) may be provided in a plain text format, a rich text format, or an HTML format.
- the request received via the application programming interface includes a requested format for the default display; and the advertisement server provides the default display according to the requested format.
- the advertisement may include an audio version or an audio component; and the server(s) (945) provides the audio file URL (965) of the audio version/component to allow the client application to retrieve the audio file separately from the response (e.g., for improved performance).
- a client application may pre-fetch the audio component or cache the audio component from previous request. If the audio component is already in the cache of the client application, the re -transmission of the audio component to the client application can be eliminated.
- the client application can determine whether is a change to the cached audio component by examining the audio file URL (965). For example, after an audio file for an advertisement is changed, the audio file URL (965) is also changed. Thus, the client application can compare the audio file URL (965) and URL of the cached version of the audio file to determine whether there is a need to re-load the audio file.
- the request may include a requested format (e.g., wav, mp3, Ogg Vorbis, AC-3, MPEG-4, RealAudio, etc.) for the audio file; and the server(s) filters the advertisements based on the requested format, or converts the audio files into the requested format for the client application.
- a requested format e.g., wav, mp3, Ogg Vorbis, AC-3, MPEG-4, RealAudio, etc.
- the advertisement may include a video version or a video component; and the server(s) (945) provides the video file URL (965) of the video file to allow the client application to retrieve the video file separately from the response (e.g., for improved performance).
- the request may include a requested format (e.g., MPEG, DVIX, H.263, WMV, etc.) for the video file; and the server(s) filters the advertisements based on the requested format, or converts the video files into the requested format for the client application.
- a requested format e.g., MPEG, DVIX, H.263, WMV, etc.
- the advertisement may include an image version or an image component (e.g., logo); and the server(s) (945) provides the image file URL to allow the client application to retrieve the image file separately from the response (e.g., for improved performance).
- the request may include a requested format (e.g., JPG, GIF, TIF, etc.) for the image file; and the server(s) filters the advertisements based on the requested format, or converts the images into the requested format for the client application.
- the response to the remote procedure call includes an identifier of the advertisement. The identifier can be used to determine whether one or more components of the advertisement is already in the cache of the client application.
- the identifier can be used to check for updates to specific components of the advertisement.
- the client application may use the identifier to check whether an audio/video component is in the cache and remove the older version of the audio/video component when a newer version is available.
- the identifier of the advertisement is specific to the advertisement listing from the point of view of the advertisers; and the identifier of the advertisement is not specific to the parameters to be tracked, such as the demand partner, the keywords used in the search, the date of the search, etc.
- the request received via the application programming interface indicates whether the advertisements are retrieved for caching, or for presentation to a customer.
- the client application can search for advertisements that are likely to be presented, cache the advertisements, especially large components of the advertisements (e.g., the audio, video, image files), before the opportunity for advertising to a customer arrives.
- Such an indication allows the advertisement server to count presentations of advertisements precisely, while allowing the caching of the advertisements.
- Figure 23 illustrates a method to connect a telephonic apparatus to an advertiser according to one embodiment.
- a query based on the search criterion is submitted (571) over a data communication network to a server (or to a peer to peer network).
- At least one advertisement is identified (573) according to the query.
- a telephonic reference of a connection server is generated (575) to contain information including a search criterion of the query and a telephonic reference of an advertiser of the advertisement.
- the telephonic reference of the connection server may be a session initiation protocol (SIP) uniform resource identifier (URI), a telephone number with an extension, or a Voice over Internet Protocol (VoIP) user identifier.
- SIP session initiation protocol
- URI uniform resource identifier
- VoIP Voice over Internet Protocol
- the telephonic reference is provided in a form according to a calling capability of the telephonic apparatus indicated in the query.
- the telephonic reference of the connection server is encrypted with information about the query, such as the search criterion, an identification of the advertisement, a timestamp of the query, an entity of the telephonic apparatus, an identification of a user of the telephonic apparatus, a position of the advertisement in a result of a search performed in response to the query, a price of an advertisement fee offered by the advertiser, etc.
- the telephonic reference of the connection server is further encrypted information such as an identification of a distributor of the telephonic apparatus, an identification of a distribution channel of the advertisement, or an identifier of a party who has a contribution in a process of delivering the advertisement to the telephonic apparatus.
- the advertisement is provided (577) with the telephonic reference of the connection provider for presentation on the telephonic apparatus. Responsive to a user selection of the advertisement at the telephonic apparatus, a telephonic call is initiated (579) to a connection server using the telephonic reference of the connection provider. In one embodiment, the telephonic reference of the connection server is transmitted to the connection server via a data communication network in a process of the telephonic apparatus initiating the telephonic call to the connection server.
- the telephonic apparatus initiates the telephonic call via a gateway between the telephonic apparatus and the connection server; the telephonic apparatus communicates with the gateway in a first protocol; and the gateway communicates with the connection server in a second protocol.
- the gateway is selected from a plurality of gateways based on a distance on Internet between the gateways and the connection server.
- the search criterion and the telephonic reference of the advertiser are extracted (581) from the telephonic reference used to call the connection server.
- the telephonic call is then connected (583) to the advertiser using the telephonic reference of the advertiser.
- the telephonic call is then associated (585) with the search criterion.
- an encrypted string is generated as part of the telephonic reference to include information about the query and a telephonic reference of the advertiser.
- the encrypted string includes an identification of the telephonic apparatus from which the query is received; and the connection server is to determined, using the encrypted string, whether an identification of the telephonic apparatus which initiates the telephonic call to the connection server matches with the identification of the telephonic apparatus from which the query is received.
- the encrypted string includes an identification of a user of the telephonic apparatus from which the query is received; and the connection server is to determine, using the encrypted string, whether an identification of a user of the telephonic apparatus which initiates the telephonic call to the connection server matches with the identification of the user of the telephonic apparatus from which the query is received.
- the server retrieves the advertisement via a web service in response to the query and provides the advertisement to the telephonic apparatus.
- the server further retrieves a listing from a listing database maintained by the server and provides the listing with the advertisement to the telephonic apparatus.
- the advertisement and the listing are selectively provided based on data representing a social network maintained by the server.
- a geographic location of the telephonic apparatus is determined and submitted with the query.
- the advertisement is selected based at least in part on the geographic location.
- the geographic location can be determined based on a user preference stored in the telephonic apparatus, a server, or a peer to peer network, a user input specified with the search criterion, an Internet address associated with the telephonic apparatus, a GPS receiver coupled with the telephonic apparatus, or via an access point of a wireless communication system or a cellular position determination system.
- Figure 24 illustrates a method to track parameters associated with a call via a call signaling message to a connection server that contains the parameters to be tracked according to one embodiment.
- a query submitted (1001) from a telephonic apparatus over a data communication network at least one listing is identified (1003) according to the query.
- the listing is provided (1005) with information about the query to the telephonic apparatus.
- a call signaling message is sent (1007) with the information about the query from the telephonic apparatus to a connection server.
- the connection server connects (1009) the telephonic call from the telephonic apparatus to the callee of the listing and associates (1010) the telephonic call with the information about the query.
- Figure 25 illustrates a method to track parameters associated with a call via a report message from the telephonic apparatus that associates the call with the parameters to be tracked according to one embodiment.
- a query submitted (1021) from a telephonic apparatus over a data communication network at least one listing is identified (1023) according to the query and provided (1025) with information about the query to the telephonic apparatus.
- a message with the information about the query and a telephonic reference of the telephonic apparatus is sent from the telephonic apparatus to a connection server to request a callback to the telephonic apparatus.
- the connection server (1029) calls back the telephonic apparatus using the telephonic reference of the telephonic apparatus provided in the message, calls (1031) the callee of the listing, bridges (1033) the call to the telephonic apparatus and the call to the callee of the listing to provide a telephonic connection between the telephonic apparatus and the callee, and associates (1035) the telephonic connection with the information about the query.
- Figure 26 illustrates a method to track parameters associated with a call via a request message that contains the parameters to be tracked to resolve a telephonic reference of the callee according to one embodiment.
- a query submitted (1041) from a telephonic apparatus over a data communication network at least one listing is identified (1043) according to the query and provided (1045) to the telephonic apparatus together with information about the query and a telephonic reference of the callee of the listing.
- a call is established (1047) with the callee using the telephonic reference of the callee.
- the telephonic apparatus reports (1049) the association between the call to the callee and the information about the query over the data communication network.
- Figure 27 illustrates a method to track parameters associated with a call via a callback message that contains the parameters to be tracked according to one embodiment.
- a query submitted (1061) from a telephonic apparatus over a data communication network at least one listing is identified (1063) according to the query and provided (1065) to the telephonic apparatus together with information about the query and a reference to the callee of the listing.
- a message containing the reference to the callee and the information about the query is sent to receive (1069), as a response to the message, a telephonic reference of the callee.
- the telephonic apparatus uses the telephonic reference of the callee, the telephonic apparatus calls (1071) the callee.
- Embodiments disclosed can be implemented using hardware, programs of instruction, or combinations of hardware and programs of instructions.
- routines executed to implement the embodiments may be implemented as part of an operating system or a specific application, component, program, object, module or sequence of instructions referred to as "computer programs.”
- the computer programs typically comprise one or more instructions set at various times in various memory and storage devices in a computer, and that, when read and executed by one or more processors in a computer, cause the computer to perform operations necessary to execute elements involving the various aspects.
- Examples of computer-readable media include but are not limited to recordable and non-recordable type media such as volatile and non- volatile memory devices, read only memory (ROM), random access memory (RAM), flash memory devices, floppy and other removable disks, magnetic disk storage media, optical storage media (e.g., Compact Disk Read-Only Memory (CD ROMs), Digital Versatile Disks, (DVDs), etc.), among others.
- the instructions may be embodied in digital and analog communication links for electrical, optical, acoustical or other forms of propagated signals, such as carrier waves, infrared signals, digital signals, etc.
- a machine readable medium can be used to store software and data which when executed by a data processing system causes the system to perform various methods.
- the executable software and data may be stored in various places including for example ROM, volatile RAM, non- volatile memory and/or cache. Portions of this software and/or data may be stored in any one of these storage devices.
- a machine readable medium includes any mechanism that provides (i.e., stores and/or transmits) information in a form accessible by a machine (e.g., a computer, network device, personal digital assistant, manufacturing tool, any device with a set of one or more processors, etc.).
- a machine e.g., a computer, network device, personal digital assistant, manufacturing tool, any device with a set of one or more processors, etc.
- aspects disclosed may be embodied, at least in part, in software. That is, the techniques may be carried out in a computer system or other data processing system in response to its processor, such as a microprocessor, executing sequences of instructions contained in a memory, such as ROM, volatile RAM, non-volatile memory, cache or a remote storage device.
- processor such as a microprocessor
- a memory such as ROM, volatile RAM, non-volatile memory, cache or a remote storage device.
- hardwired circuitry may be used in combination with software instructions to implement the techniques.
- the techniques are not limited to any specific combination of hardware circuitry and software nor to any particular source for the instructions executed by the data processing system.
Landscapes
- Business, Economics & Management (AREA)
- Engineering & Computer Science (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Entrepreneurship & Innovation (AREA)
- Accounting & Taxation (AREA)
- Physics & Mathematics (AREA)
- Development Economics (AREA)
- Theoretical Computer Science (AREA)
- Finance (AREA)
- General Physics & Mathematics (AREA)
- Human Resources & Organizations (AREA)
- Economics (AREA)
- Marketing (AREA)
- Signal Processing (AREA)
- Game Theory and Decision Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Data Mining & Analysis (AREA)
- Multimedia (AREA)
- Operations Research (AREA)
- Quality & Reliability (AREA)
- Tourism & Hospitality (AREA)
- Telephonic Communication Services (AREA)
Abstract
La présente invention concerne des procédés et des systèmes pour faciliter des communications en temps réel via des appareils téléphoniques acceptant la communication de données. Dans un mode de réalisation, un appareil téléphonique comprend : - une interface utilisateur pour recevoir un critère de recherche, - une interface réseau couplée à l'interface utilisateur pour soumettre une requête de l'appareil téléphonique sur un réseau de communication de données et recevoir au moins une publicité, celle-ci comprenant une référence téléphonique contenant des informations sur la requête, - un module d'appel couplé à l'interface utilisateur et à l'interface réseau. En réponse à une sélection utilisateur de la publicité, le module d'appel consiste à établir une connexion avec un serveur de connexion pour un appel téléphonique utilisant la référence téléphonique, le serveur de connexion servant à extraire de la référence téléphonique les informations concernant la requête et à connecter l'appel téléphonique avec un annonceur de la publicité.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP08745320A EP2153399A4 (fr) | 2007-04-30 | 2008-04-08 | Procédés et appareils pour connecter des personnes pour des communications en temps réel par voip |
CA2685678A CA2685678C (fr) | 2007-04-30 | 2008-04-08 | Procedes et appareils pour connecter des personnes pour des communications en temps reel par voip |
Applications Claiming Priority (10)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US91510407P | 2007-04-30 | 2007-04-30 | |
US60/915,104 | 2007-04-30 | ||
US11/752,267 US8599832B2 (en) | 2005-09-28 | 2007-05-22 | Methods and apparatuses to connect people for real time communications via voice over internet protocol (VOIP) |
US11/752,267 | 2007-05-22 | ||
US11/761,800 | 2007-06-12 | ||
US11/761,987 US9094487B2 (en) | 2005-09-28 | 2007-06-12 | Methods and apparatuses to track information via telephonic apparatuses |
US11/761,800 US9143619B2 (en) | 2005-09-28 | 2007-06-12 | Methods and apparatuses to track information using call signaling messages |
US11/761,932 US9094486B2 (en) | 2005-09-28 | 2007-06-12 | Methods and apparatuses to track information via passing information during telephonic call process |
US11/761,932 | 2007-06-12 | ||
US11/761,987 | 2007-06-12 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2008134207A1 true WO2008134207A1 (fr) | 2008-11-06 |
Family
ID=39926027
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2008/059687 WO2008134207A1 (fr) | 2007-04-30 | 2008-04-08 | Procédés et appareils pour connecter des personnes pour des communications en temps réel par voip |
Country Status (3)
Country | Link |
---|---|
EP (1) | EP2153399A4 (fr) |
CA (1) | CA2685678C (fr) |
WO (1) | WO2008134207A1 (fr) |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106164906A (zh) * | 2014-04-07 | 2016-11-23 | 谷歌公司 | 用于计算网页上的电话号码的显著性分值并且自动将其注释/附加至广告的方法 |
US9553851B2 (en) | 2005-09-28 | 2017-01-24 | Yellowpages.Com Llc | Methods and apparatuses to track information using call signaling messages |
US9679295B2 (en) | 2005-02-25 | 2017-06-13 | Yellowpages.Com Llc | Methods and apparatuses for sorting lists for presentation |
US9984377B2 (en) | 2003-10-06 | 2018-05-29 | Yellowpages.Com Llc | System and method for providing advertisement |
US10074110B2 (en) | 2003-10-06 | 2018-09-11 | Yellowpages.Com Llc | Methods and apparatuses for pay-per-call advertising in mobile/wireless applications |
US10102548B2 (en) | 2003-10-06 | 2018-10-16 | Yellowpages.Com Llc | Method and apparatuses for offline selection of pay-per-call advertisers |
US10262340B2 (en) | 2004-05-04 | 2019-04-16 | Yellowpages.Com Llc | Method and apparatus to allocate and recycle telephone numbers in a call-tracking system |
US10380637B2 (en) | 2007-06-18 | 2019-08-13 | Yellowpages.Com Llc | Systems and methods to provide voice connections via local telephone numbers |
US10380631B2 (en) | 2003-10-06 | 2019-08-13 | Yellowpages.Com Llc | Systems and methods to provide advertisements for real time communications |
US10425538B2 (en) | 2003-10-06 | 2019-09-24 | Yellowpages.Com Llc | Methods and apparatuses for advertisements on mobile devices for communication connections |
US10469424B2 (en) | 2016-10-07 | 2019-11-05 | Google Llc | Network based data traffic latency reduction |
US11115529B2 (en) | 2014-04-07 | 2021-09-07 | Google Llc | System and method for providing and managing third party content with call functionality |
CN113726895A (zh) * | 2021-08-31 | 2021-11-30 | 广州艾美网络科技有限公司 | 文件传输方法、装置及网络ktv系统 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20030043827A (ko) * | 2003-04-14 | 2003-06-02 | 이수창 | 온라인 광고효과 분석 시스템 및 방법 |
JP2005141583A (ja) * | 2003-11-07 | 2005-06-02 | Toshiyuki Yamamoto | 広告評価装置 |
US20060074760A1 (en) * | 2004-09-21 | 2006-04-06 | Helin Calvin D | System and method for calling and communication based on search engine |
US20070005585A1 (en) * | 2005-06-30 | 2007-01-04 | At&T Corp. | Automated call router for business directory using the World Wide Web |
US7177415B1 (en) * | 1997-10-28 | 2007-02-13 | Samsung Electronics Co., Ltd. | Telephone number searching system supporting automatic telephone connection and method therefor |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7656878B2 (en) * | 2004-12-03 | 2010-02-02 | Cisco Technology, Inc. | System and method for providing enhanced caller ID in a session initiation protocol (SIP) environment |
-
2008
- 2008-04-08 EP EP08745320A patent/EP2153399A4/fr not_active Withdrawn
- 2008-04-08 WO PCT/US2008/059687 patent/WO2008134207A1/fr active Application Filing
- 2008-04-08 CA CA2685678A patent/CA2685678C/fr active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7177415B1 (en) * | 1997-10-28 | 2007-02-13 | Samsung Electronics Co., Ltd. | Telephone number searching system supporting automatic telephone connection and method therefor |
KR20030043827A (ko) * | 2003-04-14 | 2003-06-02 | 이수창 | 온라인 광고효과 분석 시스템 및 방법 |
JP2005141583A (ja) * | 2003-11-07 | 2005-06-02 | Toshiyuki Yamamoto | 広告評価装置 |
US20060074760A1 (en) * | 2004-09-21 | 2006-04-06 | Helin Calvin D | System and method for calling and communication based on search engine |
US20070005585A1 (en) * | 2005-06-30 | 2007-01-04 | At&T Corp. | Automated call router for business directory using the World Wide Web |
Non-Patent Citations (1)
Title |
---|
See also references of EP2153399A4 * |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10380631B2 (en) | 2003-10-06 | 2019-08-13 | Yellowpages.Com Llc | Systems and methods to provide advertisements for real time communications |
US9984377B2 (en) | 2003-10-06 | 2018-05-29 | Yellowpages.Com Llc | System and method for providing advertisement |
US10074110B2 (en) | 2003-10-06 | 2018-09-11 | Yellowpages.Com Llc | Methods and apparatuses for pay-per-call advertising in mobile/wireless applications |
US10102548B2 (en) | 2003-10-06 | 2018-10-16 | Yellowpages.Com Llc | Method and apparatuses for offline selection of pay-per-call advertisers |
US10425538B2 (en) | 2003-10-06 | 2019-09-24 | Yellowpages.Com Llc | Methods and apparatuses for advertisements on mobile devices for communication connections |
US10262340B2 (en) | 2004-05-04 | 2019-04-16 | Yellowpages.Com Llc | Method and apparatus to allocate and recycle telephone numbers in a call-tracking system |
US9679295B2 (en) | 2005-02-25 | 2017-06-13 | Yellowpages.Com Llc | Methods and apparatuses for sorting lists for presentation |
US10037551B2 (en) | 2005-02-25 | 2018-07-31 | Yellowpages.Com Llc | Methods and apparatuses for sorting lists for presentation |
US9553851B2 (en) | 2005-09-28 | 2017-01-24 | Yellowpages.Com Llc | Methods and apparatuses to track information using call signaling messages |
US10380637B2 (en) | 2007-06-18 | 2019-08-13 | Yellowpages.Com Llc | Systems and methods to provide voice connections via local telephone numbers |
CN106164906A (zh) * | 2014-04-07 | 2016-11-23 | 谷歌公司 | 用于计算网页上的电话号码的显著性分值并且自动将其注释/附加至广告的方法 |
US10943144B2 (en) | 2014-04-07 | 2021-03-09 | Google Llc | Web-based data extraction and linkage |
US11115529B2 (en) | 2014-04-07 | 2021-09-07 | Google Llc | System and method for providing and managing third party content with call functionality |
US10469424B2 (en) | 2016-10-07 | 2019-11-05 | Google Llc | Network based data traffic latency reduction |
US12132692B2 (en) | 2016-10-07 | 2024-10-29 | Google Llc | Network based data traffic latency reduction |
CN113726895A (zh) * | 2021-08-31 | 2021-11-30 | 广州艾美网络科技有限公司 | 文件传输方法、装置及网络ktv系统 |
CN113726895B (zh) * | 2021-08-31 | 2023-08-25 | 广州艾美网络科技有限公司 | 文件传输方法、装置及网络ktv系统 |
Also Published As
Publication number | Publication date |
---|---|
EP2153399A1 (fr) | 2010-02-17 |
CA2685678A1 (fr) | 2008-11-06 |
CA2685678C (fr) | 2016-01-12 |
EP2153399A4 (fr) | 2012-04-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9553851B2 (en) | Methods and apparatuses to track information using call signaling messages | |
CA2685678C (fr) | Procedes et appareils pour connecter des personnes pour des communications en temps reel par voip | |
US10147099B2 (en) | Systems and methods to dynamically generate listings to selectively track user responses | |
US8185437B2 (en) | Systems and methods to provide communication connections via partners | |
US8724789B2 (en) | Systems and methods to connect people for real time communications via directory assistance | |
US10210531B2 (en) | Systems and methods to facilitate the specification of a complex geographic area | |
US8687783B2 (en) | Systems and methods to provide information via connections for real time communications between people | |
US8838476B2 (en) | Systems and methods to provide information and connect people for real time communications | |
US9237213B2 (en) | Methods and apparatuses to initiate telephone connections | |
US8554617B2 (en) | Systems and methods to provide alternative connections for real time communications | |
US9300703B2 (en) | Systems and methods to provide telephonic connections via concurrent calls | |
US9026515B2 (en) | Systems and methods to provide communication references from different sources to connect people for real time communications | |
US20090144068A1 (en) | Methods and Apparatuses to Provide Connections for Real Time Communications | |
US8515035B2 (en) | Systems and methods to connect people for real time communications | |
US20090037309A1 (en) | Systems and Methods to Convert a Real Time Communication Connection | |
US8837466B2 (en) | Systems and methods to provide communication references based on recommendations to connect people for real time communications |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 08745320 Country of ref document: EP Kind code of ref document: A1 |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2685678 Country of ref document: CA |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
REEP | Request for entry into the european phase |
Ref document number: 2008745320 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2008745320 Country of ref document: EP |