53 lines
1.2 KiB
C++
53 lines
1.2 KiB
C++
/*
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
* SPDX-FileCopyrightText: 2020 Johan Ouwerkerk <jm.ouwerkerk@gmail.com>
|
|
*/
|
|
#include "validation.h"
|
|
|
|
#include "../base32/base32.h"
|
|
#include "../oath/oath.h"
|
|
|
|
namespace accounts
|
|
{
|
|
|
|
bool checkId(const QUuid &id)
|
|
{
|
|
return !id.isNull();
|
|
}
|
|
|
|
bool checkSecret(const QString &secret)
|
|
{
|
|
return !secret.isEmpty() && base32::validate(secret);
|
|
}
|
|
|
|
bool checkName(const QString &name)
|
|
{
|
|
return !name.isEmpty();
|
|
}
|
|
|
|
bool checkIssuer(const QString &issuer)
|
|
{
|
|
return issuer.isNull() || (!issuer.isEmpty() && !issuer.contains(QLatin1Char(':')));
|
|
}
|
|
|
|
bool checkTokenLength(uint tokenLength)
|
|
{
|
|
return tokenLength >= 6U && tokenLength <= 10U;
|
|
}
|
|
|
|
bool checkTimeStep(uint timeStep)
|
|
{
|
|
return timeStep > 0U;
|
|
}
|
|
|
|
bool checkEpoch(const QDateTime &epoch, const std::function<qint64(void)> &clock)
|
|
{
|
|
return epoch.isValid() && epoch.toMSecsSinceEpoch() <= clock();
|
|
}
|
|
|
|
bool checkOffset(const std::optional<uint> &offset, QCryptographicHash::Algorithm algorithm)
|
|
{
|
|
return oath::Algorithm::validate(algorithm, offset);
|
|
}
|
|
}
|