bluetoothengine/btnotif/btnotifsrv/src/btnotifoutgoingpairinghandler.cpp
author hgs
Tue, 19 Oct 2010 15:09:34 +0300
changeset 70 f5508c13dfe0
parent 57 5ebadcda06cb
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     1
/*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     3
* All rights reserved.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     8
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    11
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    12
* Contributors:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    13
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    14
* Description: Pairing handler for local device initiated pairing
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    15
*
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    16
*/
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    17
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    18
#include "btnotifoutgoingpairinghandler.h"
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    19
#include <btengconstants.h>
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    20
#include <btservices/btdevextension.h>
42
hgs
parents: 31
diff changeset
    21
#include "btnotifsecuritymanager.h"
hgs
parents: 31
diff changeset
    22
#include "bluetoothtrace.h"
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    23
#include "bluetoothnotification.h"
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    24
#include "btnotifserver.h"
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    25
#include "btnotifconnectiontracker.h"
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    26
#include "btnotificationmanager.h"
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    27
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    28
/**  Length of the default PIN. */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    29
const TInt KDefaultHeadsetPinLength = 4;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    30
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    31
/** Maximum repeated outgoing pairing attempt.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    32
 *  if the pairing fails the UI specs says
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    33
 *  we can ask twice the user if he/she want 
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    34
 *  to retry pairing. 
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    35
 */
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    36
const TInt KMaxRepeatedPairingAttempt = 2;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    37
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    38
enum TPairingStageId
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    39
    {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    40
    /**
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    41
     * no pairing operation ongoing
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    42
     */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    43
    ENoBonding = 0,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    44
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    45
    /**
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    46
     * pair with dedicated bonding method
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    47
     */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    48
    EDedicatedBonding = 200,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    49
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    50
    /**
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    51
     * pair with general bonding by establishing L2CAP connection.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    52
     */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    53
    EGeneralBonding,  
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    54
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    55
    /**
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    56
     * delaying next pairing request for a while
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    57
     */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    58
    EGeneralBondingRetryTimer,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    59
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    60
    /**
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    61
     * The last pairing retry
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    62
     */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    63
    EGeneralBondingRetry,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    64
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    65
    /**
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    66
     * disconnecting physical link after pairing operation.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    67
     * 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    68
     * todo: not used yet.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    69
     */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    70
    EDisconnectLinkAfterBonding,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    71
    };
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    72
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    73
/**  SDP PSM (used for pairing) */
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    74
const TInt KSDPPSM = 0x0001;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    75
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    76
// Delay time to void Repeated Attempts on pairing
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    77
const TInt KGeneralBondingRetryDelayMicroSeconds = 5000000; // 5.0s
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    78
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    79
// ======== MEMBER FUNCTIONS ========
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    80
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    81
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    82
// C++ default constructor
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    83
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    84
//
42
hgs
parents: 31
diff changeset
    85
CBTNotifOutgoingPairingHandler::CBTNotifOutgoingPairingHandler( CBTNotifSecurityManager& aParent, const TBTDevAddr& aAddr)
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    86
    :  CBTNotifBasePairingHandler( aParent, aAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    87
    {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
    88
    iDialogIsOrphan = EFalse;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    89
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    90
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    91
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    92
// Symbian 2nd-phase constructor
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    93
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    94
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    95
void CBTNotifOutgoingPairingHandler::ConstructL()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    96
    {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    97
    BaseConstructL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
    98
    User::LeaveIfError( iTimer.CreateLocal() );
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
    99
    iPairingAttempt = KMaxRepeatedPairingAttempt;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   100
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   101
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   102
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   103
// NewL
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   104
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   105
//
42
hgs
parents: 31
diff changeset
   106
CBTNotifBasePairingHandler* CBTNotifOutgoingPairingHandler::NewL( CBTNotifSecurityManager& aParent, 
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   107
        const TBTDevAddr& aAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   108
    {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   109
    CBTNotifOutgoingPairingHandler* self = new( ELeave ) CBTNotifOutgoingPairingHandler( aParent, aAddr );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   110
    CleanupStack::PushL( self );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   111
    self->ConstructL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   112
    CleanupStack::Pop( self );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   113
    return self;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   114
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   115
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   116
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   117
// Destructor
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   118
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   119
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   120
CBTNotifOutgoingPairingHandler::~CBTNotifOutgoingPairingHandler()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   121
    {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   122
    if ( iActive ) 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   123
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   124
        iActive->Cancel();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   125
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   126
    iBondingSession.Close();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   127
    iSocket.Close();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   128
    iTimer.Close();
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   129
    if( iNotification && !iDialogIsOrphan)
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   130
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   131
        // Clear the notification callback, we cannot receive them anymore.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   132
        iNotification->RemoveObserver();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   133
        iNotification->Close(); // Also dequeues the notification from the queue.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   134
        iNotification = NULL;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   135
        }
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   136
    if( iNotification && iDialogIsOrphan)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   137
        {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   138
        // Clear the notification callback, we cannot receive them anymore.
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   139
        iNotification->RemoveObserver();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   140
        }
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   141
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   142
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   143
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   144
// Simply deny the request as this is handing outgoing pairing
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   145
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   146
//
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   147
TInt CBTNotifOutgoingPairingHandler::ObserveIncomingPair( const TBTDevAddr& aAddr )
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   148
    {
70
hgs
parents: 57
diff changeset
   149
    if(iAddr == aAddr)
hgs
parents: 57
diff changeset
   150
        {
hgs
parents: 57
diff changeset
   151
        return KErrNone;
hgs
parents: 57
diff changeset
   152
        }
hgs
parents: 57
diff changeset
   153
    else
hgs
parents: 57
diff changeset
   154
        {
hgs
parents: 57
diff changeset
   155
        return KErrServerBusy;
hgs
parents: 57
diff changeset
   156
        }
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   157
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   158
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   159
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   160
// Accept the request only this device is not busy with another pairing request.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   161
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   162
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   163
void CBTNotifOutgoingPairingHandler::HandleOutgoingPairL( const TBTDevAddr& aAddr, TUint aCod )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   164
    {
70
hgs
parents: 57
diff changeset
   165
    BOstrace1(TRACE_DEBUG,DUMMY_DEVLIST,_L(" cod 0x%08x"), aCod );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   166
    if ( iActive->IsActive() || aAddr != iAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   167
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   168
        // we don't allow another pairing request.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   169
        User::Leave( KErrServerBusy );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   170
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   171
    iAddr = aAddr;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   172
    iCod = TBTDeviceClass( aCod );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   173
    UnSetPairResult();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   174
    iParent.UnpairDevice( iAddr );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   175
    if ( CBtDevExtension::IsHeadset( iCod ) )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   176
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   177
        // If the devie is a headset, set to 0000 pin auto pairing
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   178
        iPairMode = EBTOutgoingHeadsetAutoPairing;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   179
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   180
    else
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   181
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   182
        iPairMode = EBTOutgoingNoneHeadsetPairing;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   183
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   184
    DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   185
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   186
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   187
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   188
// Cancels an outstanding pair request by self-destruct
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   189
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   190
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   191
void CBTNotifOutgoingPairingHandler::CancelOutgoingPair()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   192
    {
42
hgs
parents: 31
diff changeset
   193
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   194
    ShowPairingFailureDialog();
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   195
    iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   196
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   197
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   198
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   199
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   200
// when phone initiated a pairing request towards a headset,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   201
// Pin code 0000 is first tried.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   202
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   203
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   204
void CBTNotifOutgoingPairingHandler::GetPinCode( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   205
        TBTPinCode& aPin, const TBTDevAddr& aAddr, TInt aMinPinLength )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   206
    {
42
hgs
parents: 31
diff changeset
   207
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   208
    aPin().iLength = 0;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   209
    if ( aMinPinLength <= KDefaultHeadsetPinLength 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   210
            && aAddr == iAddr
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   211
            && iPairMode == EBTOutgoingHeadsetAutoPairing)
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   212
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   213
        // if the pairing requires a stronger security level (indicated
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   214
        // by aMinPinLength), 
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   215
        // 0000 will not be supplied as it does not meet the security
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   216
        // requirements
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   217
        const TUint8 KZeroPinValue = '0';
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   218
        for (TInt i = 0; i < KDefaultHeadsetPinLength; ++i)
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   219
            {
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   220
                aPin().iPIN[i] = KZeroPinValue;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   221
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   222
        aPin().iLength = KDefaultHeadsetPinLength;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   223
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   224
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   225
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   226
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   227
// Abort pairing handling, request the owner to destroy this.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   228
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   229
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   230
void CBTNotifOutgoingPairingHandler::StopPairHandling( const TBTDevAddr& aAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   231
    {
42
hgs
parents: 31
diff changeset
   232
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   233
    if ( aAddr == iAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   234
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   235
        iParent.OutgoingPairCompleted( KErrCancel );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   236
        iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   237
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   238
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   239
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   240
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   241
// Pairing result will be received when pairing operation completes.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   242
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   243
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   244
void CBTNotifOutgoingPairingHandler::DoHandlePairServerResult( TInt aResult )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   245
    {
42
hgs
parents: 31
diff changeset
   246
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   247
	if (aResult == (KHCIErrorBase-EPairingNotAllowed))
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   248
		{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   249
		// if EPairingNotAllowed is recieved then any further pairing attempts will fail
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   250
		// so don't attampt to pair
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   251
        iPairMode = EBTOutgoingPairNone;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   252
        ShowPairingFailureDialog();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   253
        iParent.OutgoingPairCompleted( aResult );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   254
        iParent.RenewPairingHandler( NULL );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   255
		}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   256
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   257
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   258
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   259
// Cancels possible outstanding pairing and notify user pair success.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   260
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   261
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   262
void CBTNotifOutgoingPairingHandler::DoHandleRegistryNewPairedEvent( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   263
        const TBTNamelessDevice& aDev )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   264
    {
42
hgs
parents: 31
diff changeset
   265
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   266
    TInt err( KErrNone );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   267
    // If pairing was performed using Just Works mode, we set a 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   268
    // UICookie to indicate that the device is successfully 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   269
    // bonded so that this device will be listed in paired device view of
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   270
    // bluetooth application:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   271
    if ( aDev.LinkKeyType() == ELinkKeyUnauthenticatedNonUpgradable )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   272
        {
70
hgs
parents: 57
diff changeset
   273
        BOstrace0(TRACE_DEBUG,DUMMY_DEVLIST,_L("[BTNOTIF] Outgoing Pairing, Just Works pairing"));
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   274
        err = iParent.AddUiCookieJustWorksPaired( aDev );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   275
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   276
    iActive->Cancel();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   277
    SetPairResult( err ? err : KErrNone );
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   278
    if(err == KErrNone)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   279
	    {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   280
        // Trust the device
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   281
        if(iTrustDevice)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   282
		    {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   283
            iParent.TrustDevice(iAddr);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   284
            }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   285
        TRAP_IGNORE(ShowPairingResultNoteL(err));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   286
        }
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   287
    iParent.OutgoingPairCompleted( err );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   288
    iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   289
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   290
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   291
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   292
// From class MBTNotifPairingAOObserver.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   293
// Based on the result code, decides the next operation, either try pairing 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   294
// with another mode, or complete pair request.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   295
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   296
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   297
void CBTNotifOutgoingPairingHandler::RequestCompletedL( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   298
        CBtSimpleActive* aActive, TInt aStatus )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   299
    {
42
hgs
parents: 31
diff changeset
   300
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
70
hgs
parents: 57
diff changeset
   301
    BOstraceExt3(TRACE_DEBUG,DUMMY_DEVLIST,_L("reqid %d, status: %d, pair mode %d "), aActive->RequestId(), 
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   302
            aStatus, iPairMode);
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   303
    if( aActive->RequestId() == EDedicatedBonding && 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   304
				( aStatus == KErrRemoteDeviceIndicatedNoBonding || 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   305
					( aStatus && iPairMode != EBTOutgoingNoneHeadsetPairing && iPairMode != EBTOutgoingPairNone ) )   )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   306
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   307
        // try general pairing if the remote doesn't have dedicated bonding, or
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   308
        // pairing fails with a headset.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   309
        DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   310
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   311
    else if ( aStatus && iPairMode == EBTOutgoingHeadsetAutoPairing )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   312
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   313
        iPairMode = EBTOutgoingHeadsetManualPairing;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   314
        // auto pairing with headset failed, try to pair again with manual pin:
70
hgs
parents: 57
diff changeset
   315
        BOstrace0(TRACE_DEBUG,DUMMY_DEVLIST,_L(" auto pairing failed, switch to manual pairing"));     
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   316
        DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   317
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   318
    else if ( aStatus && aActive->RequestId() == EGeneralBonding && 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   319
              iPairMode == EBTOutgoingHeadsetManualPairing )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   320
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   321
        // pairing headset with manual pin failed, wait for a while and try again:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   322
        iActive->SetRequestId( EGeneralBondingRetryTimer );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   323
        iTimer.After( iActive->iStatus, KGeneralBondingRetryDelayMicroSeconds );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   324
        iActive->GoActive();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   325
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   326
    else if( aActive->RequestId() == EGeneralBondingRetryTimer )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   327
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   328
        // try to pair headset again with manual pin again:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   329
        DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   330
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   331
    else if ( aStatus )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   332
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   333
        // we only starts showing note if pairing failed.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   334
        // For a successful pair, we must wait until registry has been updated.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   335
        if ( !IsPairResultSet() )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   336
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   337
            SetPairResult( aStatus );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   338
            }
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   339
        if ( aStatus <= KHCIErrorBase - EUnknownOpcode)
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   340
            {
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   341
            // retry pairing
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   342
            if(iPairingAttempt > 0)
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   343
                {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   344
                if(aActive->RequestId() == EGeneralBondingRetry && iPairMode == EBTOutgoingHeadsetManualPairing)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   345
                    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   346
                    // Headset pairing failed, reset and try again from auto pairing
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   347
                    iActive->SetRequestId(EGeneralBonding);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   348
                    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   349
                iPairingAttempt --;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   350
                ShowPairingRetryDialog();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   351
                }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   352
            else
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   353
                {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   354
                iPairingAttempt --;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   355
                iParent.OutgoingPairCompleted( aStatus );
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   356
                ShowPairingFailureDialog();
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   357
                iParent.RenewPairingHandler( NULL );
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   358
                }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   359
             }
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   360
        else
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   361
            {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   362
            iParent.OutgoingPairCompleted( aStatus );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   363
            ShowPairingFailureDialog();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   364
            iParent.RenewPairingHandler( NULL );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   365
            }
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   366
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   367
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   368
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   369
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   370
// From class MBTEngActiveObserver.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   371
// cancels an outstanding request according to the given id.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   372
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   373
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   374
void CBTNotifOutgoingPairingHandler::CancelRequest( TInt aRequestId )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   375
    {
42
hgs
parents: 31
diff changeset
   376
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   377
    switch ( aRequestId )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   378
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   379
        case EDedicatedBonding:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   380
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   381
            iBondingSession.Close();
42
hgs
parents: 31
diff changeset
   382
            break;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   383
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   384
        case EGeneralBonding:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   385
        case EGeneralBondingRetry:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   386
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   387
            iSocket.CancelConnect();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   388
            iSocket.Close();
42
hgs
parents: 31
diff changeset
   389
            break;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   390
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   391
        case EGeneralBondingRetryTimer:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   392
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   393
            iTimer.Cancel();
42
hgs
parents: 31
diff changeset
   394
            break;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   395
            }     
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   396
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   397
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   398
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   399
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   400
// From class MBTEngActiveObserver.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   401
// Handles a leave in RequestCompleted by self-destructing.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   402
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   403
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   404
void CBTNotifOutgoingPairingHandler::HandleError( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   405
        CBtSimpleActive* aActive, TInt aError )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   406
    {
70
hgs
parents: 57
diff changeset
   407
    BOstrace1(TRACE_DEBUG,DUMMY_DEVLIST,_L("error: %d"), aError );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   408
    // Our RunL can actually not leave, so we should never reach here.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   409
    (void) aActive;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   410
    iParent.OutgoingPairCompleted( aError );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   411
    iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   412
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   413
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   414
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   415
// decide the next state and issue pair request
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   416
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   417
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   418
void CBTNotifOutgoingPairingHandler::DoPairingL()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   419
    {
42
hgs
parents: 31
diff changeset
   420
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   421
    TPairingStageId currentMode = ( TPairingStageId ) iActive->RequestId();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   422
    ASSERT( !iActive->IsActive() );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   423
    TPairingStageId nextMode( EGeneralBonding );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   424
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   425
    // if running BTv2.0 stack, dedicated bonding method 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   426
    // is not available.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   427
    if ( currentMode == ENoBonding && iParent.PairingServer() != NULL )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   428
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   429
        nextMode = EDedicatedBonding;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   430
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   431
    else if(currentMode == EGeneralBondingRetryTimer)
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   432
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   433
        nextMode = EGeneralBondingRetry;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   434
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   435
    
70
hgs
parents: 57
diff changeset
   436
    BOstraceExt2(TRACE_DEBUG,DUMMY_DEVLIST,_L("[BTNOTIF] CBTEngOtgPair::DoPairingL: bonding mode: pre %d, next %d"), currentMode, nextMode);
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   437
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   438
    iActive->SetRequestId( nextMode );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   439
    if ( nextMode == EDedicatedBonding )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   440
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   441
        iBondingSession.Start( *iParent.PairingServer(), iAddr, iActive->RequestStatus() );          
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   442
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   443
    else
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   444
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   445
        TBTServiceSecurity sec;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   446
        sec.SetAuthentication( ETrue );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   447
        iSockAddr.SetBTAddr( iAddr );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   448
        iSockAddr.SetPort(KSDPPSM);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   449
        iSockAddr.SetSecurity( sec );    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   450
        iSocket.Close();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   451
        User::LeaveIfError( iSocket.Open( iParent.SocketServ(), KL2CAPDesC ) );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   452
        iSocket.Connect( iSockAddr, iActive->RequestStatus() );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   453
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   454
    iActive->GoActive();
42
hgs
parents: 31
diff changeset
   455
    BOstraceFunctionExit0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   456
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   457
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   458
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   459
// From class MBTNotificationResult.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   460
// Handle a result from a user query.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   461
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   462
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   463
void CBTNotifOutgoingPairingHandler::MBRDataReceived( CHbSymbianVariantMap& aData )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   464
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   465
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   466
    (void) aData;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   467
    BOstraceFunctionExit0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   468
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   469
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   470
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   471
// From class MBTNotificationResult.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   472
// The notification is finished.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   473
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   474
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   475
void CBTNotifOutgoingPairingHandler::MBRNotificationClosed( TInt aError, const TDesC8& aData )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   476
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   477
    BOstraceFunctionEntryExt( DUMMY_DEVLIST, this, aError );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   478
    // First unregister from the notification, so we can already get the next one.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   479
    iNotification->RemoveObserver();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   480
    iNotification = NULL;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   481
    TRAP_IGNORE( NotificationClosedL( aError, aData ) );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   482
    BOstraceFunctionExit1( DUMMY_DEVLIST, this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   483
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   484
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   485
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   486
// Get and configure a notification.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   487
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   488
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   489
void CBTNotifOutgoingPairingHandler::PrepareNotificationL( TBluetoothDialogParams::TBTDialogType aType,
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   490
    TBTDialogResourceId aResourceId )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   491
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   492
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   493
    iNotification = 
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   494
            iParent.ConnectionTracker().NotificationManager()->GetNotification();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   495
    User::LeaveIfNull( iNotification ); // For OOM exception, leaves with KErrNoMemory
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   496
    iNotification->SetObserver( this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   497
    iNotification->SetNotificationType( aType, aResourceId );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   498
    const CBtDevExtension* dev = iParent.BTDevRepository().Device(iAddr);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   499
    if(dev)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   500
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   501
        User::LeaveIfError(iNotification->SetData( TBluetoothDeviceDialog::EDeviceName, dev->Alias()));
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   502
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   503
    else
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   504
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   505
        TBTDeviceName name;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   506
        iAddr.GetReadable(name);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   507
        User::LeaveIfError(iNotification->SetData( TBluetoothDeviceDialog::EDeviceName, name));
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   508
        NOTIF_NOTHANDLED( !err )            
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   509
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   510
    iParent.ConnectionTracker().NotificationManager()->QueueNotificationL( iNotification);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   511
    NOTIF_NOTHANDLED( !err )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   512
    BOstraceFunctionExit0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   513
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   514
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   515
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   516
// The notification is finished, handle the result.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   517
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   518
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   519
void CBTNotifOutgoingPairingHandler::NotificationClosedL( TInt aError, const TDesC8& aData )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   520
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   521
    BOstraceFunctionEntryExt( DUMMY_DEVLIST, this, aError );
70
hgs
parents: 57
diff changeset
   522
    (void)aError;
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   523
    // Read the result.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   524
    TPckgC<TBool> result( EFalse );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   525
    result.Set( aData.Ptr(), result.Length() ); // Read the part containing the result
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   526
    // Set a pointer descriptor to capture the remaining data, if any.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   527
    TPtrC8 dataPtr( aData.Mid( result.Length() ) );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   528
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   529
    if(result() && iPairingAttempt >= 0)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   530
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   531
            HandleOutgoingPairL(iAddr,iCod.DeviceClass());
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   532
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   533
    else
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   534
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   535
            iPairingAttempt = KMaxRepeatedPairingAttempt; // reset the counter
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   536
            iParent.OutgoingPairCompleted( KErrCancel );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   537
            iParent.RenewPairingHandler( NULL );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   538
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   539
    BOstraceFunctionExit1( DUMMY_DEVLIST, this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   540
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   541
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   542
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   543
// Show a dialog to ask the user to retry the pairing
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   544
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   545
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   546
void CBTNotifOutgoingPairingHandler::ShowPairingRetryDialog()
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   547
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   548
    PrepareNotificationL( TBluetoothDialogParams::EQuery, EPairingFailureRetry);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   549
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   550
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   551
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   552
// Show a dialog to tell the user pairing retry attempt failed
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   553
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   554
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   555
void CBTNotifOutgoingPairingHandler::ShowPairingFailureDialog()
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   556
    {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   557
    if(!iPairingCancelledByUser)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   558
        {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   559
        iDialogIsOrphan = ETrue;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   560
        PrepareNotificationL( TBluetoothDialogParams::EQuery, EPairingFailureOk );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   561
        }
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   562
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   563
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   564
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   565