wlanutilities/wlanwizard/inc/wlanwizardhelper.h
author hgs
Mon, 24 May 2010 21:11:39 +0300
changeset 31 e8f4211554fb
child 39 7b3e49e4608a
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: 
hgs
parents:
diff changeset
    15
*   WLAN Wizard Plugin API: Interface for plugins to wizard services.
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef WLANWIZARDHELPER_H
hgs
parents:
diff changeset
    19
#define WLANWIZARDHELPER_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
// System includes
hgs
parents:
diff changeset
    22
#include <cmmanagerdefines_shim.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// User includes
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// Forward declarations
hgs
parents:
diff changeset
    27
class HbMainWindow;
hgs
parents:
diff changeset
    28
class HbWidget;
hgs
parents:
diff changeset
    29
class WlanWizardPage;
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// External data types
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// Constants
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
/*!
hgs
parents:
diff changeset
    36
 * @addtogroup group_wlan_wizard_api_internal
hgs
parents:
diff changeset
    37
 * @{
hgs
parents:
diff changeset
    38
 */
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
/*!
hgs
parents:
diff changeset
    41
   This class specifies the interface class that wizard plugins (EAP and WPS) 
hgs
parents:
diff changeset
    42
   can use to access wizard framework services.
hgs
parents:
diff changeset
    43
 */
hgs
parents:
diff changeset
    44
class WlanWizardHelper
hgs
parents:
diff changeset
    45
{
hgs
parents:
diff changeset
    46
public:
hgs
parents:
diff changeset
    47
    /*!
hgs
parents:
diff changeset
    48
        WLAN Wizard configuration, which are accessible by wlan wizard and it's 
hgs
parents:
diff changeset
    49
        plugins. WLAN wizard pages uses this information to store configurations
hgs
parents:
diff changeset
    50
        from ui and state events.
hgs
parents:
diff changeset
    51
        
hgs
parents:
diff changeset
    52
        Please remember to update trace.properties upon changes.
hgs
parents:
diff changeset
    53
     */
hgs
parents:
diff changeset
    54
    enum ConfigurationId {
hgs
parents:
diff changeset
    55
        //! QString: WLAN Network name (aka SSID)
hgs
parents:
diff changeset
    56
        ConfSsid = 0,
hgs
parents:
diff changeset
    57
        //! int: CMManagerShim::WlanConnectionMode
hgs
parents:
diff changeset
    58
        ConfNetworkMode = 1,
hgs
parents:
diff changeset
    59
        //! int: CMManagerShim::WlanSecMode
hgs
parents:
diff changeset
    60
        ConfSecurityMode = 2,
hgs
parents:
diff changeset
    61
        //! QString: WPA PSK
hgs
parents:
diff changeset
    62
        ConfKeyWpa = 3,
hgs
parents:
diff changeset
    63
        //! QString: WEP Key 1
hgs
parents:
diff changeset
    64
        ConfKeyWep1 = 4,
hgs
parents:
diff changeset
    65
        //! QString: WEP Key 2
hgs
parents:
diff changeset
    66
        ConfKeyWep2 = 5,
hgs
parents:
diff changeset
    67
        //! QString: WEP Key 3
hgs
parents:
diff changeset
    68
        ConfKeyWep3 = 6,
hgs
parents:
diff changeset
    69
        //! QString: WEP Key 4
hgs
parents:
diff changeset
    70
        ConfKeyWep4 = 7,
hgs
parents:
diff changeset
    71
        //! int: CMManagerShim:::WlanWepKeyIndex, Default WEP Key index
hgs
parents:
diff changeset
    72
        ConfKeyWepDefault = 8,
hgs
parents:
diff changeset
    73
        //! bool: Internet Connectivity Test result, true passed.
hgs
parents:
diff changeset
    74
        ConfIctStatus = 9,
hgs
parents:
diff changeset
    75
        //! int, -1 (WlanQtUtils::IapIdNone): not defined: IAP ID
hgs
parents:
diff changeset
    76
        ConfIapId = 10,
hgs
parents:
diff changeset
    77
        //! bool: true if connection was established successfully
hgs
parents:
diff changeset
    78
        ConfConnected = 11,
hgs
parents:
diff changeset
    79
        //! bool: if true hidden WLAN
hgs
parents:
diff changeset
    80
        ConfHiddenWlan = 12,
hgs
parents:
diff changeset
    81
        //! bool: if true use psk, if false use EAP 
hgs
parents:
diff changeset
    82
        ConfUsePsk = 13,
hgs
parents:
diff changeset
    83
        //! bool: if true processing connection page is required.
hgs
parents:
diff changeset
    84
        ConfProcessSettings = 14,
hgs
parents:
diff changeset
    85
        //! QString: Localized error string for WlanWizardPageGenericError
hgs
parents:
diff changeset
    86
        ConfGenericErrorString = 15,
hgs
parents:
diff changeset
    87
    };
hgs
parents:
diff changeset
    88
    
hgs
parents:
diff changeset
    89
public:
hgs
parents:
diff changeset
    90
    
hgs
parents:
diff changeset
    91
    /*!
hgs
parents:
diff changeset
    92
       Reader method for wlan configurations.
hgs
parents:
diff changeset
    93
       
hgs
parents:
diff changeset
    94
       See ConfigurationId for further details about the data types in QVariant.
hgs
parents:
diff changeset
    95
       
hgs
parents:
diff changeset
    96
       @param [in] confId Defines what configuration is read.
hgs
parents:
diff changeset
    97
       
hgs
parents:
diff changeset
    98
       @return configuration value.
hgs
parents:
diff changeset
    99
     */
hgs
parents:
diff changeset
   100
    virtual QVariant configuration(ConfigurationId confId) const = 0;
hgs
parents:
diff changeset
   101
    
hgs
parents:
diff changeset
   102
    /*!
hgs
parents:
diff changeset
   103
       Sets wlan configuration value for given configuration identifier.
hgs
parents:
diff changeset
   104
       See ConfigurationId for further details about the data types in QVariant.
hgs
parents:
diff changeset
   105
       
hgs
parents:
diff changeset
   106
       @param [in] confId Configuration Identifier do to be set
hgs
parents:
diff changeset
   107
       @param [in] value  Value for configuration.
hgs
parents:
diff changeset
   108
     */
hgs
parents:
diff changeset
   109
    virtual void setConfiguration(
hgs
parents:
diff changeset
   110
        ConfigurationId confId, 
hgs
parents:
diff changeset
   111
        const QVariant &value) = 0;
hgs
parents:
diff changeset
   112
    
hgs
parents:
diff changeset
   113
    /*!
hgs
parents:
diff changeset
   114
       Enables the next button in wizard.
hgs
parents:
diff changeset
   115
       
hgs
parents:
diff changeset
   116
       @param [in] enable to enable button set to true.
hgs
parents:
diff changeset
   117
     */
hgs
parents:
diff changeset
   118
    virtual void enableNextButton(bool enable) = 0;
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
    /*!
hgs
parents:
diff changeset
   121
       Enables the previous button in wizard.
hgs
parents:
diff changeset
   122
       
hgs
parents:
diff changeset
   123
       @param [in] enable to enable button set to true.
hgs
parents:
diff changeset
   124
     */
hgs
parents:
diff changeset
   125
    virtual void enablePrevButton(bool enable) = 0;
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
    /*!
hgs
parents:
diff changeset
   128
       Adds a new wizard page into the wizard framework.
hgs
parents:
diff changeset
   129
       
hgs
parents:
diff changeset
   130
       @param [in] pageId The identifier of Page. See WlanWizardPage::PageIds.
hgs
parents:
diff changeset
   131
       @param [in] page New wizard page.
hgs
parents:
diff changeset
   132
     */
hgs
parents:
diff changeset
   133
    virtual void addPage(int pageId, WlanWizardPage *page) = 0;
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
    /*!
hgs
parents:
diff changeset
   136
       Triggers movement to the next page.
hgs
parents:
diff changeset
   137
       
hgs
parents:
diff changeset
   138
       @note This operation has been protected with 1.5 second timer to prevent
hgs
parents:
diff changeset
   139
       too short lasting pages.
hgs
parents:
diff changeset
   140
       
hgs
parents:
diff changeset
   141
       @note Must be used with WlanWizardPage::startOperation().
hgs
parents:
diff changeset
   142
     */
hgs
parents:
diff changeset
   143
    virtual void nextPage() = 0;
hgs
parents:
diff changeset
   144
    
hgs
parents:
diff changeset
   145
    /*!
hgs
parents:
diff changeset
   146
       @return the main window of wizard.
hgs
parents:
diff changeset
   147
     */
hgs
parents:
diff changeset
   148
    virtual HbMainWindow *mainWindow() const = 0;
hgs
parents:
diff changeset
   149
    
hgs
parents:
diff changeset
   150
    /*!
hgs
parents:
diff changeset
   151
       Checks if provided page visualization is the current visible page.
hgs
parents:
diff changeset
   152
       
hgs
parents:
diff changeset
   153
       @param [in] page Wizard Page visualization to be checked
hgs
parents:
diff changeset
   154
       
hgs
parents:
diff changeset
   155
       @return true if the page is currently visible.
hgs
parents:
diff changeset
   156
     */
hgs
parents:
diff changeset
   157
    virtual bool isCurrentPage(const HbWidget *page) const = 0;
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
    /*!
hgs
parents:
diff changeset
   160
       Can be used to get correct page id based on the existing configuration.
hgs
parents:
diff changeset
   161
       
hgs
parents:
diff changeset
   162
       This method can be used in so called entry points to wizards
hgs
parents:
diff changeset
   163
       - WLAN Wizard has been lauched and setParameters() has been called
hgs
parents:
diff changeset
   164
       - WLAN Wizard makes own internal scanning
hgs
parents:
diff changeset
   165
       - WPS Wizard uses manual configuration mode.
hgs
parents:
diff changeset
   166
       
hgs
parents:
diff changeset
   167
       @param [in] useWps true: if WPS Wizard needs to be opened, false: otherwise
hgs
parents:
diff changeset
   168
       
hgs
parents:
diff changeset
   169
       @return Page Id based on configurations:
hgs
parents:
diff changeset
   170
       - WEP/WPA(2) with PSK: WlanWizardPageInternal::PageKeyQuery
hgs
parents:
diff changeset
   171
       - Open: WlanWizardPage::PageProcessSettings
hgs
parents:
diff changeset
   172
       - 802.1x or WPA (2) with EAP: WlanWizardPage::PageEapStart
hgs
parents:
diff changeset
   173
       - UseWps: WlanWizardPage::PageWpsStart
hgs
parents:
diff changeset
   174
     */
hgs
parents:
diff changeset
   175
    virtual int nextPageId(bool useWps) = 0;
hgs
parents:
diff changeset
   176
    
hgs
parents:
diff changeset
   177
signals:
hgs
parents:
diff changeset
   178
    
hgs
parents:
diff changeset
   179
public slots:
hgs
parents:
diff changeset
   180
    
hgs
parents:
diff changeset
   181
protected:
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
protected slots:
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
private:
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
private slots:
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
private: // data
hgs
parents:
diff changeset
   190
};
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
/*! @} */
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
#endif // WLANWIZARDHELPER_H