bluetoothengine/btnotif/btnotifsrv/src/btnotifoutgoingpairinghandler.cpp
author hgs
Fri, 03 Sep 2010 16:17:59 +0300
changeset 57 5ebadcda06cb
parent 47 9e2a905b887f
child 70 f5508c13dfe0
permissions -rw-r--r--
201035_7
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
    {
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   149
    (void)aAddr;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   150
    return KErrServerBusy;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   151
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   152
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   153
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   154
// Accept the request only this device is not busy with another pairing request.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   155
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   156
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   157
void CBTNotifOutgoingPairingHandler::HandleOutgoingPairL( const TBTDevAddr& aAddr, TUint aCod )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   158
    {
42
hgs
parents: 31
diff changeset
   159
    BOstrace1(TRACE_DEBUG,DUMMY_DEVLIST," cod 0x%08x", aCod );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   160
    if ( iActive->IsActive() || aAddr != iAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   161
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   162
        // we don't allow another pairing request.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   163
        User::Leave( KErrServerBusy );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   164
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   165
    iAddr = aAddr;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   166
    iCod = TBTDeviceClass( aCod );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   167
    UnSetPairResult();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   168
    iParent.UnpairDevice( iAddr );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   169
    if ( CBtDevExtension::IsHeadset( iCod ) )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   170
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   171
        // If the devie is a headset, set to 0000 pin auto pairing
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   172
        iPairMode = EBTOutgoingHeadsetAutoPairing;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   173
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   174
    else
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   175
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   176
        iPairMode = EBTOutgoingNoneHeadsetPairing;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   177
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   178
    DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   179
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   180
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   181
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   182
// Cancels an outstanding pair request by self-destruct
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   183
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   184
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   185
void CBTNotifOutgoingPairingHandler::CancelOutgoingPair()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   186
    {
42
hgs
parents: 31
diff changeset
   187
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   188
    ShowPairingFailureDialog();
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   189
    iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   190
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   191
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   192
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   193
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   194
// when phone initiated a pairing request towards a headset,
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   195
// Pin code 0000 is first tried.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   196
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   197
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   198
void CBTNotifOutgoingPairingHandler::GetPinCode( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   199
        TBTPinCode& aPin, const TBTDevAddr& aAddr, TInt aMinPinLength )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   200
    {
42
hgs
parents: 31
diff changeset
   201
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   202
    aPin().iLength = 0;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   203
    if ( aMinPinLength <= KDefaultHeadsetPinLength 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   204
            && aAddr == iAddr
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   205
            && iPairMode == EBTOutgoingHeadsetAutoPairing)
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   206
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   207
        // if the pairing requires a stronger security level (indicated
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   208
        // by aMinPinLength), 
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   209
        // 0000 will not be supplied as it does not meet the security
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   210
        // requirements
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   211
        const TUint8 KZeroPinValue = '0';
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   212
        for (TInt i = 0; i < KDefaultHeadsetPinLength; ++i)
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   213
            {
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   214
                aPin().iPIN[i] = KZeroPinValue;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   215
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   216
        aPin().iLength = KDefaultHeadsetPinLength;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   217
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   218
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   219
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   220
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   221
// Abort pairing handling, request the owner to destroy this.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   222
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   223
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   224
void CBTNotifOutgoingPairingHandler::StopPairHandling( const TBTDevAddr& aAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   225
    {
42
hgs
parents: 31
diff changeset
   226
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   227
    if ( aAddr == iAddr )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   228
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   229
        iParent.OutgoingPairCompleted( KErrCancel );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   230
        iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   231
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   232
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   233
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   234
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   235
// Pairing result will be received when pairing operation completes.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   236
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   237
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   238
void CBTNotifOutgoingPairingHandler::DoHandlePairServerResult( TInt aResult )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   239
    {
42
hgs
parents: 31
diff changeset
   240
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   241
	if (aResult == (KHCIErrorBase-EPairingNotAllowed))
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   242
		{
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   243
		// if EPairingNotAllowed is recieved then any further pairing attempts will fail
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   244
		// so don't attampt to pair
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   245
        iPairMode = EBTOutgoingPairNone;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   246
        ShowPairingFailureDialog();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   247
        iParent.OutgoingPairCompleted( aResult );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   248
        iParent.RenewPairingHandler( NULL );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   249
		}
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   250
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   251
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   252
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   253
// Cancels possible outstanding pairing and notify user pair success.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   254
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   255
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   256
void CBTNotifOutgoingPairingHandler::DoHandleRegistryNewPairedEvent( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   257
        const TBTNamelessDevice& aDev )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   258
    {
42
hgs
parents: 31
diff changeset
   259
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   260
    TInt err( KErrNone );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   261
    // If pairing was performed using Just Works mode, we set a 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   262
    // UICookie to indicate that the device is successfully 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   263
    // bonded so that this device will be listed in paired device view of
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   264
    // bluetooth application:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   265
    if ( aDev.LinkKeyType() == ELinkKeyUnauthenticatedNonUpgradable )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   266
        {
42
hgs
parents: 31
diff changeset
   267
        BOstrace0(TRACE_DEBUG,DUMMY_DEVLIST,"[BTNOTIF] Outgoing Pairing, Just Works pairing");
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   268
        err = iParent.AddUiCookieJustWorksPaired( aDev );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   269
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   270
    iActive->Cancel();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   271
    SetPairResult( err ? err : KErrNone );
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   272
    if(err == KErrNone)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   273
	    {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   274
        // Trust the device
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   275
        if(iTrustDevice)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   276
		    {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   277
            iParent.TrustDevice(iAddr);
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   278
            }
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   279
        TRAP_IGNORE(ShowPairingResultNoteL(err));
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   280
        }
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   281
    iParent.OutgoingPairCompleted( err );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   282
    iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   283
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   284
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   285
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   286
// From class MBTNotifPairingAOObserver.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   287
// Based on the result code, decides the next operation, either try pairing 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   288
// with another mode, or complete pair request.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   289
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   290
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   291
void CBTNotifOutgoingPairingHandler::RequestCompletedL( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   292
        CBtSimpleActive* aActive, TInt aStatus )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   293
    {
42
hgs
parents: 31
diff changeset
   294
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   295
    BOstraceExt3(TRACE_DEBUG,DUMMY_DEVLIST,"reqid %d, status: %d, pair mode %d ", aActive->RequestId(), 
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   296
            aStatus, iPairMode);
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   297
    if( aActive->RequestId() == EDedicatedBonding && 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   298
				( aStatus == KErrRemoteDeviceIndicatedNoBonding || 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   299
					( aStatus && iPairMode != EBTOutgoingNoneHeadsetPairing && iPairMode != EBTOutgoingPairNone ) )   )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   300
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   301
        // try general pairing if the remote doesn't have dedicated bonding, or
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   302
        // pairing fails with a headset.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   303
        DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   304
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   305
    else if ( aStatus && iPairMode == EBTOutgoingHeadsetAutoPairing )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   306
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   307
        iPairMode = EBTOutgoingHeadsetManualPairing;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   308
        // auto pairing with headset failed, try to pair again with manual pin:
42
hgs
parents: 31
diff changeset
   309
        BOstrace0(TRACE_DEBUG,DUMMY_DEVLIST," auto pairing failed, switch to manual pairing");     
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   310
        DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   311
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   312
    else if ( aStatus && aActive->RequestId() == EGeneralBonding && 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   313
              iPairMode == EBTOutgoingHeadsetManualPairing )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   314
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   315
        // pairing headset with manual pin failed, wait for a while and try again:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   316
        iActive->SetRequestId( EGeneralBondingRetryTimer );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   317
        iTimer.After( iActive->iStatus, KGeneralBondingRetryDelayMicroSeconds );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   318
        iActive->GoActive();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   319
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   320
    else if( aActive->RequestId() == EGeneralBondingRetryTimer )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   321
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   322
        // try to pair headset again with manual pin again:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   323
        DoPairingL();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   324
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   325
    else if ( aStatus )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   326
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   327
        // we only starts showing note if pairing failed.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   328
        // For a successful pair, we must wait until registry has been updated.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   329
        if ( !IsPairResultSet() )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   330
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   331
            SetPairResult( aStatus );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   332
            }
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   333
        if ( aStatus <= KHCIErrorBase - EUnknownOpcode)
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   334
            {
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   335
            // retry pairing
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   336
            if(iPairingAttempt > 0)
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   337
                {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   338
                if(aActive->RequestId() == EGeneralBondingRetry && iPairMode == EBTOutgoingHeadsetManualPairing)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   339
                    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   340
                    // Headset pairing failed, reset and try again from auto pairing
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   341
                    iActive->SetRequestId(EGeneralBonding);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   342
                    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   343
                iPairingAttempt --;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   344
                ShowPairingRetryDialog();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   345
                }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   346
            else
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   347
                {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   348
                iPairingAttempt --;
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   349
                iParent.OutgoingPairCompleted( aStatus );
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   350
                ShowPairingFailureDialog();
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   351
                iParent.RenewPairingHandler( NULL );
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   352
                }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   353
             }
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   354
        else
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   355
            {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   356
            iParent.OutgoingPairCompleted( aStatus );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   357
            ShowPairingFailureDialog();
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   358
            iParent.RenewPairingHandler( NULL );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   359
            }
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   360
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   361
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   362
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   363
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   364
// From class MBTEngActiveObserver.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   365
// cancels an outstanding request according to the given id.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   366
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   367
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   368
void CBTNotifOutgoingPairingHandler::CancelRequest( TInt aRequestId )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   369
    {
42
hgs
parents: 31
diff changeset
   370
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   371
    switch ( aRequestId )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   372
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   373
        case EDedicatedBonding:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   374
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   375
            iBondingSession.Close();
42
hgs
parents: 31
diff changeset
   376
            break;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   377
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   378
        case EGeneralBonding:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   379
        case EGeneralBondingRetry:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   380
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   381
            iSocket.CancelConnect();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   382
            iSocket.Close();
42
hgs
parents: 31
diff changeset
   383
            break;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   384
            }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   385
        case EGeneralBondingRetryTimer:
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   386
            {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   387
            iTimer.Cancel();
42
hgs
parents: 31
diff changeset
   388
            break;
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   389
            }     
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   390
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   391
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   392
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   393
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   394
// From class MBTEngActiveObserver.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   395
// Handles a leave in RequestCompleted by self-destructing.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   396
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   397
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   398
void CBTNotifOutgoingPairingHandler::HandleError( 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   399
        CBtSimpleActive* aActive, TInt aError )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   400
    {
42
hgs
parents: 31
diff changeset
   401
    BOstrace1(TRACE_DEBUG,DUMMY_DEVLIST,"error: %d", aError );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   402
    // Our RunL can actually not leave, so we should never reach here.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   403
    (void) aActive;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   404
    iParent.OutgoingPairCompleted( aError );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   405
    iParent.RenewPairingHandler( NULL );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   406
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   407
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   408
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   409
// decide the next state and issue pair request
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   410
// ---------------------------------------------------------------------------
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   411
//
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   412
void CBTNotifOutgoingPairingHandler::DoPairingL()
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   413
    {
42
hgs
parents: 31
diff changeset
   414
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   415
    TPairingStageId currentMode = ( TPairingStageId ) iActive->RequestId();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   416
    ASSERT( !iActive->IsActive() );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   417
    TPairingStageId nextMode( EGeneralBonding );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   418
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   419
    // if running BTv2.0 stack, dedicated bonding method 
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   420
    // is not available.
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   421
    if ( currentMode == ENoBonding && iParent.PairingServer() != NULL )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   422
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   423
        nextMode = EDedicatedBonding;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   424
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   425
    else if(currentMode == EGeneralBondingRetryTimer)
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   426
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   427
        nextMode = EGeneralBondingRetry;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   428
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   429
    
42
hgs
parents: 31
diff changeset
   430
    BOstraceExt2(TRACE_DEBUG,DUMMY_DEVLIST,"[BTENG] CBTEngOtgPair::DoPairingL: bonding mode: pre %d, next %d", currentMode, nextMode);
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   431
    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   432
    iActive->SetRequestId( nextMode );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   433
    if ( nextMode == EDedicatedBonding )
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   434
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   435
        iBondingSession.Start( *iParent.PairingServer(), iAddr, iActive->RequestStatus() );          
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   436
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   437
    else
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   438
        {
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   439
        TBTServiceSecurity sec;
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   440
        sec.SetAuthentication( ETrue );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   441
        iSockAddr.SetBTAddr( iAddr );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   442
        iSockAddr.SetPort(KSDPPSM);
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   443
        iSockAddr.SetSecurity( sec );    
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   444
        iSocket.Close();
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   445
        User::LeaveIfError( iSocket.Open( iParent.SocketServ(), KL2CAPDesC ) );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   446
        iSocket.Connect( iSockAddr, iActive->RequestStatus() );
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   447
        }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   448
    iActive->GoActive();
42
hgs
parents: 31
diff changeset
   449
    BOstraceFunctionExit0( DUMMY_DEVLIST );
31
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   450
    }
a0ea99b6fa53 201019_1
hgs
parents:
diff changeset
   451
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   452
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   453
// From class MBTNotificationResult.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   454
// Handle a result from a user query.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   455
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   456
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   457
void CBTNotifOutgoingPairingHandler::MBRDataReceived( CHbSymbianVariantMap& aData )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   458
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   459
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   460
    (void) aData;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   461
    BOstraceFunctionExit0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   462
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   463
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   464
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   465
// From class MBTNotificationResult.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   466
// The notification is finished.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   467
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   468
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   469
void CBTNotifOutgoingPairingHandler::MBRNotificationClosed( TInt aError, const TDesC8& aData )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   470
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   471
    BOstraceFunctionEntryExt( DUMMY_DEVLIST, this, aError );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   472
    // First unregister from the notification, so we can already get the next one.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   473
    iNotification->RemoveObserver();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   474
    iNotification = NULL;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   475
    TRAP_IGNORE( NotificationClosedL( aError, aData ) );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   476
    BOstraceFunctionExit1( DUMMY_DEVLIST, this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   477
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   478
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   479
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   480
// Get and configure a notification.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   481
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   482
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   483
void CBTNotifOutgoingPairingHandler::PrepareNotificationL( TBluetoothDialogParams::TBTDialogType aType,
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   484
    TBTDialogResourceId aResourceId )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   485
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   486
    BOstraceFunctionEntry0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   487
    iNotification = 
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   488
            iParent.ConnectionTracker().NotificationManager()->GetNotification();
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   489
    User::LeaveIfNull( iNotification ); // For OOM exception, leaves with KErrNoMemory
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   490
    iNotification->SetObserver( this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   491
    iNotification->SetNotificationType( aType, aResourceId );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   492
    const CBtDevExtension* dev = iParent.BTDevRepository().Device(iAddr);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   493
    if(dev)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   494
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   495
        User::LeaveIfError(iNotification->SetData( TBluetoothDeviceDialog::EDeviceName, dev->Alias()));
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   496
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   497
    else
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   498
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   499
        TBTDeviceName name;
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   500
        iAddr.GetReadable(name);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   501
        User::LeaveIfError(iNotification->SetData( TBluetoothDeviceDialog::EDeviceName, name));
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   502
        NOTIF_NOTHANDLED( !err )            
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   503
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   504
    iParent.ConnectionTracker().NotificationManager()->QueueNotificationL( iNotification);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   505
    NOTIF_NOTHANDLED( !err )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   506
    BOstraceFunctionExit0( DUMMY_DEVLIST );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   507
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   508
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   509
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   510
// The notification is finished, handle the result.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   511
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   512
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   513
void CBTNotifOutgoingPairingHandler::NotificationClosedL( TInt aError, const TDesC8& aData )
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   514
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   515
    BOstraceFunctionEntryExt( DUMMY_DEVLIST, this, aError );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   516
    // Read the result.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   517
    TPckgC<TBool> result( EFalse );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   518
    result.Set( aData.Ptr(), result.Length() ); // Read the part containing the result
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   519
    // Set a pointer descriptor to capture the remaining data, if any.
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   520
    TPtrC8 dataPtr( aData.Mid( result.Length() ) );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   521
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   522
    if(result() && iPairingAttempt >= 0)
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   523
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   524
            HandleOutgoingPairL(iAddr,iCod.DeviceClass());
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   525
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   526
    else
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   527
        {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   528
            iPairingAttempt = KMaxRepeatedPairingAttempt; // reset the counter
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   529
            iParent.OutgoingPairCompleted( KErrCancel );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   530
            iParent.RenewPairingHandler( NULL );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   531
        }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   532
    BOstraceFunctionExit1( DUMMY_DEVLIST, this );
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   533
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   534
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   535
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   536
// Show a dialog to ask the user to retry the pairing
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   537
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   538
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   539
void CBTNotifOutgoingPairingHandler::ShowPairingRetryDialog()
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   540
    {
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   541
    PrepareNotificationL( TBluetoothDialogParams::EQuery, EPairingFailureRetry);
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   542
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   543
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   544
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   545
// Show a dialog to tell the user pairing retry attempt failed
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   546
// ---------------------------------------------------------------------------
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   547
//
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   548
void CBTNotifOutgoingPairingHandler::ShowPairingFailureDialog()
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   549
    {
57
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   550
    if(!iPairingCancelledByUser)
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   551
        {
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   552
        iDialogIsOrphan = ETrue;
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   553
        PrepareNotificationL( TBluetoothDialogParams::EQuery, EPairingFailureOk );
5ebadcda06cb 201035_7
hgs
parents: 47
diff changeset
   554
        }
47
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   555
    }
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   556
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   557
9e2a905b887f 201029_02
hgs
parents: 42
diff changeset
   558