securitysettings/qtconfigutils/eapqtconfiginterface/src/eapqtvalidatorpassword.cpp
branchRCL_3
changeset 18 bad0cc58d154
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/securitysettings/qtconfigutils/eapqtconfiginterface/src/eapqtvalidatorpassword.cpp	Tue Aug 31 15:16:37 2010 +0300
@@ -0,0 +1,135 @@
+/*
+ * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
+ * All rights reserved.
+ * This component and the accompanying materials are made available
+ * under the terms of "Eclipse Public License v1.0"
+ * which accompanies this distribution, and is available
+ * at the URL "http://www.eclipse.org/legal/epl-v10.html".
+ *
+ * Initial Contributors:
+ * Nokia Corporation - initial contribution.
+ *
+ * Contributors:
+ *
+ * Description: 
+ *   EAP method password format validator
+ *
+ */
+
+/*
+ * %version: 9 %
+ */
+
+// System includes
+#include <HbEditorInterface>
+#include <HbLineEdit>
+
+// User includes
+#include "eapqtvalidatorpassword.h"
+#include "eapqtconfiginterface_p.h"
+
+/*!
+ *  \class EapQtValidatorPassword
+ *  \brief EAP method password format validator
+ */
+
+// External function prototypes
+
+// Local constants
+
+// ======== LOCAL FUNCTIONS ========
+
+// ======== MEMBER FUNCTIONS ========
+
+EapQtValidatorPassword::EapQtValidatorPassword(const EapQtExpandedEapType& type) :
+    mEapType(type)
+{
+}
+
+EapQtValidatorPassword::~EapQtValidatorPassword()
+{
+}
+
+EapQtValidator::Status EapQtValidatorPassword::validate(const QVariant& value)
+{
+    qDebug("EapQtValidatorPassword::validate()");
+
+    Status status(StatusOk);
+
+    switch (mEapType.type()) {
+    case EapQtExpandedEapType::TypeEapGtc:
+    case EapQtExpandedEapType::TypeEapMschapv2:
+    case EapQtExpandedEapType::TypeLeap:
+    case EapQtExpandedEapType::TypePap:
+    case EapQtExpandedEapType::TypePlainMschapv2:
+        status = validateGeneral(value);
+        break;
+    default:
+        // for methods that do not have a password
+        status = StatusInvalid;
+    }
+
+    return status;
+}
+
+EapQtValidator::Status EapQtValidatorPassword::validateGeneral(const QVariant& value)
+{
+    Status status(StatusOk);
+    QString str = value.toString();
+
+    // input must be of correct type
+    if (value.type() != QVariant::String) {
+        status = StatusInvalid;
+    }
+    // zero length password is not ok
+    else if (str.length() <= 0) {
+        status = StatusTooShort;
+    }
+    // check maximum length
+    else if (str.length() > EapQtConfigInterfacePrivate::StringMaxLength) {
+        status = StatusTooLong;
+    }
+
+    // any character is ok for passwords
+    qDebug("EapQtValidatorPassword::validateGeneral - return status: %d", status);
+
+    return status;
+}
+
+void EapQtValidatorPassword::updateEditor(HbLineEdit* const edit)
+{
+    qDebug("EapQtValidatorPassword::updateEditor()");
+
+    Q_ASSERT(edit);
+    if(edit == NULL) {
+        return;
+    }
+
+    switch (mEapType.type()) {
+    case EapQtExpandedEapType::TypeEapGtc:
+    case EapQtExpandedEapType::TypeEapMschapv2:
+    case EapQtExpandedEapType::TypeLeap:
+    case EapQtExpandedEapType::TypePap:
+    case EapQtExpandedEapType::TypePlainMschapv2:
+        updateEditorGeneral(edit);
+        // falls through on purpose
+    default:
+        // nothing for methods that do not have a password
+        break;
+    }
+}
+
+void EapQtValidatorPassword::updateEditorGeneral(HbLineEdit* const edit)
+{
+    qDebug("EapQtValidatorPassword::updateEditorGeneral()");
+
+    Q_ASSERT(edit);
+
+    edit->setMaxLength(EapQtConfigInterfacePrivate::StringMaxLength);
+    edit->setInputMethodHints(Qt::ImhNoAutoUppercase | Qt::ImhPreferLowercase
+        | Qt::ImhNoPredictiveText);
+
+    // do not set editor class or auto completing since they might leak the pwd
+    HbEditorInterface editInterface(edit);
+    editInterface.setSmileyTheme(HbSmileyTheme());
+}