mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-05 13:37:43 +03:00
Add entry view column for password strength
* Closes #4216 Reduced to three-tiered rating system and fixed column implementation. Hide password strength indicator in entry view if excluded from reports. Introduce password health caching to prevent unnecessary calculations.
This commit is contained in:
parent
c9c19d043f
commit
022154462e
23 changed files with 213 additions and 187 deletions
|
@ -17,14 +17,12 @@
|
|||
*/
|
||||
#include "Entry.h"
|
||||
|
||||
#include "config-keepassx.h"
|
||||
|
||||
#include "core/Clock.h"
|
||||
#include "core/Config.h"
|
||||
#include "core/Database.h"
|
||||
#include "core/DatabaseIcons.h"
|
||||
#include "core/Group.h"
|
||||
#include "core/Metadata.h"
|
||||
#include "core/PasswordHealth.h"
|
||||
#include "core/Tools.h"
|
||||
#include "totp/totp.h"
|
||||
|
||||
|
@ -245,6 +243,25 @@ QString Entry::defaultAutoTypeSequence() const
|
|||
return m_data.defaultAutoTypeSequence;
|
||||
}
|
||||
|
||||
const QSharedPointer<PasswordHealth>& Entry::passwordHealth()
|
||||
{
|
||||
if (!m_data.passwordHealth) {
|
||||
m_data.passwordHealth.reset(new PasswordHealth(resolvePlaceholder(password())));
|
||||
}
|
||||
return m_data.passwordHealth;
|
||||
}
|
||||
|
||||
bool Entry::excludeFromReports() const
|
||||
{
|
||||
return customData()->contains(CustomData::ExcludeFromReports)
|
||||
&& customData()->value(CustomData::ExcludeFromReports) == TRUE_STR;
|
||||
}
|
||||
|
||||
void Entry::setExcludeFromReports(bool state)
|
||||
{
|
||||
customData()->set(CustomData::ExcludeFromReports, state ? TRUE_STR : FALSE_STR);
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine the effective sequence that will be injected
|
||||
* This function return an empty string if a parent group has autotype disabled or if the entry has no parent
|
||||
|
@ -673,6 +690,8 @@ void Entry::setUsername(const QString& username)
|
|||
|
||||
void Entry::setPassword(const QString& password)
|
||||
{
|
||||
// Reset Password Health
|
||||
m_data.passwordHealth.reset();
|
||||
m_attributes->set(EntryAttributes::PasswordKey, password, m_attributes->isProtected(EntryAttributes::PasswordKey));
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue