|Publication number||US6347085 B2|
|Application number||US 08/911,133|
|Publication date||12 Feb 2002|
|Filing date||14 Aug 1997|
|Priority date||16 Aug 1996|
|Also published as||US20010055299|
|Publication number||08911133, 911133, US 6347085 B2, US 6347085B2, US-B2-6347085, US6347085 B2, US6347085B2|
|Inventors||Keith C. Kelly|
|Original Assignee||Netspeak Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (10), Non-Patent Citations (1), Referenced by (158), Classifications (21), Legal Events (8)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This application claims priority to United States Provisional Patent Application 60/023,891 entitled Apparatus For Placing Internet/Intranet Calls by Keith C. Kelly, filed Aug. 16, 1996.
This application is the one of two U.S. patent applications filed on an even date herewith and commonly assigned, including Ser. No. 08/911,519, by Keith C. Kelly, entitled Domain Name Server Architecture for Translating Telephone Number Domain Names into Network Protocol Addresses, the subject matter of which, by this reference, is incorporated herein.
In addition, the subject matters of the following related applications are also incorporated herein by reference:
U.S. patent application Ser. No. 08/533,115 entitled Point-to-Point Internet Protocol, by Glenn W. Hutton, filed Sep. 25, 1995;
U.S. patent application Ser. No. 08/719,894, entitled Directory Server For Providing Dynamically Assigned Network Protocol Addresses, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/721,316, entitled Graphic User Interface For Internet Telephony Application, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/719,891, entitled Method And Apparatus For Distribution And Presentation Of Multimedia Data Over A Computer Network, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/719,554, entitled Point-to-point Computer Network Communication Utility Utilizing Dynamically Assigned Network Protocol Addresses, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/719,640, entitled Method And Apparatus For Dynamically Defining Data Communication Utilities, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/719,898, entitled Method And Apparatus For Providing Caller Identification Based Out-going Messages In A Computer Telephony Environment, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/718,911, entitled Method And Apparatus For Providing Caller Identification Based Call Blocking In A Computer Telephony Environment, by Mattaway et al., filed Sep. 25, 1996;
U.S. patent application Ser. No. 08/719,639, entitled Method And Apparatus For Providing Caller Identification Responses In A Computer Telephony Environment, by Mattaway et al., filed Sep. 25, 1996; and
U.S. patent application Ser. No. 08/832,746, entitled Virtual Circuit Switching Architecture, by Mattaway et al., filed Apr. 4, 1997;
The invention relates, generally, to data processing systems and telecommunication systems, and, more specifically, to a technique for enabling communication connections between circuit-switched communication networks and packet-switched data processing networks.
Two fundamentally different switching technologies exist that enable digital communications. The first type, circuit-switched networks, operate by establishing a dedicated connection or circuit between two points, similar to public switched telephone networks(PSTN). A telephone call causes a circuit to be established from the originating phone through the local switching office across trunk lines, to a remote switching office and finally to the intended destination telephone. While such circuit is in place, the call is guaranteed a data path for digitized or analog voice signals regardless of other network activity. The second type packet-switched networks, typically connect computers and establish an asynchronous “virtual” channel between two points. In a packet-switched network, data, such as a voice signal, is divided into small pieces called packets which are then multiplexed onto high capacity connections for transmission. Network hardware delivers packets to specific destinations where the packets are reassembled into the original data set. With packet-switched networks, multiple communications among different computers can proceed concurrently with the network connections shared by different pairs of computers concurrently communicating. Packet-switched networks are, however, sensitive to network capacity. If the network becomes overloaded, there is no guarantee that data will be timely delivered. Despite this drawback, packet-switched networks have become quite popular, particularly as part of the Internet and Intranets, due to their cost effectiveness and performance.
In a packet-switched data network one or more common network protocols hide the technological differences between individual portions of the network, making interconnection between portions of the network independent of the underlying hardware and/or software. A popular network protocol, the Transmission Control Protocol/Internet Protocol (TCP/IP) is utilized by the Internet and Intranets> Intranets are private networks such as Local Area Networks (LANs) and Wide Area Networks (WAN). The TCP/IP protocol utilizes universal addressing as well as a software protocol to map the universal addresses into low level machine addresses. For purposes of this discussion, networks which adhere to the TCP/IP protocol will be referred to hereinafter “IP-based” or as utilizing “IP addresses” or “Internet Protocol address”.
It is desirable for communications originating from an IP-based network to terminate at equipment in a PSTN network, and vice versa , or for calls which originate and terminate on a PSTN network to utilize a packet-switched data network as an interim communication medium. Problems arise, however, when a user on an IP-based or other packet switched data network tries to establish a communication link beyond the perimeter of the network, due to the disparity in addressing techniques among other differences used by the two types of networks.
The exchange/subscriber addressing scheme utilized by public switched telephone networks is closely related to the actual physical architecture of the network and therefore to the geographic location of terminating apparatus, i.e. telephone withthin the network. For example, in the United States, a telephone number may be partitioned into a three-digit area code, a three-digit exchange, and a four-digit subscriber number within the exchange. PSTN carriers currently have large, well-established networks with multitudes of subscribers utilizing such naming systems and are set up to interact with other PSTN carrier networks and to account for the variances in local geographic dialing patterns.
Conversely, packet-switched data networks adhere to a network protocol such as the TCP/IP protocol utilizes a hierarchical naming system which is neither based on the underlying hardware of the network nor the geographic locus of the various hardware components. Instead, the TCP/IP protocol partitions computers along lines of authority irrespective of physical location. In TCP/IP, hierarchical machine names are assigned according to structures of organization for parts of name space, not necessarily according to the structure of a physical network interconnection. The TCP/IP protocol implements a naming hierarchy called the Domain Name System (DNS). The Domain Name System utilizes a hierarchical naming scheme referred to as domain names. Domain names consist of a sequence of subdomain names, separated by a delimiter character, i.e. “.” The subdomain names of a domain name are sometimes referred to as labels. For example, the domain name “www.netspeak.com” contains three labels: “www”, “netspeak”, and “com”. Any suffix of a label in a domain name is called a domain. In the above example, the top-level domain is “com.” The domain name system is well documented in various public specifications and will not be described hereinafter for the sake of brevity.
The reader will appreciate that due to the naming schemes utilized by PSTN networks and TCP/IP based networks, such as the Internet establishment of direct connections from the Internet to public switched telephone network subscribers and vice versa, is impractical.
In light of the above, a need currently exists for a mechanism which enables translation of a conventional telephone number from a client task on an IP-based network into a network protocol address representing a gateway capable of contacting the subscriber apparatus associated with the telephone number.
A need further exists for a mechanism which accounts for the dilemma of geographic dialing patterns and the nongeographic nature of IP-based networks such as the Internet, versus the hardwired, geographic nature of public switched telephone networks.
A need further exists for a mechanism which facilitates communication between packet-switched networks and circuit-switched networks and which accommodate the existing infrastructure of circuit-switched networks, including inoperability among carriers, subscriber volumes and billing logistics.
The invention describes a method and apparatus which allows communications between packet-switched data networks and traditional circuit-switched networks. Specifically, calls originating from a IP-based network may be routed to a public switched telephone network or vice versa, using a technique which allows a traditional telephone number to be resolved to the IP address of an appropriate network gateway.
According to a first aspect of the present invention, a method for establishing communication between an executing task on a packet-switched data network and a terminating apparatus on a circuit-switched communication network comprises the steps of generating a telephone number domain name identifying a telephone number, supplying the telephone number domain name to a domain name server operatively coupled to the packet-switched network, obtaining a network protocol address of a gateway, and establishing a communication connection with the terminating apparatus identified by the telephone number domain name. In one embodiment, the telephone number domain name includes a plurality of segments which represent carrier name, country code, area code, and exchange domain names, respectively. In such embodiment, the method of obtaining the network protocol address of the appropriate gateway comprises the steps of recursively determining the network protocol addresses associated with each of the respective domain name segments of the telephone number domain name.
In accordance with a second aspect of the present invention, a computer program product for use with a computer system operatively coupled over a packet-switched data network to a domain name server, and at least one gateway comprises a computer useable medium having a program code embodied on the medium. The program code comprises code for receiving data identifying a telephone number, code for generating a telephone number domain name, code responsive to the telephone number domain name for obtaining the network protocol address of a gateway, code for forwarding the telephone number domain name to the gateway, and code for communicating with the subscriber apparatus identified by the telephone numbers. In one embodiment, the code for obtaining the network protocol address comprises code for supplying the telephone number domain name to a domain name server and code for receiving a network protocol address of a gateway associated with the telephone number domain name. In an alternative embodiment, the code for obtaining the network protocol address comprises code responsive to the received identifying data for determining whether a domain name identifier of a gateway is contained therein and code for retrieving the network protocol address of the gateway identified by the domain name identifier from a directory.
In accordance with a third aspect of the invention, a method for establishing a communication link between subscriber apparatus on a circuit-switched communication network and a task executing on a packet-switched data network both networks interconnected, by a gateway, comprises the steps of a) receiving from subscriber apparatus on the circuit-switched communication network information identifying a callee task on the packet-switched data network, b) determining from the received identifying data the network protocol address of the callee task, and c) establishing a communication connection between the subscriber apparatus on the circuit-switched communication network and the callee task on the packet-switched data network. In one embodiment, the identified callee task comprises a gateway coupled to the packets switched data network and the identifying data is supplied to the gateway. In another embodiment, the information identifying the callee task comprises a telephone number.
In accordance with a fourth aspect of the present invention, a gateway apparatus for connecting a circuit-switched communication network to a packet-switched data network comprises a processor for manipulating data; packetizing logic configured to translate data from the circuit-switched communication network into a format suitable for transmission over the packet-switched data network, unpacking logic configured to translate data from the packet-switched data network into a format suitable for transmission over the circuit-switched communication network and a memory, operatively coupled to the processor and the transmission logics, for storing information associated with one or more tasks on the packet-switched data network.
The above and other features, objects, and advantages of the invention will be better understood by referring to the following description in conjunction with the accompanying drawing in which:
FIG. 1 is a block diagram of a computer systems suitable for use with the present invention;
FIG. 2 is a conceptual illustration of a communications network environment in which the present invention may be utilized;
FIG. 3 is a block diagram of a gateway system in accordance with the present invention;
FIG. 4 illustrates conceptually a hierarchical domain naming structure utilized with the server of the present invention;
FIGS. 5A-C illustrate conceptually the data structures used to implement the inventive servers of the present invention;
FIG. 6 illustrates conceptually the inventive steps utilized to resolve a telephone number to a network address of a gateway in accordance with the present invention, and
FIG. 7 is a flow chart illustrating the process steps of the method in accordance with the present invention.
FIG. 1 illustrates the system architecture for a computer system 100, such as an IBM PS/2® computer on which the invention can be implemented. The exemplary computer system of FIG. 1 is for descriptive purposes only. Although the description below may refer to terms commonly used in describing particular computer systems, such as an IBM PS/2 computer, the description and concepts equally apply to other systems, including systems having architectures dissimilar to FIG. 1.
The computer system 100 includes a central processing unit (CPU) 105, which may include a conventional microprocessor, a random access memory (RAM) 110 for temporary storage of information, and a read only memory (ROM) 115 for permanent storage of information. A memory controller 120 is provided for controlling system RAM 110. A bus controller 125 is provided for controlling bus 130, and an interrupt controller 135 is used for receiving and processing various interrupt signals from the other system components. Mass storage may be provided by diskette 142, CD ROM 147 or hard drive 152. Data and software may be exchanged with computer system 100 via removable media such as diskette 142 and CD ROM 147. Diskette 142 is insertable into diskette drive 141 which is, in turn, connected to bus 130 by a controller 140. Similarly, CD ROM 147 is insertable into CD ROM drive 146 which is connected to bus 130 by controller 145. Hard disk 152 is part of a fixed disk drive 151 which is connected to bus 130 by controller 150.
User input to computer system 100 may be provided by a number of devices. For example, a keyboard 156 and mouse 157 are connected to bus 130 by controller 155. An audio transducer 196, which may act as both a microphone and a speaker, is connected to bus 130 by audio controller 197, as illustrated. It will be obvious to those reasonably skilled in the art that other input devices such as a pen and/or tablet and a microphone for voice input may be connected to computer system 100 through bus 130 and an appropriate controller/software. controller 160 is provided for performing direct memory access to system RAM 110. A visual display is generated by video controller 165 which controls video display 170. Computer system 100 also includes a communications adaptor 190 which allows the system to be interconnected to a local area network (LAN) or a wide area network (WAN), schematically illustrated by bus 191 and network 195.
Computer system 100 is generally controlled and coordinated by operating system software, such the OS/2® operating system, available from International Business Machines Corporation, Armonk, N.Y. The operating system controls allocation of system resources and performs tasks such as process scheduling, memory management, and networking and I/O services, among other things.
FIG. 2 illustrates a telecommunications environment in which the invention may be practiced such environment being for exemplary purposes only and not to be considered limiting. Network 200 of FIG. 2 illustrates a hybrid telecommunication environment including both a traditional public switched telephone network as well as Internet and Intranet networks and apparatus bridging between the two. The elements illustrated in FIG. 2 are to facilitate an understanding of the invention. Not every element illustrated in FIG. 2 or described herein is necessary for the implementation or the operation of the invention.
A pair of PSTN central offices 210A-B serve to operatively couple various terminating apparatus through either a circuit switched network or a packet switched network. Specifically, central offices 210A-B are interconnected by a toll network 260. Toll network 260 may be implemented as a traditional PSTN network including all of the physical elements including routers, trunk lines, fiber optic cables, etc. Connected to central office 210A is a traditional telephone terminating apparatus 214 and an Internet telephone 232A. Terminating apparatus 214 may be implemented with either a digital or analog telephone or any other apparatus capable of receiving a call such as modems, facsimile machines, etc., such apparatus being referred to collectively hereinafter as a terminating apparatus, whether the network actually terminates. Further, the PSTN network may be implemented as either an integrated services digital network (ISDN) or a plain old telephone service (POTS) network. The Internet telephony is conceptually illustrated as a telephone icon symbolizing the Internet telephone client application executing on a personal computer and interconnected to central office 210A via a modem 270A. Similarly, telephone 214C is connected to central office 210D and WebPhone 232C is connected to central office 210B via modem 270C. Central offices 210A-B are, in turn, operatively coupled to Internet 220 by ISP 250B and 250C, respectively. In addition, central office 210A is coupled to ISP250B by gateway 218B. Similarly, central office 210B is connected to ISP 250C by gateway 218C. In addition, a telephone 214B and Internet telephone 232B, similar to telephone 214A and Internet telephone 232A, respectively, are interconnected to Internet 220 via PBX 212, gateway 218A and ISP 258A. In addition, global server 252 is coupled to the Internet 220 are a domain name system server 254 and 255. Global server 252 may be implemented as described in U.S. patent application Ser. No. 08/719,894, entitled Directory Server for Providing Dynamically Assigned Network Protocol Addresses, previously referenced and incorporated herein. A global server suitable for use as Global Server 252 is commercially available from NetSpeak Corporation in the form of a collection of intelligent software modules including connection server Part No. CSR1, information server, Model ISR1, and database server, Model DBSR1. Name servers 254 and 255 are described as set forth hereinafter. Finally, Internet Service Providers (ISPs) 250A-D may comprise any number of currently commercially available Internet service providers such as America On Line, the IBM Global Network, etc. An Intranet implemented as LAN 275 is coupled to Internet 220 via ISP 250D and server 256. Server 256 may have the architecture as illustrated in FIG. 1 and functions as a proxy server for LAN 275 to which WebPhone 232E is connected via a LAN-based TCP/IP network connector 280. A plurality of Internet telephone 232F and 232E are coupled to LAN 275 via LAN connectors 280. The gateways and Internet telephony client applications may be implemented as set forth in greater detail hereinafter.
Internet telephone 232 may be implemented as described in the previously referenced U.S. patent applications incorporated herein by reference. An Internet telephony application suitable for use with the present invention is the WebPhone 1.0, 2.0 or 3.0, client software application commercially available from NetSpeak Corporation, Boca Raton, Fla., referred to hereafter as the WebPhone client. For the remainder of this description, the Internet telephone will be referred to as the WebPhone client. It will be obvious to those reasonably skilled in the arts that other Internet telephone applications implementing similar functionality may be substituted for the WebPhone without affecting the inventive concepts contained herein. The WebPhone comprises a collection of intelligent software modules which perform a broad range of Internet telephony functions. For the purpose of this disclosure, a “virtual” WebPhone client refers to the same functionality embodied in the WebPhone client application without a graphic user interface. Such virtual WebPhone client can be embedded into a gateway, automatic call distribution, server, or other apparatus which do not require extensive visual input/output from a user and may interact with any other WebPhone clients or servers adhering to the WebPhone protocol. For the purpose of this disclosure, WebPhone 232 or any of the virtual WebPhones implemented in other apparatus, may be considered WebPhone client applications, “WebPhone Clients”, as opposed to other apparatus such as the connection/information server, which adheres to the WebPhone Protocol.
The WebPhone software applications may run on the computer system described with reference to FIG. 1, or a similar architecture whether implemented as a personal computer or dedicated server . In such an environment, the sound card 197 accompanying the computer system 100 of FIG. 1, may be an MCI compliant sound card while communication controller 190 may be implemented through either an analog modem 270 or a LAN-based TCP/IP network connector 280 to enable Internet/intranet connectivity.
The WebPhones, as well as any other apparatus having a virtual WebPhone embodied therein, each have their own unique E-mail address and adhere to the WebPhone Protocol and packet definitions, as extensively described in the previously referenced U.S. patent applications. For the reader's benefit, short summary of a portion of the WebPhone Protocol is set forth to illustrate the interaction of WebPhone clients with each other and the connection/information server when establishing a communication connection.
Each WebPhone client, may serve either as a calling party or a caller party, i.e. the party being called. The calling party transmits an on-line request packet to a connection/information server upon connection to an IP-based network, e.g. the Internet or an Intranet. The on-line request packet contains configuration and settings information, a unique E-mail address and a fixed or dynamically assigned IP address for the WebPhone client. The callee party, also a utilizing a WebPhone client, transmits a similar on-line request packet containing its respective configuration and setting information, E-mail address and IP address to the same or a different connection server upon connection to an IP-based network. The calling party originates a call by locating the callee party in a directory associated with either its own WebPhone client or the connection/information server to which it is connected. The callee party may be identified by alias, E-mail address or key word search criteria. Once the E-mail address of the calling party is identified, the calling party's WebPhone forwards a request packet to the connection/information server, the request packet containing the callee party's E-mail address. The connection/information server uses the E-mail address in the received request packet to locate the last known IP address assigned to the callee party. The connection/information server then transmits to the calling party an information packet containing the IP address of the callee party. Upon receipt of the located IP address from the connection server, the calling party's WebPhone initiates a direct point-to-point communication link with the callee party by sending a call packet directly to the IP address of the callee party. The callee party either accepts or rejects the call with appropriate response packets. If the call is accepted, a communication session is established directly between the caller and the callee, without intervention of the connection/information server. The above scenario describes establishment of a communication link which originates and terminates with clients on an IP-based network.
To facilitate interaction with WebPhone clients, a virtual WebPhone is implemented in the gateway 218, either executable in RAM memory or embedded in ROM memory associated with such apparatus. The gateway 218 comprises a virtual WebPhone which acts as a proxy device and voice processing hardware that bridges from an IP-based network to a PSTN network. The gateway 218 may be implemented with either a microprocessor based architecture or with dedicated digital signal processing logic and embedded software. A gateway suitable for use as gateway 218 with the present invention is either NetSpeak Model Nos. WGX-MD/24, a 24-port digital T-1 IP telephony gateway, or WGX-M/16, a 16-port analog IP telephony gateway, both commercially available from NetSpeak Corporation, Boca Raton, Fla. Gateway 218 is described in greater detail with reference to FIG. 3 hereinafter.
FIG. 3 illustrates the system architecture for gateway 300, which may be implemented as gateway 218. Gateway 300 may be implemented using a computer architecture similar to computer system 100 described with reference to FIG. 1, such elements having been described in detail and not shown in FIG. 3. In addition, gateway 300 comprises a server 302, one or more voice cards 304, one or more compression/decompression (codec) cards 306, a database 308 and a network interface 310. Server 302 may embody one or both of the architecture function of the connection server and information servers similar to those embodied in global server 252 and as described in detail in the previously referenced copending patent application. The server 300 is a multiple-instance server implementing the WebPhone protocol that functions as a connection server to provide connectivity to global server 252 and as a virtual WebPhone on behalf of a telephone that is connected to either a public branch exchange, such as PBX212, or a central office, such as central office 210A. Each instance of the server 300 interfaces with one channel of voice card 304 via the application program interface on the voice card, to provide a conversation path between a conventional telephone and a WebPhone or database 308.
The voice card 304 provides a T-1 or analog connection to the PBX or central office or analog telephone lines which have a conventional telephony interface, for example, DID, ENM. The voice card application program interface enable the instance of server 300 to emulate a conventional telephone on a PBX or central office of a PSTN carrier. Multichannel audio compression and decompression is accessed by server 300 via application program interfaces on the respective sound cards and is processed by the appropriate audio codec. Any number of commercially available voice cards may be used to implement voice card 304. Similarly, any number of commercially available audio codecs providing adequate audio quality may be utilized. Each instance of server 300 interfaces with the TCP/IP network through a series of ports which adhere to the WebPhone protocol. Gateway 300 interfaces with the T1 line of the PSTN network through the interfaces contained within voice card(s) 304.
Gateway 300 may optionally include a database 308 which may be implemented using any number of commercially available database server products including Microsoft SQL Server 6.X. Database 308 interacts with each instance of server 302 typically via ODBC format.
In the preferred embodiment, gateway 300 is a combined software hardware implementation which runs on an operating system such as Windows NT.
FIG. 4 illustrates conceptually a small part of the Internet domain hierarchy tree in accordance with the present invention. At the top of the tree is the unnamed root. Underneath the root are top level subdomains including .edu, .com, .mil, as illustrated, as well as .gov, .net, .arpa, .int, and various country code abbreviations, (not illustrated). Underneath the “.com” domain are the subdomains “carrier”, “NetSpeak” and “provider 2”. Underneath the “carrier” and “provider 2” domains exists a tree hierarchy of each their respective subdomains representing the country codes, area codes and exchange codes of traditional telephone numbers. For example, the country codes for the United States, Denmark, and Germany exist under the domain name node “carrier.com.” Under the domain name “1” for the United States country code, exists a number of subdomain name representing selected area codes in the United States. Similarly, underneath the domain name for area code “561”, exists a plurality of subdomains for the exchanges contained within area code 561, etc. The parent domain name for provider2.com is arranged similarly with different respective values. In this manner, the geographical dialing patterns of traditional PSTN telephone numbers have been arranged into an organization hierarchy similar to the domain name system hierarchy used by the domain name system and which further identify the IP address of the gateway to dial the terminating equipment.
Any of the domain name servers, including primary domain name server 254, as well as the domain name servers used to resolve a telephone domain name into network protocol addresses may be implemented utilizing the computer architecture described with reference to FIG. 1 herein. The actual implementation of the data structures utilized to resolve a domain name or subdomain name to a network protocol address may be implemented as illustrated in FIG. 5A-C. FIG. 5A illustrates a look-up table-type data structure which may be retained in system memory and utilized by a carrier domain name server to resolve country code subdomain names into the network protocol addresses of a country code domain name server. FIG. 5B illustrates a look-up table type data structure which may be retained in system memory and utilized by a country code domain name server to resolve area code subdomain names into the network protocol addresses of area code domain name servers. FIG. 5C illustrates a look-up table type data structure which may be retained in system memory utilized by an area code domain name server which may be utilized to resolve exchange subdomains into the network protocol addresses of either the respective corresponding gateway or a subscriber domain name server. In FIGS. 5A-B, the network protocol addresses are illustrated as having a format similar to that utilized by the Internet protocol. It will be obvious to those reasonably skilled in the art that as the Internet protocol evolves and/or new network protocols are adopted, that the actual format and implementation of the network protocol address may be modified accordingly without effecting the telephone domain name resolution process. Further, the actual format of the subdomain identifier into each of the look-up tables in FIGS. 5A-C may be implemented with any number of reference formats.
The invention contemplates that the data structures illustrated in FIGS. 5A-C, respectively may be combined and implemented on a single server. In a single server solution, the server may be the carrier domain name server and can resolve all references to country code, area code, exchange code and possibly subscriber subdomains directly to the appropriate network protocol address of the relevant gateway internally within the carrier domain name server itself or with an appropriate messaging protocol without having to return to either the WebPhone client application or the primary name server at each level during the domain name resolution process. Such a single server embodiment lends itself more readily to recursive resolution of a telephone number domain name. In such an embodiment, the primary domain name server need only contact the root domain name server for the domain name system and possibly one or two additional domain name servers before reaching the carrier domain name server which performs the majority of the resolution translation activities.
Alternatively, the data structures for the domain name servers illustrated in FIGS. 5A-C each may be implemented with separate respective domain name server platforms, such embodiment lending itself more readily to a distributed domain name server environment.
For the reader's benefit, some background information is provided to illustrate how name queries are resolved within the Domain Name System using the name resolver protocol and name servers. The mechanism in which the Domain Name System maps domain names to addresses consists of an independent cooperative system of name servers. A name server such as server 354 of FIG. 2 comprises a server program that supplies name-to-address translation, and mapping from domain names to Internet Protocol addresses. The server comprises the server software typically referred to as the name resolver and the dedicated processor which is referred to as the name server. The name resolver may use one or more name servers when translating a domain name query.
There are two ways to use the domain name system to resolve a domain name query. First, domain name servers may be contacted one at a time for each domain address. Alternatively, a single domain name server may perform a complete translation. In either case, the client software forms a domain name query that contains the name to be resolved. If a client application requests a complete translation, i.e., a recursive resolution, the a primary name server contacts a domain name server that can resolve the name and return the answer to the client. If the client application requests a nonrecursive solution, i.e. an iterative solution, the primary name server will not supply an answer but only generates a reply that specifies the name server the client application should contact to resolve the next portion of the name. In accordance with the Domain Name System, each Domain Name server is required to know the address of at least one route server and must know the address of the server for the domain immediately above it, i.e., the parent domain. Domain name servers use predefined ports for all communications so that clients know how to communicate with a name server once the IP address of the computer on which the server is executing. Numerous publicly-available documents describe the domain name system in greater detail including a work entitled Internet Working With TCP/IP Volume 1 by Douglas E. Comer, 2d Edition.
Multiple communication scenarios are available through the network illustrated in FIG. 2. To facilitate a better understanding of a communication between a packet-switched network and a circuit switched network, examples of communications over each of those types of networks are first set forth for the reader's benefit. In FIG. 2, a circuit switched telephone network may comprise the operative interconnection of telephone 214A, central office 210A, toll network 260, central office 210B and telephone 214C. A caller at telephone 214A would place a call by dialing the appropriate telephone number of telephone 214C. Central offices 210A-B of the respective carriers will make the appropriate connections through the toll network 260 to establish the connection. Since a toll network is utilized, this scenario likely entails a long distance connection. A simpler example of a circuit switched connection would be the operative interconnection of telephone 214A, central office 210A, PBX 212 and telephone 214B. Since toll network 260 is not used this scenario is more characteristic of a telephone call within a single exchange.
A communication link over a packet-switched network may be established with the network illustrated in FIG. 2, using the WebPhone protocol as disclosed in U.S. patent application Ser. No. 08/533,115 entitled “POINT-TO-POINT INTERNET PROTOCOL” by Glenn W. Hutton, filed Sep. 25, 1995, previously incorporated herein by reference. Specifically, WebPhone 232A may connect to Internet 220 through central office 210A, ISP 250B and register with global server 252, notifying server 252 of its current dynamically signed Internet protocol address. Subsequently, WebPhone 232A may inquire as to the current Internet protocol address of another WebPhone client, for example, WebPhone 232C. If WebPhone 252 is currently connected to the Internet and has likewise registered with the global server 252 will return the Internet protocol address of WebPhone 232C to WebPhone 232A. WebPhone 232A may then establish a direct connection to WebPhone 232C via central office 210A, ISP 250B, Internet 220, ISP 250C, and central office 210B. Alternatively, a point-to-point connection over a packet-switched network may be established over a local area network 275 by means of a direct connection from WebPhone 232E to 232F, such connection being possible if the Internet protocol addresses of the respective WebPhones are fixed.
The present invention provides a solution for communications which cross between circuit-switched (PSTN) networks and packet switched (TCP/IP) networks. The invention addresses at least three calling scenarios involving dialing techniques between any of the WebPhone clients and the gateways. The three dialing scenarios are: 1) WebPhone client to gateway to PSTN, 2) PSTN to gateway to WebPhone Client, and 3) PSTN to first gateway to second gateway to PSTN, as described in greater detail below.
In the illustrative embodiment, the invention enables a user to enter a traditional phone number through the graphic user interface of the WebPhone client and establish a call to the specified telephone exchange on a PSTN. A user enters the a destination telephone number consisting of country code, area code, and exchange and subscriber number segment or data, for example “1-561-997-4001”, into the WebPhone client utilizing either the WebPhone virtual keypad or computer keyboard. For purposes of this disclosure, exchange data such as “997” in the above example, are considered to be the same as city codes. For convenience, the WebPhone client may be configured to recognize when either the country or area code information is missing and to insert, by default, a user-defined country code or area code. In the above example, entering 997-4001 would default to a local country code of “1” and area code “561”. Alternatively, the local gateway 218 may be configured with the appropriate country, area, and city codes, the user need only dial “997-4001” and gateway 218 will append the predefined country and area codes, as explained hereafter. The WebPhone client may also be configured with a default or user selectable PSTN carrier such as MCI, Sprint, AT&T, etc., such carrier will be referred to generically hereafter as “carrier.com”. Upon receiving the desired telephone number the WebPhone client reverses the number and appends the carrier's domain name resulting in a hybrid telephone/domain name having the form “4001-997-561-1.carrier.com”. The hybrid telephone number domain name referred to hereafter as the “telephone number domain name” is passed by the WebPhone client in an acceptable format to the name resolver protocol executing on a DNS name server on the TCIP/IP network, as described hereinafter.
FIG. 6 illustrates conceptually the arrangement of domain name servers of the domain name hierarchy illustrated in FIG. 4. In theory, each server knows the addresses of lower level servers for all subdomains within the domain for which that name server it is responsible. Realistically, a name server for an organization such as carrier.com is connected directly to the root name server. At each node of the domain name tree constructed under the “carrier.com” or “provider2.com” node, a name server is configured to return a referral packet containing the IP address of one or more child domain servers. It will be obvious to those skilled in the art that a separate physical name server does not have to exist for each subdomain. A single physical server may function as the name server for multiple domains, so that the entire domain hierarchical tree structure for “carrier.com” or “provider2.com” could be configured and supported by one physical server apparatus.
Referring to FIG. 6, a recursive process of resolving the telephone number domain name previously entered into the WebPhone client to the appropriate IP address of a gateway on a PSTN is illustrated conceptually: In step 1, the WebPhone client 232 forwards the telephone number domain name to primary name server 254 in packetized form via Internet 220 and ISP 250. Using a name packet, primary name server 254 queries the root name server of the domain name system (DNS) for the address of “4001.997.561.1.carrier.com” in step 2. The name server for the DNS root returns a reference to the name server for “.com” in step 3. Next, name server 254 queries the referenced name server “.com” for the address of “4001.997.561.1.carrier.com” in step 4. In response, a referral to “carrier.com” is returned in step 5. Name server 254 then queries the name server “carrier.com” for “4001.997.561.1.carrier.com” in step 6. In response, a referral to “1.carrier.com” is returned in step 7. Name server 254 then queries the name server to “1.carrier.com,” for “4001.997.561.1.carrier.com” in step 8. In response a reference of “561.1.carrier.com”, is returned in step 9. Name server 254 then queries name server for “561.1.carrier.com,” in step 10 for “4001.997.561.1.carrier.com.” In response, a reference to “997.561.1.carrier.com” is returned in step 11. This last reference contains the IP address of the desired gateway which is then forwarded via Internet 220 and ISP 250 to WebPhone client 232 by name server 254 in step 12. In the above-described process, the resolution is executed to the level of the exchange code “997.” It will be obvious to those reasonably skilled in the art that the domain name level may be further resolved if the appropriate name server hierarchy is arranged to allow for resolution to the actual subscriber number domain level or partial subscriber number level. In such an embodiment, specific gateways would be associated with subscriber numbers, therefore allowing the additional step of resolution, using the domain name system.
The process illustrated by FIG. 6 is a recursive process for resolving a telephone number domain name to a network protocol address. The technique of using an iterative process to resolve a telephone number domain name to a network protocol address is substantially similar as that illustrated with reference to FIG. 6 except that the references or network protocol addresses to the respective name servers are returned to the WebPhone client application at each level, either directly or through the primary name server. With such embodiment, rather than the primary name server performing the complete domain name resolution, the WebPhone client is involved at multiple subdomain levels. For example, in step 3, a reference to the name server for “.com” would be returned directly to the WebPhone client either from the name server for DNS route or through the primary name server. In response, the client application will pass a name packet containing the telephone number domain name to the name server for “.com” identified by the reference. Similar interactions between the client application and the respective domain name servers occur for steps 5-11, which will not be described hereinafter.
After step 12, the call packet containing the entire telephone number domain name entry “4001.997.561.1.carrier.com” is then sent to initiate a call session to the IP address of the gateway, for example, gateway 218C, and the call is offered. The gateway 218C, depending on available resources, then evaluates the call packet data, responds accordingly by dialing 1-561-997-4001 and accepts the call. A call session is then established. The gateway may be coupled directly to a PSTN without connection through either a central office, as illustrated in FIG. 2. Once a call is established, the gateway serves to translate the packetized audio data from the packet switched-based network into analog or digital signals for the circuit-switched telephone network. The gateway further serves to translate either audio or digital signals from the PSTN network into packetized audio data suitable for transmission over a IP-based network to the WebPhone client.
The reader will appreciate from the foregoing description that the invention provides a method in which an Internet telephone such as the WebPhone clients may specify a traditional telephone number, have that telephone number translated into the IP address of an appropriate gateway by the existing Domain Name System on the Internet, and have the gateway perform the connection through to the telephone on the public switched telephone network. By utilizing the invention as previously described, a gateway may be selected on a least cost routing basis to minimize the toll charges on a traditional PSTN network. For example, if a call is originating with an Internet telephone in the United States to a PSTN apparatus in Germany, the invention may be utilized to identify a gateway in Germany proximate to the terminating apparatus rather than a gateway in the United States. As such, a substantial portion of the costs of the call can be transmitted over the Internet more cheaply than if traditional long-distance and overseas carrier lines were utilized.
The invention further contemplates a model for overriding a default preferred carrier. Suppose that the subscriber intends to use “provider2” to reach the same number. At the user interface, the entered number would be “1-561-997-4001 @@provider2.com”. Implemented in this manner, the dialed entry fails the rules for valid E-MAIL addresses. The client WebPhone software, recognizing two @ symbols and the numeric data representing the terminating phone number, could parse the entered data and generate the required domain name of “997.561.1.provider2.com”. The mechanism could be modified to be more readily apparent to the user, but the technique would remain the same.
One or more gateways installed in the above network may be assigned to their own unique E-MAIL addresses. If this information is known to the subscriber, the technique illustrated herein may be modified slightly and be used to route a call to a specific gateway. If the desired WGX was “email@example.com”, a user could place the call “firstname.lastname@example.org@provider2.com. The WebPhone client, recognizing this as a phone number, would resolve the IP address for “email@example.com” but pass 1-561-887-4001 as the phone number in the call packet when offering the call. If the desired gateway has a fixed IP address, the WebPhone client may connect to the gateway directly and pass the “name” phone number in the call packet when offering the call to the gateway. If the gateways IP address is dynamically assigned, the WebPhone client would contact the global server 252 for the current Internet protocol address of the desired server. Upon receiving such IP address, the WebPhone client would contact the server directly, passing the phone number in the call packet when offering the call. This particular technique is useful when a WebPhone client makes frequent calls to a specific gateway. The WebPhone client may be modified to include either a cashing algorithm or a small directory which includes the E-mail addresses and/or IP addresses of those gateways most frequently called by the WebPhone client. In this manner, the previously described technique for resolving the IP address of a gateway utilizing the domain name system may be avoided and the call initiated directly from the WebPhone client to the gateway, and, ultimately, to the PSTN subscriber.
As an alternative to the illustrative embodiment, a provider may install routers or define subnets or some combination thereof for the nodes in its respective domains. Additionally, routers or equipment that manage the subnets may apply algorithms optimized to phone number lookups rather than the general algorithms previously described for resolving names. In the Internet/Intranet environment, these methods are applicable independent of the physical medium on which the communication takes place.
FIG. 7 is a flow chart illustrating the basic process steps used by the WebPhone client in accordance with the present invention. The coding of the process steps of the illustrated flowchart into instructions suitable to control the WebPhone client will be understood by one having ordinary skill in the art of programming. Following power-on initialization and registration with global server 252, the WebPhone client process remains idle until detecting a telephone number input from either the virtual keyboard or the hardware keyboard associated with the computer on which the WebPhone client is executing, as illustrated by decisional step 700. The input “name” is then parsed by the WebPhone client as illustrated by process 702 to determine whether or not an E-mail address of a gateway is present within the input character string, as illustrated by decisional block 7504. If no E-mail address for a carrier gateway is present within the input name, the name is formatted as illustrated in procedural step 706. As described previously, formatting may include reversing the order of the actual segments of the phone number name as well as pending predefined or default values for country codes, area codes, and carriers, etc. Once the phone number domain name has been properly formatted, as illustrated in procedure step 706, the names forwarded to a domain system server as previously described. The WebPhone client awaits the return of the IP address of the gateway as determined by one or more domain name system servers in accordance with the process steps previously described with reference to FIG. 4, e.g. iterative resolution of the domain name supplied. If, in decisional step 704, the E-mail address of a gateway had been entered, the WebPhone client would attempt to resolve the IP address of the gateway either from its own local directory, in the event of a gateway having a fixed IP address, or through clearing the global server 252 to which the WebPhone client is operatively coupled over an IP-based network.
Having received the Internet protocol address of the appropriate gateway, either through process step 710 or from a domain name server, the WebPhone client forwards a call packet containing the telephone number domain name to the gateway and offers a call, as illustrated in procedural step 714 and 716. If a call is established, as illustrated in decisional block 718, the WebPhone client will function as described in the previously referenced patent applications. Otherwise, the WebPhone client will eventually return to an idle mode, awaiting input for an additional telephone number data. In the event a call is established, the WebPhone will detect the disconnection of the call as illustrated in procedural block 720 and will return to an idle state if not powered down, as illustrated by decisional block 722.
The reader will appreciate that the inventive technique provides a method for entering traditional PSTN telephone numbers into an Internet telephone application and having the call completed through use of the domain name server and a gateway to complete the call in the manner which is efficient and may be substantially transparent to the user.
A gateway user calling from the PSTN would be prompted for the desired phone number and user number and pin code via voice response or voice recognition techniques. The virtual WebPhone proxy device functions similar to Scenario 1. The destination phone number is resolved based on the configured location of the gateway (country code, area code, exchange, etc.), and the configured service provider. Scenario 2 is similar to Scenario 1 except that the gateway may be configured with user information, including E-MAIL and phone number of a specific WebPhone client, and then utilized as a inverse connection server to return the E-MAIL address of the desired parties' WebPhone client. The gateway through which a PSTN originating call is received would be configured with information indicating which connection server, similar to global server 252, contains the E-mail address corresponding to the desired phone number. The gateway then connects to the global server to determine the current IP address of the WebPhone client callee. Upon receiving the IP address of the WebPhone client, the gateway then establishes a direct contact to the WebPhone client and offers the call. When the WebPhone client is reached, the user, through the capabilities of the virtual WebPhone proxy software of the gateway, has the ability to leave online or offline voice mail or communication in real time, if desired.
The technique utilized in the previously described Scenario 2 may be utilized to establish calls originating and ending at PSTN apparatus, but which utilize a portion of a IP-based network, typically to reduce costs. For example, in the previously described scenario, instead of contacting a global server for the IP address of the destination WebPhone client, the gateway would be configured with information relating to which other gateway would be most suitable in accordance with any number of predetermined conditions, including lease cost routing, to complete the call. The initially contacted gateway would then contact the selected gateway, using either the E-mail address of the gateway or a fixed IP address and offer a call packet, including the destination phone number. If the call is accepted, a real-time communication link will be established from telephone 214A, to gateway 218B, through ISP 250B, Internet 220, ISP 250C, gateway 218C, and onto telephone 214C. As such, the single communication link will originate on a circuit switched network, bridge a packet-switched data communication network, and terminate on a second circuit-switched network.
In addition to the inventive technique for calling over the Internet/Intranet, the ability to validate a subscriber's identity and rights and perform billing services is desirable. In the WebPhone client, one piece of required information is a subscriber phone number. In the client implementation, this is intended to be a valid traditional phone number for the user's home or office desktop phone. If this phone number comprises a country code, area code, exchange and subscriber number, and additionally a user pin code (or 4 or more digits), the phone number can be resolved to a specific domain and gateway, and the user may be validated by their respective home access gateway. A gateway, which provides service for the user, is configured with similar information. For example, the user, configured with a home number and pin code desires to place a call to “972-4-99777-583” in Israel. Additionally, the user is currently located in Germany. The user configuration information, which may or may not employ encryption depending on the secure nature of the network, would be sent by the client in a user validation packet to the gateway servicing “4001.997.407.1.carrier.com”. A response approving or disapproving the individual is returned. The client then repeats the above phone number resolution process for the terminating number “583.9977.4.972.provider2.com”.
In a similar method to that described for subscriber validation, billing information may be collected by the gateway and collected later over the same network. Call statistics (destination, length of call, number of bytes transferred, quality of service, etc.) may be collected by the home gateway and periodically downloaded and analyzed.
The gateway may function as a personal attendant for the subscriber, since user network related queries may be resolved at the gateway, the gateway could offer services such as voice mail, find me—follow me services, custom outgoing message storage site, personal out going messages storage/playback based on caller id information, account information retrieval, LAPD personal directory and business card information, etc. Depending on available resources such as available memory, processor capability and network bandwidth, a gateway may provide services for 10,000 or more customers.
The techniques described herein for call resolution and user validation distributes the load while also improving reliability, and further, does not preclude alternate call resolution strategies when success is not achieved. The reliability and success rate of placing calls may be improved by employing alternate techniques according to error conditions. Failure to resolve the gateway address may result in a second attempt. Clients sending ONLINE packets with a specified service provider may be forwarded a list of containing the E-MAIL or IP addresses for other redundant, alternate equipment in the event of an equipment failure along with instructions to direct the ONLINE packet to one of the alternate servers or gateways.
The above described inventive technique may be utilized regardless of the specific name of the domain under which the carrier name server is implemented. For example, the authority which regulates domain names may add a special “.tel” domain specifically designed for carriers and other businesses providing telecommunication services. Such a domain name would facilitate ease of use of the technique but would not change the technique described herein.
A software implementation may comprise a series of computer instructions either fixed on a tangible medium, such as a computer readable media, e.g. diskette 142, CD-ROM 147, ROM 115, or fixed disk 152 of FIG. 1A, or transmittable to a computer system, via a modem or other interface device, such as communications adapter 190 connected to the network 195 over a medium 191. Medium 191 can be either a tangible medium, including but not limited to optical or analog communications lines, or may be implemented with wireless techniques, including but not limited to microwave, infrared or other transmission techniques. The series of computer instructions embodies all or part of the functionality previously described herein with respect to the invention. Those skilled in the art will appreciate that such computer instructions can be written in a number of programming languages for use with many computer architectures or operating systems. Further, such instructions may be stored using any memory technology, present or future, including, but not limited to, semiconductor, magnetic, optical or other memory devices, or transmitted using any communications technology, present or future, including but not limited to optical, infrared, microwave, or other transmission technologies. It is contemplated that such a computer program product may be distributed as a removable media with accompanying printed or electronic documentation, e.g., shrink wrapped software, preloaded with a computer system, e.g., on system ROM or fixed disk, or distributed from a server or electronic bulletin board over a network, e.g., the Internet or World Wide Web.
Although various exemplary embodiments of the invention have been disclosed, it will be apparent to those skilled in the art that various changes and modifications can be made which will achieve some of the advantages of the invention without departing from the spirit and scope of the invention. Further, many of the system components described herein such as the WebPhone client application and the gateway have been described using products from NetSpeak Corporation. It will be obvious to those reasonably skilled in the art that other components performing the same functions may be suitably substituted. Further, the methods of the invention may be achieved in either all software implementations, using the appropriate processor instructions, or in hybrid implementations which utilize a combination of hardware logic and software logic to achieve the same results. Further, aspects such as the size of memory, number of bits utilized to represent datum or a signal, data word size, the number of clock cycles necessary to execute an instruction, and the specific configuration of logic and/or instructions utilized to achieve a particular function, as well as other modifications to the inventive concept are intended to be covered by the appended claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5608786 *||13 Feb 1995||4 Mar 1997||Alphanet Telecom Inc.||Unified messaging system and method|
|US5742668 *||6 Jun 1995||21 Apr 1998||Bell Communications Research, Inc.||Electronic massaging network|
|US5742762 *||19 May 1995||21 Apr 1998||Telogy Networks, Inc.||Network management gateway|
|US5742905 *||19 Sep 1994||21 Apr 1998||Bell Communications Research, Inc.||Personal communications internetworking|
|US5790548 *||18 Apr 1996||4 Aug 1998||Bell Atlantic Network Services, Inc.||Universal access multimedia data network|
|US6021126 *||9 Oct 1996||1 Feb 2000||Bell Atlantic Network Services, Inc.||Telecommunication number portability|
|US6069890 *||26 Jun 1996||30 May 2000||Bell Atlantic Network Services, Inc.||Internet telephone service|
|US6122255 *||3 Feb 1997||19 Sep 2000||Bell Atlantic Network Services, Inc.||Internet telephone service with mediation|
|US6125113 *||16 Aug 1996||26 Sep 2000||Bell Atlantic Network Services, Inc.||Internet telephone service|
|US6154445 *||17 Sep 1997||28 Nov 2000||Bell Atlantic Network Services, Inc.||Telephony communication via varied redundant networks|
|1||*||C. Yang, "INETPhone: Telephone Services and Servers on Internet", Network Working Group RFC: 1789, pp. 1-6, Apr. 1995.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US6449267 *||25 May 1999||10 Sep 2002||Hughes Electronics Corporation||Method and apparatus for medium access control from integrated services packet-switched satellite networks|
|US6507908 *||4 Mar 1999||14 Jan 2003||Sun Microsystems, Inc.||Secure communication with mobile hosts|
|US6594254 *||14 Aug 1997||15 Jul 2003||Netspeak Corporation||Domain name server architecture for translating telephone number domain names into network protocol addresses|
|US6597687 *||26 Jun 1998||22 Jul 2003||Intel Corporation||Method and apparatus for switching voice calls using a computer system|
|US6600738 *||2 Oct 1999||29 Jul 2003||Ericsson, Inc.||Routing in an IP network based on codec availability and subscriber preference|
|US6603757 *||14 Apr 1999||5 Aug 2003||Excel Switching Corporation||Voice-data access concentrator for node in an expandable telecommunications system|
|US6618368 *||18 Feb 1999||9 Sep 2003||Hitachi, Ltd.||Data gateway and method for relaying data|
|US6665303 *||31 Dec 1998||16 Dec 2003||Kabushiki Kaisha Toshiba||Scheme for realizing communications through external network from contents processing device connected to local network in home environment|
|US6700884||20 Jun 2002||2 Mar 2004||Emerson, Iii Harry E.||Integrating the Internet with the public switched telephone network|
|US6704803 *||29 Dec 1998||9 Mar 2004||International Business Machines Corporation||Method and system for distributing data events over an information bus|
|US6704804 *||29 Dec 1998||9 Mar 2004||International Business Machines Corporation||Method and system for communicating information among interactive applications|
|US6754183 *||14 Jun 1999||22 Jun 2004||Sun Microsystems, Inc.||System and method for integrating a vehicle subnetwork into a primary network|
|US6754202 *||13 Jun 2000||22 Jun 2004||Altigen Communications, Inc.||Network call-back data capture method and apparatus|
|US6785263 *||23 Nov 1999||31 Aug 2004||Fujitsu Limited||Communication control method in complex switched network and gateway using the method|
|US6791970 *||16 Sep 1999||14 Sep 2004||Mediaring Ltd.||PC-to-phone for least cost routing with user preferences|
|US6801522 *||14 Aug 1998||5 Oct 2004||Yugen Kaisha Ls Net||Method of communicating with subscriber devices through a global communication network|
|US6801523 *||1 Jul 1999||5 Oct 2004||Nortel Networks Limited||Method and apparatus for performing internet protocol address resolutions in a telecommunications network|
|US6801952 *||26 Aug 2002||5 Oct 2004||Nortel Networks Limited||Method and devices for providing network services from several servers|
|US6807166 *||1 Feb 1999||19 Oct 2004||Fujitsu Limited||Gateway for internet telephone|
|US6813036 *||28 Jan 1999||2 Nov 2004||Brother Kogyo Kabushiki Kaisha||Internet facsimile machine|
|US6873689 *||7 Apr 2000||29 Mar 2005||International Business Machines Corporation||Voice processing system|
|US6931001 *||16 Jun 2003||16 Aug 2005||Verizon Laboratories Inc.||System for interconnecting packet-switched and circuit-switched voice communications|
|US6937587 *||9 Nov 1998||30 Aug 2005||Telefonaktiebolaget Lm Ericsson (Publ)||Method of and an arrangement for providing telecommunications service to a user in a data network|
|US6963928 *||26 May 2000||8 Nov 2005||Bagley David T||Systems and methods for communicating across various communication applications using single address strings|
|US6975601||19 Jun 2002||13 Dec 2005||The Directv Group, Inc.||Method and apparatus for medium access control for integrated services packet-switched satellite networks|
|US7023862||24 Jul 2003||4 Apr 2006||Kabushiki Kaisha Toshiba||Scheme for realizing communications through external network from contents processing device connected to local network in home environment|
|US7058047 *||8 Jun 2004||6 Jun 2006||Altigen Communications, Inc.||Network call-back data capture method and apparatus|
|US7103645 *||17 Apr 2003||5 Sep 2006||Massachusetts Institute Of Technology||Method and system for providing content delivery to a set of participating content providers|
|US7120630 *||28 Aug 2003||10 Oct 2006||International Business Machines Corporation||Full match (FM) search algorithm implementation for a network processor|
|US7213211||20 Oct 2003||1 May 2007||Dynamic Knowledge Transfer, Llc||System for knowledge transfer in a group setting|
|US7359960 *||20 Jul 2000||15 Apr 2008||Net2Phone, Inc.||Telecommunications control system using data interchange|
|US7366779 *||19 Jun 2000||29 Apr 2008||Aol Llc, A Delaware Limited Liability Company||Direct file transfer between subscribers of a communications system|
|US7369545 *||17 Sep 2003||6 May 2008||Cisco Technology, Inc.||System using a signaling protocol for controlling voice calls originating in a circuit switching telephone network and routed over a packet switching network|
|US7406071 *||31 Jan 2000||29 Jul 2008||Nokia Corporation||Method and system for resolving between geographic information and network addresses in a wide area network, preferably in the internet|
|US7411971||9 Sep 2004||12 Aug 2008||Avaya Inc.||Systems and methods for the schedule alignment of packet flow|
|US7443855 *||15 Nov 2004||28 Oct 2008||At & T Intellectual Property I, L.P.||Communication system and method using partially non-geographic addressing method for forming same|
|US7450596||3 Nov 2003||11 Nov 2008||Kabushiki Kaisha Toshiba||Scheme for realizing communications through external network from contents processing device connected to local network in home environment|
|US7502339 *||21 Jun 1999||10 Mar 2009||Nokia Telecommunications Oyj||Mobility within a packet-switched telephony network|
|US7512116 *||5 Aug 2004||31 Mar 2009||Fujitsu Limited||Gateway for internet telephone|
|US7535826 *||10 Dec 2001||19 May 2009||Juniper Networks, Inc||Routing protocols for accommodating nodes with redundant routing facilities|
|US7546337||18 May 2000||9 Jun 2009||Aol Llc, A Delaware Limited Liability Company||Transferring files|
|US7587039||18 Sep 2003||8 Sep 2009||At&T Intellectual Property, I, L.P.||Method, system and storage medium for providing automated call acknowledgement services|
|US7664097||22 Mar 2004||16 Feb 2010||Verizon Services Corp.||Telephone service via networking|
|US7664495||5 Dec 2005||16 Feb 2010||At&T Mobility Ii Llc||Voice call redirection for enterprise hosted dual mode service|
|US7693137||5 Jun 2006||6 Apr 2010||Verizon Corporate Sevices Group Inc.||Multi-line appearance telephony via a computer network|
|US7693959||1 Sep 2006||6 Apr 2010||Massachusetts Institute Of Technology||Content distribution system using an alternative domain name system (DNS) and content servers|
|US7715371||30 Oct 2006||11 May 2010||Comcast Ip Holdings I, Llc||Method and apparatus for accessing communication data relevant to a target entity identified by a number string|
|US7715413||25 Oct 2004||11 May 2010||Emerj, Inc.||Multi-network exchange system for telephony applications|
|US7756518 *||15 Oct 2003||13 Jul 2010||Alcatel-Lucent Usa Inc.||Method and system for minimizing call setup delay for calls occurring in one or more wireless networks|
|US7797433||29 Jun 2001||14 Sep 2010||Net2Phone||System, method, and computer program product for resolving addressing in a network including a network address translator|
|US7804816||25 Feb 2005||28 Sep 2010||Comcast Ip Holdings I, Llc||Method and apparatus for accessing communication data relevant to a target entity identified by a number string|
|US7808977 *||30 Oct 2007||5 Oct 2010||Genesys Telecommunications Laboratories, Inc.||Network telephony interface systems between data network telephony and plain old telephone service|
|US7813332||7 Feb 2005||12 Oct 2010||Verizon Services Corp.||Voice call alternative routing through PSTN and internet networks|
|US7817619||28 Feb 2000||19 Oct 2010||Verizon Services Corp.||Internet long distance telephone service|
|US7822871||30 Sep 2002||26 Oct 2010||Level 3 Communications, Llc||Configurable adaptive global traffic control and management|
|US7830860||21 May 2003||9 Nov 2010||Verizon Services Corp.||Packet data network voice call quality monitoring|
|US7860964||26 Oct 2007||28 Dec 2010||Level 3 Communications, Llc||Policy-based content delivery network selection|
|US7903641||20 Feb 2009||8 Mar 2011||Comcast Ip Holdings, I, Llc||Method and apparatus for accessing communication data relevant to a target entity identified by a number string|
|US7921161 *||29 Dec 2003||5 Apr 2011||Verizon Corporate Services Group Inc.||Routing T-37 E-mail over an H 323 (VOIP) network|
|US7945693||31 Oct 2007||17 May 2011||Level 3 Communications, Llc||Controlling subscriber information rates in a content delivery network|
|US7948968||2 Nov 2004||24 May 2011||Verizon Communications Inc.||Network session management|
|US7949779||31 Oct 2007||24 May 2011||Level 3 Communications, Llc||Controlling subscriber information rates in a content delivery network|
|US7953888||30 Jul 2003||31 May 2011||Level 3 Communications, Llc||On-demand overlay routing for computer-based communication networks|
|US7957366 *||18 Mar 2005||7 Jun 2011||Panasonic Corporation||IP telephone system, IP telephone apparatus and calling method|
|US7957368||7 Sep 2007||7 Jun 2011||U.S.I.P. Group Llc||Method and apparatus for establishing communications with a remote node on a switched network based on hypertext calling received from a packet network|
|US7958243||28 Apr 2008||7 Jun 2011||Aol Inc.||Direct file transfer between subscribers of a communications system|
|US8000316 *||14 Oct 2005||16 Aug 2011||Panasonic Corporation||IP telephone apparatus, ENUM server, terminal apparatus and IP telephone system|
|US8010680||3 Jun 2009||30 Aug 2011||Aol Inc.||Transferring files|
|US8060613||31 Oct 2007||15 Nov 2011||Level 3 Communications, Llc||Resource invalidation in a content delivery network|
|US8073961||5 Apr 2010||6 Dec 2011||Massachusetts Institute Of Technology||Global hosting system|
|US8089954 *||13 Jun 2005||3 Jan 2012||Panasonic Corporation||IP telephone system, IP telephone apparatus and communications method|
|US8149819 *||27 Jun 2005||3 Apr 2012||Panasonic Corporation||ENUM system, ENUM client apparatus and method for communicating using ENUM client apparatus|
|US8170008||20 Feb 2009||1 May 2012||Comcast Ip Holdings I, Llc|
|US8171084||20 Jan 2004||1 May 2012||Microsoft Corporation||Custom emoticons|
|US8185635 *||21 Apr 2008||22 May 2012||Microsoft Corporation||Transport system for instant messaging|
|US8189565||20 Feb 2009||29 May 2012||Comcast Ip Holdings I, Llc|
|US8204046||9 Aug 2010||19 Jun 2012||Comcast Ip Holdings I, Llc||Method and apparatus for accessing service resource items that are for use in a telecommunications system|
|US8208452 *||28 Jan 2009||26 Jun 2012||The Distribution Systems Research Institute||Integrated information communication system|
|US8223752||9 Feb 2012||17 Jul 2012||Comcast Ip Holdings I, Llc||Method for accessing service resource items that are for use in a telecommunications system|
|US8281035||26 May 2006||2 Oct 2012||Level 3 Communications, Llc||Optimized network resource location|
|US8291046||30 May 2007||16 Oct 2012||Level 3 Communications, Llc||Shared content delivery infrastructure with rendezvous based on load balancing and network conditions|
|US8296396||31 Oct 2007||23 Oct 2012||Level 3 Communications, Llc||Delivering resources to clients in a distributed computing environment with rendezvous based on load balancing and network conditions|
|US8358768 *||10 Apr 2007||22 Jan 2013||Tekelec, Inc.||Methods, systems, and computer program products for providing a country code identifier in an international ENUM system|
|US8379531||29 Sep 2008||19 Feb 2013||Verizon Services Corp.||Telephony communication via varied redundant networks|
|US8391134 *||10 Apr 2009||5 Mar 2013||Juniper Networks, Inc.||Routing protocols for accommodating nodes with redundant routing facilities|
|US8468245||30 May 2007||18 Jun 2013||Level 3 Communications, Llc||Delivering resources to clients in a distributed computing environment|
|US8473613||16 May 2011||25 Jun 2013||Level 3 Communications, Llc||Transparent redirection of resource requests|
|US8478903||23 Feb 2005||2 Jul 2013||Level 3 Communications, Llc||Shared content delivery infrastructure|
|US8543901||1 Nov 1999||24 Sep 2013||Level 3 Communications, Llc||Verification of content stored in a network|
|US8553681||15 Feb 2010||8 Oct 2013||Verizon Services Corp.||Telephone service via packet-switched networking|
|US8572208||30 May 2007||29 Oct 2013||Level 3 Communications, Llc||Shared content delivery infrastructure|
|US8572210||31 Oct 2007||29 Oct 2013||Level 3 Communications, Llc||Shared content delivery infrastructure and method of generating a web page|
|US8583751||14 Sep 2012||12 Nov 2013||Facebook, Inc.||Providing an indication that a user of a communications system is composing a message|
|US8599697||30 May 2011||3 Dec 2013||Level 3 Communications, Llc||Overlay network|
|US8645517||24 Dec 2010||4 Feb 2014||Level 3 Communications, Llc||Policy-based content delivery network selection|
|US8683076||30 May 2007||25 Mar 2014||Level 3 Communications, Llc||Method of generating a web page|
|US8699687||20 Dec 2005||15 Apr 2014||At&T Intellectual Property I, L.P.||Methods, systems, and computer program products for providing automated call acknowledgement and answering services|
|US8713114||6 Jun 2011||29 Apr 2014||Facebook, Inc.||Direct file transfer between subscribers of a communications systems|
|US8737386||21 Nov 2011||27 May 2014||Bear Creek Technologies, Inc.||System for interconnecting standard telephony communications equipment to internet|
|US8775557||26 Aug 2011||8 Jul 2014||Facebook, Inc.||Transferring files|
|US8924466||30 Oct 2007||30 Dec 2014||Level 3 Communications, Llc||Server handoff in content delivery network|
|US8930538||21 Mar 2009||6 Jan 2015||Level 3 Communications, Llc||Handling long-tail content in a content delivery network (CDN)|
|US8938062||18 Jun 2012||20 Jan 2015||Comcast Ip Holdings I, Llc||Method for accessing service resource items that are for use in a telecommunications system|
|US8942709||29 Dec 2009||27 Jan 2015||Shoretel, Inc.||Call redirection for enterprise hosted dual mode service|
|US8964949 *||1 Jul 2013||24 Feb 2015||Google Inc.||Voice response apparatus and method of providing automated voice responses with silent prompting|
|US8971216||7 Mar 2006||3 Mar 2015||Alcatel Lucent||Method for routing transactions between internal and external partners in a communication center|
|US8976782||31 Oct 2007||10 Mar 2015||Verizon Patent And Licensing Inc.||Network session management for telephony over hybrid networks|
|US9002920||13 May 2008||7 Apr 2015||Genesys Telecommunications Laboratories, Inc.||Method and apparatus for extended management of state and interaction of a remote knowledge worker from a contact center|
|US9008075||22 Dec 2008||14 Apr 2015||Genesys Telecommunications Laboratories, Inc.||System and methods for improving interaction routing performance|
|US9014177||14 Feb 2011||21 Apr 2015||Bear Creek Technologies, Inc.||System for interconnecting standard telephony communications equipment to internet|
|US9021057||14 Sep 2012||28 Apr 2015||Facebook, Inc.||Updating transferred files|
|US9021112||18 Mar 2008||28 Apr 2015||Level 3 Communications, Llc||Content request routing and load balancing for content distribution networks|
|US9025748 *||14 Sep 2012||5 May 2015||ZipDial Mobile Solutions Pvt. Ltd||Delivering specialized services to users of phones|
|US9031058||21 Nov 2011||12 May 2015||Bear Creek Technologies, Inc.||System for interconnecting standard telephony communications equipment to internet|
|US9037740||14 Sep 2012||19 May 2015||Facebook, Inc.||Preference based transferring of files|
|US20010056476 *||12 Apr 2001||27 Dec 2001||International Business Machines Corporation||System and method for accessing a server connected to an IP network through a non-permanent connection|
|US20020083198 *||2 Jul 2001||27 Jun 2002||Yong-Woon Kim||Method of automatically generating IPv6 address using E.164 telephone number and of looking up IP address assigned to E.164 telephone number|
|US20030079027 *||18 Oct 2001||24 Apr 2003||Michael Slocombe||Content request routing and load balancing for content distribution networks|
|US20040022194 *||30 Jul 2003||5 Feb 2004||Digital Island, Inc.||On-demand overlay routing for computer-based communication networks|
|US20040080544 *||29 Oct 2002||29 Apr 2004||Stripling Jeffrey Ricks||System and method for providing network access to devices using numeric input|
|US20040100978 *||3 Nov 2003||27 May 2004||Kabushiki Kaisha Toshiba|
|US20040162916 *||17 Feb 2004||19 Aug 2004||Ryan William Kenneth||Multiple use of identical names to identify different IP numerical addresses|
|US20040172588 *||8 Mar 2004||2 Sep 2004||Mattaway Shane D.||Collaborative multimedia architecture for packet-switched data networks|
|US20040174880 *||22 Mar 2004||9 Sep 2004||White Patrick E.||Internet telephone service|
|US20040243596 *||30 Jul 2003||2 Dec 2004||Roy Lillqvist||Enhancement of database performance in a Domain Name System|
|US20040252683 *||29 Jun 2001||16 Dec 2004||Kennedy Thomas Scott||System, method , and computer program product for resolving addressing in a network including a network address translator|
|US20050008008 *||5 Aug 2004||13 Jan 2005||Hitoshi Ohura||Gateway for internet telephone|
|US20050063364 *||8 Jun 2004||24 Mar 2005||Altigen Communications, Inc.||Network call-back data capture method and apparatus|
|US20050086312 *||29 Dec 2003||21 Apr 2005||Goodman Lee N.||Routing T-37 E-mail over an H 323 (VOIP) network|
|US20050091407 *||25 Oct 2004||28 Apr 2005||Tivox Systems, Inc||Multi-network exchange system for telephony applications|
|US20050111362 *||9 Sep 2004||26 May 2005||Cetacean Networks, Inc.||Systems and methods for the schedule alignment of a packet flow|
|US20050122939 *||9 Dec 2003||9 Jun 2005||Heng-Chien Chen||Roaming local area network|
|US20050141491 *||25 Feb 2005||30 Jun 2005||Hewlett-Packard Development Company, L.P.|
|US20050152340 *||2 Nov 2004||14 Jul 2005||Voit Eric A.||Network session management|
|US20050156873 *||20 Jan 2004||21 Jul 2005||Microsoft Corporation||Custom emoticons|
|US20050163125 *||15 Nov 2004||28 Jul 2005||Epley Robert V.||Communication system and method using partially non-geographic addressing method for forming same|
|US20050177552 *||28 Aug 2003||11 Aug 2005||Bass Brian M.||Full match (FM) search algorithm implementation for a network processor|
|US20050198334 *||23 Feb 2005||8 Sep 2005||Farber David A.||Optimized network resource location|
|US20050226223 *||18 Mar 2005||13 Oct 2005||Matsushita Electric Industrial Co., Ltd.||IP telephone system, IP telephone apparatus and calling method|
|US20060018311 *||13 Jun 2005||26 Jan 2006||Matsushita Electric Industrial, Co., Ltd.||IP telephone system, IP telephone apparatus and communications method|
|US20060020713 *||27 Jun 2005||26 Jan 2006||Matsushita Electric Industrial Co., Ltd.||ENUM system, ENUM client apparatus and method for communicating using ENUM client apparatus|
|US20060052110 *||15 Oct 2003||9 Mar 2006||Jianming Xu||Method and system for minimizing call setup delay for calls occurring in one or more wireless networks|
|US20060083217 *||2 Sep 2005||20 Apr 2006||Keun-Ah Bae||Element management method and system in multiple networks|
|US20060092922 *||14 Oct 2005||4 May 2006||Matsushita Electric Industrial Co., Ltd.||IP telephone apparatus, ENUM server, terminal apparatus and IP telephone system|
|US20060098792 *||20 Dec 2005||11 May 2006||Frank Scott M||Methods, systems, and computer program products for providing automated call acknowledgement and answering services|
|US20060140176 *||15 Feb 2006||29 Jun 2006||Verizon Services Corp.||Telephony communication via varied redundant networks|
|US20060195540 *||10 May 2006||31 Aug 2006||Michael Hamilton||Message routing with telecommunication number addressing and key management|
|US20060250990 *||5 Jun 2006||9 Nov 2006||Gardell Steven E||Multi-line appearance telephony via a computer network|
|US20070005689 *||1 Sep 2006||4 Jan 2007||Leighton F T||Content distribution system using an alternative domain name system (DNS) and content servers|
|US20080049918 *||10 Apr 2007||28 Feb 2008||Tekelec||Methods, systems, and computer program products for providing a country code identifier in an international enum system|
|US20100118861 *||1 Apr 2008||13 May 2010||Andreas Witzel||Inter-Working Between a Packet-Switched Domain and a Circuit-Switched Domain|
|US20130003955 *||3 Jan 2013||ZipDial Mobile Solutions Pvt. Ltd||Delivering specialized services to users of phones|
|USRE45583||19 Apr 2013||23 Jun 2015||Genesys Telecommunications Laboratories, Inc.||Method and apparatus for providing enhanced communication capability for mobile devices on a virtual private network|
|USRE45606||7 Mar 2013||7 Jul 2015||Genesys Telecommunications Laboratories, Inc.||Call and data correspondence in a call-in center employing virtual restructuring for computer telephony integrated functionality|
|WO2002084987A1 *||3 Apr 2002||24 Oct 2002||Sprint Spectrum Lp||Computer program and method for automatically setting up call routing for a metropolitan statistical area|
|WO2003003678A1 *||24 Jun 2002||9 Jan 2003||Harry E Emerson Iii||Integrating the internet with the public switched telephone network|
|WO2003009549A2 *||16 Jul 2002||30 Jan 2003||Harry E Emerson Iii||Central office for integrating the internet with pstn|
|WO2005025244A2 *||9 Sep 2004||17 Mar 2005||Avaya Technology Corp||Systems and methods for the schedule alignment of a packet flow|
|U.S. Classification||370/352, 370/401, 709/218|
|International Classification||H04L29/12, H04L12/64, H04M7/00, H04Q3/00|
|Cooperative Classification||H04L12/6418, H04L29/12103, H04L61/1535, H04M7/1285, H04L29/1216, H04L61/157, H04Q3/0025|
|European Classification||H04L61/15H, H04L61/15B, H04L29/12A2B, H04L29/12A2H, H04Q3/00D2, H04L12/64B, H04M7/12H18|
|29 Oct 1997||AS||Assignment|
Owner name: NETSPEAK CORPORATION, FLORIDA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:KELLY, KEITH C.;REEL/FRAME:008771/0343
Effective date: 19971020
|8 Aug 2005||FPAY||Fee payment|
Year of fee payment: 4
|12 Sep 2005||AS||Assignment|
Owner name: VOIP TECHNOLOGY HOLDINGS, LLC, NEW JERSEY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NETSPEAK CORPORATION;REEL/FRAME:016522/0205
Effective date: 20040325
|28 Oct 2005||AS||Assignment|
Owner name: NET2PHONE, INC., NEW JERSEY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NETSPEAK CORPORATION;REEL/FRAME:016945/0890
Effective date: 20051006
Owner name: NET2PHONE, INC., NEW JERSEY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:VOIP TECHNOLOGY HOLDINGS, LLC;REEL/FRAME:016945/0858
Effective date: 20051006
|9 Dec 2005||AS||Assignment|
Owner name: NET2PHONE, INC., NEW JERSEY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:VOIP TECHNOLOGY HOLDINGS, LLC;REEL/FRAME:017105/0240
Effective date: 20051006
|6 Aug 2009||FPAY||Fee payment|
Year of fee payment: 8
|12 Sep 2013||FPAY||Fee payment|
Year of fee payment: 12
|12 Sep 2013||SULP||Surcharge for late payment|
Year of fee payment: 11