localconnectivityservice/dun/plugins/inc/usb/DunUsbConfig.h
author hgs
Fri, 25 Jun 2010 16:54:01 +0800
changeset 29 3ae5cb0b4c02
child 54 4dc88a4ac6f4
permissions -rw-r--r--
201025_07
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2006-2007 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  DUN USB configuration accessor and listener
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    16
*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    17
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    18
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
#ifndef C_CDUNUSBCONFIG_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#define C_CDUNUSBCONFIG_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <e32property.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include <usb/acmconfig.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
#include "DunPlugin.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
enum TUsbConfigState
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
    EUsbConfigStateIdle,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
    EUsbConfigStateWaiting
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
 *  Notification interface class to report USB ACM configuration change
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
 *  @lib dunusb.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
 *  @since S60 v3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
NONSHARABLE_CLASS( MDunUsbConfig )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
	{
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
     * Gets called when one or more ACM configurations are added
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
     * @param aIndex Index (also port number) of added ACM configuration
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
     * @return Symbian error code on error, KErrNone otherwise
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
    virtual TInt NotifyConfigAddition( TInt aIndex ) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
     * Gets called when one or more ACM configurations are removed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
     * @param aIndex Index (also port number) of removed ACM configuration
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
     * @return Symbian error code on error, KErrNone otherwise
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
    virtual TInt NotifyConfigRemoval( TInt aIndex ) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
	};
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
 *  Class for detecting USB ACM configuration change
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
 *  @lib dunutils.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
 *  @since S60 v3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
NONSHARABLE_CLASS( CDunUsbConfig ) : public CActive
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
     * Two-phased constructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
     * @param aServer Server
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
     * @param aCallback Pointer to listener callback
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
     * @param aProtocol Protocol number to listen
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
     * @return Instance of self
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
	static CDunUsbConfig* NewL( MDunServerCallback* aServer,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
                                MDunUsbConfig* aCallback,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
                                TUint8 aProtocol );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    * Destructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
    virtual ~CDunUsbConfig();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
     * Resets data to initial values
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
     * @return None
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
    void ResetData();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
     * Compares initialized protocol number to configuration by index
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
     * @param aIndex Index for which to compare protocol number
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
     * @param aValidity If initialized protocol matched at aIndex then ETrue
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
     * @return Symbian error code on error, KErrNone otherwise
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
    TInt GetConfigValidityByIndex( TInt aIndex, TBool& aValidity );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
     * Starts listening for ACM configuration changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
     * @return Symbian error code on error, KErrNone otherwise
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
    TInt IssueRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
     * Stops listening for ACM configuration changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
     * @return Symbian error code on error, KErrNone otherwise
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
    TInt Stop();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
    CDunUsbConfig( MDunServerCallback* aServer,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
                   MDunUsbConfig* aCallback,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
                   TUint8 aProtocol );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
    void ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
     * Initializes this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
     * @return None
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
    void Initialize();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
    /*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
     * Gets current ACM configuration
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    TInt GetConfiguration( TPublishedAcmConfigs& aConfig );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
// from base class CActive
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
     * From CActive.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
     * Gets called when ACM configuration changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
     * @return None
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
    void RunL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
     * From CActive.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
     * Gets called on cancel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
     * @since S60 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
     * @return None
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
    void DoCancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
private:  // data
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
     * Callback to call when notification via MDunServerCallback to be made
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
     * Not own.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    MDunServerCallback* iServer;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
     * Callback to call when notification(s) via MDunUsbConfig to be made
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    MDunUsbConfig* iCallback;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
     * Current state of configuration waiting: active or inactive
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
    TUsbConfigState iConfigState;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
    /*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
     * Protocol number of USB ACM to which listening is done
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
    TUint8 iProtocol;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
     * ACM config from the previous Get()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
     * Used to check whether configs are added or removed and also array data
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
     * needed for check in the removal case
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
    TPublishedAcmConfigs iConfig;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
    /*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
     * ACM configuration property
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
    RProperty iAcmProperty;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
    /*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
     * Flag to indicate if configuration already received
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
    TBool iConfigExist;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
#endif  // C_CDUNUSBCONFIG_H