In today's voice over IP (VoIP) environment, provisioning of VoIP phones is typically a “high touch” process. Typically, a truck rolls and or an on-site technician must be sent to a customer's premises in order that the VoIP phone may be installed and configured by the on-site technician so that the VoIP phone may provide the particular services desired by a user. The VoIP phone must then be provisioned at a feature server before the VoIP phone may operate on a communication network or use the features provided by a feature server. This requirement for truck rolls and on-site technicians makes the provisioning process both costly and time consuming.
An embodiment of a method for provisioning of a communication device includes receiving a registration request from a first communication device. The registration request includes an address associated with the first communication device. The method further includes registering the first communication device in response to receiving the registration request, placing a call request to the first communication device, and establishing a call session with the first communication device. The method further includes prompting a user of the first communication device for a user identifier, and receiving a user identifier from the user of the first communication device. The method still further includes sending one or more configuration parameters associated with the user identifier to the first communication device. The one or more configuration parameters are operable to configure the first communication device.
An embodiment of an apparatus for provisioning of a communication device includes a memory and at least one processor. The at least one processor is configured to retrieve computer readable instructions from the memory and execute the computer readable instruction so as to receive a registration request from a first communication device. The registration request includes an address associated with the first communication device. The at least one processor is further configured to register the first communication device in response to receiving the registration request, and receive a user identifier from the first communication device. The at least one processor is further configured to send one or more configuration parameters associated with the user identifier to the first communication device. The one or more configuration parameters are operable to configure the first communication device.
An embodiment of a method for user-initiated provisioning a communication device includes sending a registration request to a feature server. The registration request includes an address associated with a first communication device. The method further includes receiving a call request from the feature server in response to sending the registration request, and establishing a call session with the feature server. The method further includes receiving a prompt from the feature server for a user to provide a user identifier, receiving a user identifier from the user, and sending the user identifier to the feature server. The method further includes receiving one or more configuration parameters associated with the user identifier. The one or more configuration parameters are operable to configure the first communication device.
Illustrative embodiments of the present invention are described in detail below with reference to the attached drawing figures, which are incorporated by reference herein and wherein:
In various embodiments, the first communication device 105 is a packet-based telephony network phone. In a particular embodiment, the first communication device 105 is a VoIP phone. In still other embodiments, the first communication device 105 may include a cell phone, a wireless phone, a software phone, or any other communication device. The first communication device 105 includes a configuration file storage 110, a processor 115 and a memory 120. The configuration file storage 110 is configured to store one or more configuration files for use in configuring the first communication device 105. The configuration files include configuration information and configuration parameters for the first communication device 105. For example, the configuration parameters may include configuration information required to support calling features available for the first communication device 105. The processor 115 is configured to retrieve computer readable instructions from the memory 120 and execute the computer readable instructions to perform the various functions of the first communication device 105, described herein. In various embodiments, the first communication device 105 is configured to initiate and receive requests to establish communication sessions with one or more other communication devices. In particular embodiments, the communication sessions include a voice calling session.
In various embodiments, the network(s) 125 is one or more of a wireless network, a wired network, a packet switched network, an asynchronous transfer mode (ATM) network, a public switched telephone network (PSTN), and any other communication network.
In various embodiments, the feature server 130 is configured to provide calling features and other desired phone features to the first communication device 105, as well as provision the first communication device 105 for operation with the network(s) 125. Examples of call features that may be provided to the first communication device 105 by the feature server 130 include calling forwarding, selective call forwarding, selective call acceptance, selective call rejection, call blocking, conference calling, call directories, 911 services, and voice mail services. A particular embodiment of the feature server 130 is further described with respect to
In various embodiments, the second communication device 135 may include a telephone, a mobile phone, or any other communication device. Upon provisioning of the first communication device 105, a user or the first communication device 105 may send or receive call requests to and from the second communication device 135, and use calling features provided by the feature server 130.
The user profile storage 205 is configured to store one or more user profiles associated with one or more users or customers that are to use calling features or services provided by the feature server 130. In various embodiments, each user profile is associated with a particular communication device in communication with the network(s) 125, for example, the first communication device 105. In a particular embodiment, a particular user profile includes a user identifier associated with the first communication device 105, an address associated with the first communication device 105, and a configuration file associated with the user identifier. In at least one embodiment, the configuration file includes configuration parameters for configuring the first communication device 105 for operation with the network(s) 125, and for operation with any features and/or services provided by the feature server 130 to which the user is authorized.
The features module 210 is configured to provide one or more calling features and service to communication devices registered with the feature server 130. In a particular embodiment, the features module 210 is configured to provide one or more calling features and/or services to the first communication device 105 that are authorized.
The IVR module 215 is configured to receive a voice input from a user of the first communication device 105, process the voice input, and perform a desired function or functions in response to the voice input. In a particular embodiment, the IVR module 215 may receive a user identifier spoken by the user of the first communication device 105. The feature server 130 may then match the user identifier to a corresponding user profile for use in configuring and provisioning the first communication device 105.
The provisioning module 220 is configured to provision the first communication device 105 for operation with the feature server 130 and the network(s) 125. In a particular embodiment, the provisioning module 220 is configured to receive an address associated with the first communication device 105, for example, a media access control (MAC) address, and populate a provisioning table with the received address. In various embodiments, the provisioning module 220 is operable to receive a user identifier associated with the first communication device 105 from a user of the first communication device, and send a configuration file associated with the user identifier to the first communication device 105 in response to receiving the user identifier.
As described, the feature server 130 further includes a processor 225 and a memory 230. In various embodiments, the processor 225 is configured to retrieve computer readable instructions from the memory 230 and execute the computer readable instructions to perform the various functions of the feature server 130 described herein.
In step 320, the user-specific configuration file is associated with the user profile. The user profile is then stored in the user profile storage 205 for subsequent download to the first communication device 105 during a provisioning procedure. In at least one embodiment, the first communication device 105 is preconfigured with a default configuration file within the configuration file storage 110. The default configuration file is not specific to a particular user. In various embodiments, the first communication device 105 is drop shipped to a customer premise location and a user is instructed to couple the first communication device 105 to a power source and network connection. Upon coupling the first communication device 105 to a power source and a network connection, the first communication device 105 retrieves an address associated with the feature server 130 from the default configuration file and sends a registration request to the feature server 130 with a destination address equal to the address associated with the feature server 130. In a particular embodiment, the address associated with the feature server 130 is an IP address. In various embodiments, the feature server 130 is configured to send the user-specific configuration file to the first communication device 105 in response to receiving the registration request. In some embodiments, the feature server 130 is further configured to provision the first communication device 105 at the feature server 130.
In step 435, the call session between the first communication device 105 and the feature server 130 is disconnected. In a particular embodiment, the IVR module 215 of the feature server 130 prompts the user of the first communication device 105 to hang up in order to disconnect the call session. After disconnection of the call session, the feature server 130 sends a reboot request to the first communication device 105 in step 440. The reboot request instructs the first communication device 105 to reboot and/or restart. In step 445, the feature server 130 matches the user identifier to an associated user profile stored in the user profile storage 205 and sends a user-specific configuration file associated with the user profile to the first communication device 105. In various embodiments, the user-specific configuration file is used by the first communication device 105 to configure the user communication device 105 for operation with the feature server 130, as well as with the authorized features provided for the first communication device 105 by the feature server 130.
In step 450, the address associated with the first communication device is stored by the feature server 130. In a particular embodiment, the feature server 130 stores the address in a provisioning table of the processing module 220. In a particular embodiment, the address is a MAC address of the first communication device 105 and is populated in a provisioning table of the feature server 130. In step 455, the address associated with the first communication device 105 is associated with the user profile. Accordingly, the user profile, the address associated with the first communication device 105, and the user-specific configuration file are associated together and stored within the user profile storage 205 of the feature server 130.
After configuration and provisioning of the first communication device 105 by the feature server 130, the first communication device 105 is configured to operate with the feature server 130 and network(s) 125 and features provided by the feature server 130 and placing and receiving calls with other communication devices coupled to the network(s) 125, such as the second communication device 135. In step 460, the procedure 400 ends.
In step 505, the user connects the first communication device to a power source. In at least one embodiment, the user connects the first communication device 105 to a power source by plugging a power cord of the first communication device into a power outlet. In another embodiment, the user may connect the first communication device to a power source by installing batteries within the first communication device 105. In step 510, the user connects the first communication device 105 to a network connection. The network connection places the first communication device 105 in communication with the network(s) 125. In at least one embodiment, the network connection is an internet connection. In step 515, the first communication device 105 retrieves the feature server address from the default configuration file in response to connecting the first communication device 105 to the network connection. In at least one embodiment, the feature server address is an IP address associated with the feature server. In still other embodiments, the first communication device 105 may be connected to the internet connection prior to being connected to the power source. In still other embodiments, the network connection is a wireless connection that is established with the network(s) 125 after the first communication device 105 is powered-on.
In step 520, the first communication device 105 sends a registration request to the feature server at the feature server address retrieved from the default configuration file. The registration request includes an address associated with the first communication device 105 that is stored in a memory 120 of the first communication device 105. In a particular embodiment, the address associated with the first communication 105 is a MAC address. The registration request is received by the feature server 130, and the feature server 130 registers the first communication device 105 in response to receiving the registration request. The feature server 130 then sends a call request to the first communication device 105. In step 525, the first communication device 105 receives the call request from the feature server 130. In step 530, the user of the first communication device 105 answers the call request and a call session is established between the first communication device 105 and the feature server 130. In step 535, the first communication device 105 receives a prompt from the feature server 130 prompting a user of the first communication device 105 to provide a user identifier. In at least one embodiment, the prompt from the feature server may include an audio prompt instructing the user to provide a user identifier. In still other embodiments, the prompt from the feature server 130 may include a text prompt that is displayed on a display of the first communication device 105 instructing the user to provide a user identifier.
In step 540, the first communication device 105 receives the user identifier from the user. In at least one embodiment, the user provides the user identifier to the first communication device by speaking the user identifier into a microphone or handset of the first communication device 105. In other embodiments, the user provides the user identifier to the first communication device 105 by typing the user identifier on a keypad or other tactile input device of the first communication device 105. In step 545, the first communication device 105 sends the user identifier to the feature server 130. In step 550, the call session is disconnected. In a particular embodiment, the feature server 130 may prompt the user of the first communication device 105 by either voice or text to hang up the connection in order to disconnect the call session. In step 555, the first communication device 105 receives a reboot request from the feature server 130. In response to receiving the reboot request, the first communication device 105 reboots and/or restarts. In step 565, the first communication device 105 receives a user-specific configuration file associated with the user identifier from the feature server 130. In a particular embodiment, the user-specific configuration file is stored within the configuration file storage 110 of the first communication device 105. In some embodiments, the default configuration file and the user-specific configuration file are both stored within the configuration file storage 110. In still other embodiments, the user-specific configuration file may replace the default configuration file within the configuration file storage 110.
In step 570, the first communication device 105 is configured according to one or more configuration parameters within the user-specific configuration file. Once the first communication device 105 is configured according to the user-specific configuration file, the first communication device 105 may use call features provided by the feature server 130, as well as communicate with other communication devices in communication with the network(s) 125. For example, the first communication device 105 may place or receive a call to the second communication device 130, and establish a communication session between the first communication device 105 and the second communication device 130. In a particular embodiment, the established communication session between the first communication device 105 and the second communication device 135 is a voice call session. In step 575, the procedure 500 ends.
In alternative embodiments, the user of the first communication device 105 is prompted to enter the user identifier when the first communication device 105 is turned on for the first time by the user. In particular embodiments, the prompt includes one or more of a text prompt or a voice prompt. The user identifier is then communicated automatically to the feature server 130, and the feature server 130 registers the first communication device 105 in response to receiving the user identifier. In at least one embodiment, the user identifier is to sent to the feature server 130 as part of a registration request. At the same time as or immediately after the feature server 130 registers the first communication device 105, the feature server 130 automatically sends the user-specific configuration file to the first communication device 105. In response to receiving the user-specific configuration file, the first communication device 105 is configured according to one or more configuration parameters within the user-specific configuration file. Once the first communication device 105 is configured according to the user-specific configuration file, the first communication device 105 may use call features provided by the feature server 130, as well as communicate with other communication devices in communication with the network(s) 125.
In various embodiments, user initiated provisioning of communication devices, such as IP phones, eliminates the need to send a truck roll or a technician to a customer's premises. In some embodiments, the use of the IVR module 215 allows for a user to self-provision a communication device via voice while requiring little to no technical knowledge or expertise by the end user.
The illustrative embodiments can take the form of an entirely hardware embodiment, an entirely software embodiment, or an embodiment containing both hardware and software elements. Furthermore, the illustrative embodiments can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer-readable medium can be any tangible apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The computer-usable or computer-readable medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk, and an optical disk. Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W), and DVD.
Further, a computer storage medium may contain or store a computer-readable program code, such that when the computer-readable program code is executed on a computer, the execution of this computer-readable program code causes the computer to transmit another computer-readable program code over a communication link. This communication link may use a medium that is, for example, without limitation, physical, or wireless.
The previous detailed description is of a small number of embodiments for implementing the invention and is not intended to be limiting in scope. One of skill in this art will immediately envisage the methods and variations used to implement this invention in other areas than those described in detail. The following claims set forth a number of the embodiments of the invention disclosed with greater particularity.
This application is a continuation of U.S. patent application Ser. No. 14/543,685 filed Nov. 17, 2014 by Mike A. Roberts et al. and titled, “System, Method, and Apparatus for User-Initiated Provisioning of a Communication Device”, which is a continuation of U.S. patent application Ser. No. 12/250,349 (now U.S. Pat. No. 8,917,718), filed Oct. 13, 2008 by Mike A. Roberts et al. and titled, “System, Method, and Apparatus for User-Initiated Provisioning of a Communication Device”, the entire teachings of which are incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5414697 | Osaki | May 1995 | A |
6345051 | Gupta et al. | Feb 2002 | B1 |
6901425 | Dykes et al. | May 2005 | B1 |
7079540 | Wilson et al. | Jul 2006 | B1 |
7152117 | Stapp et al. | Dec 2006 | B1 |
7447632 | Itou | Nov 2008 | B2 |
7526762 | Astala | Apr 2009 | B1 |
7580402 | Masuhiro et al. | Aug 2009 | B2 |
7639696 | Wu | Dec 2009 | B2 |
7639792 | Qiu et al. | Dec 2009 | B2 |
7940773 | Kerr et al. | May 2011 | B2 |
7948909 | Bugenhagen et al. | May 2011 | B2 |
7996013 | Hansson et al. | Aug 2011 | B2 |
8364746 | Annamalai | Jan 2013 | B2 |
8527980 | Stich | Sep 2013 | B2 |
8917718 | Roberts | Dec 2014 | B2 |
9584562 | Roberts et al. | Feb 2017 | B2 |
20010030977 | May | Oct 2001 | A1 |
20020003789 | Kim et al. | Jan 2002 | A1 |
20020075845 | Mullaney et al. | Jun 2002 | A1 |
20020085577 | Kim | Jul 2002 | A1 |
20020110121 | Mishra | Aug 2002 | A1 |
20020163447 | Runyon | Nov 2002 | A1 |
20020193989 | Geilhufe et al. | Dec 2002 | A1 |
20030110371 | Yang et al. | Jun 2003 | A1 |
20030194078 | Wood et al. | Oct 2003 | A1 |
20030206546 | Beyda | Nov 2003 | A1 |
20040119894 | Higgins et al. | Jun 2004 | A1 |
20040141461 | Zimmer et al. | Jul 2004 | A1 |
20040230695 | Anschutz et al. | Nov 2004 | A1 |
20050013301 | Bouchat et al. | Jan 2005 | A1 |
20050204162 | Rayes et al. | Sep 2005 | A1 |
20050226215 | Delregno et al. | Oct 2005 | A1 |
20060020460 | Itou | Jan 2006 | A1 |
20060101028 | Banks | May 2006 | A1 |
20060159008 | Sridhar et al. | Jul 2006 | A1 |
20060165086 | Wilson et al. | Jul 2006 | A1 |
20060168167 | Kushalnagar et al. | Jul 2006 | A1 |
20060218624 | Ravikumar | Sep 2006 | A1 |
20060239183 | Robitaille | Oct 2006 | A1 |
20060245435 | Sajassi | Nov 2006 | A1 |
20060245439 | Sajassi | Nov 2006 | A1 |
20070036358 | Nguyen et al. | Feb 2007 | A1 |
20070076607 | Volt et al. | Apr 2007 | A1 |
20070153799 | Sorrini et al. | Apr 2007 | A1 |
20070123288 | Hofbauer | May 2007 | A1 |
20070147356 | Malas | Jun 2007 | A1 |
20070167175 | Wong et al. | Jul 2007 | A1 |
20070171912 | Mitsumori | Jul 2007 | A1 |
20070177548 | Oyama et al. | Aug 2007 | A1 |
20070204330 | Townsley et al. | Aug 2007 | A1 |
20070206582 | Kuncoro | Sep 2007 | A1 |
20070220596 | Keeler et al. | Sep 2007 | A1 |
20070258456 | Khouderchah et al. | Nov 2007 | A1 |
20070280267 | Ould-Brahim | Dec 2007 | A1 |
20070286207 | Almalki et al. | Dec 2007 | A1 |
20070299987 | Parker et al. | Dec 2007 | A1 |
20080034068 | Vaughan | Feb 2008 | A1 |
20080046873 | Rumsey | Feb 2008 | A1 |
20080049623 | Qiu et al. | Feb 2008 | A1 |
20080075261 | Ramanathan | Mar 2008 | A1 |
20080098006 | Pedersen et al. | Apr 2008 | A1 |
20080120694 | Pandey | May 2008 | A1 |
20080130628 | Lin et al. | Jun 2008 | A1 |
20080151906 | Kolli et al. | Jun 2008 | A1 |
20080207181 | Jiang | Aug 2008 | A1 |
20080293408 | Jiang | Nov 2008 | A1 |
20080314973 | Zuhars | Dec 2008 | A1 |
20090016517 | Emmanuel | Jan 2009 | A1 |
20090028315 | Tovino | Jan 2009 | A1 |
20090067437 | Krishnan | Mar 2009 | A1 |
20090109845 | Andreasen | Apr 2009 | A1 |
20090168756 | Kurapati | Jul 2009 | A1 |
20090185564 | Kerr et al. | Jul 2009 | A1 |
20090217317 | White | Aug 2009 | A1 |
20100091762 | Roberts et al. | Apr 2010 | A1 |
20100142445 | Schlicht | Jun 2010 | A1 |
20100144313 | Chun | Jun 2010 | A1 |
20100217837 | Ansari | Aug 2010 | A1 |
20120331524 | Mower | Dec 2012 | A1 |
20150078373 | Roberts et al. | Mar 2015 | A1 |
Entry |
---|
U.S. Appl. No. 12/250,349; Issue Notification dated Dec. 3, 2014; 1 page. |
U.S. Appl. No. 12/009,384; Non-Final Rejection dated Sep. 15, 2009; 25 pages. |
U.S. Appl. No. 12/009,384; Final Rejection dated Jan. 29, 2010; 24 pages. |
U.S. Appl. No. 12/009,384; Non-Final Rejection dated Apr. 29, 2010; 25 pages. |
U.S. Appl. No. 12/009,384; Non-Final Rejection dated Sep. 1, 2010; 24 pages. |
U.S. Appl. No. 12/009,384; Notice of Allowance dated Feb. 8, 2011; 17 pages. |
U.S. Appl. No. 12/009,384; Issue Notification dated Apr. 20, 2011; 1 page. |
U.S. Appl. No. 12/250,349; Non-Final Rejection dated Mar. 15, 2012; 35 pages. |
U.S. Appl. No. 12/250,349; Final Rejection dated Jul. 19, 2012; 44 pages. |
U.S. Appl. No. 12/250,349; Non-Final Rejection dated Sep. 25, 2012; 49 pages. |
U.S. Appl. No. 12/250,349; Final Rejection dated Dec. 20, 2012; 50 pages. |
U.S. Appl. No. 12/250,349; Non-Final Rejection dated Jul. 31, 2013; 26 pages. |
U.S. Appl. No. 12/250,349; Final Rejection dated Dec. 17, 2013; 24 pages. |
U.S. Appl. No. 12/250,349; Non-Final Rejection dated Apr. 8, 2014; 33 pages. |
U.S. Appl. No. 12/250,349; Notice of Allowance dated Aug. 15, 2014; 28 pages. |
U.S. Appl. No. 14/543,685; Non-Final Rejection dated Jun. 24, 2015; 42 pages. |
U.S. Appl. No. 14/543,685; Final Rejection dated Oct. 27, 2015; 35 pages. |
An Chan, VoIP over Multiple IEEE 802.11 Wireless Lans; 2007; IEEE. |
U.S. Appl. No. 14/543,685; Non-Final Rejection dated Mar. 2, 2016; 37 pages. |
U.S. Appl. No. 14/543,685; Final Rejection dated Jun. 27, 2016; 38 pages. |
U.S. Appl. No. 14/543,685; Notice of Allowance dated Oct. 18, 2016; 21 pages. |
U.S. Appl. No. 14/543,685; Issue Notification dated Feb. 8, 2017; 1 page. |
Number | Date | Country | |
---|---|---|---|
20170149847 A1 | May 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14543685 | Nov 2014 | US |
Child | 15426327 | US | |
Parent | 12250349 | Oct 2008 | US |
Child | 14543685 | US |