A communication device is configured to store one or more aggregator service application modules for use in accessing one or more different aggregator, services. Each aggregator service offers access through a plurality of offered wireless networks identified by a plurality of offered wireless network identifiers. The communication device maintains a prioritized list of profiles which include one or more aggregator service profiles associated with the one or more aggregator services. A scanning operation is performed for identifying one or more available wireless networks in a geographic area of the device, for producing a scan list of one or more available wireless network identifiers corresponding to the one or more available wireless networks. One of the aggregator service profiles is selected from the prioritized list, causing one of the aggregator service application modules corresponding to the selected profile to be invoked. The invoked module causes one of the available wireless network identifiers from the scan list that matches one of the offered wireless network identifiers to be selected, if such matching identifier exists. A connection is established with one of the available wireless networks corresponding to the selected available wireless network identifier, for accessing a selected aggregator service corresponding to the selected aggregator service profile.
|
1. A network selection method for use in a communication device, the method comprising:
maintaining, in memory, a prioritized list of profiles, which prioritized list includes a plurality of hotspot aggregator service profiles associated with one or more hotspot aggregator services provided by a plurality of offered wireless networks, wherein each hotspot aggregator service profile among the plurality of hotspot aggregator service profiles includes an aggregator identifier and login credentials associated with the each hotspot aggregator service profile, wherein the each hotspot aggregator service profile corresponds to a hotspot aggregator service application module among a plurality of hotspot aggregator service application modules;
causing a scanning operation to be performed for identifying one or more available wireless networks in a geographic area of the communication device, for producing a scan list of one or more available wireless network identifiers corresponding to one or more available wireless networks;
identifying a selected hotspot aggregator service profile from among the prioritized list of profiles;
invoking the hotspot aggregator service application module corresponding to the selected hotspot aggregator service profile, the hotspot aggregator service application module configured to:
identify a plurality of offered wireless network identifiers corresponding to the plurality of offered wireless networks that offer a hotspot aggregator service corresponding to the selected hotspot aggregator service profile;
compare the one or more available wireless network identifiers in the scan list with the plurality of offered wireless network identifiers to identify one or more matching wireless network identifiers;
cause a connection to be established with one of the wireless networks that are both offered and available corresponding to one of the matching wireless network identifiers; and
respond to a request, from the one of the wireless networks, for login credentials specific to the selected hotspot aggregator service profile.
24. A non-transitory computer readable medium having instructions stored thereon executable by one or more processors of a communication device, the instructions comprising instructions for:
maintaining, in memory, a prioritized list of profiles, which prioritized list includes a plurality of hotspot aggregator service profiles associated with one or more hotspot aggregator services provided by a plurality of offered wireless networks, wherein each hotspot aggregator service profile among the plurality of hotspot aggregator service profiles includes an aggregator identifier and login credentials associated with the each hotspot aggregator service profile, wherein the each hotspot aggregator service profile corresponds to a hotspot aggregator service application module among a plurality of hotspot aggregator service application modules;
causing a scanning operation to be performed for identifying one or more available wireless networks in a geographic area of the communication device, for producing a scan list of one or more available wireless network identifiers corresponding to one or more available wireless networks;
identifying a selected hotspot aggregator service profile from among the prioritized list of profiles;
invoking the hotspot aggregator service application module corresponding to the selected hotspot aggregator service profile, the hotspot aggregator service application module configured to:
identify a plurality of offered wireless network identifiers corresponding to the plurality of offered wireless networks that offer a hotspot aggregator service corresponding to the selected hotspot aggregator service profile;
compare the one or more available wireless network identifiers in the scan list with the plurality of offered wireless network identifiers to identify one or more matching wireless network identifiers; and
cause a connection to be established with one of the wireless networks that are both offered and available corresponding to one of the matching wireless network identifiers; and
respond to a request, from the one of the wireless networks, for login credentials specific to the selected hotspot aggregator service profile.
13. A communication device comprising:
one or more processors;
a wireless transceiver coupled to the one or more processors;
a memory coupled to the one or more processors;
the memory being configured to store a prioritized list of profiles, which prioritized list includes a plurality of hotspot aggregator service profiles associated with one or more hotspot aggregator services provided by a plurality of offered wireless networks, wherein each hotspot aggregator service profile among the plurality of hotspot aggregator service profiles includes an aggregator identifier and login credentials associated with the each hotspot aggregator service profile, wherein the each hotspot aggregator service profile corresponds to a hotspot aggregator service application module among a plurality of hotspot aggregator service application modules;
a wireless network connection module which is executed by the one or more processors, the wireless network connection module being configured:
to cause a scanning operation to be performed, with use of the wireless transceiver, for identifying one or more available wireless networks in a geographic area of the communication device, for producing a scan list of one or more available wireless network identifiers corresponding to the one or more available wireless networks; and
to cause a connection to be established, with use of the wireless transceiver, with a selected available wireless network identified by a selected available wireless network identifier; and
a master service management module which is executed by the one or more processors, the master service management module being configured to:
select, in prioritized order, one of the hotspot aggregator service profiles in the prioritized list of profiles to, thereby, identify a selected hotspot aggregator service profile;
invoke the hotspot aggregator service application module corresponding to the selected hotspot aggregator service profile, the hotspot aggregator service application module being configured to:
identify a plurality of offered wireless network identifiers corresponding to the plurality of offered wireless networks that offer a hotspot aggregator service corresponding to the selected hotspot aggregator service profile;
compare the one or more available wireless network identifiers in the scan list with the plurality of offered wireless network identifiers to identify one or more matching wireless network identifiers;
cause the connection to be established with one of the wireless networks that are both offered and available corresponding to one of the one or more matching wireless network identifiers; and
respond to a request, from the one of the wireless networks, for login credentials associated with the selected hotspot aggregator service profile.
2. The method of
3. The method of
4. The method of
communicating, from a master service management module to the hotspot aggregator service application module, the one or more available wireless network identifiers; and
receiving, at the master service management module from the hotspot aggregator service application module, the one or more matching wireless network identifiers.
5. The method of
communicating, from a master service management module to the hotspot aggregator service application module, the one or more available wireless network identifiers; and
receiving, at the master service management module from the hotspot aggregator service application module, the one or more matching wireless network identifiers that were identified by the hotspot aggregator service application module.
6. The method of
invoking a second one of the hotspot aggregator service application modules corresponding to a second selected hotspot aggregator service profile from the prioritized list, for selecting a second one of the available wireless network identifiers in the scan list that matches a second one of the plurality of offered wireless network identifiers provided via the second hotspot aggregator service application module; and
causing a connection to be established with a second one of the available wireless networks corresponding to the selected second available wireless network identifier.
7. The method of
causing the prioritized list of profiles, which include the wireless network profiles and the plurality of hotspot aggregator service profiles, to be displayed in a display of the communication device; and
causing the identifying of the selected hotspot aggregator service profile from among the prioritized list to be accomplished in accordance with a manual network selection method.
8. The method of
receiving a request for login; and
calling the hotspot aggregator service application module for submission of the login credentials to the wireless network.
9. The method of
10. The method of
when there are two or more matching wireless network identifiers, selecting, by the master service management module, a preferred matching wireless network identifier based on predetermined criteria.
11. The method of
12. The method of
14. The communication device of
15. The communication device of
16. The communication device of
17. The communication device of
18. The communication device of
19. The communication device of
20. The communication device of
21. The communication device of
22. The communication device of
23. The communication device of
|
The present application is a continuation of U.S. patent application Ser. No. 12/858,584, which was filed Aug. 18, 2010, now U.S. Pat. No. 9,107,142, issued Aug. 11, 2015.
The present disclosure relates generally to techniques for use in providing access to aggregator services for a mobile communication device via a wireless network, such as via a wireless local area network (WLAN) hotspot or similar environment.
A mobile communication device may obtain communication services in wireless communication networks, such as wireless local area networks (WLANs) which are based on IEEE 802.11-based communication standards. Throughout operation, the mobile device may exit and enter many different WLANs. To assist in selecting from these networks, the mobile device may utilize a prioritized list of network identifications.
The mobile device may encounter a WLAN which may be a “hotspot” which provides a captive portal. Here, a user login or other user response will be required prior to the mobile device obtaining any useful services via the WLAN hotspot. With laptop computers, users often intend to use and “surf” the Internet, interacting with the keyboard of the laptop computer to invoke a Web browser application when desired. When the Web browser application is opened, the request is detected which causes a request for a server site to be sent in order to receive data of a desired website. However, the request is typically redirected by a WLANs hotspot for user login, after which the mobile device will obtain service, assuming the authentication is positive. For mobile devices which are intended primarily for voice telephony (e.g. cell phones), electronic mail (e-mail) communications, and/or other “push-type” data communications, login is also required.
The popularity of Internet access through WLANs hotspots has led to the emergence of a new kind of entity: a hotspot aggregator. A hotspot aggregator provides wireless Internet access to its customers by renting a WLAN connection to the Internet (i.e. the “WLAN hotspot”) from a plurality of hotspot owners (e.g. at coffee shops, hotels, and airports). In contrast to an ordinary telecommunications entity, a hotspot aggregator does not (necessarily) Own the access networks, but rather relies on a network of independently-owned and operated WLANs hotspots. Examples of current hotspot aggregators are Boingo and iPass.
One or more aggregator services may be offered in a single WLAN hotspot and, in any given WLAN hotspot, some aggregator services may be made offered while others may not be. A WLAN hotspot may utilize only a single Set Service Identifier (SSID) for identification, and it may not be readily apparent to roaming mobile devices what particular aggregator service is provided in any particular WLAN hotspot. Traditionally, an aggregator provides client software to install in the mobile device to aid in finding the appropriate WLANs and signing in for service. Locally-stored directories of WLAN hotspot locations and details may be provided (e.g. which SSIDs are supported), which requires some type of network connection for updates. The existing ways of obtaining service are specific to each particular aggregator. For, example, each WLAN hotspot may require a different way of logging in for access (e.g. different web sites for login).
Typically, after installation, conventional client software seizes and maintains control over the WLAN selection mechanism of the mobile device which is utilized for selecting and connecting to an appropriate WLAN. There is little flexibility for a conventional mobile device to be able to utilize multiple aggregator services in an easy and efficient manner.
Accordingly, what are needed are methods and apparatus which overcome these and other related deficiencies of the prior art. Other types of networks and devices may experience the same or similar deficiencies.
Embodiments of present invention will now be described by way of example with reference to attached figures, wherein:
Network selection methods and apparatus for communication devices utilizing a “master” service management module and a prioritized list of multiple aggregator service profiles for accessing multiple aggregator services are described herein. A communication device is configured to store one or more aggregator service application modules for use in accessing one or more different aggregator services. Each aggregator service offers access through a plurality of offered wireless networks identified by a plurality of offered wireless network identifiers. The communication device maintains a prioritized list of profiles which include one or more aggregator service profiles associated with the one or more aggregator services. A scanning operation is performed for identifying one or more available wireless networks in a geographic area of the device, for producing a scan list of one or more available wireless network identifiers corresponding to the one or more available wireless networks. One of the aggregator service profiles is selected from the prioritized list, causing one of the aggregator service application modules corresponding to the selected profile to be invoked. The invoked module causes one of the available wireless network identifiers from the scan list that matches one of the offered wireless network identifiers provided via the aggregator service application module to be selected, if such matching identifier exists. A connection is established with one of the available wireless networks corresponding to the selected available wireless network identifier, for accessing a selected aggregator service corresponding to the selected aggregator service profile.
To illustrate one exemplary network architecture,
Mobile device 202 may also operate on different WLANs, such as WLAN 122. Similar to WLAN 104, WLAN 122 has a plurality of wireless APs 128, 130 and 132, one or more servers 124, and a gateway 126. In this embodiment, WLAN 122 is a private communication network of an enterprise (small company, corporation, etc.) associated with mobile device 202.
Such WLANs 104 and 122 may provide or allow access to various data and communication services to its terminals. For example, the WLANs may provide for access to Internet 120 via the Web browser application, or voice telephony communication services with use of Voice over IP (VoIP) communications or other techniques. Note that some communication applications utilized by terminals, such as VoIP applications, require the use of SIP. SIP is well-documented in standard documents such as Request For Comments (RFC) 3261.
For “push-type” data or message synchronization services, mobile device 202 is enabled to maintain data synchronization with a server (e.g. server 106, 118, or 124) for user data of an application associated with a user account. The application of mobile device 202 and the server may be or include, for example, an electronic mail (e-mail) application program for the communication of e-mail messages. In this case, the data synchronization is a message synchronization for the e-mail messages associated with the user account for an e-mail application program. The data synchronization may alternatively or additionally be or include an address book synchronization for address book contacts in an address book organizer, or a calendar appointment synchronization for calendar appointments in a calendar application program. These and other applications of mobile device 202 are also identified later in relation to
In contrast to WLAN 122, WLAN 104 may be a public WiFi “hotspot” for public use and include what is referred to as a “captive portal” or “walled garden.” For devices connected in WLAN 104 via one of wireless APs 112, 114, and 116, gateway 110 is configured to permit or deny access to the data, applications, and/or functionality, as well as to permit or deny external access outside of WLAN 104 to Internet 120. To do this, gateway 110 has a set of IP address filters which define a set of addresses that are permissible/impermissible, if any at all, for access by devices. Access by a device depends on whether or not a device has been authorized and what access rights are given upon authorization.
Typically, when a request by a device in WLAN 104 is made prior to proper authorization, gateway 110 is configured to redirect the request to redirect server 108. In response, redirect server 108 is configured to respond to mobile device 202 to provide data for producing information (e.g. a Web page information) which is rendered in a visual display of mobile device 202 via a Web browser application. The information may solicit a user response. For example, the information may solicit a user registration or login with user fields for entering a user name and/or password information. As another example, the information may solicit a user payment with user payment fields for entering in user payment information. Further, the information may solicit a user acceptance of terms of use, a license, or a legal disclaimer (options of “YES” or “NO”, or “ACCEPT” or “DECLINE”). Redirect server 108 may be referred to by a different name depending on any more specific purpose (e.g. authentication server, registration server, user confirmation server, etc.).
The user will enter a user response via the Web browser application, for example, which is sent by mobile device 202 and received by gateway 110. Gateway 110 identifies whether the received user response is sufficient (e.g. whether the user name and password match prestored user name and password information, whether the user payment is accepted, whether the user acceptance is confirmed, etc.). If the user response is deemed sufficient, gateway 110 permits access to the data, applications, and/or functionality in or outside of WLAN 104.
Again, in contrast to WLAN 104, WLAN 122 may be a private communication network of an enterprise associated with mobile device 202. For devices attempting to access WLAN 122 via Internet 120, gateway 126 is configured to accept or reject access requests external to the network. Functions of gateway 126 may be or include authentication, security, QoS functions, account management, and redirection.
As described earlier, the popularity of Internet access through hotspots has led to the emergence of a new kind of entity, namely, a hotspot aggregator. In general, a hotspot aggregator provides wireless Internet access to its customers by renting a WLAN connection to the Internet (i.e. a “WLAN hotspot”) from hotspot owners (e.g. at coffee shops, hotels, and Is airports). In contrast to an ordinary telecommunications entity, a hotspot aggregator does not (necessarily) own the access networks, but rather relies on a network of independently-owned and operated access networks. Examples of current hotspot aggregators are Boingo and iPass.
In
Another service which may be provided may be based on Generic Access Network (GAN) technologies. Using GAN based technologies, mobile device 202 may also access communication services from a core network 134 of a Public Land Mobile Network (PLMN) 132 (e.g. cellular). GAN technology may provide, amongst other things, a voice communication service for mobile device 202 via the WLAN hotspot. PLMN 132 includes a core network 134, a plurality of base station controllers such as a base station controller (BSC) 138 coupled to core network 134, and a plurality of base stations such as a base station (BS) 140 and a base station 142 coupled to associated BSCs 138. Core network 134, BSC 138, and BS 140 operate in a conventional fashion as well-documented. Other PLMNs in the environment have a similar or the same architecture as PLMN 132. Such environments may be referred to as cellular telecommunications networks.
Communications between WLAN 104 and core network 134 of PLMN 132 may be facilitated through a suitable connecting network such as a broadband, wide-area IP communication network (e.g. the Internet 120) or any suitable public or private wide area network. Gateway/controller or GAN controller (GANC) 136 is provided between the Internet 120 and core network 134 of PLMN 132 in order to facilitate access to core network 134 by terminals through alternative links (e.g. radio links wireless APs 112, 114, and 116) different than those conventional radio links offered in the PLMN 132 (e.g. radio links of base stations 140 and 142). Thus, mobile device 202 may also access services of core network 134 of PLMN 132 via WLANs, such as WLAN 104, through use of a WLAN radio interface as opposed to a cellular telephony interface. For such communications, GANC 136 and mobile device 202 are adapted to establish and maintain a (secure) tunnel connection between each other through the intervening networks. Note that WLAN 104 may be operator-controlled or provided (e.g. controlled or provided by the operator associated with PLMN 132), user-controlled or provided (e.g. controlled or provided by the end user of mobile device 202), or third-party-controlled or provided. Again, GANC 136 operates in accordance with GAN based technology (formerly known as Unlicensed Mobile Access (UMA), and may be or include GANC 136 (formerly known as UMA Network Controller or UNC) or the like. Finally, note that mobile device 202 may be a wireless handset of the dual-mode type, having both WLAN and cellular (WWAN) radio interfaces. Thus, mobile device 202 may access services of core network 134 of PLMN 132 with use of its cellular radio interface, as well as access services via WLANs with use of its WLAN radio interface.
Referring now to
As shown in
Communication subsystem 211 includes a receiver 212, a transmitter 214, and associated components, such as one or more (e.g. embedded or internal) antenna elements 216 and 218, local oscillators (LOs) 213, and a processing module such as a baseband (BB) and media access control (MAC) processing module 220. Communication subsystem may be or referred to as a radio frequency (RF) transceiver or wireless transceiver. As will be apparent to those skilled in the field of communications, the particular design of communication subsystem 211 depends on the communication network in which mobile device 202 is intended to operate. In the present disclosure, communication subsystem 211 (including its associated processor/processing components) are operative in accordance with IEEE 802.11 standards.
Mobile device 202 may send and receive communication signals through the network after required network procedures have been completed. Signals received by antenna 216 through the network are input to receiver 212, which may perform such common receiver functions as signal amplification, frequency down conversion, filtering, channel selection, and like, and in example shown in
Since mobile device 202 may be a handheld portable battery-powered device, it also includes a battery interface 254 for receiving one or more rechargeable batteries 256. Such a battery 256 provides electrical power to most if not all electrical circuitry in mobile device 202, and battery interface 254 provides for a mechanical and electrical connection for it. Battery interface 254 is coupled to a regulator (not shown in
Mobile device 202 includes a microprocessor 238 (one type of processor or controller) that controls overall operation of mobile device 202. This control includes the network selection techniques of the present disclosure. Communication functions, including at least data and voice communications, are performed through communication subsystem 211. Microprocessor 238 also interacts with additional device subsystems such as a display 222, a flash memory 224, a random access memory (RAM) 226, auxiliary input/output (I/O) subsystems 228, a serial port 230, a keyboard 232, a speaker 234, a microphone 236, a short-range communications subsystem 240, and any other device subsystems generally designated at 242. Some of the subsystems shown in
Operating system software used by microprocessor 238 may be stored in a persistent store such as flash memory 224, which may alternatively be a read-only memory (ROM) or similar storage element (not shown). Those skilled in the art will appreciate that the operating system, specific device applications, or parts thereof, may be temporarily loaded into a volatile store such as RAM 226. Microprocessor 238, in addition to its operating system functions, enables execution of software applications on mobile device 202. A predetermined set of applications that control basic device operations, including data and/or voice communication applications, will normally be installed on mobile device 202 during its manufacture. This includes applications or modules which are configured to perform the network selection techniques of the present disclosure. For this reason, microprocessor 238 (and any other processor(s) or modules of mobile device 202) may enable execution of particular applications or modules for performing enhanced network selection techniques for access to multiple aggregator services.
Another application that may be loaded onto mobile device 202 may be a personal information manager (PIM) application having the ability to organize and manage data items relating to user such as, but not limited to, e-mail, calendar events, voice mails, appointments, and task items. The PIM application has the ability to send and receive data items via the wireless network. In one embodiment, PIM data items are seamlessly integrated, synchronized, and updated via the wireless network, with the wireless device user's corresponding data items stored and/or associated with a host computer system thereby creating a mirrored host computer on mobile device 202 with respect to such items. This is especially advantageous where the host computer system is the wireless device user's office computer system. Additional applications may also be loaded onto mobile device 202 through network, an auxiliary I/O subsystem 228, serial port 230, short-range communications subsystem 240, or any other suitable subsystem 242, and installed by a user in RAM 226 or a non-volatile store (not shown) for execution by microprocessor 238. Such flexibility in application installation increases the functionality of mobile device 202 and may provide enhanced on-device functions, communication-related functions, or both. For example, secure communication applications may enable electronic commerce functions and other such financial transactions to be performed using mobile device 202.
In a data communication mode, a received signal such as a text message, an e-mail message, or web page download will be processed by communication subsystem 211 and input to microprocessor 238. Microprocessor 238 may further process the signal for output to display 222 or alternatively to auxiliary I/O device 228. A user of mobile device 202 may also compose data items, for example, using keyboard 232 in conjunction with display 222 and possibly auxiliary I/O device 228. In accordance with the present techniques, microprocessor 238 may process outgoing message requests and incoming responses described later in relation to
For voice communications, the overall operation of mobile, device 202 is substantially similar, except that the received signals would be output to speaker 234 and signals for transmission would be generated by microphone 236. Alternative voice or audio I/O subsystems, such as a voice message recording subsystem, may also be implemented on mobile device 202. Although voice or audio signal output may be accomplished primarily through speaker 234, display 222 may also be used to provide an indication of the identity of a calling party, duration of a voice call, or other voice call related information, as some examples.
Serial port 230 in
Referring ahead now to
Keys 428 of keyboard 232 are disposed on a front face of a housing 406 and positioning wheel 410 is disposed at a side of housing 406. Keyboard 232 is in the example form of a reduced QWERTY keyboard including a plurality of keys 428 that serve as input members. It can be seen that the arrangement of the characters 448 on keys 428 of keyboard 424 is generally of the QWERTY arrangement, albeit with many of keys 428 including two of characters 448. In the example depiction of keyboard 424, many of keys 428 include two characters, such as including a first character 452 and a second character 456 assigned thereto. Characters may include letters, digits, symbols and the like and can additionally include ideographic characters, components thereof, and the like. One of keys 428 of keyboard 424 includes as the characters 448 thereof the letters “Q” and “W”, and an adjacent key 428 includes as the characters 448 thereof the letters “E” and “R”. Keyboard 424 may be of other configurations, such as an AZERTY keyboard, a QWERTZ keyboard, a Dvorak keyboard, or other keyboard or keypad arrangement, and either reduced or not reduced (i.e. full). In a “full” or non-reduced keyboard or keypad arrangement, each key has a single letter (not multiple letters) of the alphabet assigned to it.
Among keys 428 of keyboard 232 are a <NEXT> key 440 and an <ENTER> key 444. The <NEXT> key 440, wherein, for example, “<NEXT>” may be a symbol or may be the word “next” provided (e.g. printed) on the key, may be pressed to provide a selection input to the processor and provides substantially the same selection input as is provided by a rotational input of positioning wheel 410. Since <NEXT> key 440 is provided adjacent a number of other keys 428 of keyboard 232, the user can provide a selection input to the processor substantially without moving the user's hands away from the keyboard 232 during a text entry operation. Another key, the <ESC> key 445 is disposed on the side of housing 406 adjacent positioning wheel 438, although the same or similar key may be disposed as part of keyboard 232. Among keys 428 of the keyboard 424 additionally is a <DEL> key 486 that can be provided to delete a text entry.
Positioning wheel 410 may serve as another input member and is both rotatable, as is indicated by an arrow 412, to provide selection inputs to the processor, and also can be pressed in a direction generally toward housing 406, as is indicated by an arrow 414 to provide another selection input to the processor.
Display 222 may include a cursor 484 that depicts generally where the next input or selection from user interface 402 will be received. Display 222 is shown in
As shown now further in
The “home” screen output is shown in
Movement, navigation, and/or scrolling with use of a cursor/view positioning mechanism is beneficial given the relatively large size of visually displayed information and the compact size of display 222 of
Although a specific mobile device 202 has just been described, any suitable mobile communication device or terminal may be part of the inventive methods and apparatus which will be described in fuller detail below. Note that many components of mobile device 202 shown and described may not be included (e.g. a full QWERTY keypad may be optional). Again, keyboard 232 and display 222 may be substituted or enhanced with a touch screen display or other suitable input mechanism, or enhanced or replaced with a voice-activated input module. Also, although the description of the architecture relates to a specific example for illustration, where the WLAN is an IEEE 802.11-based network, different environments may be applicable as well. The wireless network may be a Bluetooth-based network, a WiMAX-based network. (i.e. IEEE 802.16), or an Ultra-WideBand (UWB)-based network (i.e. IEEE 802.15), as a few examples.
Referring back to the environment of
One or more aggregator services may be offered in a single WLAN hotspot and, in any given WLAN hotspot, some aggregator services may be made offered while others may not be. A WLAN hotspot may utilize only a single Set Service Identifier (SSID) for identification, and it may not be readily apparent to roaming mobile devices what particular aggregator service is provided in any particular WLAN hotspot. Traditionally, an aggregator provides client software to install in the mobile device to aid in finding the appropriate WLANs and signing in for service. Locally-stored directories of WLAN hotspot locations and details may be provided (e.g. which SSIDs are supported), which requires some type of network connection for updates. The existing ways of obtaining service are specific to each particular aggregator. For example, each WLAN hotspot may require a different way of logging in for access (e.g. different web sites for login).
After installation, conventional client software typically seizes and maintains control over the WLAN selection mechanism of the mobile device which is utilized for selecting and connecting to an appropriate WLAN. There is little flexibility for a conventional mobile device to be able to utilize multiple aggregator services in an easy and efficient manner.
As shown in
Aggregator modules 306 may include aggregator modules 312, 314, and 316 which are designated as modules 1, 2, . . . , to N, as shown in
Aggregator modules 306 are configured for use in accessing a plurality of different aggregator services (e.g. Boingo, iPass, etc.). Aggregator modules 306 may alternatively be referred to as hotspot client modules. Each aggregator service offers access through a plurality of offered wireless networks (e.g. various WLAN hotspots), and these offered wireless networks may be identified by a plurality of offered wireless network identifiers. The offered wireless network identifiers of offered wireless networks for service are provided via the corresponding aggregator module. Such information may be initially stored in memory upon installation of the aggregator module. Alternatively, or in combination with the above, such information may be received over the network as needed (e.g. per location area), which may be over-the-air via a wireless network (e.g. WLAN 112 or PLMN 132 of
Master module 304 is indeed configured to have “master” control over each one of the aggregator (“slave”) modules 306. Master module 304 is configured to interface and communicate with each one of aggregator modules 306 in accordance with an application programming interface (API) 318. Further, master module 304 is configured to maintain “master” control and interact with connection module 308, preferably in an exclusive manner (i.e. as opposed to any of aggregator modules 306 interacting with connection module 308).
During installation of one of the aggregator modules 306 in memory of the mobile device, a registration process is performed. The registration process allows master module 304 to receive aggregator service information to receive, build, or otherwise produce an aggregator service profile for the corresponding aggregator service. The information for the aggregator service profile may be obtained during or as part of the installation process, over-the-air from a wireless network, and/or via the user interface of the mobile device. In one embodiment, the information in an aggregator service profile may be or include an aggregator identification, an aggregator name, the plurality of offered wireless network identifiers (e.g. even a subset, for example, per location area), and one or more server names for authentication and/or access, as examples.
Again, master module 304 is configured to maintain “master” control and interact with connection module 308, preferably in an exclusive manner (i.e. as opposed to any of aggregator modules 306 interacting with connection module 308). In turn, connection module 308 is configured to interact with and/or instruct wireless transceiver 211 to perform scanning operations for identifying available wireless networks within a geographic region of the mobile device. Available wireless networks identified by connection module 308 are made part of a scan list 310 of wireless network identifiers corresponding to the available wireless networks. In the example of
As shown in
On the other hand, any aggregator service having a profile in prioritized list 320 may be identified by an aggregator service identifier or name. In the example of
For network selection, master module 304 is also configured to provide an automatic profile/network selection technique and a manual profile/network selection technique. These techniques make use of the prioritized list of profiles and the scan list of available wireless network identifiers (see e.g.
Master module 304 may be further configured to maintain “master” control over the use of aggregator modules 306 (its “slaves”) during wireless operation. In particular, master module 304 may receive and interpret requests from the wireless network and, in response, make the appropriate calls to the proper aggregator module, so that the aggregator module may properly respond to such requests using predetermined protocols (e.g. including proprietary protocols). For example, master module 304 may receive a hotspot/network login requirement from the wireless network and, in response, make the appropriate call to the selected aggregator module so that the aggregator module may perform its credentials submission and/or login procedure with the hotspot/network.
Even further, master module 304 may be further configured to maintain “master” control over the presentation of the display of the mobile device. Even though an aggregator service may be selected for communications, the aggregator module corresponding to the selected aggregator service makes display presentation requests (if at all) through master module 304 and, in response, master module 304 calls the appropriate display data and/or presentations with the appropriate information for display.
As described earlier in relation to
Referring to
One of the profile/network selection techniques is invoked at the mobile device (e.g. the automatic or manual profile/network selection technique). The master module identifies which profile has been selected from the profile/network selection technique (step 604 of
On the other hand, if as identified in step 606 the selected profile corresponds to an aggregator service profile, then the master module will receive such indication which includes an aggregator service identifier or name. In response, the master module selects or identifies one of the aggregator modules corresponding to the selected aggregator service identifier or name, and invokes the selected aggregator module to initiate its functionality (step 608 of
As described earlier, a selected aggregator module may provide or produce a plurality of offered wireless network identifiers. In general, the goal is to identify one of the available wireless network identifiers in the scan list that matches one of the offered wireless network identifiers provided via the aggregator module. In one embodiment, in step 610, the master module invokes the selected aggregator module so that it may identify all wireless networks that are both offered and available. In particular, the master module sends or passes the available wireless network identifiers of the scan list to the selected aggregator module, which in turn identifies whether any of the available wireless network identifiers in the scan list match any of its offered wireless network identifiers (e.g. through a comparison; step 612 of
If a single wireless network identifier is returned, then the master module instructs the connection module to establish a connection with the wireless network identified by the single wireless network identifier (step 614 of
Note that, after a connection is made in step 614, the master module may receive and interpret requests from the wireless network (e.g. for hotspot/network login) and make the appropriate call(s) to the aggregator module so that the aggregator module may properly respond to such requests (e.g. perform its credentials submission and/or login procedure with the hotspot/network).
If there is no match as identified in step 612 of
When the quality of the communications with the wireless network become poor or lost (e.g. due to roaming of the mobile device), the method repeats again starting step 602 or 604 of
Thus, network selection methods and apparatus for communication devices which utilize a “master” service management module and a prioritized list of multiple aggregator service profiles for accessing multiple aggregator services have been described. A communication device is configured to store a plurality of aggregator service application modules for use in accessing a plurality of different aggregator services. Each aggregator service offers access through a plurality of offered wireless networks identified by a plurality of offered wireless network identifiers. The communication device maintains a prioritized list of profiles which include a plurality of aggregator service profiles associated with the plurality of aggregator services. A scanning operation is performed for identifying one or more available wireless networks in a geographic area of the device, for producing a scan list of one or more available wireless network identifiers corresponding to the one or more available wireless networks. One of the aggregator service profiles is selected from the prioritized list, causing one of the aggregator service application modules corresponding to the selected profile to be invoked. The invoked module causes one of the available wireless network identifiers from the scan list that matches one of the offered wireless network identifiers to be selected, if such matching identifier exists. A connection is then established with one of the available wireless networks corresponding to the selected available wireless network identifier, for accessing a selected aggregator service corresponding to the selected aggregator service profile.
The master module utilized may receive and interpret requests from the selected wireless network and, in response, make the appropriate calls to is the appropriate aggregator module, so that the aggregator module may properly respond to such requests using predetermined protocols. Further, the master module may be configured to maintain master control over the presentation of the display of the mobile device. Here, the aggregator module may make display presentation requests through the master module and, in response, the master module calls the appropriate display data and/or presentations with the appropriate information for display.
The above-described embodiments of the present disclosure are intended to be examples only. Those of skill in the art may affect alterations, modifications and variations to the particular embodiments without departing from the scope of the application. Although the description of the architecture for
Fedotenko, Denis, Ryerson, Christopher Maybee, Oerton, Kevin, Leonov, Andrey, Zhao, Jing Chuan, Beldar, Jayesh
Patent | Priority | Assignee | Title |
10531285, | Oct 27 2014 | Samsung Electronics Co., Ltd. | Method of changing profile using identification module and electronic device implementing same |
Patent | Priority | Assignee | Title |
5987011, | Aug 30 1996 | Chai-Keong, Toh; King's College | Routing method for Ad-Hoc mobile networks |
6529491, | Nov 05 1997 | Apple Inc | Private/residential code division multiple access wireless communication system |
7221904, | Jun 02 1995 | CARUCEL INVESTMENTS, LP | Mobile communication system with moving base station |
7483984, | Dec 19 2001 | BOINGO WIRELESS, INC | Method and apparatus for accessing networks by a mobile device |
7496360, | Feb 27 2004 | Texas Instruments Incorporated; TELOGY NETWORKS, INC | Multi-function telephone |
7693516, | Dec 28 2004 | VTech Telecommunications Limited | Method and system for enhanced communications between a wireless terminal and access point |
8055256, | May 30 2008 | Google Technology Holdings LLC | Method and apparatus for selecting scanning rates in a multi-mode communication device |
8090395, | Mar 12 2009 | Qualcomm Incorporated | Scanning channels while a device is out of service |
8411604, | Dec 21 2009 | Malikie Innovations Limited | Methods and apparatus for use in facilitating access to aggregator services for mobile communication devices via wireless communication networks |
20030096611, | |||
20030148786, | |||
20040068653, | |||
20040192328, | |||
20050148332, | |||
20050163319, | |||
20050195778, | |||
20060209773, | |||
20070091861, | |||
20070191005, | |||
20080031211, | |||
20080069065, | |||
20080175166, | |||
20090068970, | |||
20100015978, | |||
20100195608, | |||
20110047603, | |||
20110075598, | |||
20110250901, | |||
EP781064, | |||
WO19981617, | |||
WO200049505, | |||
WO200163843, | |||
WO2007068992, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Aug 18 2010 | RYERSON, CHRISTOPHER MAYBEE | Research In Motion Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046754 | /0719 | |
Aug 23 2010 | OERTON, KEVIN | Research In Motion Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046754 | /0719 | |
Aug 25 2010 | FEDOTENKO, DENIS | 2012244 ONTARIO INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046754 | /0422 | |
Aug 26 2010 | BELDAR, JAYESH | Research In Motion Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046754 | /0719 | |
Aug 30 2010 | ZHAO, JING CHUAN | Research In Motion Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046754 | /0719 | |
Sep 27 2010 | LEONOV, ANDREY | Research In Motion Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046754 | /0719 | |
Oct 18 2011 | 2012244 ONTARIO INC | Research In Motion Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 046986 | /0061 | |
Jul 09 2013 | Research In Motion Limited | BlackBerry Limited | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 037963 | /0731 | |
Aug 06 2015 | BlackBerry Limited | (assignment on the face of the patent) | / | |||
May 11 2023 | BlackBerry Limited | Malikie Innovations Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 064104 | /0103 | |
May 11 2023 | BlackBerry Limited | Malikie Innovations Limited | NUNC PRO TUNC ASSIGNMENT SEE DOCUMENT FOR DETAILS | 064270 | /0001 |
Date | Maintenance Fee Events |
May 06 2022 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Date | Maintenance Schedule |
Nov 06 2021 | 4 years fee payment window open |
May 06 2022 | 6 months grace period start (w surcharge) |
Nov 06 2022 | patent expiry (for year 4) |
Nov 06 2024 | 2 years to revive unintentionally abandoned end. (for year 4) |
Nov 06 2025 | 8 years fee payment window open |
May 06 2026 | 6 months grace period start (w surcharge) |
Nov 06 2026 | patent expiry (for year 8) |
Nov 06 2028 | 2 years to revive unintentionally abandoned end. (for year 8) |
Nov 06 2029 | 12 years fee payment window open |
May 06 2030 | 6 months grace period start (w surcharge) |
Nov 06 2030 | patent expiry (for year 12) |
Nov 06 2032 | 2 years to revive unintentionally abandoned end. (for year 12) |