bluetoothengine/btnotif/btnotifsrv/inc/btnotifsession.h
author hgs
Mon, 03 May 2010 14:36:07 +0300
changeset 29 48ae3789ce00
child 31 a0ea99b6fa53
permissions -rw-r--r--
201017_2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     1
/*
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     2
* ============================================================================
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     3
*  Name        : btnotifsession.h
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     4
*  Part of     : bluetoothengine / btnotif
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     5
*  Description : Session class for handling commands from clients.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     6
*
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     7
*  Copyright © 2009 Nokia Corporation and/or its subsidiary(-ies).
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     8
*  All rights reserved.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
     9
*  This component and the accompanying materials are made available
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    10
*  under the terms of "Eclipse Public License v1.0"
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    11
*  which accompanies this distribution, and is available
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    12
*  at the URL "http://www.eclipse.org/legal/epl-v10.html".
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    13
*
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    14
*  Initial Contributors:
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    15
*  Nokia Corporation - initial contribution.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    16
*
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    17
*  Contributors:
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    18
*  Nokia Corporation
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    19
* ============================================================================
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    20
* Template version: 4.2
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    21
*/
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    22
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    23
#ifndef BTNOTIFSESSION_H
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    24
#define BTNOTIFSESSION_H
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    25
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    26
#include "btnotifserver.h"
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    27
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    28
/**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    29
 *  CBTNotifSession maintains a session with a client.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    30
 *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    31
 *  @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    32
 */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    33
NONSHARABLE_CLASS( CBTNotifSession ) : public CSession2
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    34
    {
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    35
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    36
public:
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    37
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    38
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    39
     * Two-phased constructor.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    40
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    41
    static CBTNotifSession* NewL();
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    42
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    43
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    44
    * Destructor.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    45
    */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    46
    virtual ~CBTNotifSession();
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    47
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    48
// from base class CSession2
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    49
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    50
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    51
     * From CSession2.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    52
     * Receives a message from a client.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    53
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    54
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    55
     * @param aMessage The message containing the details of the client request.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    56
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    57
    virtual void ServiceL( const RMessage2& aMessage );
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    58
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    59
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    60
     * From CSession2.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    61
     * Completes construction of the session.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    62
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    63
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    64
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    65
    virtual void CreateL();
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    66
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    67
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    68
     * Complete a client message from a message handle.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    69
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    70
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    71
     * @param aHandle The handle identifying the message.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    72
     * @param aReason The reason code to complete the message with.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    73
     * @param aReply Data to write back to the client.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    74
     * @return KErrNone on success; KErrNotFound if the message is not found.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    75
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    76
    TInt CompleteMessage( TInt aHandle, TInt aReason, const TDesC8& aReply );
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    77
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    78
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    79
     * Find a message identified by an RMessage2 handle.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    80
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    81
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    82
     * @param aHandle The handle identifying the message.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    83
     * @return The message.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    84
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    85
    const RMessage2* FindMessageFromHandle( TInt aHandle ) const;
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    86
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    87
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    88
     * Find a message identified by an RNotifier notifier UID.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    89
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    90
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    91
     * @param aUid The UID identifying the message.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    92
     * @return The message.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    93
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    94
    const RMessage2* FindMessageFromUid( TInt aUid ) const;
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    95
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    96
private:
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    97
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    98
    CBTNotifSession();
48ae3789ce00 201017_2
hgs
parents:
diff changeset
    99
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   100
    void ConstructL();
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   101
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   102
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   103
     * Returns a handle to our server.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   104
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   105
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   106
     * @param Pointer to our server.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   107
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   108
    inline CBTNotifServer* Server() const
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   109
        { return (CBTNotifServer*) CSession2::Server(); }
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   110
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   111
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   112
     * Processes a message from a client.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   113
     *
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   114
     * @since Symbian^4
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   115
     * @param aMessage The message containing the details of the client request.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   116
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   117
    void DispatchMessageL( const RMessage2& aMessage );
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   118
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   119
private: // data
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   120
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   121
    /**
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   122
     * Array of messages currently being processed.
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   123
     */
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   124
    RArray<RMessage2> iMessageQ;
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   125
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   126
    BTUNITTESTHOOK
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   127
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   128
    };
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   129
48ae3789ce00 201017_2
hgs
parents:
diff changeset
   130
#endif // BTNOTIFSESSION_H