diff -r 30e048a7b597 -r bad0cc58d154 securitysettings/qtconfigutils/eapqtconfiginterface/src/eapqtvalidatorpassword.cpp --- /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 +#include + +// 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()); +}