mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-24 13:41:33 -05:00
Fixed QuaZip for windows, renaming
QuaZip should now usable under windows (fixed include in FindQuaZip) Renamed the representation from secure and unsecure to signed and unsigned
This commit is contained in:
parent
383b8b77eb
commit
a978880b0b
@ -20,7 +20,7 @@ ELSE (QUAZIP_INCLUDE_DIRS AND QUAZIP_LIBRARIES)
|
|||||||
PATH_SUFFIXES QuaZip/lib
|
PATH_SUFFIXES QuaZip/lib
|
||||||
)
|
)
|
||||||
FIND_LIBRARY(QUAZIP_LIBRARIES NAMES libquazip${QUAZIP_LIB_VERSION_SUFFIX}.dll HINTS ${QUAZIP_LIBRARY_DIR})
|
FIND_LIBRARY(QUAZIP_LIBRARIES NAMES libquazip${QUAZIP_LIB_VERSION_SUFFIX}.dll HINTS ${QUAZIP_LIBRARY_DIR})
|
||||||
FIND_PATH(QUAZIP_INCLUDE_DIR NAMES quazip.h HINTS ${QUAZIP_LIBRARY_DIR}/../ PATH_SUFFIXES include/quazip)
|
FIND_PATH(QUAZIP_INCLUDE_DIR NAMES quazip.h HINTS ${QUAZIP_LIBRARY_DIR}/../ PATH_SUFFIXES include/quazip5)
|
||||||
FIND_PATH(QUAZIP_ZLIB_INCLUDE_DIR NAMES zlib.h)
|
FIND_PATH(QUAZIP_ZLIB_INCLUDE_DIR NAMES zlib.h)
|
||||||
ELSE(WIN32)
|
ELSE(WIN32)
|
||||||
FIND_PACKAGE(PkgConfig)
|
FIND_PACKAGE(PkgConfig)
|
||||||
|
@ -89,11 +89,11 @@ AboutDialog::AboutDialog(QWidget* parent)
|
|||||||
extensions += "\n- " + tr("SSH Agent");
|
extensions += "\n- " + tr("SSH Agent");
|
||||||
#endif
|
#endif
|
||||||
#if defined(WITH_XC_KEESHARE_SECURE) && defined(WITH_XC_KEESHARE_INSECURE)
|
#if defined(WITH_XC_KEESHARE_SECURE) && defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
extensions += "\n- " + tr("KeeShare (secure and insecure sharing)");
|
extensions += "\n- " + tr("KeeShare (signed and unsigned sharing)");
|
||||||
#elif defined(WITH_XC_KEESHARE_SECURE)
|
#elif defined(WITH_XC_KEESHARE_SECURE)
|
||||||
extensions += "\n- " + tr("KeeShare (only secure sharing)");
|
extensions += "\n- " + tr("KeeShare (only signed sharing)");
|
||||||
#elif defined(WITH_XC_KEESHARE_INSECURE)
|
#elif defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
extensions += "\n- " + tr("KeeShare (only insecure sharing)");
|
extensions += "\n- " + tr("KeeShare (only unsigned sharing)");
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_YUBIKEY
|
#ifdef WITH_XC_YUBIKEY
|
||||||
extensions += "\n- " + tr("YubiKey");
|
extensions += "\n- " + tr("YubiKey");
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#include "ui_MainWindow.h"
|
#include "ui_MainWindow.h"
|
||||||
|
|
||||||
#include <QCloseEvent>
|
#include <QCloseEvent>
|
||||||
|
#include <QFileInfo>
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QMimeData>
|
#include <QMimeData>
|
||||||
#include <QShortcut>
|
#include <QShortcut>
|
||||||
|
@ -129,12 +129,12 @@ bool KeeShare::isEnabled(const Group* group)
|
|||||||
{
|
{
|
||||||
const auto reference = KeeShare::referenceOf(group);
|
const auto reference = KeeShare::referenceOf(group);
|
||||||
#if !defined(WITH_XC_KEESHARE_SECURE)
|
#if !defined(WITH_XC_KEESHARE_SECURE)
|
||||||
if (reference.path.endsWith(secureContainerFileType(), Qt::CaseInsensitive)){
|
if (reference.path.endsWith(signedContainerFileType(), Qt::CaseInsensitive)){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if !defined(WITH_XC_KEESHARE_INSECURE)
|
#if !defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
if (reference.path.endsWith(insecureContainerFileType(), Qt::CaseInsensitive)){
|
if (reference.path.endsWith(unsignedContainerFileType(), Qt::CaseInsensitive)){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -198,13 +198,13 @@ void KeeShare::connectDatabase(QSharedPointer<Database> newDb, QSharedPointer<Da
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString &KeeShare::secureContainerFileType()
|
const QString &KeeShare::signedContainerFileType()
|
||||||
{
|
{
|
||||||
static const QString filetype("kdbx.share");
|
static const QString filetype("kdbx.share");
|
||||||
return filetype;
|
return filetype;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString &KeeShare::insecureContainerFileType()
|
const QString &KeeShare::unsignedContainerFileType()
|
||||||
{
|
{
|
||||||
static const QString filetype("kdbx");
|
static const QString filetype("kdbx");
|
||||||
return filetype;
|
return filetype;
|
||||||
|
@ -56,8 +56,8 @@ public:
|
|||||||
|
|
||||||
void connectDatabase(QSharedPointer<Database> newDb, QSharedPointer<Database> oldDb);
|
void connectDatabase(QSharedPointer<Database> newDb, QSharedPointer<Database> oldDb);
|
||||||
|
|
||||||
static const QString& secureContainerFileType();
|
static const QString& signedContainerFileType();
|
||||||
static const QString& insecureContainerFileType();
|
static const QString& unsignedContainerFileType();
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void activeChanged();
|
void activeChanged();
|
||||||
|
@ -35,7 +35,7 @@ SettingsWidgetKeeShare::SettingsWidgetKeeShare(QWidget* parent)
|
|||||||
m_ui->setupUi(this);
|
m_ui->setupUi(this);
|
||||||
|
|
||||||
#if !defined(WITH_XC_KEESHARE_SECURE)
|
#if !defined(WITH_XC_KEESHARE_SECURE)
|
||||||
// Setting does not help the user of Version without secure export
|
// Setting does not help the user of Version without signed export
|
||||||
m_ui->ownCertificateGroupBox->setVisible(false);
|
m_ui->ownCertificateGroupBox->setVisible(false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -294,11 +294,11 @@ void ShareObserver::handleFileUpdated(const QString& path)
|
|||||||
notifyAbout(success, warning, error);
|
notifyAbout(success, warning, error);
|
||||||
}
|
}
|
||||||
|
|
||||||
ShareObserver::Result ShareObserver::importSecureContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup)
|
ShareObserver::Result ShareObserver::importSingedContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup)
|
||||||
{
|
{
|
||||||
#if !defined(WITH_XC_KEESHARE_SECURE)
|
#if !defined(WITH_XC_KEESHARE_SECURE)
|
||||||
Q_UNUSED(targetGroup);
|
Q_UNUSED(targetGroup);
|
||||||
return { reference.path, Result::Warning, tr("Secured share container are not supported - import prevented") };
|
return { reference.path, Result::Warning, tr("Signed share container are not supported - import prevented") };
|
||||||
#else
|
#else
|
||||||
QuaZip zip(reference.path);
|
QuaZip zip(reference.path);
|
||||||
if (!zip.open(QuaZip::mdUnzip)) {
|
if (!zip.open(QuaZip::mdUnzip)) {
|
||||||
@ -375,7 +375,7 @@ ShareObserver::Result ShareObserver::importSecureContainerInto(const KeeShareSet
|
|||||||
merger.setForcedMergeMode(Group::Synchronize);
|
merger.setForcedMergeMode(Group::Synchronize);
|
||||||
const bool changed = merger.merge();
|
const bool changed = merger.merge();
|
||||||
if (changed) {
|
if (changed) {
|
||||||
return {reference.path, Result::Success, tr("Successful secured import")};
|
return {reference.path, Result::Success, tr("Successful signed import")};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Silent ignore of untrusted import or unchanging import
|
// Silent ignore of untrusted import or unchanging import
|
||||||
@ -391,7 +391,7 @@ ShareObserver::Result ShareObserver::importSecureContainerInto(const KeeShareSet
|
|||||||
merger.setForcedMergeMode(Group::Synchronize);
|
merger.setForcedMergeMode(Group::Synchronize);
|
||||||
const bool changed = merger.merge();
|
const bool changed = merger.merge();
|
||||||
if (changed) {
|
if (changed) {
|
||||||
return {reference.path, Result::Success, tr("Successful secured import")};
|
return {reference.path, Result::Success, tr("Successful signed import")};
|
||||||
}
|
}
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
@ -402,11 +402,11 @@ ShareObserver::Result ShareObserver::importSecureContainerInto(const KeeShareSet
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
ShareObserver::Result ShareObserver::importInsecureContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup)
|
ShareObserver::Result ShareObserver::importUnsignedContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup)
|
||||||
{
|
{
|
||||||
#if !defined(WITH_XC_KEESHARE_INSECURE)
|
#if !defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
Q_UNUSED(targetGroup);
|
Q_UNUSED(targetGroup);
|
||||||
return {reference.path, Result::Warning, tr("Insecured share container are not supported - import prevented")};
|
return {reference.path, Result::Warning, tr("Unsigned share container are not supported - import prevented")};
|
||||||
#else
|
#else
|
||||||
QFile file(reference.path);
|
QFile file(reference.path);
|
||||||
if (!file.open(QIODevice::ReadOnly)){
|
if (!file.open(QIODevice::ReadOnly)){
|
||||||
@ -458,7 +458,7 @@ ShareObserver::Result ShareObserver::importInsecureContainerInto(const KeeShareS
|
|||||||
merger.setForcedMergeMode(Group::Synchronize);
|
merger.setForcedMergeMode(Group::Synchronize);
|
||||||
const bool changed = merger.merge();
|
const bool changed = merger.merge();
|
||||||
if (changed) {
|
if (changed) {
|
||||||
return {reference.path, Result::Success, tr("Successful secured import")};
|
return {reference.path, Result::Success, tr("Successful signed import")};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return {};
|
return {};
|
||||||
@ -473,7 +473,7 @@ ShareObserver::Result ShareObserver::importInsecureContainerInto(const KeeShareS
|
|||||||
merger.setForcedMergeMode(Group::Synchronize);
|
merger.setForcedMergeMode(Group::Synchronize);
|
||||||
const bool changed = merger.merge();
|
const bool changed = merger.merge();
|
||||||
if (changed) {
|
if (changed) {
|
||||||
return {reference.path, Result::Success, tr("Successful unsecured import")};
|
return {reference.path, Result::Success, tr("Successful unsigned import")};
|
||||||
}
|
}
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
@ -492,11 +492,11 @@ ShareObserver::Result ShareObserver::importContainerInto(const KeeShareSettings:
|
|||||||
return {reference.path, Result::Warning, tr("File does not exist")};
|
return {reference.path, Result::Warning, tr("File does not exist")};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isOfExportType(info, KeeShare::secureContainerFileType())) {
|
if (isOfExportType(info, KeeShare::signedContainerFileType())) {
|
||||||
return importSecureContainerInto(reference, targetGroup);
|
return importSingedContainerInto(reference, targetGroup);
|
||||||
}
|
}
|
||||||
if (isOfExportType(info, KeeShare::insecureContainerFileType())) {
|
if (isOfExportType(info, KeeShare::unsignedContainerFileType())) {
|
||||||
return importInsecureContainerInto(reference, targetGroup);
|
return importUnsignedContainerInto(reference, targetGroup);
|
||||||
}
|
}
|
||||||
return {reference.path, Result::Error, tr("Unknown share container type")};
|
return {reference.path, Result::Error, tr("Unknown share container type")};
|
||||||
}
|
}
|
||||||
@ -604,11 +604,11 @@ QSharedPointer<Database> ShareObserver::database()
|
|||||||
return m_db;
|
return m_db;
|
||||||
}
|
}
|
||||||
|
|
||||||
ShareObserver::Result ShareObserver::exportIntoReferenceSecureContainer(const KeeShareSettings::Reference &reference, Database *targetDb)
|
ShareObserver::Result ShareObserver::exportIntoReferenceSignedContainer(const KeeShareSettings::Reference &reference, Database *targetDb)
|
||||||
{
|
{
|
||||||
#if !defined(WITH_XC_KEESHARE_SECURE)
|
#if !defined(WITH_XC_KEESHARE_SECURE)
|
||||||
Q_UNUSED(targetDb);
|
Q_UNUSED(targetDb);
|
||||||
return {reference.path, Result::Warning, tr("Overwriting secured share container is not supported - export prevented")};
|
return {reference.path, Result::Warning, tr("Overwriting signed share container is not supported - export prevented")};
|
||||||
#else
|
#else
|
||||||
QByteArray bytes;
|
QByteArray bytes;
|
||||||
{
|
{
|
||||||
@ -670,11 +670,11 @@ ShareObserver::Result ShareObserver::exportIntoReferenceSecureContainer(const Ke
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
ShareObserver::Result ShareObserver::exportIntoReferenceInsecureContainer(const KeeShareSettings::Reference &reference, Database *targetDb)
|
ShareObserver::Result ShareObserver::exportIntoReferenceUnsignedContainer(const KeeShareSettings::Reference &reference, Database *targetDb)
|
||||||
{
|
{
|
||||||
#if !defined(WITH_XC_KEESHARE_INSECURE)
|
#if !defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
Q_UNUSED(targetDb);
|
Q_UNUSED(targetDb);
|
||||||
return {reference.path, Result::Warning, tr("Overwriting secured share container is not supported - export prevented")};
|
return {reference.path, Result::Warning, tr("Overwriting unsigned share container is not supported - export prevented")};
|
||||||
#else
|
#else
|
||||||
QFile file(reference.path);
|
QFile file(reference.path);
|
||||||
const bool fileOpened = file.open(QIODevice::WriteOnly);
|
const bool fileOpened = file.open(QIODevice::WriteOnly);
|
||||||
@ -706,13 +706,13 @@ QList<ShareObserver::Result> ShareObserver::exportIntoReferenceContainers()
|
|||||||
m_fileWatcher->ignoreFileChanges(reference.path);
|
m_fileWatcher->ignoreFileChanges(reference.path);
|
||||||
QScopedPointer<Database> targetDb(exportIntoContainer(reference, group));
|
QScopedPointer<Database> targetDb(exportIntoContainer(reference, group));
|
||||||
QFileInfo info(reference.path);
|
QFileInfo info(reference.path);
|
||||||
if (isOfExportType(info, KeeShare::secureContainerFileType())) {
|
if (isOfExportType(info, KeeShare::signedContainerFileType())) {
|
||||||
results << exportIntoReferenceSecureContainer(reference, targetDb.data());
|
results << exportIntoReferenceSignedContainer(reference, targetDb.data());
|
||||||
m_fileWatcher->observeFileChanges(true);
|
m_fileWatcher->observeFileChanges(true);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (isOfExportType(info, KeeShare::insecureContainerFileType())) {
|
if (isOfExportType(info, KeeShare::unsignedContainerFileType())) {
|
||||||
results << exportIntoReferenceInsecureContainer(reference, targetDb.data());
|
results << exportIntoReferenceUnsignedContainer(reference, targetDb.data());
|
||||||
m_fileWatcher->observeFileChanges(true);
|
m_fileWatcher->observeFileChanges(true);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -77,10 +77,10 @@ private:
|
|||||||
static void resolveReferenceAttributes(Entry* targetEntry, const Database* sourceDb);
|
static void resolveReferenceAttributes(Entry* targetEntry, const Database* sourceDb);
|
||||||
|
|
||||||
static Database* exportIntoContainer(const KeeShareSettings::Reference& reference, const Group* sourceRoot);
|
static Database* exportIntoContainer(const KeeShareSettings::Reference& reference, const Group* sourceRoot);
|
||||||
static Result exportIntoReferenceInsecureContainer(const KeeShareSettings::Reference &reference, Database *targetDb);
|
static Result exportIntoReferenceUnsignedContainer(const KeeShareSettings::Reference &reference, Database *targetDb);
|
||||||
static Result exportIntoReferenceSecureContainer(const KeeShareSettings::Reference &reference, Database *targetDb);
|
static Result exportIntoReferenceSignedContainer(const KeeShareSettings::Reference &reference, Database *targetDb);
|
||||||
static Result importSecureContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup);
|
static Result importSingedContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup);
|
||||||
static Result importInsecureContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup);
|
static Result importUnsignedContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup);
|
||||||
static Result importContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup);
|
static Result importContainerInto(const KeeShareSettings::Reference& reference, Group* targetGroup);
|
||||||
static Result importDatabaseInto();
|
static Result importDatabaseInto();
|
||||||
|
|
||||||
|
@ -108,10 +108,10 @@ void EditGroupWidgetKeeShare::showSharingState()
|
|||||||
|
|
||||||
auto supportedExtensions = QStringList();
|
auto supportedExtensions = QStringList();
|
||||||
#if defined(WITH_XC_KEESHARE_INSECURE)
|
#if defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
supportedExtensions << KeeShare::insecureContainerFileType();
|
supportedExtensions << KeeShare::unsignedContainerFileType();
|
||||||
#endif
|
#endif
|
||||||
#if defined(WITH_XC_KEESHARE_SECURE)
|
#if defined(WITH_XC_KEESHARE_SECURE)
|
||||||
supportedExtensions << KeeShare::secureContainerFileType();
|
supportedExtensions << KeeShare::signedContainerFileType();
|
||||||
#endif
|
#endif
|
||||||
const auto reference = KeeShare::referenceOf(m_temporaryGroup);
|
const auto reference = KeeShare::referenceOf(m_temporaryGroup);
|
||||||
if (!reference.path.isEmpty()) {
|
if (!reference.path.isEmpty()) {
|
||||||
@ -208,18 +208,18 @@ void EditGroupWidgetKeeShare::launchPathSelectionDialog()
|
|||||||
auto unsupportedExtensions = QStringList();
|
auto unsupportedExtensions = QStringList();
|
||||||
auto knownFilters = QStringList() << QString("%1 (*)").arg("All files");
|
auto knownFilters = QStringList() << QString("%1 (*)").arg("All files");
|
||||||
#if defined(WITH_XC_KEESHARE_INSECURE)
|
#if defined(WITH_XC_KEESHARE_INSECURE)
|
||||||
defaultFiletype = KeeShare::insecureContainerFileType();
|
defaultFiletype = KeeShare::unsignedContainerFileType();
|
||||||
supportedExtensions << KeeShare::insecureContainerFileType();
|
supportedExtensions << KeeShare::unsignedContainerFileType();
|
||||||
knownFilters.prepend(QString("%1 (*.%2)").arg(tr("KeeShare insecure container"), KeeShare::insecureContainerFileType()));
|
knownFilters.prepend(QString("%1 (*.%2)").arg(tr("KeeShare unsigned container"), KeeShare::unsignedContainerFileType()));
|
||||||
#else
|
#else
|
||||||
unsupportedExtensions << KeeShare::insecureContainerFileType();
|
unsupportedExtensions << KeeShare::unsignedContainerFileType();
|
||||||
#endif
|
#endif
|
||||||
#if defined(WITH_XC_KEESHARE_SECURE)
|
#if defined(WITH_XC_KEESHARE_SECURE)
|
||||||
defaultFiletype = KeeShare::secureContainerFileType();
|
defaultFiletype = KeeShare::signedContainerFileType();
|
||||||
supportedExtensions << KeeShare::secureContainerFileType();
|
supportedExtensions << KeeShare::signedContainerFileType();
|
||||||
knownFilters.prepend(QString("%1 (*.%2)").arg(tr("KeeShare secure container"), KeeShare::secureContainerFileType()));
|
knownFilters.prepend(QString("%1 (*.%2)").arg(tr("KeeShare signed container"), KeeShare::signedContainerFileType()));
|
||||||
#else
|
#else
|
||||||
unsupportedExtensions << KeeShare::secureContainerFileType();
|
unsupportedExtensions << KeeShare::signedContainerFileType();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
const auto filters = knownFilters.join(";;");
|
const auto filters = knownFilters.join(";;");
|
||||||
|
Loading…
Reference in New Issue
Block a user