Retrieving currently active access point using Symbian C++
Article Metadata
Compatibility
S60 3rd Edition, S60 3rd Edition FP1
Article
Overview
This article shows how to get the current active access point.
Description
There are several instances where the system will prompt the user with an access point selection dialog. For example,
- Initiating an HTTP connection
- Downloading a file with Download Manager API
- Opening a URL in Browser Control API
It is possible to reuse the active access point.
A common use case would be opening an HTTP connection and starting a file download with Download Manager API. Reusing the access point prevents the AP selection dialog from being shown twice.
Solution
MConnectionMonitorObserver is an observer class that is provided to receive any event notifications like creation or deletion of a connection, IAP availability change etc. The client application must implement this interface in order to receive notifications. The steps involved are:
- Derive the MConnectionMonitorObserver mixin class and implement the callback function EventL():
-
class CMyHTTPEngine : public MConnectionMonitorObserver
{
...
public:
// from MConnectionObserver
void EventL(const CConMonEvenBase& aConnEvent);
...
private:
RConnectionMonitor iConnMon;
};
-
- Register to get notifications on events before allowing the user to make an HTTP connection
-
TInt err = iConnMon.ConnectL();
iConnMon.NotifyEventL( *this );
// … proceed to open HTTP connection
-
- Handle received events and detect the ID of the active IAP
-
CMyHTTPEngine::EventL(const CConMonEvenBase& aConnEvent)
{
TInt event = aConnEvent.EventType();
TUint connId = aConnEvent.ConnectionId();
TUint iapId;
TRequestStatus status;
switch ( event )
{
case EConnMonCreateConnection: // New connection created
{
iConnMon.GetUintAttribute(connId, 0, KIAPId, iapId, status);
// Cast aConnEvent to CConnMonCreateConnection if needed
// GetStringAttribute(connId, 0, KIAPName, ...)
User::WaitForRequest( status );
break;
}
case EConnMonCreateSubConnection: // Subconnection to an existing AP
{
TUint subConnId;
const CConnMonCreateSubConnection
subConnEvent = (CConnMonCreateSubConnection)aConnEvent;
subConnId = subConnEvent.SubConnectionId();
iConnMon.GetUintAttribute(connId, subConnId, KIAPId, iapId, status);
// Name of AP can be retrieved with
// GetStringAttribute(connId, subConnId, KIAPName, ...)
User::WaitForRequest( status );
break;
}
default:
break;
}
// Close the monitor when event notifications are no longer required
// iConnMon.Close();
}
-
The observer can also be used for notifications on events like change in accessibility of an access point, deletion of an existing connection and changes in connection status.


Might want to add in that you need to include rconnmon.h, and the library connmon.lib from the Connection Monitor API. A search in the S60 V3 docs for MConnectionMonitorObserver finds nothing.