mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-26 22:36:59 -05:00
Refactor: Move to simple default builds
* Remove individual feature flags in favor of a single `KPXC_MINIMAL` flag that removes advanced features from the build. Basic features are no longer guarded by feature flags. * Basic features: Auto-Type, Yubikey, KeeShare * Advanced features include: Browser (and passkeys), SSH Agent, and Secret Service * Networking, Documentation, and Update Checking remain as feature flags to accommodate various distro requirements. This change also cleans up the main CMakeLists.txt by re-arranging some content and placing macros into a dedicated include file. The minimum CMake version was bumped to 3.16.0 to conform to our minimum Ubuntu support of Focal (20.04). This also allows us to default to C++20, we fall back to C++17 for Qt versions less than 5.15.0 due to lack of support. Lastly this change removes the KEEPASSXC_BUILD_TYPE="PreRelease" which is never used. We only support "Snapshot" and "Release" now.
This commit is contained in:
parent
9e29b5c7b6
commit
cfa94f69f3
527
CMakeLists.txt
527
CMakeLists.txt
@ -1,4 +1,4 @@
|
|||||||
# Copyright (C) 2018 KeePassXC Team <team@keepassxc.org>
|
# Copyright (C) 2024 KeePassXC Team <team@keepassxc.org>
|
||||||
# Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
# Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
||||||
#
|
#
|
||||||
# This program is free software: you can redistribute it and/or modify
|
# This program is free software: you can redistribute it and/or modify
|
||||||
@ -14,119 +14,80 @@
|
|||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.10.0)
|
cmake_minimum_required(VERSION 3.16.0)
|
||||||
|
|
||||||
project(KeePassXC)
|
project(KeePassXC)
|
||||||
set(APP_ID "org.keepassxc.${PROJECT_NAME}")
|
set(APP_ID "org.keepassxc.${PROJECT_NAME}")
|
||||||
|
|
||||||
if(NOT CMAKE_BUILD_TYPE)
|
# Version Number
|
||||||
set(CMAKE_BUILD_TYPE "RelWithDebInfo" CACHE STRING
|
|
||||||
"Choose the type of build, options are: Debug Release RelWithDebInfo Profile"
|
|
||||||
FORCE)
|
|
||||||
endif()
|
|
||||||
string(TOLOWER "${CMAKE_BUILD_TYPE}" CMAKE_BUILD_TYPE_LOWER)
|
|
||||||
if(CMAKE_BUILD_TYPE_LOWER STREQUAL "debug" OR CMAKE_BUILD_TYPE_LOWER STREQUAL "relwithdebinfo")
|
|
||||||
set(IS_DEBUG_BUILD TRUE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake)
|
|
||||||
|
|
||||||
# Support Visual Studio Code
|
|
||||||
include(CMakeToolsHelpers OPTIONAL)
|
|
||||||
include(FeatureSummary)
|
|
||||||
include(KPXCMacDeployHelpers)
|
|
||||||
|
|
||||||
include(CheckCCompilerFlag)
|
|
||||||
include(CheckCXXCompilerFlag)
|
|
||||||
include(CheckCXXSourceCompiles)
|
|
||||||
|
|
||||||
option(WITH_TESTS "Enable building of unit tests" ON)
|
|
||||||
option(WITH_GUI_TESTS "Enable building of GUI tests" OFF)
|
|
||||||
option(WITH_DEV_BUILD "Use only for development. Disables/warns about deprecated methods." OFF)
|
|
||||||
option(WITH_ASAN "Enable address sanitizer checks (Linux / macOS only)" OFF)
|
|
||||||
option(WITH_COVERAGE "Use to build with coverage tests (GCC only)." OFF)
|
|
||||||
option(WITH_APP_BUNDLE "Enable Application Bundle for macOS" ON)
|
|
||||||
option(WITH_CCACHE "Use ccache for build" OFF)
|
|
||||||
|
|
||||||
set(WITH_XC_ALL OFF CACHE BOOL "Build in all available plugins")
|
|
||||||
|
|
||||||
option(WITH_XC_AUTOTYPE "Include Auto-Type." ON)
|
|
||||||
option(WITH_XC_NETWORKING "Include networking code (e.g. for downloading website icons)." OFF)
|
|
||||||
option(WITH_XC_BROWSER "Include browser integration with keepassxc-browser." OFF)
|
|
||||||
option(WITH_XC_BROWSER_PASSKEYS "Passkeys support for browser integration." OFF)
|
|
||||||
option(WITH_XC_YUBIKEY "Include YubiKey support." OFF)
|
|
||||||
option(WITH_XC_SSHAGENT "Include SSH agent support." OFF)
|
|
||||||
option(WITH_XC_KEESHARE "Sharing integration with KeeShare" OFF)
|
|
||||||
option(WITH_XC_UPDATECHECK "Include automatic update checks; disable for controlled distributions" ON)
|
|
||||||
if(UNIX AND NOT APPLE)
|
|
||||||
option(WITH_XC_FDOSECRETS "Implement freedesktop.org Secret Storage Spec server side API." OFF)
|
|
||||||
endif()
|
|
||||||
option(WITH_XC_DOCS "Enable building of documentation" ON)
|
|
||||||
|
|
||||||
set(WITH_XC_X11 ON CACHE BOOL "Enable building with X11 deps")
|
|
||||||
|
|
||||||
if(APPLE)
|
|
||||||
# Perform the platform checks before applying the stricter compiler flags.
|
|
||||||
# Otherwise the kSecAccessControlTouchIDCurrentSet deprecation warning will result in an error.
|
|
||||||
try_compile(XC_APPLE_COMPILER_SUPPORT_BIOMETRY
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/tiometry_test/
|
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/cmake/compiler-checks/macos/control_biometry_support.mm)
|
|
||||||
message(STATUS "Biometry compiler support: ${XC_APPLE_COMPILER_SUPPORT_BIOMETRY}")
|
|
||||||
|
|
||||||
try_compile(XC_APPLE_COMPILER_SUPPORT_TOUCH_ID
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/touch_id_test/
|
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/cmake/compiler-checks/macos/control_touch_id_support.mm)
|
|
||||||
message(STATUS "Touch ID compiler support: ${XC_APPLE_COMPILER_SUPPORT_TOUCH_ID}")
|
|
||||||
|
|
||||||
try_compile(XC_APPLE_COMPILER_SUPPORT_WATCH
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/tiometry_test/
|
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/cmake/compiler-checks/macos/control_watch_support.mm)
|
|
||||||
message(STATUS "Apple watch compiler support: ${XC_APPLE_COMPILER_SUPPORT_WATCH}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_CCACHE)
|
|
||||||
# Use the Compiler Cache (ccache) program
|
|
||||||
# (install with: sudo apt get ccache)
|
|
||||||
find_program(CCACHE_FOUND ccache)
|
|
||||||
if(NOT CCACHE_FOUND)
|
|
||||||
message(FATAL_ERROR "ccache requested but cannot be found.")
|
|
||||||
endif()
|
|
||||||
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ${CCACHE_FOUND})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_ALL)
|
|
||||||
# Enable all options (except update check and docs)
|
|
||||||
set(WITH_XC_AUTOTYPE ON)
|
|
||||||
set(WITH_XC_NETWORKING ON)
|
|
||||||
set(WITH_XC_BROWSER ON)
|
|
||||||
set(WITH_XC_BROWSER_PASSKEYS ON)
|
|
||||||
set(WITH_XC_YUBIKEY ON)
|
|
||||||
set(WITH_XC_SSHAGENT ON)
|
|
||||||
set(WITH_XC_KEESHARE ON)
|
|
||||||
if(UNIX AND NOT APPLE)
|
|
||||||
set(WITH_XC_FDOSECRETS ON)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Prefer WITH_XC_NETWORKING setting over WITH_XC_UPDATECHECK
|
|
||||||
if(NOT WITH_XC_NETWORKING AND WITH_XC_UPDATECHECK)
|
|
||||||
message(STATUS "Disabling WITH_XC_UPDATECHECK because WITH_XC_NETWORKING is disabled")
|
|
||||||
set(WITH_XC_UPDATECHECK OFF)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(UNIX AND NOT APPLE AND NOT WITH_XC_X11)
|
|
||||||
message(STATUS "Disabling WITH_XC_AUTOTYPE because WITH_XC_X11 is disabled")
|
|
||||||
set(WITH_XC_AUTOTYPE OFF)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(KEEPASSXC_VERSION_MAJOR "2")
|
set(KEEPASSXC_VERSION_MAJOR "2")
|
||||||
set(KEEPASSXC_VERSION_MINOR "8")
|
set(KEEPASSXC_VERSION_MINOR "8")
|
||||||
set(KEEPASSXC_VERSION_PATCH "0")
|
set(KEEPASSXC_VERSION_PATCH "0")
|
||||||
set(KEEPASSXC_VERSION "${KEEPASSXC_VERSION_MAJOR}.${KEEPASSXC_VERSION_MINOR}.${KEEPASSXC_VERSION_PATCH}")
|
set(KEEPASSXC_VERSION "${KEEPASSXC_VERSION_MAJOR}.${KEEPASSXC_VERSION_MINOR}.${KEEPASSXC_VERSION_PATCH}")
|
||||||
set(OVERRIDE_VERSION "" CACHE STRING "Override the KeePassXC Version for Snapshot builds")
|
|
||||||
|
|
||||||
set(KEEPASSXC_BUILD_TYPE "Snapshot" CACHE STRING "Set KeePassXC build type to distinguish between stable releases and snapshots")
|
string(TOLOWER "${CMAKE_BUILD_TYPE}" CMAKE_BUILD_TYPE_LOWER)
|
||||||
set_property(CACHE KEEPASSXC_BUILD_TYPE PROPERTY STRINGS Snapshot Release PreRelease)
|
|
||||||
|
# CMake Modules
|
||||||
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake)
|
||||||
|
|
||||||
|
include(CMakeToolsHelpers OPTIONAL) # Support Visual Studio Code
|
||||||
|
include(FeatureSummary)
|
||||||
|
include(KPXCMacDeployHelpers)
|
||||||
|
include(CLangFormat)
|
||||||
|
|
||||||
|
include(CompilerFlags)
|
||||||
|
include(CheckCCompilerFlag)
|
||||||
|
include(CheckCXXCompilerFlag)
|
||||||
|
include(CheckCXXSourceCompiles)
|
||||||
|
|
||||||
|
# Build Scope
|
||||||
|
option(WITH_TESTS "Enable building of unit tests" ON)
|
||||||
|
option(WITH_GUI_TESTS "Enable building of GUI tests" OFF)
|
||||||
|
option(WITH_WARN_DEPRECATED "Development only: warn about deprecated methods, including Qt." OFF)
|
||||||
|
option(WITH_ASAN "Enable address sanitizer checks (Linux / macOS only)" OFF)
|
||||||
|
option(WITH_COVERAGE "Use to build with coverage tests (GCC only)." OFF)
|
||||||
|
option(WITH_APP_BUNDLE "Enable Application Bundle for macOS" ON)
|
||||||
|
option(WITH_CCACHE "Use ccache for build" OFF)
|
||||||
|
option(WITH_X11 "Enable building with X11 dependencies" ON)
|
||||||
|
|
||||||
|
# Advanced Features Control
|
||||||
|
option(KPXC_MINIMAL "Build KeePassXC with the minimal feature set required for basic usage" OFF)
|
||||||
|
option(KPXC_FEATURE_BROWSER "Browser integration and passkeys support" ON)
|
||||||
|
option(KPXC_FEATURE_SSHAGENT "SSH Agent integration" ON)
|
||||||
|
option(KPXC_FEATURE_FDOSECRETS "freedesktop.org Secret Service integration; replace system keyring" ON)
|
||||||
|
|
||||||
|
if(KPXC_MINIMAL)
|
||||||
|
# Disable advanced features in minimal mode
|
||||||
|
set(KPXC_FEATURE_BROWSER OFF)
|
||||||
|
set(KPXC_FEATURE_SSHAGENT OFF)
|
||||||
|
set(KPXC_FEATURE_FDOSECRETS OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Minor Feature Flags
|
||||||
|
option(KPXC_FEATURE_NETWORK "Include code that reaches out to external networks (e.g. downloading icons)" ON)
|
||||||
|
option(KPXC_FEATURE_UPDATES "Include automatic update checks; disable for managed distributions" ON)
|
||||||
|
option(KPXC_FEATURE_DOCS "Build offline documentation; requires asciidoctor tool" ON)
|
||||||
|
|
||||||
|
# Reconcile update feature with overall network feature
|
||||||
|
if(NOT KPXC_FEATURE_NETWORK AND KPXC_FEATURE_UPDATES)
|
||||||
|
message(STATUS "Disabling KPXC_FEATURE_UPDATES because KPXC_FEATURE_NETWORK is disabled")
|
||||||
|
set(KPXC_FEATURE_UPDATES OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# FDO Secrets is only available on Linux
|
||||||
|
if(NOT UNIX OR APPLE OR HAIKU)
|
||||||
|
set(KPXC_FEATURE_FDOSECRETS OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Define feature summaries
|
||||||
|
add_feature_info("Browser" KPXC_FEATURE_BROWSER "Browser integration and passkeys support")
|
||||||
|
add_feature_info("SSH Agent" KPXC_FEATURE_SSHAGENT "SSH Agent integration")
|
||||||
|
if(UNIX AND NOT APPLE)
|
||||||
|
add_feature_info("Secret Service" KPXC_FEATURE_FDOSECRETS "Replace system keyring with freedesktop.org Secret Service integration")
|
||||||
|
endif()
|
||||||
|
add_feature_info("Networking" KPXC_FEATURE_NETWORK "Code that can reach out to external networks is included (e.g. downloading icons)")
|
||||||
|
add_feature_info("Update Checks" KPXC_FEATURE_UPDATES "Periodic update checks can be performed")
|
||||||
|
add_feature_info("Documentation" KPXC_FEATURE_DOCS "Offline documentation")
|
||||||
|
|
||||||
# Retrieve git HEAD revision hash
|
# Retrieve git HEAD revision hash
|
||||||
set(GIT_HEAD_OVERRIDE "" CACHE STRING "Manually set the Git HEAD hash when missing (eg, when no .git folder exists)")
|
set(GIT_HEAD_OVERRIDE "" CACHE STRING "Manually set the Git HEAD hash when missing (eg, when no .git folder exists)")
|
||||||
@ -142,7 +103,12 @@ elseif(EXISTS ${CMAKE_SOURCE_DIR}/.gitrev)
|
|||||||
endif()
|
endif()
|
||||||
message(STATUS "Found Git HEAD Revision: ${GIT_HEAD}\n")
|
message(STATUS "Found Git HEAD Revision: ${GIT_HEAD}\n")
|
||||||
|
|
||||||
# Check if on a tag, if so build as a release
|
# KeePassXC Versioning and Build Type
|
||||||
|
set(OVERRIDE_VERSION "" CACHE STRING "Override the KeePassXC Version for Snapshot builds")
|
||||||
|
set(KEEPASSXC_BUILD_TYPE "Snapshot" CACHE STRING "Set KeePassXC build type to distinguish between stable releases and snapshots")
|
||||||
|
set_property(CACHE KEEPASSXC_BUILD_TYPE PROPERTY STRINGS Snapshot Release)
|
||||||
|
|
||||||
|
# Check if on a tag or has .version file, if so build as a release
|
||||||
execute_process(COMMAND git tag --points-at HEAD
|
execute_process(COMMAND git tag --points-at HEAD
|
||||||
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
|
||||||
OUTPUT_VARIABLE GIT_TAG
|
OUTPUT_VARIABLE GIT_TAG
|
||||||
@ -157,67 +123,103 @@ endif()
|
|||||||
|
|
||||||
string(REGEX REPLACE "(\r?\n)+" "" OVERRIDE_VERSION "${OVERRIDE_VERSION}")
|
string(REGEX REPLACE "(\r?\n)+" "" OVERRIDE_VERSION "${OVERRIDE_VERSION}")
|
||||||
if(OVERRIDE_VERSION)
|
if(OVERRIDE_VERSION)
|
||||||
if(OVERRIDE_VERSION MATCHES "^[\\.0-9]+-beta[0-9]*")
|
if(OVERRIDE_VERSION MATCHES "^[\\.0-9]+$")
|
||||||
set(KEEPASSXC_BUILD_TYPE "PreRelease")
|
|
||||||
set(KEEPASSXC_VERSION ${OVERRIDE_VERSION})
|
|
||||||
elseif(OVERRIDE_VERSION MATCHES "^[\\.0-9]+$")
|
|
||||||
set(KEEPASSXC_BUILD_TYPE "Release")
|
set(KEEPASSXC_BUILD_TYPE "Release")
|
||||||
set(KEEPASSXC_VERSION ${OVERRIDE_VERSION})
|
set(KEEPASSXC_VERSION ${OVERRIDE_VERSION})
|
||||||
else()
|
else()
|
||||||
set(KEEPASSXC_BUILD_TYPE "Snapshot")
|
set(KEEPASSXC_BUILD_TYPE "Snapshot")
|
||||||
set(KEEPASSXC_VERSION ${OVERRIDE_VERSION})
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
if(KEEPASSXC_BUILD_TYPE STREQUAL "PreRelease")
|
|
||||||
set(KEEPASSXC_VERSION "${KEEPASSXC_VERSION}-preview")
|
|
||||||
elseif(KEEPASSXC_BUILD_TYPE STREQUAL "Snapshot")
|
|
||||||
set(KEEPASSXC_VERSION "${KEEPASSXC_VERSION}-snapshot")
|
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(KEEPASSXC_BUILD_TYPE STREQUAL "Release")
|
if(KEEPASSXC_BUILD_TYPE STREQUAL "Release")
|
||||||
set(KEEPASSXC_BUILD_TYPE_RELEASE ON)
|
set(KEEPASSXC_BUILD_TYPE_RELEASE ON)
|
||||||
elseif(KEEPASSXC_BUILD_TYPE STREQUAL "PreRelease")
|
|
||||||
set(KEEPASSXC_BUILD_TYPE_PRE_RELEASE ON)
|
|
||||||
else()
|
else()
|
||||||
set(KEEPASSXC_BUILD_TYPE_SNAPSHOT ON)
|
set(KEEPASSXC_BUILD_TYPE_SNAPSHOT ON)
|
||||||
|
set(KEEPASSXC_VERSION "${KEEPASSXC_VERSION}-snapshot")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
message(STATUS "Setting up build for KeePassXC v${KEEPASSXC_VERSION}\n")
|
message(STATUS "Setting up build for KeePassXC v${KEEPASSXC_VERSION}\n")
|
||||||
|
|
||||||
# Distribution info
|
# Distribution info
|
||||||
set(KEEPASSXC_DIST ON)
|
set(KEEPASSXC_DIST_TYPE "Native" CACHE STRING "KeePassXC Distribution Type")
|
||||||
set(KEEPASSXC_DIST_TYPE "Other" CACHE STRING "KeePassXC Distribution Type")
|
set_property(CACHE KEEPASSXC_DIST_TYPE PROPERTY STRINGS Snap AppImage Flatpak Native)
|
||||||
set_property(CACHE KEEPASSXC_DIST_TYPE PROPERTY STRINGS Snap AppImage Flatpak Other)
|
|
||||||
if(KEEPASSXC_DIST_TYPE STREQUAL "Snap")
|
if(KEEPASSXC_DIST_TYPE STREQUAL "Snap")
|
||||||
set(KEEPASSXC_DIST_SNAP ON)
|
set(KEEPASSXC_DIST_SNAP ON)
|
||||||
elseif(KEEPASSXC_DIST_TYPE STREQUAL "AppImage")
|
elseif(KEEPASSXC_DIST_TYPE STREQUAL "AppImage")
|
||||||
set(KEEPASSXC_DIST_APPIMAGE ON)
|
set(KEEPASSXC_DIST_APPIMAGE ON)
|
||||||
elseif(KEEPASSXC_DIST_TYPE STREQUAL "Flatpak")
|
elseif(KEEPASSXC_DIST_TYPE STREQUAL "Flatpak")
|
||||||
set(KEEPASSXC_DIST_FLATPAK ON)
|
set(KEEPASSXC_DIST_FLATPAK ON)
|
||||||
elseif(KEEPASSXC_DIST_TYPE STREQUAL "Other")
|
|
||||||
unset(KEEPASSXC_DIST)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Standards
|
||||||
|
set(CMAKE_C_STANDARD 99)
|
||||||
|
set(CMAKE_CXX_STANDARD 20)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
|
# Compiler Features
|
||||||
|
if(APPLE)
|
||||||
|
# Perform the platform checks before applying the stricter compiler flags.
|
||||||
|
# Otherwise the kSecAccessControlTouchIDCurrentSet deprecation warning will result in an error.
|
||||||
|
try_compile(XC_APPLE_COMPILER_SUPPORT_BIOMETRY
|
||||||
|
${CMAKE_BINARY_DIR}/macos-trycompile/
|
||||||
|
${CMAKE_SOURCE_DIR}/cmake/compiler-checks/control_biometry_support.mm)
|
||||||
|
message(STATUS "Biometry compiler support: ${XC_APPLE_COMPILER_SUPPORT_BIOMETRY}")
|
||||||
|
|
||||||
|
try_compile(XC_APPLE_COMPILER_SUPPORT_TOUCH_ID
|
||||||
|
${CMAKE_BINARY_DIR}/macos-trycompile/
|
||||||
|
${CMAKE_SOURCE_DIR}/cmake/compiler-checks/control_touch_id_support.mm)
|
||||||
|
message(STATUS "Touch ID compiler support: ${XC_APPLE_COMPILER_SUPPORT_TOUCH_ID}")
|
||||||
|
|
||||||
|
try_compile(XC_APPLE_COMPILER_SUPPORT_WATCH
|
||||||
|
${CMAKE_BINARY_DIR}/macos-trycompile/
|
||||||
|
${CMAKE_SOURCE_DIR}/cmake/compiler-checks/control_watch_support.mm)
|
||||||
|
message(STATUS "Apple watch compiler support: ${XC_APPLE_COMPILER_SUPPORT_WATCH}")
|
||||||
|
|
||||||
|
try_compile(HAVE_PT_DENY_ATTACH
|
||||||
|
${CMAKE_BINARY_DIR}/macos-trycompile/
|
||||||
|
${CMAKE_SOURCE_DIR}/cmake/compiler-checks/ptrace_deny_attach.cpp)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(UNIX)
|
||||||
|
check_cxx_source_compiles("#include <sys/prctl.h>
|
||||||
|
int main() { prctl(PR_SET_DUMPABLE, 0); return 0; }"
|
||||||
|
HAVE_PR_SET_DUMPABLE)
|
||||||
|
|
||||||
|
check_cxx_source_compiles("#include <malloc.h>
|
||||||
|
int main() { return 0; }"
|
||||||
|
HAVE_MALLOC_H)
|
||||||
|
|
||||||
|
check_cxx_source_compiles("#include <malloc.h>
|
||||||
|
int main() { malloc_usable_size(NULL); return 0; }"
|
||||||
|
HAVE_MALLOC_USABLE_SIZE)
|
||||||
|
|
||||||
|
check_cxx_source_compiles("#include <sys/resource.h>
|
||||||
|
int main() {
|
||||||
|
struct rlimit limit;
|
||||||
|
limit.rlim_cur = 0;
|
||||||
|
limit.rlim_max = 0;
|
||||||
|
setrlimit(RLIMIT_CORE, &limit);
|
||||||
|
return 0;
|
||||||
|
}" HAVE_RLIMIT_CORE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# ccache support
|
||||||
|
if(WITH_CCACHE)
|
||||||
|
find_program(CCACHE_FOUND ccache)
|
||||||
|
if(NOT CCACHE_FOUND)
|
||||||
|
message(FATAL_ERROR "ccache requested but cannot be found.")
|
||||||
|
endif()
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ${CCACHE_FOUND})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Create position independent code for shared libraries and executables
|
||||||
|
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
||||||
if(${CMAKE_VERSION} VERSION_GREATER_EQUAL "3.14.0")
|
if(${CMAKE_VERSION} VERSION_GREATER_EQUAL "3.14.0")
|
||||||
cmake_policy(SET CMP0083 NEW)
|
cmake_policy(SET CMP0083 NEW)
|
||||||
include(CheckPIESupported)
|
include(CheckPIESupported)
|
||||||
check_pie_supported()
|
check_pie_supported()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Find Botan early since the version affects subsequent compiler options
|
|
||||||
find_package(Botan REQUIRED)
|
|
||||||
if(BOTAN_VERSION VERSION_GREATER_EQUAL "3.0.0")
|
|
||||||
set(WITH_XC_BOTAN3 TRUE)
|
|
||||||
elseif(BOTAN_VERSION VERSION_LESS "2.11.0")
|
|
||||||
# Check for minimum Botan version
|
|
||||||
message(FATAL_ERROR "Botan 2.11.0 or higher is required")
|
|
||||||
endif()
|
|
||||||
include_directories(SYSTEM ${BOTAN_INCLUDE_DIR})
|
|
||||||
|
|
||||||
# Create position independent code for shared libraries and executables
|
|
||||||
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
|
||||||
|
|
||||||
if("${CMAKE_SIZEOF_VOID_P}" EQUAL "4")
|
if("${CMAKE_SIZEOF_VOID_P}" EQUAL "4")
|
||||||
set(IS_32BIT TRUE)
|
set(IS_32BIT TRUE)
|
||||||
endif()
|
endif()
|
||||||
@ -235,66 +237,7 @@ if("${CMAKE_CXX_COMPILER}" MATCHES "clang(\\+\\+)?$"
|
|||||||
set(CMAKE_COMPILER_IS_CLANGXX 1)
|
set(CMAKE_COMPILER_IS_CLANGXX 1)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
macro(add_gcc_compiler_cxxflags FLAGS)
|
# Compiler Flags
|
||||||
if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_COMPILER_IS_CLANGXX)
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${FLAGS}")
|
|
||||||
endif()
|
|
||||||
endmacro(add_gcc_compiler_cxxflags)
|
|
||||||
|
|
||||||
macro(add_gcc_compiler_cflags FLAGS)
|
|
||||||
if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
|
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${FLAGS}")
|
|
||||||
endif()
|
|
||||||
endmacro(add_gcc_compiler_cflags)
|
|
||||||
|
|
||||||
macro(add_gcc_compiler_flags FLAGS)
|
|
||||||
add_gcc_compiler_cxxflags("${FLAGS}")
|
|
||||||
add_gcc_compiler_cflags("${FLAGS}")
|
|
||||||
endmacro(add_gcc_compiler_flags)
|
|
||||||
|
|
||||||
# Copies of above macros that first ensure the compiler understands a given flag
|
|
||||||
# Because check_*_compiler_flag() sets -D with name, need to provide "safe" FLAGNAME
|
|
||||||
macro(check_add_gcc_compiler_cxxflag FLAG FLAGNAME)
|
|
||||||
check_cxx_compiler_flag("${FLAG}" CXX_HAS${FLAGNAME})
|
|
||||||
if(CXX_HAS${FLAGNAME})
|
|
||||||
add_gcc_compiler_cxxflags("${FLAG}")
|
|
||||||
endif()
|
|
||||||
endmacro(check_add_gcc_compiler_cxxflag)
|
|
||||||
|
|
||||||
macro(check_add_gcc_compiler_cflag FLAG FLAGNAME)
|
|
||||||
check_c_compiler_flag("${FLAG}" CC_HAS${FLAGNAME})
|
|
||||||
if(CC_HAS${FLAGNAME})
|
|
||||||
add_gcc_compiler_cflags("${FLAG}")
|
|
||||||
endif()
|
|
||||||
endmacro(check_add_gcc_compiler_cflag)
|
|
||||||
|
|
||||||
# This is the "front-end" for the above macros
|
|
||||||
# Optionally takes additional parameter(s) with language to check (currently "C" or "CXX")
|
|
||||||
macro(check_add_gcc_compiler_flag FLAG)
|
|
||||||
string(REGEX REPLACE "[-=]" "_" FLAGNAME "${FLAG}")
|
|
||||||
set(check_lang_spec ${ARGN})
|
|
||||||
list(LENGTH check_lang_spec num_extra_args)
|
|
||||||
set(langs C CXX)
|
|
||||||
if(num_extra_args GREATER 0)
|
|
||||||
set(langs "${check_lang_spec}")
|
|
||||||
endif()
|
|
||||||
if("C" IN_LIST langs)
|
|
||||||
check_add_gcc_compiler_cflag("${FLAG}" "${FLAGNAME}")
|
|
||||||
endif()
|
|
||||||
if("CXX" IN_LIST langs)
|
|
||||||
check_add_gcc_compiler_cxxflag("${FLAG}" "${FLAGNAME}")
|
|
||||||
endif()
|
|
||||||
endmacro(check_add_gcc_compiler_flag)
|
|
||||||
|
|
||||||
add_definitions(-DQT_NO_EXCEPTIONS -DQT_STRICT_ITERATORS -DQT_NO_CAST_TO_ASCII)
|
|
||||||
if(NOT IS_DEBUG_BUILD)
|
|
||||||
add_definitions(-DQT_NO_DEBUG_OUTPUT)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_APP_BUNDLE)
|
|
||||||
add_definitions(-DWITH_APP_BUNDLE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_gcc_compiler_flags("-fno-common")
|
add_gcc_compiler_flags("-fno-common")
|
||||||
find_package(OpenMP)
|
find_package(OpenMP)
|
||||||
if(OpenMP_FOUND)
|
if(OpenMP_FOUND)
|
||||||
@ -310,10 +253,8 @@ if(CMAKE_BUILD_TYPE_LOWER STREQUAL "debug")
|
|||||||
check_add_gcc_compiler_flag("-Wshadow-compatible-local")
|
check_add_gcc_compiler_flag("-Wshadow-compatible-local")
|
||||||
check_add_gcc_compiler_flag("-Wshadow-local")
|
check_add_gcc_compiler_flag("-Wshadow-local")
|
||||||
add_gcc_compiler_flags("-Werror")
|
add_gcc_compiler_flags("-Werror")
|
||||||
# This is needed since compiling against Botan3 requires compiling against C++20
|
# C++20 marks enum arithmetic as deprecated, but we use it in Botan and Qt5
|
||||||
if(WITH_XC_BOTAN3)
|
add_gcc_compiler_cxxflags("-Wno-deprecated-enum-enum-conversion -Wno-error=deprecated ")
|
||||||
add_gcc_compiler_cxxflags("-Wno-error=deprecated-enum-enum-conversion -Wno-error=deprecated")
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (NOT HAIKU)
|
if (NOT HAIKU)
|
||||||
@ -358,14 +299,6 @@ if(UNIX AND NOT APPLE)
|
|||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,-z,relro,-z,now")
|
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,-z,relro,-z,now")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(CMAKE_C_STANDARD 99)
|
|
||||||
if(WITH_XC_BOTAN3)
|
|
||||||
set(CMAKE_CXX_STANDARD 20)
|
|
||||||
else()
|
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
|
||||||
endif()
|
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
||||||
|
|
||||||
check_cxx_compiler_flag("-fsized-deallocation" CXX_HAS_fsized_deallocation)
|
check_cxx_compiler_flag("-fsized-deallocation" CXX_HAS_fsized_deallocation)
|
||||||
if(CXX_HAS_fsized_deallocation)
|
if(CXX_HAS_fsized_deallocation)
|
||||||
# Do additional check: the deallocation functions must be there too.
|
# Do additional check: the deallocation functions must be there too.
|
||||||
@ -383,7 +316,7 @@ if(APPLE AND CMAKE_COMPILER_IS_CLANGXX)
|
|||||||
add_gcc_compiler_cxxflags("-stdlib=libc++")
|
add_gcc_compiler_cxxflags("-stdlib=libc++")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WITH_DEV_BUILD)
|
if(WITH_WARN_DEPRECATED)
|
||||||
add_definitions(-DQT_DEPRECATED_WARNINGS)
|
add_definitions(-DQT_DEPRECATED_WARNINGS)
|
||||||
else()
|
else()
|
||||||
add_definitions(-DQT_NO_DEPRECATED_WARNINGS)
|
add_definitions(-DQT_NO_DEPRECATED_WARNINGS)
|
||||||
@ -392,54 +325,36 @@ endif()
|
|||||||
|
|
||||||
# MSVC specific options
|
# MSVC specific options
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
if(MSVC_TOOLSET_VERSION LESS 141)
|
if(MSVC_TOOLSET_VERSION LESS 142)
|
||||||
message(FATAL_ERROR "Only Microsoft Visual Studio 17 and newer are supported!")
|
message(FATAL_ERROR "Only Microsoft Visual Studio 2019 and newer are supported!")
|
||||||
endif()
|
endif()
|
||||||
add_compile_options(/permissive- /utf-8 /MP)
|
# Turn on multi-processor support and faster PDB generation (/Zf)
|
||||||
if(IS_DEBUG_BUILD)
|
add_compile_options(/permissive- /utf-8 /MP /Zf)
|
||||||
add_compile_options(/Zf)
|
# Enable built-in ASAN
|
||||||
if(MSVC_TOOLSET_VERSION GREATER 141)
|
add_compile_definitions(/fsanitize=address)
|
||||||
add_compile_definitions(/fsanitize=address)
|
|
||||||
endif()
|
# Enable high entropy ASLR on release builds
|
||||||
|
if(CMAKE_BUILD_TYPE_LOWER STREQUAL "release")
|
||||||
|
add_compile_options(/guard:cf)
|
||||||
|
add_link_options(/DYNAMICBASE /HIGHENTROPYVA /GUARD:CF)
|
||||||
|
endif()
|
||||||
|
elseif(MINGW)
|
||||||
|
# Enable high entropy ASLR on release builds
|
||||||
|
if(CMAKE_BUILD_TYPE_LOWER STREQUAL "release")
|
||||||
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--nxcompat -Wl,--dynamicbase -Wl,--high-entropy-va")
|
||||||
|
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--nxcompat -Wl,--dynamicbase -Wl,--high-entropy-va")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(CMAKE_RC_COMPILER_INIT windres)
|
|
||||||
enable_language(RC)
|
|
||||||
if(MINGW)
|
|
||||||
set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> <FLAGS> -O coff <DEFINES> -i <SOURCE> -o <OBJECT>")
|
|
||||||
endif()
|
|
||||||
if(NOT IS_DEBUG_BUILD)
|
|
||||||
if(MSVC)
|
|
||||||
# By default MSVC enables NXCOMPAT
|
|
||||||
add_compile_options(/guard:cf)
|
|
||||||
add_link_options(/DYNAMICBASE /HIGHENTROPYVA /GUARD:CF)
|
|
||||||
else(MINGW)
|
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--nxcompat -Wl,--dynamicbase")
|
|
||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--nxcompat -Wl,--dynamicbase")
|
|
||||||
# Enable high entropy ASLR for 64-bit builds
|
|
||||||
if(NOT IS_32BIT)
|
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--high-entropy-va")
|
|
||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--high-entropy-va")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(APPLE AND WITH_APP_BUNDLE OR WIN32)
|
|
||||||
set(PROGNAME KeePassXC)
|
set(PROGNAME KeePassXC)
|
||||||
else()
|
|
||||||
set(PROGNAME keepassxc)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
set(CLI_INSTALL_DIR ".")
|
set(CLI_INSTALL_DIR ".")
|
||||||
set(PROXY_INSTALL_DIR ".")
|
set(PROXY_INSTALL_DIR ".")
|
||||||
set(BIN_INSTALL_DIR ".")
|
set(BIN_INSTALL_DIR ".")
|
||||||
set(PLUGIN_INSTALL_DIR ".")
|
set(PLUGIN_INSTALL_DIR ".")
|
||||||
set(DATA_INSTALL_DIR "share")
|
set(DATA_INSTALL_DIR "share")
|
||||||
elseif(APPLE AND WITH_APP_BUNDLE)
|
elseif(APPLE AND WITH_APP_BUNDLE)
|
||||||
|
set(PROGNAME KeePassXC)
|
||||||
set(BUNDLE_INSTALL_DIR "${PROGNAME}.app/Contents")
|
set(BUNDLE_INSTALL_DIR "${PROGNAME}.app/Contents")
|
||||||
set(CMAKE_INSTALL_MANDIR "${BUNDLE_INSTALL_DIR}/Resources/man")
|
set(CMAKE_INSTALL_MANDIR "${BUNDLE_INSTALL_DIR}/Resources/man")
|
||||||
set(CLI_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/MacOS")
|
set(CLI_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/MacOS")
|
||||||
@ -447,9 +362,10 @@ elseif(APPLE AND WITH_APP_BUNDLE)
|
|||||||
set(BIN_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/MacOS")
|
set(BIN_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/MacOS")
|
||||||
set(PLUGIN_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/PlugIns")
|
set(PLUGIN_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/PlugIns")
|
||||||
set(DATA_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/Resources")
|
set(DATA_INSTALL_DIR "${BUNDLE_INSTALL_DIR}/Resources")
|
||||||
|
add_definitions(-DWITH_APP_BUNDLE)
|
||||||
else()
|
else()
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
set(PROGNAME keepassxc)
|
||||||
set(CLI_INSTALL_DIR "${CMAKE_INSTALL_BINDIR}")
|
set(CLI_INSTALL_DIR "${CMAKE_INSTALL_BINDIR}")
|
||||||
set(PROXY_INSTALL_DIR "${CMAKE_INSTALL_BINDIR}")
|
set(PROXY_INSTALL_DIR "${CMAKE_INSTALL_BINDIR}")
|
||||||
set(BIN_INSTALL_DIR "${CMAKE_INSTALL_BINDIR}")
|
set(BIN_INSTALL_DIR "${CMAKE_INSTALL_BINDIR}")
|
||||||
@ -457,10 +373,6 @@ else()
|
|||||||
set(DATA_INSTALL_DIR "${CMAKE_INSTALL_DATADIR}/keepassxc")
|
set(DATA_INSTALL_DIR "${CMAKE_INSTALL_DATADIR}/keepassxc")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WITH_TESTS)
|
|
||||||
enable_testing()
|
|
||||||
endif(WITH_TESTS)
|
|
||||||
|
|
||||||
if(WITH_COVERAGE)
|
if(WITH_COVERAGE)
|
||||||
# Include code coverage, use with -DCMAKE_BUILD_TYPE=Debug
|
# Include code coverage, use with -DCMAKE_BUILD_TYPE=Debug
|
||||||
include(CodeCoverage)
|
include(CodeCoverage)
|
||||||
@ -489,11 +401,10 @@ if(WITH_COVERAGE)
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
include(CLangFormat)
|
# Find Qt
|
||||||
|
|
||||||
set(QT_COMPONENTS Core Network Concurrent Gui Svg Widgets Test LinguistTools)
|
set(QT_COMPONENTS Core Network Concurrent Gui Svg Widgets Test LinguistTools)
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
if(WITH_XC_X11)
|
if(WITH_X11)
|
||||||
list(APPEND QT_COMPONENTS X11Extras)
|
list(APPEND QT_COMPONENTS X11Extras)
|
||||||
endif()
|
endif()
|
||||||
find_package(Qt5 COMPONENTS ${QT_COMPONENTS} DBus REQUIRED)
|
find_package(Qt5 COMPONENTS ${QT_COMPONENTS} DBus REQUIRED)
|
||||||
@ -512,14 +423,13 @@ else()
|
|||||||
find_package(Qt5 COMPONENTS ${QT_COMPONENTS} REQUIRED)
|
find_package(Qt5 COMPONENTS ${QT_COMPONENTS} REQUIRED)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Minimum Qt version check
|
||||||
if(Qt5Core_VERSION VERSION_LESS "5.12.0")
|
if(Qt5Core_VERSION VERSION_LESS "5.12.0")
|
||||||
message(FATAL_ERROR "Qt version 5.12.0 or higher is required")
|
message(FATAL_ERROR "Qt version 5.12.0 or higher is required")
|
||||||
endif()
|
endif()
|
||||||
|
# C++20 is not supported before Qt 5.15.0
|
||||||
get_filename_component(Qt5_PREFIX ${Qt5_DIR}/../../.. REALPATH)
|
if(Qt5Core_VERSION VERSION_LESS "5.15.0")
|
||||||
if(APPLE)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
# Add includes under Qt5 Prefix in case Qt6 is also installed
|
|
||||||
include_directories(SYSTEM ${Qt5_PREFIX}/include)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Process moc automatically
|
# Process moc automatically
|
||||||
@ -529,7 +439,17 @@ set(CMAKE_AUTOUIC ON)
|
|||||||
# Process .qrc files automatically
|
# Process .qrc files automatically
|
||||||
set(CMAKE_AUTORCC ON)
|
set(CMAKE_AUTORCC ON)
|
||||||
|
|
||||||
|
add_definitions(-DQT_NO_EXCEPTIONS -DQT_STRICT_ITERATORS -DQT_NO_CAST_TO_ASCII)
|
||||||
|
if(NOT CMAKE_BUILD_TYPE_LOWER STREQUAL "debug")
|
||||||
|
add_definitions(-DQT_NO_DEBUG_OUTPUT)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
get_filename_component(Qt5_PREFIX ${Qt5_DIR}/../../.. REALPATH)
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
|
# Add includes under Qt5 Prefix in case Qt6 is also installed
|
||||||
|
include_directories(SYSTEM ${Qt5_PREFIX}/include)
|
||||||
|
|
||||||
set(CMAKE_MACOSX_RPATH TRUE)
|
set(CMAKE_MACOSX_RPATH TRUE)
|
||||||
find_program(MACDEPLOYQT_EXE macdeployqt HINTS ${Qt5_PREFIX}/bin ${Qt5_PREFIX}/tools/qt5/bin ENV PATH)
|
find_program(MACDEPLOYQT_EXE macdeployqt HINTS ${Qt5_PREFIX}/bin ${Qt5_PREFIX}/tools/qt5/bin ENV PATH)
|
||||||
if(NOT MACDEPLOYQT_EXE)
|
if(NOT MACDEPLOYQT_EXE)
|
||||||
@ -545,9 +465,16 @@ elseif(WIN32)
|
|||||||
message(STATUS "Using windeployqt: ${WINDEPLOYQT_EXE}")
|
message(STATUS "Using windeployqt: ${WINDEPLOYQT_EXE}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Debian sets the build type to None for package builds.
|
# Find Botan
|
||||||
# Make sure we don't enable asserts there.
|
# TODO: Increase minimum to 2.19.1 and drop Argon2 package
|
||||||
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS_NONE QT_NO_DEBUG)
|
find_package(Botan REQUIRED)
|
||||||
|
if(BOTAN_VERSION VERSION_GREATER_EQUAL "3.0.0")
|
||||||
|
set(WITH_BOTAN3 TRUE)
|
||||||
|
elseif(BOTAN_VERSION VERSION_LESS "2.12.0")
|
||||||
|
# Check for minimum Botan version
|
||||||
|
message(FATAL_ERROR "Botan 2.12.0 or higher is required")
|
||||||
|
endif()
|
||||||
|
include_directories(SYSTEM ${BOTAN_INCLUDE_DIR})
|
||||||
|
|
||||||
# Find Argon2 -- Botan 2.18 and below does not support threaded Argon2
|
# Find Argon2 -- Botan 2.18 and below does not support threaded Argon2
|
||||||
find_library(ARGON2_LIBRARIES NAMES argon2)
|
find_library(ARGON2_LIBRARIES NAMES argon2)
|
||||||
@ -564,70 +491,40 @@ include_directories(SYSTEM ${ZLIB_INCLUDE_DIR})
|
|||||||
# Find Minizip
|
# Find Minizip
|
||||||
find_package(Minizip REQUIRED)
|
find_package(Minizip REQUIRED)
|
||||||
|
|
||||||
if(WITH_XC_YUBIKEY)
|
# Find PCSC and LibUSB for hardware key support
|
||||||
find_package(PCSC REQUIRED)
|
find_package(PCSC REQUIRED)
|
||||||
include_directories(SYSTEM ${PCSC_INCLUDE_DIRS})
|
include_directories(SYSTEM ${PCSC_INCLUDE_DIRS})
|
||||||
|
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
find_library(LIBUSB_LIBRARIES NAMES usb-1.0 REQUIRED)
|
find_library(LIBUSB_LIBRARIES NAMES usb-1.0 REQUIRED)
|
||||||
find_path(LIBUSB_INCLUDE_DIR NAMES libusb.h PATH_SUFFIXES "libusb-1.0" "libusb" REQUIRED)
|
find_path(LIBUSB_INCLUDE_DIR NAMES libusb.h PATH_SUFFIXES "libusb-1.0" "libusb" REQUIRED)
|
||||||
include_directories(SYSTEM ${LIBUSB_INCLUDE_DIR})
|
include_directories(SYSTEM ${LIBUSB_INCLUDE_DIR})
|
||||||
endif()
|
|
||||||
|
# For PolKit QuickUnlock
|
||||||
|
find_library(KEYUTILS_LIBRARIES NAMES keyutils REQUIRED)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(UNIX)
|
# Find zxcvbn or use the bundled version
|
||||||
check_cxx_source_compiles("#include <sys/prctl.h>
|
|
||||||
int main() { prctl(PR_SET_DUMPABLE, 0); return 0; }"
|
|
||||||
HAVE_PR_SET_DUMPABLE)
|
|
||||||
|
|
||||||
check_cxx_source_compiles("#include <malloc.h>
|
|
||||||
int main() { return 0; }"
|
|
||||||
HAVE_MALLOC_H)
|
|
||||||
|
|
||||||
check_cxx_source_compiles("#include <malloc.h>
|
|
||||||
int main() { malloc_usable_size(NULL); return 0; }"
|
|
||||||
HAVE_MALLOC_USABLE_SIZE)
|
|
||||||
|
|
||||||
check_cxx_source_compiles("#include <sys/resource.h>
|
|
||||||
int main() {
|
|
||||||
struct rlimit limit;
|
|
||||||
limit.rlim_cur = 0;
|
|
||||||
limit.rlim_max = 0;
|
|
||||||
setrlimit(RLIMIT_CORE, &limit);
|
|
||||||
return 0;
|
|
||||||
}" HAVE_RLIMIT_CORE)
|
|
||||||
|
|
||||||
if(APPLE)
|
|
||||||
check_cxx_source_compiles("#include <sys/types.h>
|
|
||||||
#include <sys/ptrace.h>
|
|
||||||
int main() { ptrace(PT_DENY_ATTACH, 0, 0, 0); return 0; }"
|
|
||||||
HAVE_PT_DENY_ATTACH)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
include_directories(SYSTEM ${ZLIB_INCLUDE_DIR})
|
|
||||||
|
|
||||||
find_library(ZXCVBN_LIBRARIES zxcvbn)
|
find_library(ZXCVBN_LIBRARIES zxcvbn)
|
||||||
if(NOT ZXCVBN_LIBRARIES)
|
if(NOT ZXCVBN_LIBRARIES)
|
||||||
add_subdirectory(src/thirdparty/zxcvbn)
|
add_subdirectory(src/thirdparty/zxcvbn)
|
||||||
set(ZXCVBN_LIBRARIES zxcvbn)
|
set(ZXCVBN_LIBRARIES zxcvbn)
|
||||||
endif(NOT ZXCVBN_LIBRARIES)
|
endif()
|
||||||
|
|
||||||
|
# Add KeePassXC sources and tests
|
||||||
add_subdirectory(src)
|
add_subdirectory(src)
|
||||||
add_subdirectory(share)
|
add_subdirectory(share)
|
||||||
if(WITH_TESTS)
|
|
||||||
add_subdirectory(tests)
|
|
||||||
endif(WITH_TESTS)
|
|
||||||
|
|
||||||
if(WITH_XC_DOCS)
|
if(WITH_TESTS)
|
||||||
|
enable_testing()
|
||||||
|
add_subdirectory(tests)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(KPXC_FEATURE_DOCS)
|
||||||
add_subdirectory(docs)
|
add_subdirectory(docs)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(PRINT_SUMMARY)
|
# Print out summary information
|
||||||
# This will print ENABLED, REQUIRED and DISABLED
|
message(STATUS "")
|
||||||
feature_summary(WHAT ALL)
|
feature_summary(QUIET_ON_EMPTY WHAT ENABLED_FEATURES DESCRIPTION "Enabled features:")
|
||||||
else()
|
feature_summary(QUIET_ON_EMPTY WHAT DISABLED_FEATURES DESCRIPTION "Disabled features:")
|
||||||
# This will only print ENABLED and DISABLED feature
|
|
||||||
feature_summary(WHAT ENABLED_FEATURES DESCRIPTION "Enabled features:")
|
|
||||||
feature_summary(WHAT DISABLED_FEATURES DESCRIPTION "Disabled features:")
|
|
||||||
endif()
|
|
||||||
|
71
INSTALL.md
71
INSTALL.md
@ -1,19 +1,17 @@
|
|||||||
Build and Install KeePassXC
|
# Build and Install KeePassXC
|
||||||
=================
|
|
||||||
|
|
||||||
This document will guide you through the steps to build and install KeePassXC from source.
|
This document will guide you through the steps to build and install KeePassXC from source.
|
||||||
For more information, see also the [_Building KeePassXC_](https://github.com/keepassxreboot/keepassxc/wiki/Building-KeePassXC) page on the wiki.
|
For more information, see also the [_Building KeePassXC_](https://github.com/keepassxreboot/keepassxc/wiki/Building-KeePassXC) page on the wiki.
|
||||||
|
|
||||||
The [QuickStart Guide](https://keepassxc.org/docs/KeePassXC_GettingStarted.html) gets you started using KeePassXC on your Windows, macOS, or Linux computer using pre-compiled binaries from the [downloads page](https://keepassxc.org/download).
|
The [QuickStart Guide](https://keepassxc.org/docs/KeePassXC_GettingStarted.html) gets you started using KeePassXC on your Windows, macOS, or Linux computer using pre-compiled binaries from the [downloads page](https://keepassxc.org/download).
|
||||||
|
|
||||||
Toolchain and Build Dependencies
|
## Toolchain and Build Dependencies
|
||||||
================================
|
|
||||||
|
|
||||||
The following build tools must exist within your PATH:
|
The following build tools must exist within your PATH:
|
||||||
|
|
||||||
* cmake (>= 3.10.0)
|
* cmake (>= 3.16.0)
|
||||||
* make (>= 4.2) or ninja (>= 1.10)
|
* make (>= 4.2) or ninja (>= 1.10)
|
||||||
* g++ (>= 4.9) or clang++ (>= 6.0)
|
* g++ (>= 9.3.0) or clang++ (>= 10.0)
|
||||||
* asciidoctor (>= 2.0)
|
* asciidoctor (>= 2.0)
|
||||||
|
|
||||||
* Besides a working C++ toolchain, KeePassXC also has a number of direct build and runtime dependencies. For detailed information about how to install them, please refer to the GitHub wiki:
|
* Besides a working C++ toolchain, KeePassXC also has a number of direct build and runtime dependencies. For detailed information about how to install them, please refer to the GitHub wiki:
|
||||||
@ -22,8 +20,8 @@ The following build tools must exist within your PATH:
|
|||||||
* [Set up Build Environment on Windows](https://github.com/keepassxreboot/keepassxc/wiki/Set-up-Build-Environment-on-Windows)
|
* [Set up Build Environment on Windows](https://github.com/keepassxreboot/keepassxc/wiki/Set-up-Build-Environment-on-Windows)
|
||||||
* [Set up Build Environment on macOS](https://github.com/keepassxreboot/keepassxc/wiki/Set-up-Build-Environment-on-macOS)
|
* [Set up Build Environment on macOS](https://github.com/keepassxreboot/keepassxc/wiki/Set-up-Build-Environment-on-macOS)
|
||||||
|
|
||||||
Build Steps
|
## Build Steps
|
||||||
===========
|
|
||||||
We recommend using the release tool to perform builds, please read up-to-date instructions [on our wiki](https://github.com/keepassxreboot/keepassxc/wiki/Building-KeePassXC#building-using-the-release-tool).
|
We recommend using the release tool to perform builds, please read up-to-date instructions [on our wiki](https://github.com/keepassxreboot/keepassxc/wiki/Building-KeePassXC#building-using-the-release-tool).
|
||||||
|
|
||||||
To compile from source, open a **Terminal (Linux/MacOS)**, the **MSVC Tools Command Prompt (Windows)**, or **MSYS2-MinGW shell (Windows)**. For code development on Windows, you can use Visual Studio 2022, Visual Studio Code, or CLion.
|
To compile from source, open a **Terminal (Linux/MacOS)**, the **MSVC Tools Command Prompt (Windows)**, or **MSYS2-MinGW shell (Windows)**. For code development on Windows, you can use Visual Studio 2022, Visual Studio Code, or CLion.
|
||||||
@ -55,10 +53,10 @@ To compile from source, open a **Terminal (Linux/MacOS)**, the **MSVC Tools Comm
|
|||||||
```
|
```
|
||||||
mkdir build
|
mkdir build
|
||||||
cd build
|
cd build
|
||||||
cmake -DWITH_XC_ALL=ON ..
|
cmake ..
|
||||||
make
|
make
|
||||||
```
|
```
|
||||||
|
|
||||||
If you have `vcpkg` installed, add `-DCMAKE_TOOLCHAIN_FILE=${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake` to the `cmake` command to automatically download and install all required build and runtime dependencies locally to your build directory before compiling KeePassXC. Using `vcpkg` is the preferred way to install dependencies on macOS and required on Windows if using the MSVC toolchain.
|
If you have `vcpkg` installed, add `-DCMAKE_TOOLCHAIN_FILE=${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake` to the `cmake` command to automatically download and install all required build and runtime dependencies locally to your build directory before compiling KeePassXC. Using `vcpkg` is the preferred way to install dependencies on macOS and required on Windows if using the MSVC toolchain.
|
||||||
|
|
||||||
For more detailed build instructions for each platform, please refer to the [GitHub wiki](https://github.com/keepassxreboot/keepassxc/wiki/Building-KeePassXC).
|
For more detailed build instructions for each platform, please refer to the [GitHub wiki](https://github.com/keepassxreboot/keepassxc/wiki/Building-KeePassXC).
|
||||||
@ -77,49 +75,39 @@ When building with ASAN support on macOS, you need to use `export ASAN_OPTIONS=d
|
|||||||
|
|
||||||
If you are using MSYS2, you have to add ```-G "MSYS Makefiles"``` at the beginning of the cmake command.
|
If you are using MSYS2, you have to add ```-G "MSYS Makefiles"``` at the beginning of the cmake command.
|
||||||
|
|
||||||
CMake Configuration Options
|
|
||||||
==========================
|
|
||||||
|
|
||||||
## Recommended CMake Build Parameters
|
|
||||||
|
|
||||||
```
|
|
||||||
-DCMAKE_VERBOSE_MAKEFILE=ON
|
|
||||||
-DCMAKE_BUILD_TYPE=<RelWithDebInfo/Debug/Release>
|
|
||||||
-DWITH_GUI_TESTS=ON
|
|
||||||
```
|
|
||||||
|
|
||||||
## Additional CMake Parameters
|
## Additional CMake Parameters
|
||||||
|
|
||||||
KeePassXC comes with a variety of build options that can turn on/off features. Most notably, we allow you to build the application with all TCP/IP networking code disabled. Please note that we still require and link against Qt5's network library in order to use local named pipes on all operating systems. Each of these build options are supplied at the time of calling cmake:
|
KeePassXC comes with a variety of build options that can turn on/off features. Each of these build options are supplied at the time of calling cmake:
|
||||||
|
|
||||||
```
|
```
|
||||||
-DWITH_XC_AUTOTYPE=[ON|OFF] Enable/Disable Auto-Type (default: ON)
|
-DKPXC_MINIMAL=[ON|OFF] Build KeePassXC with the minimal feature set required for basic usage (default: OFF)
|
||||||
-DWITH_XC_YUBIKEY=[ON|OFF] Enable/Disable YubiKey HMAC-SHA1 authentication support (default: OFF)
|
-DKPXC_FEATURE_BROWSER=[ON|OFF] Browser integration and passkeys support (default: ON)
|
||||||
-DWITH_XC_BROWSER=[ON|OFF] Enable/Disable KeePassXC-Browser extension support (default: OFF)
|
-DKPXC_FEATURE_SSHAGENT=[ON|OFF] SSH Agent integration (default: ON)
|
||||||
-DWITH_XC_BROWSER_PASSKEYS=[ON|OFF] Enable/Disable Passkeys support for browser integration (default: OFF)
|
-DKPXC_FEATURE_FDOSECRETS=[ON|OFF] (Linux Only) freedesktop.org Secret Service integration; replace system keyring (default:ON)
|
||||||
-DWITH_XC_NETWORKING=[ON|OFF] Enable/Disable Networking support (e.g., favicon downloading) (default: OFF)
|
|
||||||
-DWITH_XC_SSHAGENT=[ON|OFF] Enable/Disable SSHAgent support (default: OFF)
|
|
||||||
-DWITH_XC_FDOSECRETS=[ON|OFF] (Linux Only) Enable/Disable Freedesktop.org Secrets Service support (default:OFF)
|
|
||||||
-DWITH_XC_KEESHARE=[ON|OFF] Enable/Disable KeeShare group synchronization extension (default: OFF)
|
|
||||||
-DWITH_XC_ALL=[ON|OFF] Enable/Disable compiling all plugins above (default: OFF)
|
|
||||||
|
|
||||||
-DWITH_XC_UPDATECHECK=[ON|OFF] Enable/Disable automatic updating checking (requires WITH_XC_NETWORKING) (default: ON)
|
-DKPXC_FEATURE_NETWORK=[ON|OFF] Include code that reaches out to external networks (e.g. downloading icons) (default: ON)
|
||||||
|
-DKPXC_FEATURE_UPDATES=[ON|OFF] Include automatic update checks; disable for managed distributions (requires networking) (default: ON)
|
||||||
|
-DKPXC_FEATURE_DOCS=[ON|OFF] Build offline documentation; requires asciidoctor tool (default: ON)
|
||||||
|
|
||||||
-DWITH_TESTS=[ON|OFF] Enable/Disable building of unit tests (default: ON)
|
-DWITH_TESTS=[ON|OFF] Enable/Disable building of unit tests (default: ON)
|
||||||
-DWITH_GUI_TESTS=[ON|OFF] Enable/Disable building of GUI tests (default: OFF)
|
-DWITH_GUI_TESTS=[ON|OFF] Enable/Disable building of GUI tests (default: OFF)
|
||||||
-DWITH_DEV_BUILD=[ON|OFF] Enable/Disable deprecated method warnings (default: OFF)
|
-DWITH_WARN_DEPRECATED=[ON|OFF] Development only: warn about deprecated methods, including Qt. (default: OFF)
|
||||||
-DWITH_ASAN=[ON|OFF] Enable/Disable address sanitizer checks (Linux / macOS only) (default: OFF)
|
-DWITH_ASAN=[ON|OFF] Enable/Disable address sanitizer checks (Linux / macOS only) (default: OFF)
|
||||||
-DWITH_COVERAGE=[ON|OFF] Enable/Disable coverage tests (GCC only) (default: OFF)
|
-DWITH_COVERAGE=[ON|OFF] Enable/Disable coverage tests (GCC only) (default: OFF)
|
||||||
-DWITH_APP_BUNDLE=[ON|OFF] Enable Application Bundle for macOS (default: ON)
|
-DWITH_APP_BUNDLE=[ON|OFF] Enable Application Bundle for macOS (default: ON)
|
||||||
|
-DWITH_CCACHE=[ON|OFF] Use ccache for build speed optimization (default: OFF)
|
||||||
|
-DWITH_X11=[ON|OFF] Enable building with X11 dependencies (default: ON)
|
||||||
|
|
||||||
-DKEEPASSXC_BUILD_TYPE=[Snapshot|PreRelease|Release] Set the build type to show/hide stability warnings (default: "Snapshot")
|
-DKEEPASSXC_BUILD_TYPE=[Snapshot|Release] Set the build type to show/hide stability warnings (default: "Snapshot")
|
||||||
-DKEEPASSXC_DIST_TYPE=[Snap|AppImage|Other] Specify the distribution method (default: "Other")
|
-DKEEPASSXC_DIST_TYPE=[Snap|AppImage|Flatpak|Native] Specify the distribution method (default: "Native")
|
||||||
-DOVERRIDE_VERSION=[X.X.X] Specify a version number when building. Used with snapshot builds (default: "")
|
-DOVERRIDE_VERSION=[X.X.X] Specify a version number when building. Used with snapshot builds (default: "")
|
||||||
-DGIT_HEAD_OVERRIDE=[XXXXXXX] Specify the 7 digit git commit ref for this build. Used with distribution builds (default: "")
|
-DGIT_HEAD_OVERRIDE=[XXXXXXX] Specify the 7 digit git commit ref for this build. Used with distribution builds (default: "")
|
||||||
```
|
```
|
||||||
|
|
||||||
Installation
|
Note: Even though you can build the application with all TCP/IP networking code disabled, we still require and link against
|
||||||
============
|
Qt5's network library to use local named pipes on all operating systems.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
After you have successfully built KeePassXC, install the binary by executing the following:
|
After you have successfully built KeePassXC, install the binary by executing the following:
|
||||||
|
|
||||||
@ -127,8 +115,7 @@ After you have successfully built KeePassXC, install the binary by executing the
|
|||||||
sudo make install
|
sudo make install
|
||||||
```
|
```
|
||||||
|
|
||||||
Packaging
|
## Packaging
|
||||||
=========
|
|
||||||
|
|
||||||
You can create a package to redistribute KeePassXC (zip, deb, rpm, dmg, etc..). Refer to [keepassxc-packaging](https://github.com/keepassxreboot/keepassxc-packaging) for packaging scripts.
|
You can create a package to redistribute KeePassXC (zip, deb, rpm, dmg, etc..). Refer to [keepassxc-packaging](https://github.com/keepassxreboot/keepassxc-packaging) for packaging scripts.
|
||||||
|
|
||||||
@ -138,21 +125,23 @@ To package using CMake, run the following command using whichever [generators](h
|
|||||||
cpack -G "ZIP;WIX"
|
cpack -G "ZIP;WIX"
|
||||||
```
|
```
|
||||||
|
|
||||||
Testing
|
## Testing
|
||||||
=======
|
|
||||||
|
|
||||||
You can perform tests on the built executables with:
|
You can perform tests on the built executables with:
|
||||||
|
|
||||||
```
|
```
|
||||||
make test ARGS+="--output-on-failure"
|
make test ARGS+="--output-on-failure"
|
||||||
```
|
```
|
||||||
|
|
||||||
On Linux, if you are not currently running on an X Server or Wayland, run the tests as follows:
|
On Linux, if you are not currently running on an X Server or Wayland, run the tests as follows:
|
||||||
|
|
||||||
```
|
```
|
||||||
make test ARGS+="-E test\(cli\|gui\) --output-on-failure"
|
make test ARGS+="-E test\(cli\|gui\) --output-on-failure"
|
||||||
xvfb-run -e errors -a --server-args="-screen 0 1024x768x24" make test ARGS+="-R test\(cli\|gui\) --output-on-failure"
|
xvfb-run -e errors -a --server-args="-screen 0 1024x768x24" make test ARGS+="-R test\(cli\|gui\) --output-on-failure"
|
||||||
```
|
```
|
||||||
|
|
||||||
Common parameters:
|
Common parameters:
|
||||||
|
|
||||||
```
|
```
|
||||||
CTEST_OUTPUT_ON_FAILURE=1
|
CTEST_OUTPUT_ON_FAILURE=1
|
||||||
ARGS+=-jX
|
ARGS+=-jX
|
||||||
|
36
README.md
36
README.md
@ -1,4 +1,5 @@
|
|||||||
# <img src="https://keepassxc.org/assets/img/keepassxc.svg" width="40" height="40"/> KeePassXC
|
# <img src="https://keepassxc.org/assets/img/keepassxc.svg" width="40" height="40"/> KeePassXC
|
||||||
|
|
||||||
[![OpenSSF Best Practices](https://bestpractices.coreinfrastructure.org/projects/6326/badge)](https://bestpractices.coreinfrastructure.org/projects/6326)
|
[![OpenSSF Best Practices](https://bestpractices.coreinfrastructure.org/projects/6326/badge)](https://bestpractices.coreinfrastructure.org/projects/6326)
|
||||||
[![TeamCity Build Status](https://ci.keepassxc.org/app/rest/builds/buildType:\(project:KeepassXC\)/statusIcon)](https://ci.keepassxc.org/?guest=1)
|
[![TeamCity Build Status](https://ci.keepassxc.org/app/rest/builds/buildType:\(project:KeepassXC\)/statusIcon)](https://ci.keepassxc.org/?guest=1)
|
||||||
[![codecov](https://codecov.io/gh/keepassxreboot/keepassxc/branch/develop/graph/badge.svg)](https://codecov.io/gh/keepassxreboot/keepassxc)
|
[![codecov](https://codecov.io/gh/keepassxreboot/keepassxc/branch/develop/graph/badge.svg)](https://codecov.io/gh/keepassxreboot/keepassxc)
|
||||||
@ -10,32 +11,37 @@
|
|||||||
[KeePassXC](https://keepassxc.org) is a modern, secure, and open-source password manager that stores and manages your most sensitive information. You can run KeePassXC on Windows, macOS, and Linux systems. KeePassXC is for people with extremely high demands of secure personal data management. It saves many different types of information, such as usernames, passwords, URLs, attachments, and notes in an offline, encrypted file that can be stored in any location, including private and public cloud solutions. For easy identification and management, user-defined titles and icons can be specified for entries. In addition, entries are sorted into customizable groups. An integrated search function allows you to use advanced patterns to easily find any entry in your database. A customizable, fast, and easy-to-use password generator utility allows you to create passwords with any combination of characters or easy to remember passphrases.
|
[KeePassXC](https://keepassxc.org) is a modern, secure, and open-source password manager that stores and manages your most sensitive information. You can run KeePassXC on Windows, macOS, and Linux systems. KeePassXC is for people with extremely high demands of secure personal data management. It saves many different types of information, such as usernames, passwords, URLs, attachments, and notes in an offline, encrypted file that can be stored in any location, including private and public cloud solutions. For easy identification and management, user-defined titles and icons can be specified for entries. In addition, entries are sorted into customizable groups. An integrated search function allows you to use advanced patterns to easily find any entry in your database. A customizable, fast, and easy-to-use password generator utility allows you to create passwords with any combination of characters or easy to remember passphrases.
|
||||||
|
|
||||||
## Quick Start
|
## Quick Start
|
||||||
|
|
||||||
The [QuickStart Guide](https://keepassxc.org/docs/KeePassXC_GettingStarted.html) gets you started using KeePassXC on your Windows, macOS, or Linux computer using pre-compiled binaries from the [downloads page](https://keepassxc.org/download). Additionally, individual Linux distributions may ship their own versions, so please check your distribution's package list to see if KeePassXC is available. Detailed documentation is available in the [User Guide](https://keepassxc.org/docs/KeePassXC_UserGuide.html).
|
The [QuickStart Guide](https://keepassxc.org/docs/KeePassXC_GettingStarted.html) gets you started using KeePassXC on your Windows, macOS, or Linux computer using pre-compiled binaries from the [downloads page](https://keepassxc.org/download). Additionally, individual Linux distributions may ship their own versions, so please check your distribution's package list to see if KeePassXC is available. Detailed documentation is available in the [User Guide](https://keepassxc.org/docs/KeePassXC_UserGuide.html).
|
||||||
|
|
||||||
## Features List
|
## Features List
|
||||||
|
|
||||||
KeePassXC has numerous features for novice and power users alike. Our goal is to create an application that can be used by anyone while still offering advanced features to those that need them.
|
KeePassXC has numerous features for novice and power users alike. Our goal is to create an application that can be used by anyone while still offering advanced features to those that need them.
|
||||||
|
|
||||||
### Basic
|
### Core Features
|
||||||
* Create, open, and save databases in the KDBX format (KeePass-compatible with KDBX4 and KDBX3)
|
|
||||||
* Store sensitive information in entries that are organized by groups
|
|
||||||
* Search for entries
|
|
||||||
* Password generator
|
|
||||||
* Auto-Type passwords into applications
|
|
||||||
* Browser integration with Google Chrome, Mozilla Firefox, Microsoft Edge, Chromium, Vivaldi, Brave, and Tor-Browser
|
|
||||||
* Entry icon download
|
|
||||||
* Import databases from CSV, 1Password, and KeePass1 formats
|
|
||||||
|
|
||||||
### Advanced
|
* Create, open, and save databases in the KDBX format (KeePass-compatible with KDBX4 and KDBX3)
|
||||||
* Database reports (password health, HIBP, and statistics)
|
* All information is encrypted at rest and never exposed outside the program
|
||||||
* Database export to CSV and HTML formats
|
* Store sensitive information in entries that are organized by groups
|
||||||
|
* Password generator
|
||||||
|
* Search for entries
|
||||||
* TOTP storage and generation
|
* TOTP storage and generation
|
||||||
|
* YubiKey/OnlyKey challenge-response support
|
||||||
|
* Auto-Type passwords into applications
|
||||||
|
* Browser integration with all major browsers
|
||||||
|
* Share database entries with KeeShare
|
||||||
|
* Import databases from CSV, 1Password, and Bitwarden formats
|
||||||
|
|
||||||
|
### Additional Features
|
||||||
|
|
||||||
|
* Entry icon download
|
||||||
|
* Auto-Open databases
|
||||||
|
* Password health reports, database statistics, and Have I Been Pwned search
|
||||||
|
* Export to CSV, HTML, and XML formats
|
||||||
* Field references between entries
|
* Field references between entries
|
||||||
* File attachments and custom attributes
|
* File attachments and custom attributes
|
||||||
* Entry history and data restoration
|
* Entry history and data restoration
|
||||||
* YubiKey/OnlyKey challenge-response support
|
|
||||||
* Command line interface (keepassxc-cli)
|
* Command line interface (keepassxc-cli)
|
||||||
* Auto-Open databases
|
|
||||||
* KeeShare shared databases (import, export, and synchronize)
|
|
||||||
* SSH Agent integration
|
* SSH Agent integration
|
||||||
* FreeDesktop.org Secret Service (replace Gnome keyring, etc.)
|
* FreeDesktop.org Secret Service (replace Gnome keyring, etc.)
|
||||||
* Additional encryption choices: Twofish and ChaCha20
|
* Additional encryption choices: Twofish and ChaCha20
|
||||||
|
65
cmake/CompilerFlags.cmake
Normal file
65
cmake/CompilerFlags.cmake
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
# Copyright (C) 2024 KeePassXC Team <team@keepassxc.org>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 2 or (at your option)
|
||||||
|
# version 3 of the License.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
macro(add_gcc_compiler_cxxflags FLAGS)
|
||||||
|
if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_COMPILER_IS_CLANGXX)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${FLAGS}")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(add_gcc_compiler_cflags FLAGS)
|
||||||
|
if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
|
||||||
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${FLAGS}")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(add_gcc_compiler_flags FLAGS)
|
||||||
|
add_gcc_compiler_cxxflags("${FLAGS}")
|
||||||
|
add_gcc_compiler_cflags("${FLAGS}")
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
# Copies of above macros that first ensure the compiler understands a given flag
|
||||||
|
# Because check_*_compiler_flag() sets -D with name, need to provide "safe" FLAGNAME
|
||||||
|
macro(check_add_gcc_compiler_cxxflag FLAG FLAGNAME)
|
||||||
|
check_cxx_compiler_flag("${FLAG}" CXX_HAS${FLAGNAME})
|
||||||
|
if(CXX_HAS${FLAGNAME})
|
||||||
|
add_gcc_compiler_cxxflags("${FLAG}")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(check_add_gcc_compiler_cflag FLAG FLAGNAME)
|
||||||
|
check_c_compiler_flag("${FLAG}" CC_HAS${FLAGNAME})
|
||||||
|
if(CC_HAS${FLAGNAME})
|
||||||
|
add_gcc_compiler_cflags("${FLAG}")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
# This is the "front-end" for the above macros
|
||||||
|
# Optionally takes additional parameter(s) with language to check (currently "C" or "CXX")
|
||||||
|
macro(check_add_gcc_compiler_flag FLAG)
|
||||||
|
string(REGEX REPLACE "[-=]" "_" FLAGNAME "${FLAG}")
|
||||||
|
set(check_lang_spec ${ARGN})
|
||||||
|
list(LENGTH check_lang_spec num_extra_args)
|
||||||
|
set(langs C CXX)
|
||||||
|
if(num_extra_args GREATER 0)
|
||||||
|
set(langs "${check_lang_spec}")
|
||||||
|
endif()
|
||||||
|
if("C" IN_LIST langs)
|
||||||
|
check_add_gcc_compiler_cflag("${FLAG}" "${FLAGNAME}")
|
||||||
|
endif()
|
||||||
|
if("CXX" IN_LIST langs)
|
||||||
|
check_add_gcc_compiler_cxxflag("${FLAG}" "${FLAGNAME}")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
8
cmake/compiler-checks/ptrace_deny_attach.cpp
Normal file
8
cmake/compiler-checks/ptrace_deny_attach.cpp
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#include <sys/ptrace.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
ptrace(PT_DENY_ATTACH, 0, 0, 0);
|
||||||
|
return 0;
|
||||||
|
}
|
20
release-tool
20
release-tool
@ -47,7 +47,6 @@ CMAKE_OPTIONS=""
|
|||||||
CPACK_GENERATORS="WIX;ZIP"
|
CPACK_GENERATORS="WIX;ZIP"
|
||||||
COMPILER="g++"
|
COMPILER="g++"
|
||||||
MAKE_OPTIONS="-j$(getconf _NPROCESSORS_ONLN)"
|
MAKE_OPTIONS="-j$(getconf _NPROCESSORS_ONLN)"
|
||||||
BUILD_PLUGINS="all"
|
|
||||||
INSTALL_PREFIX="/usr/local"
|
INSTALL_PREFIX="/usr/local"
|
||||||
ORIG_BRANCH=""
|
ORIG_BRANCH=""
|
||||||
ORIG_CWD="$(pwd)"
|
ORIG_CWD="$(pwd)"
|
||||||
@ -132,8 +131,6 @@ Options:
|
|||||||
-m, --make-options Make options for compiling sources (default: '${MAKE_OPTIONS}')
|
-m, --make-options Make options for compiling sources (default: '${MAKE_OPTIONS}')
|
||||||
-g, --generators Additional CPack generators (default: '${CPACK_GENERATORS}')
|
-g, --generators Additional CPack generators (default: '${CPACK_GENERATORS}')
|
||||||
-i, --install-prefix Install prefix (default: '${INSTALL_PREFIX}')
|
-i, --install-prefix Install prefix (default: '${INSTALL_PREFIX}')
|
||||||
-p, --plugins Space-separated list of plugins to build
|
|
||||||
(default: ${BUILD_PLUGINS})
|
|
||||||
--snapshot Don't checkout the release tag
|
--snapshot Don't checkout the release tag
|
||||||
-n, --no-source-tarball Don't build source tarball
|
-n, --no-source-tarball Don't build source tarball
|
||||||
-h, --help Show this help
|
-h, --help Show this help
|
||||||
@ -829,10 +826,6 @@ build() {
|
|||||||
INSTALL_PREFIX="$2"
|
INSTALL_PREFIX="$2"
|
||||||
shift ;;
|
shift ;;
|
||||||
|
|
||||||
-p|--plugins)
|
|
||||||
BUILD_PLUGINS="$2"
|
|
||||||
shift ;;
|
|
||||||
|
|
||||||
-n|--no-source-tarball)
|
-n|--no-source-tarball)
|
||||||
build_source_tarball=false ;;
|
build_source_tarball=false ;;
|
||||||
|
|
||||||
@ -870,13 +863,9 @@ build() {
|
|||||||
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_BUILD_TYPE=Snapshot -DOVERRIDE_VERSION=${RELEASE_NAME}"
|
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_BUILD_TYPE=Snapshot -DOVERRIDE_VERSION=${RELEASE_NAME}"
|
||||||
else
|
else
|
||||||
checkWorkingTreeClean
|
checkWorkingTreeClean
|
||||||
if echo "$TAG_NAME" | grep -qE '\-(alpha|beta)[0-9]+$'; then
|
|
||||||
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_BUILD_TYPE=PreRelease"
|
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_BUILD_TYPE=Release"
|
||||||
logInfo "Checking out pre-release tag '${TAG_NAME}'..."
|
logInfo "Checking out release tag '${TAG_NAME}'..."
|
||||||
else
|
|
||||||
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_BUILD_TYPE=Release"
|
|
||||||
logInfo "Checking out release tag '${TAG_NAME}'..."
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! git checkout "$TAG_NAME" > /dev/null 2>&1; then
|
if ! git checkout "$TAG_NAME" > /dev/null 2>&1; then
|
||||||
exitError "Failed to check out target branch."
|
exitError "Failed to check out target branch."
|
||||||
@ -922,9 +911,6 @@ build() {
|
|||||||
cd "${OUTPUT_DIR}/build-release"
|
cd "${OUTPUT_DIR}/build-release"
|
||||||
|
|
||||||
logInfo "Configuring sources..."
|
logInfo "Configuring sources..."
|
||||||
for p in ${BUILD_PLUGINS}; do
|
|
||||||
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DWITH_XC_$(echo $p | tr '[:lower:]' '[:upper:]')=On"
|
|
||||||
done
|
|
||||||
if [ -n "$OS_LINUX" ] && ${build_appimage}; then
|
if [ -n "$OS_LINUX" ] && ${build_appimage}; then
|
||||||
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_DIST_TYPE=AppImage"
|
CMAKE_OPTIONS="${CMAKE_OPTIONS} -DKEEPASSXC_DIST_TYPE=AppImage"
|
||||||
# linuxdeploy requires /usr as install prefix
|
# linuxdeploy requires /usr as install prefix
|
||||||
|
@ -253,7 +253,6 @@ function Invoke-GpgSignFiles([string[]] $files, [string] $key) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# Handle errors and restore state
|
# Handle errors and restore state
|
||||||
$OrigDir = (Get-Location).Path
|
$OrigDir = (Get-Location).Path
|
||||||
$OrigBranch = & git rev-parse --abbrev-ref HEAD
|
$OrigBranch = & git rev-parse --abbrev-ref HEAD
|
||||||
@ -345,6 +344,7 @@ if ($Merge) {
|
|||||||
Write-Host "All done!"
|
Write-Host "All done!"
|
||||||
Write-Host "Please merge the release branch back into the develop branch now and then push your changes."
|
Write-Host "Please merge the release branch back into the develop branch now and then push your changes."
|
||||||
Write-Host "Don't forget to also push the tags using 'git push --tags'."
|
Write-Host "Don't forget to also push the tags using 'git push --tags'."
|
||||||
|
|
||||||
} elseif ($Build) {
|
} elseif ($Build) {
|
||||||
$Vcpkg = (Resolve-Path "$Vcpkg/scripts/buildsystems/vcpkg.cmake").Path
|
$Vcpkg = (Resolve-Path "$Vcpkg/scripts/buildsystems/vcpkg.cmake").Path
|
||||||
|
|
||||||
@ -357,6 +357,13 @@ if ($Merge) {
|
|||||||
|
|
||||||
Test-RequiredPrograms
|
Test-RequiredPrograms
|
||||||
|
|
||||||
|
# Create directories
|
||||||
|
New-Item "$OutDir" -ItemType Directory -Force | Out-Null
|
||||||
|
$OutDir = (Resolve-Path $OutDir).Path
|
||||||
|
|
||||||
|
$BuildDir = "$OutDir\build-release"
|
||||||
|
New-Item "$BuildDir" -ItemType Directory -Force | Out-Null
|
||||||
|
|
||||||
if ($Snapshot) {
|
if ($Snapshot) {
|
||||||
$Tag = "HEAD"
|
$Tag = "HEAD"
|
||||||
$SourceBranch = & git rev-parse --abbrev-ref HEAD
|
$SourceBranch = & git rev-parse --abbrev-ref HEAD
|
||||||
@ -366,38 +373,26 @@ if ($Merge) {
|
|||||||
} else {
|
} else {
|
||||||
Test-WorkingTreeClean
|
Test-WorkingTreeClean
|
||||||
|
|
||||||
# Clear output directory
|
# Clear build directory except for installed vcpkg files to prevent having to re-sign everything
|
||||||
if (Test-Path $OutDir) {
|
if (Test-Path $BuildDir) {
|
||||||
Remove-Item $OutDir -Recurse
|
Get-ChildItem $BuildDir -Recurse | Where-Object {$_.FullName -notlike "$BuildDir\vcpkg_installed*"} | Remove-Item -Recurse -Force
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Version -match "-beta\d*$") {
|
$CMakeOptions = "-DKEEPASSXC_BUILD_TYPE=Release $CMakeOptions"
|
||||||
$CMakeOptions = "-DKEEPASSXC_BUILD_TYPE=PreRelease $CMakeOptions"
|
|
||||||
} else {
|
|
||||||
$CMakeOptions = "-DKEEPASSXC_BUILD_TYPE=Release $CMakeOptions"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Setup Tag if not defined then checkout tag
|
# Setup Tag if not defined then checkout tag
|
||||||
if ($Tag -eq "" -or $Tag -eq $null) {
|
if ($Tag -eq "" -or $null -eq $Tag) {
|
||||||
$Tag = $Version
|
$Tag = $Version
|
||||||
}
|
}
|
||||||
Write-Host "Checking out tag 'tags/$Tag' to build." -ForegroundColor Cyan
|
Write-Host "Checking out tag 'tags/$Tag' to build." -ForegroundColor Cyan
|
||||||
Invoke-Cmd "git" "checkout `"tags/$Tag`""
|
Invoke-Cmd "git" "checkout `"tags/$Tag`""
|
||||||
}
|
}
|
||||||
|
|
||||||
# Create directories
|
|
||||||
New-Item "$OutDir" -ItemType Directory -Force | Out-Null
|
|
||||||
$OutDir = (Resolve-Path $OutDir).Path
|
|
||||||
|
|
||||||
$BuildDir = "$OutDir\build-release"
|
|
||||||
New-Item "$BuildDir" -ItemType Directory -Force | Out-Null
|
|
||||||
|
|
||||||
# Enter build directory
|
# Enter build directory
|
||||||
Set-Location "$BuildDir"
|
Set-Location "$BuildDir"
|
||||||
|
|
||||||
# Setup CMake options
|
# Setup CMake options
|
||||||
$CMakeOptions = "-DWITH_XC_ALL=ON -DWITH_TESTS=OFF -DCMAKE_BUILD_TYPE=Release $CMakeOptions"
|
$CMakeOptions = "-DWITH_TESTS=OFF -DCMAKE_BUILD_TYPE=Release -DCMAKE_TOOLCHAIN_FILE:FILEPATH=`"$Vcpkg`" -DX_VCPKG_APPLOCAL_DEPS_INSTALL=ON"
|
||||||
$CMakeOptions = "-DCMAKE_TOOLCHAIN_FILE:FILEPATH=`"$Vcpkg`" -DX_VCPKG_APPLOCAL_DEPS_INSTALL=ON $CMakeOptions"
|
|
||||||
|
|
||||||
Write-Host "Configuring build..." -ForegroundColor Cyan
|
Write-Host "Configuring build..." -ForegroundColor Cyan
|
||||||
Invoke-Cmd "cmake" "-G `"$CMakeGenerator`" $CMakeOptions `"$SourceDir`""
|
Invoke-Cmd "cmake" "-G `"$CMakeGenerator`" $CMakeOptions `"$SourceDir`""
|
||||||
@ -436,6 +431,7 @@ if ($Merge) {
|
|||||||
# Restore state
|
# Restore state
|
||||||
Invoke-Command {git checkout $OrigBranch}
|
Invoke-Command {git checkout $OrigBranch}
|
||||||
Set-Location "$OrigDir"
|
Set-Location "$OrigDir"
|
||||||
|
|
||||||
} elseif ($Sign) {
|
} elseif ($Sign) {
|
||||||
Test-RequiredPrograms
|
Test-RequiredPrograms
|
||||||
|
|
||||||
@ -459,8 +455,8 @@ if ($Merge) {
|
|||||||
# SIG # Begin signature block
|
# SIG # Begin signature block
|
||||||
# MIImVAYJKoZIhvcNAQcCoIImRTCCJkECAQExDzANBglghkgBZQMEAgEFADB5Bgor
|
# MIImVAYJKoZIhvcNAQcCoIImRTCCJkECAQExDzANBglghkgBZQMEAgEFADB5Bgor
|
||||||
# BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG
|
# BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG
|
||||||
# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCCRMgDV7DQ6PzRo
|
# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCBnhvt4NN16Hfle
|
||||||
# 3ULpsxL1VU2JvIFnZPXlxq/hkfU2Y6CCH2owggYUMIID/KADAgECAhB6I67aU2mW
|
# eDfbtgcr43dOfERdBCPSlLlozTRPoaCCH2owggYUMIID/KADAgECAhB6I67aU2mW
|
||||||
# D5HIPlz0x+M/MA0GCSqGSIb3DQEBDAUAMFcxCzAJBgNVBAYTAkdCMRgwFgYDVQQK
|
# D5HIPlz0x+M/MA0GCSqGSIb3DQEBDAUAMFcxCzAJBgNVBAYTAkdCMRgwFgYDVQQK
|
||||||
# Ew9TZWN0aWdvIExpbWl0ZWQxLjAsBgNVBAMTJVNlY3RpZ28gUHVibGljIFRpbWUg
|
# Ew9TZWN0aWdvIExpbWl0ZWQxLjAsBgNVBAMTJVNlY3RpZ28gUHVibGljIFRpbWUg
|
||||||
# U3RhbXBpbmcgUm9vdCBSNDYwHhcNMjEwMzIyMDAwMDAwWhcNMzYwMzIxMjM1OTU5
|
# U3RhbXBpbmcgUm9vdCBSNDYwHhcNMjEwMzIyMDAwMDAwWhcNMzYwMzIxMjM1OTU5
|
||||||
@ -632,34 +628,34 @@ if ($Merge) {
|
|||||||
# Z28gTGltaXRlZDErMCkGA1UEAxMiU2VjdGlnbyBQdWJsaWMgQ29kZSBTaWduaW5n
|
# Z28gTGltaXRlZDErMCkGA1UEAxMiU2VjdGlnbyBQdWJsaWMgQ29kZSBTaWduaW5n
|
||||||
# IENBIFIzNgIQBkM/zMzkM6iSzBe3RqWMZTANBglghkgBZQMEAgEFAKCBhDAYBgor
|
# IENBIFIzNgIQBkM/zMzkM6iSzBe3RqWMZTANBglghkgBZQMEAgEFAKCBhDAYBgor
|
||||||
# BgEEAYI3AgEMMQowCKACgAChAoAAMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEE
|
# BgEEAYI3AgEMMQowCKACgAChAoAAMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEE
|
||||||
# MBwGCisGAQQBgjcCAQsxDjAMBgorBgEEAYI3AgEVMC8GCSqGSIb3DQEJBDEiBCCw
|
# MBwGCisGAQQBgjcCAQsxDjAMBgorBgEEAYI3AgEVMC8GCSqGSIb3DQEJBDEiBCB3
|
||||||
# CjBOFSrHIl5SZxVeFP1D+IfXa4B5pNieNHIkm0/SqTANBgkqhkiG9w0BAQEFAASC
|
# VDtldlpqUJGX7ENprygJeJxr+V2oUTlguFLaSOkkcTANBgkqhkiG9w0BAQEFAASC
|
||||||
# AgAgFK2xkUz0aie9HSo0e4qyDk83CNX9G/GR7+DObTay5l7OYVZIdB2kOZIS8UbH
|
# AgAIu1lvIg5zEwMJ87vlGg8H5BvvXdCiQllHuZir0ULpGs/IG03o3uvL9bI8IEt0
|
||||||
# 4gMSsjplIVObVyf1DjGGCctq4bFDABL7wpwqm7P3tEjs2d/HK2Yxoe1c8YFTYMJJ
|
# Elq5ePQ1qlg2z3BT3a+7+SyMChGVVoko3U60aQyjjlXPtzh7HUEKdQWDyrabHmEk
|
||||||
# Vc6Q9l/nZA7ZC/SCH1NyEgK+w3vQ6SARudN8/ZgFVa1P3DdwOADmLD774v3bOUKq
|
# YACxpRF/h6FoJAkQqVr5cF5d+Ey8SdfE9h9MyqcaxeWtJPEFI/qjp4sfQuJZuXpN
|
||||||
# XKDOySeYD7bkCekPv6yx6DnrWBBsYIKFRv2Yv4duThki4CC1FMgEVTmdBDJIP3R8
|
# saallK9xM+xKrigwTx8s7C/clWZX8OtAIIegpf8mnU5ETYS6XnvefcAMsXKBmxjI
|
||||||
# 1BgXjPvVxYX3aQ9emC3KluyNr/BEPZiVdwBjXCE60n7g/Y8qNgqY0ZaImSpl9MFx
|
# 01GadXwlpJ/I7d/1LrZ5OjOmqVrAWnJEOkdV5+5xJbnJInPvgnBOrLeQyR7QEU6V
|
||||||
# VkrxE7iNfBcBE8xVCghyDahs1BxyEeEdQk+QlLD1Cv3KGODlyWjgncDAX7fnkC6l
|
# XtiD6k+LqgfU7bP8AQCouz33M2DdxmfKZPPReMuZaNI3RvNX9M49wAXey/iuy+pm
|
||||||
# M7KUttjXGi9uQG3g2dUCX+744wPhRg+DBfch2Em70I0kYsPY6ETyrQogZdi6QzKO
|
# G9+DwGT3IHCIhOrL5GimdTO8vcVkdzIFdPgAb/jOR4n8P3VRaPH1sH0rO5vHuwfG
|
||||||
# Hlf/hUW0o9HCc6BrTSL4y8G0mlKVCgUpMOjlrip88bvW05ZUX20arGKxGg1uxFIA
|
# nO7Mrb4AMYo4sP0RXkIGWXhj0Z7VrajAYHtcSnwCedUbHxk9faDbF5Vrh4kTCt+T
|
||||||
# r7wvQyFn+RvNc0kqWt/xgwp3HAc80ABPCYumLqGwucBWisiMt4P2s+fkLpYJdC/n
|
# utMXrepDzK6kWtr8BX68aA/meoSzN0ZhOchWbWXxC4kPSTtNTnBHAWVKaCjxBVq4
|
||||||
# pS/3fRoepfGmv8J1WAIjGiO7e12aDrTQqNP+2RUzkNpy2eRQDL+3VUFQOQqEfkVL
|
# J+CTlKGLdj78SVMTeE8guyifYNiRkrqRCuXghKQZEIN0ry1SbpQA27wZQWVJrL8E
|
||||||
# Y6wpN6nB7olNULhPUlwZChf49v/h+XUxhgHozWN576qoyqGCAyIwggMeBgkqhkiG
|
# XE0F54gWMGrwqCik1GSfAgPYZd3IWdLc6jPR9ec/uS/QaaGCAyIwggMeBgkqhkiG
|
||||||
# 9w0BCQYxggMPMIIDCwIBATBpMFUxCzAJBgNVBAYTAkdCMRgwFgYDVQQKEw9TZWN0
|
# 9w0BCQYxggMPMIIDCwIBATBpMFUxCzAJBgNVBAYTAkdCMRgwFgYDVQQKEw9TZWN0
|
||||||
# aWdvIExpbWl0ZWQxLDAqBgNVBAMTI1NlY3RpZ28gUHVibGljIFRpbWUgU3RhbXBp
|
# aWdvIExpbWl0ZWQxLDAqBgNVBAMTI1NlY3RpZ28gUHVibGljIFRpbWUgU3RhbXBp
|
||||||
# bmcgQ0EgUjM2AhA6UmoshM5V5h1l/MwS2OmJMA0GCWCGSAFlAwQCAgUAoHkwGAYJ
|
# bmcgQ0EgUjM2AhA6UmoshM5V5h1l/MwS2OmJMA0GCWCGSAFlAwQCAgUAoHkwGAYJ
|
||||||
# KoZIhvcNAQkDMQsGCSqGSIb3DQEHATAcBgkqhkiG9w0BCQUxDxcNMjQwOTE0MDMy
|
# KoZIhvcNAQkDMQsGCSqGSIb3DQEHATAcBgkqhkiG9w0BCQUxDxcNMjUwMTAzMDQx
|
||||||
# MTU1WjA/BgkqhkiG9w0BCQQxMgQwwrUMFcAva5866cdprEw/weWm4EfoAA4SCloN
|
# MzI4WjA/BgkqhkiG9w0BCQQxMgQwKlrwmwJXs6mQ/rkiyCJkh8uDUj2DERGpO4aA
|
||||||
# B50191F7ps9XQIxGfsz+g0vQxzxfMA0GCSqGSIb3DQEBAQUABIICAC3qVFmWQWkL
|
# iq1TY56EYG/QvCktwMVZYRTI8Cu1MA0GCSqGSIb3DQEBAQUABIICAGyQ98hsyLlN
|
||||||
# kn/AYJPZ3B7Yvwq0P7SqcHO9w5FiV5wsznH6xfvkTzXssQLhKaZdqypnHCTNth8D
|
# dOnWHLSncZ5ovUQBXEAeeMxuRhB3G7bpdcpi4a/t7q+tLzLH2CKrpCZ5dS0tbRd9
|
||||||
# 7mgr6zZYh5CgQQ3SSG2q0xVzs3wanJmZ4g6I7bVeGMLv47tFnCed9G3aP5cywDBn
|
# ng7kH4X8WbllElxzvnnwAmPrYDfX/VO8bVS/JJ8qmfrtgHhs+4dtMFkV11VXNRYs
|
||||||
# vMOiwZnQR1WwM8T6qE4sAb4lKXUYDbIVB1DMRAF3j2rQMAN9e9jF6Ok+ZyQqpBSl
|
# IC2xbYMbwuH7cWA/L+muDADM0VLONKB3HECPhbIhfHCSKJr8i2cYyW3AixC77SPG
|
||||||
# ve2vBR0TgFXeyidwiz6O2I1FWc1OzwMchbJTANbQqWRKuiQ6gm0Bj/S8dalBb77I
|
# mimDoh3umEJLjMvCsGJ32BrVbXKR4hBCOxmDN470nxKDuEurW6JvDh6GjevcdzeT
|
||||||
# jxS0Tn7kRH1Sr50ZfWRSxj7H7afsQOKbDHxhWFhctvQfbrmbNj+gHcm9j/rSPpU7
|
# ungxb0pnFIfj5IMhjjrZhccCQK1ekvFLmb/ybzfZGbXGb8QHJP4JvFm8sWNAccIn
|
||||||
# zj5OvgKyYQnjiLjCnGBTmSML2ZwvXhPv2XkFQ2yL2nYWTRqLjARdcP62kSrkQxEa
|
# dQ3SixhyKW+gOC2r0URTPrIDpbdHuGnm3LVBPhBijrJrv7w1/neEQFFLFXfrjgJb
|
||||||
# DLAZ7mcndE+HZVMllBGVI9/H5hkE7jINBU4gNvyqQQqF3xTatJMldyrXCQ6R9wfN
|
# K8zc2IMYPW+Vn/hclNGfK8EOBqLGvsn7xB0K1f13kVt7QT36nIYojIE5MwWhvPDi
|
||||||
# LsdyFB177vZXLrS1EymCzq1COpbrw3oa/LXP+1hZFhoaOYy00LUnCU5Zjd8UFWIh
|
# 1oIDdJEvZS/P8tmX6lwAXxPRQagPVhNefUUHk11/kUaBUGGi+bRpKOgcS1fPqsP1
|
||||||
# FDj3Z7O/Xz3P8BR4t7PGqUu3x8UbxcsGDH0w0e3pvPmxXiBZlspjNieg073YNKxU
|
# 1RQMSEzjsnGEzLxxqa+AtxLDre2vBJsllCD4JJwrpkQW+xu014bZleJ3i1IFDUaR
|
||||||
# Yuj0b3cX/cpYH0M0Ne/tXuHwbZthwwll3vytT7Aa+oglejolDQjRc8Gv5KW0dUK3
|
# E16d6Qi4KEC0RfZ1NwahKQFqBj3wBCMLGEY6fNndE4jVGO0BkP3vO23pt7n4xmM+
|
||||||
# LmVw9eforeFUrTExSEc/0jf29BmZz9do
|
# swJJsR48RDIDkSiV+2vPvlk/9KXVW9ji
|
||||||
# SIG # End signature block
|
# SIG # End signature block
|
||||||
|
@ -5834,17 +5834,6 @@ Are you sure you want to continue with this file?</source>
|
|||||||
<source>Don't show again for this version</source>
|
<source>Don't show again for this version</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<source>WARNING: You are using an unstable build of KeePassXC.
|
|
||||||
There is a high risk of corruption, maintain a backup of your databases.
|
|
||||||
This version is not meant for production use.</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>NOTE: You are using a pre-release version of KeePassXC.
|
|
||||||
Expect some bugs and minor issues, this version is meant for testing purposes.</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<source>No Tags</source>
|
<source>No Tags</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
@ -6184,11 +6173,9 @@ Expect some bugs and minor issues, this version is meant for testing purposes.</
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>Show Group Panel</source>
|
<source>WARNING: You are using a development snapshot build of KeePassXC.
|
||||||
<translation type="unfinished"></translation>
|
Maintain a backup of your databases in the event of unknown bugs.
|
||||||
</message>
|
This version is not meant for production use.</source>
|
||||||
<message>
|
|
||||||
<source>Toggle Show Group Panel</source>
|
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
@ -8425,10 +8412,6 @@ Kernel: %3 %4</source>
|
|||||||
<source>KeeShare</source>
|
<source>KeeShare</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<source>YubiKey</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<source>Quick Unlock</source>
|
<source>Quick Unlock</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
@ -8437,10 +8420,6 @@ Kernel: %3 %4</source>
|
|||||||
<source>Secret Service Integration</source>
|
<source>Secret Service Integration</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<source>None</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<source>Enabled extensions:</source>
|
<source>Enabled extensions:</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
@ -9035,42 +9014,7 @@ This option is deprecated, use --set-key-file instead.</source>
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>Reset Shortcuts</source>
|
<source>Hardware Keys</source>
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Double click an action to change its shortcut</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Filter...</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Shortcut Conflict</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Shortcut %1 conflicts with '%2'. Overwrite shortcut?</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Cannot generate valid passphrases because the wordlist is too short</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Delete plugin data?</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message numerus="yes">
|
|
||||||
<source>Delete plugin data from Entry(s)?</source>
|
|
||||||
<translation type="unfinished">
|
|
||||||
<numerusform></numerusform>
|
|
||||||
<numerusform></numerusform>
|
|
||||||
</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>Passkey</source>
|
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Copyright (C) 2023 KeePassXC Team <team@keepassxc.org>
|
# Copyright (C) 2024 KeePassXC Team <team@keepassxc.org>
|
||||||
# Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
# Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
||||||
#
|
#
|
||||||
# This program is free software: you can redistribute it and/or modify
|
# This program is free software: you can redistribute it and/or modify
|
||||||
@ -16,18 +16,6 @@
|
|||||||
|
|
||||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
add_feature_info(Auto-Type WITH_XC_AUTOTYPE "Automatic password typing")
|
|
||||||
add_feature_info(Networking WITH_XC_NETWORKING "Compile KeePassXC with network access code (e.g. for downloading website icons)")
|
|
||||||
add_feature_info(KeePassXC-Browser WITH_XC_BROWSER "Browser integration with KeePassXC-Browser")
|
|
||||||
add_feature_info(Passkeys WITH_XC_BROWSER_PASSKEYS "Passkeys support for browser integration")
|
|
||||||
add_feature_info(SSHAgent WITH_XC_SSHAGENT "SSH agent integration compatible with KeeAgent")
|
|
||||||
add_feature_info(KeeShare WITH_XC_KEESHARE "Sharing integration with KeeShare")
|
|
||||||
add_feature_info(YubiKey WITH_XC_YUBIKEY "YubiKey HMAC-SHA1 challenge-response")
|
|
||||||
add_feature_info(UpdateCheck WITH_XC_UPDATECHECK "Automatic update checking")
|
|
||||||
if(UNIX AND NOT APPLE)
|
|
||||||
add_feature_info(FdoSecrets WITH_XC_FDOSECRETS "Implement freedesktop.org Secret Storage Spec server side API.")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(core_SOURCES
|
set(core_SOURCES
|
||||||
core/Alloc.cpp
|
core/Alloc.cpp
|
||||||
core/AutoTypeAssociations.cpp
|
core/AutoTypeAssociations.cpp
|
||||||
@ -94,6 +82,11 @@ set(core_SOURCES
|
|||||||
keys/FileKey.cpp
|
keys/FileKey.cpp
|
||||||
keys/PasswordKey.cpp
|
keys/PasswordKey.cpp
|
||||||
keys/ChallengeResponseKey.cpp
|
keys/ChallengeResponseKey.cpp
|
||||||
|
keys/drivers/YubiKey.h
|
||||||
|
keys/drivers/YubiKey.cpp
|
||||||
|
keys/drivers/YubiKeyInterface.cpp
|
||||||
|
keys/drivers/YubiKeyInterfaceUSB.cpp
|
||||||
|
keys/drivers/YubiKeyInterfacePCSC.cpp
|
||||||
streams/HashedBlockStream.cpp
|
streams/HashedBlockStream.cpp
|
||||||
streams/HmacBlockStream.cpp
|
streams/HmacBlockStream.cpp
|
||||||
streams/LayeredStream.cpp
|
streams/LayeredStream.cpp
|
||||||
@ -189,6 +182,7 @@ set(gui_SOURCES
|
|||||||
gui/reports/ReportsPageHibp.cpp
|
gui/reports/ReportsPageHibp.cpp
|
||||||
gui/reports/ReportsWidgetStatistics.cpp
|
gui/reports/ReportsWidgetStatistics.cpp
|
||||||
gui/reports/ReportsPageStatistics.cpp
|
gui/reports/ReportsPageStatistics.cpp
|
||||||
|
gui/osutils/DeviceListener.cpp
|
||||||
gui/osutils/OSUtilsBase.cpp
|
gui/osutils/OSUtilsBase.cpp
|
||||||
gui/osutils/ScreenLockListener.cpp
|
gui/osutils/ScreenLockListener.cpp
|
||||||
gui/osutils/ScreenLockListenerPrivate.cpp
|
gui/osutils/ScreenLockListenerPrivate.cpp
|
||||||
@ -210,6 +204,7 @@ set(gui_SOURCES
|
|||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
list(APPEND gui_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
|
gui/osutils/macutils/DeviceListenerMac.cpp
|
||||||
gui/osutils/macutils/MacPasteboard.cpp
|
gui/osutils/macutils/MacPasteboard.cpp
|
||||||
gui/osutils/macutils/MacUtils.cpp
|
gui/osutils/macutils/MacUtils.cpp
|
||||||
gui/osutils/macutils/ScreenLockListenerMac.cpp
|
gui/osutils/macutils/ScreenLockListenerMac.cpp
|
||||||
@ -223,14 +218,16 @@ endif()
|
|||||||
|
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
list(APPEND gui_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
|
gui/osutils/nixutils/DeviceListenerLibUsb.cpp
|
||||||
|
gui/osutils/nixutils/NixUtils.cpp
|
||||||
gui/osutils/nixutils/ScreenLockListenerDBus.cpp
|
gui/osutils/nixutils/ScreenLockListenerDBus.cpp
|
||||||
gui/osutils/nixutils/NixUtils.cpp)
|
)
|
||||||
if("${CMAKE_SYSTEM}" MATCHES "Linux")
|
if("${CMAKE_SYSTEM}" MATCHES "Linux")
|
||||||
list(APPEND core_SOURCES
|
list(APPEND core_SOURCES
|
||||||
quickunlock/Polkit.cpp
|
quickunlock/Polkit.cpp
|
||||||
quickunlock/PolkitDbusTypes.cpp)
|
quickunlock/PolkitDbusTypes.cpp)
|
||||||
endif()
|
endif()
|
||||||
if(WITH_XC_X11)
|
if(WITH_X11)
|
||||||
list(APPEND gui_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
gui/osutils/nixutils/X11Funcs.cpp)
|
gui/osutils/nixutils/X11Funcs.cpp)
|
||||||
endif()
|
endif()
|
||||||
@ -248,15 +245,11 @@ if(UNIX AND NOT APPLE)
|
|||||||
quickunlock/dbus/org.freedesktop.PolicyKit1.Authority.xml
|
quickunlock/dbus/org.freedesktop.PolicyKit1.Authority.xml
|
||||||
polkit_dbus
|
polkit_dbus
|
||||||
)
|
)
|
||||||
|
|
||||||
find_library(KEYUTILS_LIBRARIES NAMES keyutils)
|
|
||||||
if(NOT KEYUTILS_LIBRARIES)
|
|
||||||
message(FATAL_ERROR "Could not find libkeyutils")
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
list(APPEND gui_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
|
gui/osutils/winutils/DeviceListenerWin.cpp
|
||||||
gui/osutils/winutils/ScreenLockListenerWin.cpp
|
gui/osutils/winutils/ScreenLockListenerWin.cpp
|
||||||
gui/osutils/winutils/WinUtils.cpp)
|
gui/osutils/winutils/WinUtils.cpp)
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
@ -264,86 +257,24 @@ if(WIN32)
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WITH_XC_YUBIKEY)
|
|
||||||
list(APPEND gui_SOURCES gui/osutils/DeviceListener.cpp)
|
|
||||||
if(APPLE)
|
|
||||||
list(APPEND gui_SOURCES gui/osutils/macutils/DeviceListenerMac.cpp)
|
|
||||||
elseif(UNIX)
|
|
||||||
list(APPEND gui_SOURCES gui/osutils/nixutils/DeviceListenerLibUsb.cpp)
|
|
||||||
elseif(WIN32)
|
|
||||||
list(APPEND gui_SOURCES gui/osutils/winutils/DeviceListenerWin.cpp)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_subdirectory(browser)
|
add_subdirectory(browser)
|
||||||
add_subdirectory(proxy)
|
add_subdirectory(proxy)
|
||||||
if(WITH_XC_BROWSER)
|
if(KPXC_FEATURE_BROWSER)
|
||||||
set(browser_LIB browser)
|
set(browser_LIB browser)
|
||||||
list(APPEND gui_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
gui/dbsettings/DatabaseSettingsWidgetBrowser.cpp
|
gui/dbsettings/DatabaseSettingsWidgetBrowser.cpp
|
||||||
gui/entry/EntryURLModel.cpp
|
gui/entry/EntryURLModel.cpp
|
||||||
gui/reports/ReportsWidgetBrowserStatistics.cpp
|
gui/reports/ReportsPageBrowserStatistics.cpp
|
||||||
gui/reports/ReportsPageBrowserStatistics.cpp)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_BROWSER_PASSKEYS)
|
|
||||||
list(APPEND gui_SOURCES
|
|
||||||
gui/reports/ReportsWidgetPasskeys.cpp
|
|
||||||
gui/reports/ReportsPagePasskeys.cpp
|
gui/reports/ReportsPagePasskeys.cpp
|
||||||
|
gui/reports/ReportsWidgetBrowserStatistics.cpp
|
||||||
|
gui/reports/ReportsWidgetPasskeys.cpp
|
||||||
gui/passkeys/PasskeyExporter.cpp
|
gui/passkeys/PasskeyExporter.cpp
|
||||||
gui/passkeys/PasskeyExportDialog.cpp
|
gui/passkeys/PasskeyExportDialog.cpp
|
||||||
gui/passkeys/PasskeyImporter.cpp
|
gui/passkeys/PasskeyImporter.cpp
|
||||||
gui/passkeys/PasskeyImportDialog.cpp)
|
gui/passkeys/PasskeyImportDialog.cpp)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_subdirectory(autotype)
|
if(KPXC_FEATURE_NETWORK)
|
||||||
add_subdirectory(cli)
|
|
||||||
add_subdirectory(qrcode)
|
|
||||||
set(qrcode_LIB qrcode)
|
|
||||||
|
|
||||||
add_subdirectory(keeshare)
|
|
||||||
if(WITH_XC_KEESHARE)
|
|
||||||
set(keeshare_LIB keeshare)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_subdirectory(sshagent)
|
|
||||||
if(WITH_XC_SSHAGENT)
|
|
||||||
set(sshagent_LIB sshagent)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_subdirectory(fdosecrets)
|
|
||||||
if(WITH_XC_FDOSECRETS)
|
|
||||||
set(fdosecrets_LIB fdosecrets)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_subdirectory(thirdparty)
|
|
||||||
|
|
||||||
set(autotype_SOURCES
|
|
||||||
autotype/AutoType.cpp
|
|
||||||
autotype/AutoTypeAction.cpp
|
|
||||||
autotype/AutoTypeMatchModel.cpp
|
|
||||||
autotype/AutoTypeMatchView.cpp
|
|
||||||
autotype/AutoTypeSelectDialog.cpp
|
|
||||||
autotype/PickcharsDialog.cpp
|
|
||||||
autotype/WindowSelectComboBox.cpp)
|
|
||||||
|
|
||||||
add_library(autotype STATIC ${autotype_SOURCES})
|
|
||||||
target_link_libraries(autotype Qt5::Core Qt5::Widgets)
|
|
||||||
|
|
||||||
if(WITH_XC_YUBIKEY)
|
|
||||||
list(APPEND core_SOURCES
|
|
||||||
keys/drivers/YubiKey.h
|
|
||||||
keys/drivers/YubiKey.cpp
|
|
||||||
keys/drivers/YubiKeyInterface.cpp
|
|
||||||
keys/drivers/YubiKeyInterfaceUSB.cpp
|
|
||||||
keys/drivers/YubiKeyInterfacePCSC.cpp)
|
|
||||||
else()
|
|
||||||
list(APPEND core_SOURCES
|
|
||||||
keys/drivers/YubiKey.h
|
|
||||||
keys/drivers/YubiKeyStub.cpp)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_NETWORKING)
|
|
||||||
list(APPEND gui_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
networking/HibpDownloader.cpp
|
networking/HibpDownloader.cpp
|
||||||
networking/NetworkManager.cpp
|
networking/NetworkManager.cpp
|
||||||
@ -353,12 +284,36 @@ if(WITH_XC_NETWORKING)
|
|||||||
gui/IconDownloaderDialog.cpp)
|
gui/IconDownloaderDialog.cpp)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
add_subdirectory(cli)
|
||||||
|
add_subdirectory(thirdparty)
|
||||||
|
|
||||||
|
add_subdirectory(autotype)
|
||||||
|
set(autotype_LIB autotype)
|
||||||
|
|
||||||
|
# TODO: Refactor to gui sources
|
||||||
|
add_subdirectory(qrcode)
|
||||||
|
set(qrcode_LIB qrcode)
|
||||||
|
|
||||||
|
# TODO: Move to gui sources on refactor
|
||||||
|
add_subdirectory(keeshare)
|
||||||
|
set(keeshare_LIB keeshare)
|
||||||
|
|
||||||
|
add_subdirectory(sshagent)
|
||||||
|
if(KPXC_FEATURE_SSHAGENT)
|
||||||
|
set(sshagent_LIB sshagent)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_subdirectory(fdosecrets)
|
||||||
|
if(KPXC_FEATURE_FDOSECRETS)
|
||||||
|
set(fdosecrets_LIB fdosecrets)
|
||||||
|
endif()
|
||||||
|
|
||||||
configure_file(config-keepassx.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/config-keepassx.h)
|
configure_file(config-keepassx.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/config-keepassx.h)
|
||||||
configure_file(git-info.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/git-info.h)
|
configure_file(git-info.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/git-info.h)
|
||||||
|
|
||||||
# Core Library Definition
|
# Core Library Definition
|
||||||
add_library(keepassxc_core STATIC ${core_SOURCES})
|
add_library(keepassxc_core STATIC ${core_SOURCES})
|
||||||
set_target_properties(keepassxc_core PROPERTIES COMPILE_DEFINITIONS KEEPASSX_BUILDING_CORE)
|
set_target_properties(keepassxc_core PROPERTIES COMPILE_DEFINITIONS KPXC_BUILDING_CORE)
|
||||||
target_link_libraries(keepassxc_core
|
target_link_libraries(keepassxc_core
|
||||||
${qrcode_LIB}
|
${qrcode_LIB}
|
||||||
Qt5::Core
|
Qt5::Core
|
||||||
@ -374,12 +329,12 @@ target_link_libraries(keepassxc_core
|
|||||||
|
|
||||||
# GUI Library Definition
|
# GUI Library Definition
|
||||||
add_library(keepassxc_gui STATIC ${gui_SOURCES})
|
add_library(keepassxc_gui STATIC ${gui_SOURCES})
|
||||||
set_target_properties(keepassxc_gui PROPERTIES COMPILE_DEFINITIONS KEEPASSX_BUILDING_CORE)
|
set_target_properties(keepassxc_gui PROPERTIES COMPILE_DEFINITIONS KPXC_BUILDING_CORE)
|
||||||
target_link_libraries(keepassxc_gui
|
target_link_libraries(keepassxc_gui
|
||||||
keepassxc_core
|
keepassxc_core
|
||||||
Qt5::Network
|
Qt5::Network
|
||||||
Qt5::Widgets
|
Qt5::Widgets
|
||||||
autotype
|
${autotype_LIB}
|
||||||
${browser_LIB}
|
${browser_LIB}
|
||||||
${fdosecrets_LIB}
|
${fdosecrets_LIB}
|
||||||
${keeshare_LIB}
|
${keeshare_LIB}
|
||||||
@ -396,7 +351,7 @@ if(HAIKU)
|
|||||||
endif()
|
endif()
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
target_link_libraries(keepassxc_core Qt5::DBus ${LIBUSB_LIBRARIES})
|
target_link_libraries(keepassxc_core Qt5::DBus ${LIBUSB_LIBRARIES})
|
||||||
if(WITH_XC_X11)
|
if(WITH_X11)
|
||||||
target_link_libraries(keepassxc_gui Qt5::X11Extras X11)
|
target_link_libraries(keepassxc_gui Qt5::X11Extras X11)
|
||||||
endif()
|
endif()
|
||||||
include_directories(${Qt5Gui_PRIVATE_INCLUDE_DIRS})
|
include_directories(${Qt5Gui_PRIVATE_INCLUDE_DIRS})
|
||||||
@ -534,7 +489,7 @@ if(WIN32)
|
|||||||
COMPONENT Runtime)
|
COMPONENT Runtime)
|
||||||
|
|
||||||
# install OpenSSL library
|
# install OpenSSL library
|
||||||
if(WITH_XC_NETWORKING)
|
if(KPXC_FEATURE_NETWORK)
|
||||||
find_file(OPENSSL_DLL
|
find_file(OPENSSL_DLL
|
||||||
NAMES libssl-3.dll libssl-3-x64.dll
|
NAMES libssl-3.dll libssl-3-x64.dll
|
||||||
HINTS "${OPENSSL_ROOT_DIR}/bin"
|
HINTS "${OPENSSL_ROOT_DIR}/bin"
|
||||||
|
@ -148,9 +148,7 @@ AutoType::AutoType(QObject* parent, bool test)
|
|||||||
QString pluginPath = resources()->pluginPath(pluginName);
|
QString pluginPath = resources()->pluginPath(pluginName);
|
||||||
|
|
||||||
if (!pluginPath.isEmpty()) {
|
if (!pluginPath.isEmpty()) {
|
||||||
#ifdef WITH_XC_AUTOTYPE
|
|
||||||
loadPlugin(pluginPath);
|
loadPlugin(pluginPath);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
connect(qApp, SIGNAL(aboutToQuit()), SLOT(unloadPlugin()));
|
connect(qApp, SIGNAL(aboutToQuit()), SLOT(unloadPlugin()));
|
||||||
|
@ -1,5 +1,19 @@
|
|||||||
if(WITH_XC_AUTOTYPE)
|
# Main auto-type static library
|
||||||
if(UNIX AND NOT APPLE AND NOT HAIKU)
|
set(autotype_SOURCES
|
||||||
|
AutoType.cpp
|
||||||
|
AutoTypeAction.cpp
|
||||||
|
AutoTypeMatchModel.cpp
|
||||||
|
AutoTypeMatchView.cpp
|
||||||
|
AutoTypeSelectDialog.cpp
|
||||||
|
PickcharsDialog.cpp
|
||||||
|
WindowSelectComboBox.cpp)
|
||||||
|
|
||||||
|
add_library(autotype STATIC ${autotype_SOURCES})
|
||||||
|
target_link_libraries(autotype Qt5::Core Qt5::Widgets)
|
||||||
|
|
||||||
|
# Platform specific auto-type implementations
|
||||||
|
if(UNIX AND NOT APPLE AND NOT HAIKU)
|
||||||
|
if(WITH_X11)
|
||||||
find_package(X11 REQUIRED COMPONENTS Xi XTest)
|
find_package(X11 REQUIRED COMPONENTS Xi XTest)
|
||||||
find_package(Qt5X11Extras 5.2 REQUIRED)
|
find_package(Qt5X11Extras 5.2 REQUIRED)
|
||||||
if(PRINT_SUMMARY)
|
if(PRINT_SUMMARY)
|
||||||
@ -9,13 +23,14 @@ if(WITH_XC_AUTOTYPE)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_subdirectory(xcb)
|
add_subdirectory(xcb)
|
||||||
elseif(APPLE)
|
|
||||||
add_subdirectory(mac)
|
|
||||||
elseif(WIN32)
|
|
||||||
add_subdirectory(windows)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_TESTS)
|
|
||||||
add_subdirectory(test)
|
|
||||||
endif()
|
endif()
|
||||||
|
elseif(APPLE)
|
||||||
|
add_subdirectory(mac)
|
||||||
|
elseif(WIN32)
|
||||||
|
add_subdirectory(windows)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Auto-type tests
|
||||||
|
if(WITH_TESTS)
|
||||||
|
add_subdirectory(test)
|
||||||
endif()
|
endif()
|
||||||
|
@ -17,11 +17,9 @@
|
|||||||
|
|
||||||
#include "BrowserAction.h"
|
#include "BrowserAction.h"
|
||||||
#include "BrowserMessageBuilder.h"
|
#include "BrowserMessageBuilder.h"
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
#include "BrowserPasskeys.h"
|
#include "BrowserPasskeys.h"
|
||||||
#include "PasskeyUtils.h"
|
|
||||||
#endif
|
|
||||||
#include "BrowserSettings.h"
|
#include "BrowserSettings.h"
|
||||||
|
#include "PasskeyUtils.h"
|
||||||
#include "core/Global.h"
|
#include "core/Global.h"
|
||||||
#include "core/Tools.h"
|
#include "core/Tools.h"
|
||||||
|
|
||||||
@ -110,12 +108,10 @@ QJsonObject BrowserAction::handleAction(QLocalSocket* socket, const QJsonObject&
|
|||||||
return handleGlobalAutoType(json, action);
|
return handleGlobalAutoType(json, action);
|
||||||
} else if (action.compare("get-database-entries", Qt::CaseSensitive) == 0) {
|
} else if (action.compare("get-database-entries", Qt::CaseSensitive) == 0) {
|
||||||
return handleGetDatabaseEntries(json, action);
|
return handleGetDatabaseEntries(json, action);
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
} else if (action.compare(BROWSER_REQUEST_PASSKEYS_GET) == 0) {
|
} else if (action.compare(BROWSER_REQUEST_PASSKEYS_GET) == 0) {
|
||||||
return handlePasskeysGet(json, action);
|
return handlePasskeysGet(json, action);
|
||||||
} else if (action.compare(BROWSER_REQUEST_PASSKEYS_REGISTER) == 0) {
|
} else if (action.compare(BROWSER_REQUEST_PASSKEYS_REGISTER) == 0) {
|
||||||
return handlePasskeysRegister(json, action);
|
return handlePasskeysRegister(json, action);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Action was not recognized
|
// Action was not recognized
|
||||||
@ -519,7 +515,6 @@ QJsonObject BrowserAction::handleGlobalAutoType(const QJsonObject& json, const Q
|
|||||||
return buildResponse(action, browserRequest.incrementedNonce);
|
return buildResponse(action, browserRequest.incrementedNonce);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
QJsonObject BrowserAction::handlePasskeysGet(const QJsonObject& json, const QString& action)
|
QJsonObject BrowserAction::handlePasskeysGet(const QJsonObject& json, const QString& action)
|
||||||
{
|
{
|
||||||
if (!m_associated) {
|
if (!m_associated) {
|
||||||
@ -586,7 +581,6 @@ QJsonObject BrowserAction::handlePasskeysRegister(const QJsonObject& json, const
|
|||||||
const Parameters params{{"response", response}};
|
const Parameters params{{"response", response}};
|
||||||
return buildResponse(action, browserRequest.incrementedNonce, params);
|
return buildResponse(action, browserRequest.incrementedNonce, params);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
QJsonObject BrowserAction::decryptMessage(const QString& message, const QString& nonce)
|
QJsonObject BrowserAction::decryptMessage(const QString& message, const QString& nonce)
|
||||||
{
|
{
|
||||||
|
@ -84,19 +84,15 @@ private:
|
|||||||
QJsonObject handleGetTotp(const QJsonObject& json, const QString& action);
|
QJsonObject handleGetTotp(const QJsonObject& json, const QString& action);
|
||||||
QJsonObject handleDeleteEntry(const QJsonObject& json, const QString& action);
|
QJsonObject handleDeleteEntry(const QJsonObject& json, const QString& action);
|
||||||
QJsonObject handleGlobalAutoType(const QJsonObject& json, const QString& action);
|
QJsonObject handleGlobalAutoType(const QJsonObject& json, const QString& action);
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
QJsonObject handlePasskeysGet(const QJsonObject& json, const QString& action);
|
QJsonObject handlePasskeysGet(const QJsonObject& json, const QString& action);
|
||||||
QJsonObject handlePasskeysRegister(const QJsonObject& json, const QString& action);
|
QJsonObject handlePasskeysRegister(const QJsonObject& json, const QString& action);
|
||||||
#endif
|
|
||||||
|
|
||||||
private:
|
|
||||||
QJsonObject buildResponse(const QString& action, const QString& nonce, const Parameters& params = {});
|
QJsonObject buildResponse(const QString& action, const QString& nonce, const Parameters& params = {});
|
||||||
QJsonObject getErrorReply(const QString& action, const int errorCode) const;
|
QJsonObject getErrorReply(const QString& action, const int errorCode) const;
|
||||||
QJsonObject decryptMessage(const QString& message, const QString& nonce);
|
QJsonObject decryptMessage(const QString& message, const QString& nonce);
|
||||||
BrowserRequest decodeRequest(const QJsonObject& json);
|
BrowserRequest decodeRequest(const QJsonObject& json);
|
||||||
StringPairList getConnectionKeys(const BrowserRequest& browserRequest);
|
StringPairList getConnectionKeys(const BrowserRequest& browserRequest);
|
||||||
|
|
||||||
private:
|
|
||||||
static const int MaxUrlLength;
|
static const int MaxUrlLength;
|
||||||
|
|
||||||
QString m_clientPublicKey;
|
QString m_clientPublicKey;
|
||||||
|
@ -273,7 +273,7 @@ BrowserPasskeys::buildCredentialPrivateKey(int alg, const QString& predefinedFir
|
|||||||
try {
|
try {
|
||||||
Botan::Ed25519_PrivateKey key(*randomGen()->getRng());
|
Botan::Ed25519_PrivateKey key(*randomGen()->getRng());
|
||||||
auto publicKey = key.get_public_key();
|
auto publicKey = key.get_public_key();
|
||||||
#ifdef WITH_XC_BOTAN3
|
#ifdef WITH_BOTAN3
|
||||||
auto privateKey = key.raw_private_key_bits();
|
auto privateKey = key.raw_private_key_bits();
|
||||||
#else
|
#else
|
||||||
auto privateKey = key.get_private_key();
|
auto privateKey = key.get_private_key();
|
||||||
@ -322,7 +322,7 @@ QByteArray BrowserPasskeys::buildSignature(const QByteArray& authenticatorData,
|
|||||||
std::vector<uint8_t> rawSignature;
|
std::vector<uint8_t> rawSignature;
|
||||||
if (algName == "ECDSA") {
|
if (algName == "ECDSA") {
|
||||||
Botan::ECDSA_PrivateKey privateKey(algId, privateKeyBytes);
|
Botan::ECDSA_PrivateKey privateKey(algId, privateKeyBytes);
|
||||||
#ifdef WITH_XC_BOTAN3
|
#ifdef WITH_BOTAN3
|
||||||
Botan::PK_Signer signer(
|
Botan::PK_Signer signer(
|
||||||
privateKey, *randomGen()->getRng(), "EMSA1(SHA-256)", Botan::Signature_Format::DerSequence);
|
privateKey, *randomGen()->getRng(), "EMSA1(SHA-256)", Botan::Signature_Format::DerSequence);
|
||||||
#else
|
#else
|
||||||
|
@ -23,20 +23,18 @@
|
|||||||
#include "BrowserEntrySaveDialog.h"
|
#include "BrowserEntrySaveDialog.h"
|
||||||
#include "BrowserHost.h"
|
#include "BrowserHost.h"
|
||||||
#include "BrowserMessageBuilder.h"
|
#include "BrowserMessageBuilder.h"
|
||||||
|
#include "BrowserPasskeys.h"
|
||||||
|
#include "BrowserPasskeysClient.h"
|
||||||
|
#include "BrowserPasskeysConfirmationDialog.h"
|
||||||
#include "BrowserSettings.h"
|
#include "BrowserSettings.h"
|
||||||
|
#include "PasskeyUtils.h"
|
||||||
#include "core/EntryAttributes.h"
|
#include "core/EntryAttributes.h"
|
||||||
#include "core/Tools.h"
|
#include "core/Tools.h"
|
||||||
#include "gui/MainWindow.h"
|
#include "gui/MainWindow.h"
|
||||||
#include "gui/MessageBox.h"
|
#include "gui/MessageBox.h"
|
||||||
#include "gui/UrlTools.h"
|
#include "gui/UrlTools.h"
|
||||||
#include "gui/osutils/OSUtils.h"
|
#include "gui/osutils/OSUtils.h"
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
#include "BrowserPasskeys.h"
|
|
||||||
#include "BrowserPasskeysClient.h"
|
|
||||||
#include "BrowserPasskeysConfirmationDialog.h"
|
|
||||||
#include "PasskeyUtils.h"
|
|
||||||
#include "gui/passkeys/PasskeyImporter.h"
|
#include "gui/passkeys/PasskeyImporter.h"
|
||||||
#endif
|
|
||||||
#ifdef Q_OS_MACOS
|
#ifdef Q_OS_MACOS
|
||||||
#include "gui/osutils/macutils/MacUtils.h"
|
#include "gui/osutils/macutils/MacUtils.h"
|
||||||
#endif
|
#endif
|
||||||
@ -56,11 +54,9 @@
|
|||||||
const QString BrowserService::KEEPASSXCBROWSER_NAME = QStringLiteral("KeePassXC-Browser Settings");
|
const QString BrowserService::KEEPASSXCBROWSER_NAME = QStringLiteral("KeePassXC-Browser Settings");
|
||||||
const QString BrowserService::KEEPASSXCBROWSER_OLD_NAME = QStringLiteral("keepassxc-browser Settings");
|
const QString BrowserService::KEEPASSXCBROWSER_OLD_NAME = QStringLiteral("keepassxc-browser Settings");
|
||||||
static const QString KEEPASSXCBROWSER_GROUP_NAME = QStringLiteral("KeePassXC-Browser Passwords");
|
static const QString KEEPASSXCBROWSER_GROUP_NAME = QStringLiteral("KeePassXC-Browser Passwords");
|
||||||
static int KEEPASSXCBROWSER_DEFAULT_ICON = 1;
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
static int KEEPASSXCBROWSER_PASSKEY_ICON = 13;
|
|
||||||
static const QString PASSKEYS_DEFAULT_GROUP_NAME = QStringLiteral("KeePassXC-Browser Passkeys");
|
static const QString PASSKEYS_DEFAULT_GROUP_NAME = QStringLiteral("KeePassXC-Browser Passkeys");
|
||||||
#endif
|
static int KEEPASSXCBROWSER_DEFAULT_ICON = 1;
|
||||||
|
static int KEEPASSXCBROWSER_PASSKEY_ICON = 13;
|
||||||
// These are for the settings and password conversion
|
// These are for the settings and password conversion
|
||||||
static const QString KEEPASSHTTP_NAME = QStringLiteral("KeePassHttp Settings");
|
static const QString KEEPASSHTTP_NAME = QStringLiteral("KeePassHttp Settings");
|
||||||
static const QString KEEPASSHTTP_GROUP_NAME = QStringLiteral("KeePassHttp Passwords");
|
static const QString KEEPASSHTTP_GROUP_NAME = QStringLiteral("KeePassHttp Passwords");
|
||||||
@ -632,7 +628,6 @@ QString BrowserService::getKey(const QString& id)
|
|||||||
return db->metadata()->customData()->value(CustomData::getKeyWithPrefix(CustomData::BrowserKeyPrefix, id));
|
return db->metadata()->customData()->value(CustomData::getKeyWithPrefix(CustomData::BrowserKeyPrefix, id));
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
// Passkey registration
|
// Passkey registration
|
||||||
QJsonObject BrowserService::showPasskeysRegisterPrompt(const QJsonObject& publicKeyOptions,
|
QJsonObject BrowserService::showPasskeysRegisterPrompt(const QJsonObject& publicKeyOptions,
|
||||||
const QString& origin,
|
const QString& origin,
|
||||||
@ -858,7 +853,6 @@ void BrowserService::addPasskeyToEntry(Entry* entry,
|
|||||||
|
|
||||||
entry->endUpdate();
|
entry->endUpdate();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
void BrowserService::addEntry(const EntryParameters& entryParameters,
|
void BrowserService::addEntry(const EntryParameters& entryParameters,
|
||||||
const QString& group,
|
const QString& group,
|
||||||
@ -1046,12 +1040,10 @@ QList<Entry*> BrowserService::searchEntries(const QSharedPointer<Database>& db,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
// With Passkeys, check for the Relying Party instead of URL
|
// With Passkeys, check for the Relying Party instead of URL
|
||||||
if (passkey && entry->attributes()->value(EntryAttributes::KPEX_PASSKEY_RELYING_PARTY) != siteUrl) {
|
if (passkey && entry->attributes()->value(EntryAttributes::KPEX_PASSKEY_RELYING_PARTY) != siteUrl) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
// Additional URL check may have already inserted the entry to the list
|
// Additional URL check may have already inserted the entry to the list
|
||||||
if (!entries.contains(entry)) {
|
if (!entries.contains(entry)) {
|
||||||
@ -1385,7 +1377,6 @@ bool BrowserService::shouldIncludeEntry(Entry* entry,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
// Returns all Passkey entries for the current Relying Party
|
// Returns all Passkey entries for the current Relying Party
|
||||||
QList<Entry*> BrowserService::getPasskeyEntries(const QString& rpId, const StringPairList& keyList)
|
QList<Entry*> BrowserService::getPasskeyEntries(const QString& rpId, const StringPairList& keyList)
|
||||||
{
|
{
|
||||||
@ -1460,7 +1451,6 @@ QJsonObject BrowserService::getPasskeyError(int errorCode) const
|
|||||||
{
|
{
|
||||||
return QJsonObject({{"errorCode", errorCode}});
|
return QJsonObject({{"errorCode", errorCode}});
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
bool BrowserService::handleURL(const QString& entryUrl,
|
bool BrowserService::handleURL(const QString& entryUrl,
|
||||||
const QString& siteUrl,
|
const QString& siteUrl,
|
||||||
|
@ -87,7 +87,7 @@ public:
|
|||||||
QSharedPointer<Database> getDatabase(const QUuid& rootGroupUuid = {});
|
QSharedPointer<Database> getDatabase(const QUuid& rootGroupUuid = {});
|
||||||
QSharedPointer<Database> selectedDatabase();
|
QSharedPointer<Database> selectedDatabase();
|
||||||
QList<QSharedPointer<Database>> getOpenDatabases();
|
QList<QSharedPointer<Database>> getOpenDatabases();
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
QJsonObject showPasskeysRegisterPrompt(const QJsonObject& publicKeyOptions,
|
QJsonObject showPasskeysRegisterPrompt(const QJsonObject& publicKeyOptions,
|
||||||
const QString& origin,
|
const QString& origin,
|
||||||
const QString& groupName,
|
const QString& groupName,
|
||||||
@ -111,7 +111,7 @@ public:
|
|||||||
const QString& credentialId,
|
const QString& credentialId,
|
||||||
const QString& userHandle,
|
const QString& userHandle,
|
||||||
const QString& privateKey);
|
const QString& privateKey);
|
||||||
#endif
|
|
||||||
void addEntry(const EntryParameters& entryParameters,
|
void addEntry(const EntryParameters& entryParameters,
|
||||||
const QString& group,
|
const QString& group,
|
||||||
const QString& groupUuid,
|
const QString& groupUuid,
|
||||||
@ -185,7 +185,7 @@ private:
|
|||||||
bool removeFirstDomain(QString& hostname);
|
bool removeFirstDomain(QString& hostname);
|
||||||
bool
|
bool
|
||||||
shouldIncludeEntry(Entry* entry, const QString& url, const QString& submitUrl, const bool omitWwwSubdomain = false);
|
shouldIncludeEntry(Entry* entry, const QString& url, const QString& submitUrl, const bool omitWwwSubdomain = false);
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
QList<Entry*> getPasskeyEntries(const QString& rpId, const StringPairList& keyList);
|
QList<Entry*> getPasskeyEntries(const QString& rpId, const StringPairList& keyList);
|
||||||
QList<Entry*>
|
QList<Entry*>
|
||||||
getPasskeyEntriesWithUserHandle(const QString& rpId, const QString& userId, const StringPairList& keyList);
|
getPasskeyEntriesWithUserHandle(const QString& rpId, const QString& userId, const StringPairList& keyList);
|
||||||
@ -195,7 +195,7 @@ private:
|
|||||||
const QString& rpId,
|
const QString& rpId,
|
||||||
const StringPairList& keyList);
|
const StringPairList& keyList);
|
||||||
QJsonObject getPasskeyError(int errorCode) const;
|
QJsonObject getPasskeyError(int errorCode) const;
|
||||||
#endif
|
|
||||||
bool handleURL(const QString& entryUrl,
|
bool handleURL(const QString& entryUrl,
|
||||||
const QString& siteUrl,
|
const QString& siteUrl,
|
||||||
const QString& formUrl,
|
const QString& formUrl,
|
||||||
@ -220,9 +220,7 @@ private:
|
|||||||
Q_DISABLE_COPY(BrowserService);
|
Q_DISABLE_COPY(BrowserService);
|
||||||
|
|
||||||
friend class TestBrowser;
|
friend class TestBrowser;
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
friend class TestPasskeys;
|
friend class TestPasskeys;
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline BrowserService* browserService()
|
static inline BrowserService* browserService()
|
||||||
|
@ -13,32 +13,28 @@
|
|||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
if(WITH_XC_BROWSER)
|
if(KPXC_FEATURE_BROWSER)
|
||||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
set(browser_SOURCES
|
set(browser_SOURCES
|
||||||
BrowserAccessControlDialog.cpp
|
BrowserAccessControlDialog.cpp
|
||||||
BrowserAction.cpp
|
BrowserAction.cpp
|
||||||
|
BrowserCbor.cpp
|
||||||
BrowserEntryConfig.cpp
|
BrowserEntryConfig.cpp
|
||||||
BrowserEntrySaveDialog.cpp
|
BrowserEntrySaveDialog.cpp
|
||||||
BrowserHost.cpp
|
BrowserHost.cpp
|
||||||
BrowserMessageBuilder.cpp
|
BrowserMessageBuilder.cpp
|
||||||
|
BrowserPasskeys.cpp
|
||||||
|
BrowserPasskeysClient.cpp
|
||||||
|
BrowserPasskeysConfirmationDialog.cpp
|
||||||
BrowserSettingsPage.cpp
|
BrowserSettingsPage.cpp
|
||||||
BrowserSettingsWidget.cpp
|
BrowserSettingsWidget.cpp
|
||||||
BrowserService.cpp
|
BrowserService.cpp
|
||||||
BrowserSettings.cpp
|
BrowserSettings.cpp
|
||||||
BrowserShared.cpp
|
BrowserShared.cpp
|
||||||
CustomTableWidget.cpp
|
CustomTableWidget.cpp
|
||||||
NativeMessageInstaller.cpp)
|
NativeMessageInstaller.cpp
|
||||||
|
PasskeyUtils.cpp)
|
||||||
if(WITH_XC_BROWSER_PASSKEYS)
|
|
||||||
list(APPEND browser_SOURCES
|
|
||||||
BrowserCbor.cpp
|
|
||||||
BrowserPasskeys.cpp
|
|
||||||
BrowserPasskeysClient.cpp
|
|
||||||
BrowserPasskeysConfirmationDialog.cpp
|
|
||||||
PasskeyUtils.cpp)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_library(browser STATIC ${browser_SOURCES})
|
add_library(browser STATIC ${browser_SOURCES})
|
||||||
target_link_libraries(browser Qt5::Core Qt5::Concurrent Qt5::Widgets Qt5::Network ${BOTAN_LIBRARIES})
|
target_link_libraries(browser Qt5::Core Qt5::Concurrent Qt5::Widgets Qt5::Network ${BOTAN_LIBRARIES})
|
||||||
|
@ -27,9 +27,7 @@ DatabaseCommand::DatabaseCommand()
|
|||||||
positionalArguments.append({QString("database"), QObject::tr("Path of the database."), QString("")});
|
positionalArguments.append({QString("database"), QObject::tr("Path of the database."), QString("")});
|
||||||
options.append(Command::KeyFileOption);
|
options.append(Command::KeyFileOption);
|
||||||
options.append(Command::NoPasswordOption);
|
options.append(Command::NoPasswordOption);
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
options.append(Command::YubiKeyOption);
|
options.append(Command::YubiKeyOption);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int DatabaseCommand::execute(const QStringList& arguments)
|
int DatabaseCommand::execute(const QStringList& arguments)
|
||||||
@ -55,11 +53,7 @@ int DatabaseCommand::execute(const QStringList& arguments)
|
|||||||
db = Utils::unlockDatabase(args.at(0),
|
db = Utils::unlockDatabase(args.at(0),
|
||||||
!parser->isSet(Command::NoPasswordOption),
|
!parser->isSet(Command::NoPasswordOption),
|
||||||
parser->value(Command::KeyFileOption),
|
parser->value(Command::KeyFileOption),
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
parser->value(Command::YubiKeyOption),
|
parser->value(Command::YubiKeyOption),
|
||||||
#else
|
|
||||||
"",
|
|
||||||
#endif
|
|
||||||
parser->isSet(Command::QuietOption));
|
parser->isSet(Command::QuietOption));
|
||||||
if (!db) {
|
if (!db) {
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
|
@ -51,9 +51,8 @@ Merge::Merge()
|
|||||||
options.append(Merge::KeyFileFromOption);
|
options.append(Merge::KeyFileFromOption);
|
||||||
options.append(Merge::NoPasswordFromOption);
|
options.append(Merge::NoPasswordFromOption);
|
||||||
options.append(Merge::DryRunOption);
|
options.append(Merge::DryRunOption);
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
options.append(Merge::YubiKeyFromOption);
|
options.append(Merge::YubiKeyFromOption);
|
||||||
#endif
|
|
||||||
positionalArguments.append({QString("database2"), QObject::tr("Path of the database to merge from."), QString("")});
|
positionalArguments.append({QString("database2"), QObject::tr("Path of the database to merge from."), QString("")});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,10 +21,8 @@
|
|||||||
#include "core/Entry.h"
|
#include "core/Entry.h"
|
||||||
#include "core/EntryAttributes.h"
|
#include "core/EntryAttributes.h"
|
||||||
#include "core/Global.h"
|
#include "core/Global.h"
|
||||||
#include "keys/FileKey.h"
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#include "keys/ChallengeResponseKey.h"
|
#include "keys/ChallengeResponseKey.h"
|
||||||
#endif
|
#include "keys/FileKey.h"
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
@ -170,7 +168,6 @@ namespace Utils
|
|||||||
compositeKey->addKey(fileKey);
|
compositeKey->addKey(fileKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
if (!yubiKeySlot.isEmpty()) {
|
if (!yubiKeySlot.isEmpty()) {
|
||||||
unsigned int serial = 0;
|
unsigned int serial = 0;
|
||||||
int slot;
|
int slot;
|
||||||
@ -201,18 +198,14 @@ namespace Utils
|
|||||||
|
|
||||||
YubiKey::instance()->findValidKeys();
|
YubiKey::instance()->findValidKeys();
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
Q_UNUSED(yubiKeySlot);
|
|
||||||
#endif // WITH_XC_YUBIKEY
|
|
||||||
|
|
||||||
auto db = QSharedPointer<Database>::create();
|
auto db = QSharedPointer<Database>::create();
|
||||||
QString error;
|
QString error;
|
||||||
if (db->open(databaseFilename, compositeKey, &error)) {
|
if (!db->open(databaseFilename, compositeKey, &error)) {
|
||||||
return db;
|
|
||||||
} else {
|
|
||||||
err << error << Qt::endl;
|
err << error << Qt::endl;
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
return db;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -12,34 +12,36 @@
|
|||||||
#define KEEPASSX_PLUGIN_DIR "@PLUGIN_INSTALL_DIR@"
|
#define KEEPASSX_PLUGIN_DIR "@PLUGIN_INSTALL_DIR@"
|
||||||
#define KEEPASSX_DATA_DIR "@DATA_INSTALL_DIR@"
|
#define KEEPASSX_DATA_DIR "@DATA_INSTALL_DIR@"
|
||||||
|
|
||||||
#cmakedefine WITH_XC_AUTOTYPE
|
/* Build Scope */
|
||||||
#cmakedefine WITH_XC_NETWORKING
|
#cmakedefine WITH_X11
|
||||||
#cmakedefine WITH_XC_BROWSER
|
#cmakedefine WITH_BOTAN3
|
||||||
#cmakedefine WITH_XC_BROWSER_PASSKEYS
|
|
||||||
#cmakedefine WITH_XC_YUBIKEY
|
|
||||||
#cmakedefine WITH_XC_SSHAGENT
|
|
||||||
#cmakedefine WITH_XC_KEESHARE
|
|
||||||
#cmakedefine WITH_XC_UPDATECHECK
|
|
||||||
#cmakedefine WITH_XC_FDOSECRETS
|
|
||||||
#cmakedefine WITH_XC_DOCS
|
|
||||||
#cmakedefine WITH_XC_X11
|
|
||||||
#cmakedefine WITH_XC_BOTAN3
|
|
||||||
|
|
||||||
|
/* Advanced Features */
|
||||||
|
#cmakedefine KPXC_FEATURE_BROWSER
|
||||||
|
#cmakedefine KPXC_FEATURE_SSHAGENT
|
||||||
|
#cmakedefine KPXC_FEATURE_FDOSECRETS
|
||||||
|
|
||||||
|
/* Minor Features */
|
||||||
|
#cmakedefine KPXC_FEATURE_NETWORK
|
||||||
|
#cmakedefine KPXC_FEATURE_UPDATES
|
||||||
|
#cmakedefine KPXC_FEATURE_DOCS
|
||||||
|
|
||||||
|
/* Distribution */
|
||||||
#cmakedefine KEEPASSXC_BUILD_TYPE "@KEEPASSXC_BUILD_TYPE@"
|
#cmakedefine KEEPASSXC_BUILD_TYPE "@KEEPASSXC_BUILD_TYPE@"
|
||||||
#cmakedefine KEEPASSXC_BUILD_TYPE_RELEASE
|
#cmakedefine KEEPASSXC_BUILD_TYPE_RELEASE
|
||||||
#cmakedefine KEEPASSXC_BUILD_TYPE_PRE_RELEASE
|
|
||||||
#cmakedefine KEEPASSXC_BUILD_TYPE_SNAPSHOT
|
#cmakedefine KEEPASSXC_BUILD_TYPE_SNAPSHOT
|
||||||
|
|
||||||
#cmakedefine KEEPASSXC_DIST
|
|
||||||
#cmakedefine KEEPASSXC_DIST_TYPE "@KEEPASSXC_DIST_TYPE@"
|
#cmakedefine KEEPASSXC_DIST_TYPE "@KEEPASSXC_DIST_TYPE@"
|
||||||
#cmakedefine KEEPASSXC_DIST_SNAP
|
#cmakedefine KEEPASSXC_DIST_SNAP
|
||||||
#cmakedefine KEEPASSXC_DIST_APPIMAGE
|
#cmakedefine KEEPASSXC_DIST_APPIMAGE
|
||||||
#cmakedefine KEEPASSXC_DIST_FLATPAK
|
#cmakedefine KEEPASSXC_DIST_FLATPAK
|
||||||
|
|
||||||
|
/* Security Test Results */
|
||||||
#cmakedefine HAVE_PR_SET_DUMPABLE 1
|
#cmakedefine HAVE_PR_SET_DUMPABLE 1
|
||||||
#cmakedefine HAVE_RLIMIT_CORE 1
|
#cmakedefine HAVE_RLIMIT_CORE 1
|
||||||
#cmakedefine HAVE_PT_DENY_ATTACH 1
|
#cmakedefine HAVE_PT_DENY_ATTACH 1
|
||||||
|
|
||||||
|
/* macOS Feature Support */
|
||||||
#cmakedefine01 XC_APPLE_COMPILER_SUPPORT_BIOMETRY()
|
#cmakedefine01 XC_APPLE_COMPILER_SUPPORT_BIOMETRY()
|
||||||
#cmakedefine01 XC_APPLE_COMPILER_SUPPORT_TOUCH_ID()
|
#cmakedefine01 XC_APPLE_COMPILER_SUPPORT_TOUCH_ID()
|
||||||
#cmakedefine01 XC_APPLE_COMPILER_SUPPORT_WATCH()
|
#cmakedefine01 XC_APPLE_COMPILER_SUPPORT_WATCH()
|
||||||
|
@ -208,7 +208,7 @@ namespace Bootstrap
|
|||||||
goto Cleanup;
|
goto Cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
// OpenSSH for Windows ssh-agent service is running as LocalSystem
|
// OpenSSH for Windows ssh-agent service is running as LocalSystem
|
||||||
if (!AddAccessAllowedAce(pACL,
|
if (!AddAccessAllowedAce(pACL,
|
||||||
ACL_REVISION,
|
ACL_REVISION,
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
#include <QTextStream>
|
#include <QTextStream>
|
||||||
|
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
#if defined(KEEPASSX_BUILDING_CORE)
|
#if defined(KPXC_BUILDING_CORE)
|
||||||
#define KEEPASSXC_EXPORT Q_DECL_IMPORT
|
#define KEEPASSXC_EXPORT Q_DECL_IMPORT
|
||||||
#else
|
#else
|
||||||
#define KEEPASSXC_EXPORT Q_DECL_EXPORT
|
#define KEEPASSXC_EXPORT Q_DECL_EXPORT
|
||||||
|
@ -17,14 +17,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "Group.h"
|
#include "Group.h"
|
||||||
#include "config-keepassx.h"
|
|
||||||
|
|
||||||
#include "core/Config.h"
|
#include "core/Config.h"
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
#include "keeshare/KeeShare.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "core/Global.h"
|
#include "core/Global.h"
|
||||||
#include "core/Metadata.h"
|
#include "core/Metadata.h"
|
||||||
#include "core/Tools.h"
|
#include "core/Tools.h"
|
||||||
|
@ -51,9 +51,7 @@ namespace Tools
|
|||||||
{
|
{
|
||||||
QString debugInfo = "KeePassXC - ";
|
QString debugInfo = "KeePassXC - ";
|
||||||
debugInfo.append(QObject::tr("Version %1").arg(KEEPASSXC_VERSION).append("\n"));
|
debugInfo.append(QObject::tr("Version %1").arg(KEEPASSXC_VERSION).append("\n"));
|
||||||
#ifndef KEEPASSXC_BUILD_TYPE_RELEASE
|
|
||||||
debugInfo.append(QObject::tr("Build Type: %1").arg(KEEPASSXC_BUILD_TYPE).append("\n"));
|
debugInfo.append(QObject::tr("Build Type: %1").arg(KEEPASSXC_BUILD_TYPE).append("\n"));
|
||||||
#endif
|
|
||||||
|
|
||||||
QString commitHash;
|
QString commitHash;
|
||||||
if (!QString(GIT_HEAD).isEmpty()) {
|
if (!QString(GIT_HEAD).isEmpty()) {
|
||||||
@ -63,9 +61,7 @@ namespace Tools
|
|||||||
debugInfo.append(QObject::tr("Revision: %1").arg(commitHash.left(7)).append("\n"));
|
debugInfo.append(QObject::tr("Revision: %1").arg(commitHash.left(7)).append("\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef KEEPASSXC_DIST
|
|
||||||
debugInfo.append(QObject::tr("Distribution: %1").arg(KEEPASSXC_DIST_TYPE).append("\n"));
|
debugInfo.append(QObject::tr("Distribution: %1").arg(KEEPASSXC_DIST_TYPE).append("\n"));
|
||||||
#endif
|
|
||||||
|
|
||||||
// Qt related debugging information.
|
// Qt related debugging information.
|
||||||
debugInfo.append("\n");
|
debugInfo.append("\n");
|
||||||
@ -86,35 +82,23 @@ namespace Tools
|
|||||||
debugInfo.append("\n\n");
|
debugInfo.append("\n\n");
|
||||||
|
|
||||||
QString extensions;
|
QString extensions;
|
||||||
#ifdef WITH_XC_AUTOTYPE
|
|
||||||
extensions += "\n- " + QObject::tr("Auto-Type");
|
extensions += "\n- " + QObject::tr("Auto-Type");
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER
|
|
||||||
extensions += "\n- " + QObject::tr("Browser Integration");
|
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
extensions += "\n- " + QObject::tr("Passkeys");
|
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
|
||||||
extensions += "\n- " + QObject::tr("SSH Agent");
|
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
extensions += "\n- " + QObject::tr("KeeShare");
|
extensions += "\n- " + QObject::tr("KeeShare");
|
||||||
#endif
|
extensions += "\n- " + QObject::tr("Hardware Keys");
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
extensions += "\n- " + QObject::tr("YubiKey");
|
|
||||||
#endif
|
|
||||||
#if defined(Q_OS_MACOS) || defined(Q_CC_MSVC)
|
#if defined(Q_OS_MACOS) || defined(Q_CC_MSVC)
|
||||||
extensions += "\n- " + QObject::tr("Quick Unlock");
|
extensions += "\n- " + QObject::tr("Quick Unlock");
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
|
extensions += "\n- " + QObject::tr("Browser Integration");
|
||||||
|
extensions += "\n- " + QObject::tr("Passkeys");
|
||||||
|
#endif
|
||||||
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
|
extensions += "\n- " + QObject::tr("SSH Agent");
|
||||||
|
#endif
|
||||||
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
extensions += "\n- " + QObject::tr("Secret Service Integration");
|
extensions += "\n- " + QObject::tr("Secret Service Integration");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (extensions.isEmpty()) {
|
|
||||||
extensions = " " + QObject::tr("None");
|
|
||||||
}
|
|
||||||
|
|
||||||
debugInfo.append(QObject::tr("Enabled extensions:").append(extensions).append("\n"));
|
debugInfo.append(QObject::tr("Enabled extensions:").append(extensions).append("\n"));
|
||||||
return debugInfo;
|
return debugInfo;
|
||||||
}
|
}
|
||||||
|
@ -239,7 +239,7 @@ namespace Crypto
|
|||||||
{
|
{
|
||||||
bool init()
|
bool init()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_BOTAN3
|
#ifdef WITH_BOTAN3
|
||||||
unsigned int version_major = 3, min_version_minor = 0;
|
unsigned int version_major = 3, min_version_minor = 0;
|
||||||
QString versionString = "3.x";
|
QString versionString = "3.x";
|
||||||
#else
|
#else
|
||||||
|
@ -34,7 +34,7 @@ bool SymmetricCipher::init(Mode mode, Direction direction, const QByteArray& key
|
|||||||
try {
|
try {
|
||||||
auto botanMode = modeToString(mode);
|
auto botanMode = modeToString(mode);
|
||||||
auto botanDirection =
|
auto botanDirection =
|
||||||
#ifdef WITH_XC_BOTAN3
|
#ifdef WITH_BOTAN3
|
||||||
(direction == SymmetricCipher::Encrypt ? Botan::Cipher_Dir::Encryption : Botan::Cipher_Dir::Decryption);
|
(direction == SymmetricCipher::Encrypt ? Botan::Cipher_Dir::Encryption : Botan::Cipher_Dir::Decryption);
|
||||||
#else
|
#else
|
||||||
(direction == SymmetricCipher::Encrypt ? Botan::Cipher_Dir::ENCRYPTION : Botan::Cipher_Dir::DECRYPTION);
|
(direction == SymmetricCipher::Encrypt ? Botan::Cipher_Dir::ENCRYPTION : Botan::Cipher_Dir::DECRYPTION);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
if(WITH_XC_FDOSECRETS)
|
if(KPXC_FEATURE_FDOSECRETS)
|
||||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
add_library(fdosecrets STATIC
|
add_library(fdosecrets STATIC
|
||||||
|
@ -225,7 +225,6 @@ KdbxXmlWriter::BinaryIdxMap Kdbx4Writer::writeAttachments(QIODevice* device, Dat
|
|||||||
data.append(entry->attachments()->value(key));
|
data.append(entry->attachments()->value(key));
|
||||||
|
|
||||||
CryptoHash hash(CryptoHash::Sha256);
|
CryptoHash hash(CryptoHash::Sha256);
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
// Namespace KeeShare attachments so they don't get deduplicated together with attachments
|
// Namespace KeeShare attachments so they don't get deduplicated together with attachments
|
||||||
// from other databases. Prevents potential filesize side channels.
|
// from other databases. Prevents potential filesize side channels.
|
||||||
auto group = entry->group();
|
auto group = entry->group();
|
||||||
@ -237,7 +236,6 @@ KdbxXmlWriter::BinaryIdxMap Kdbx4Writer::writeAttachments(QIODevice* device, Dat
|
|||||||
} else {
|
} else {
|
||||||
hash.addData(db->uuid().toByteArray());
|
hash.addData(db->uuid().toByteArray());
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
hash.addData(data);
|
hash.addData(data);
|
||||||
|
|
||||||
// Deduplicate attachments with the same hash
|
// Deduplicate attachments with the same hash
|
||||||
|
@ -109,7 +109,6 @@ void KdbxXmlWriter::fillBinaryIdxMap()
|
|||||||
for (const QString& key : attachmentKeys) {
|
for (const QString& key : attachmentKeys) {
|
||||||
QByteArray data = entry->attachments()->value(key);
|
QByteArray data = entry->attachments()->value(key);
|
||||||
CryptoHash hash(CryptoHash::Sha256);
|
CryptoHash hash(CryptoHash::Sha256);
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
// Namespace KeeShare attachments so they don't get deduplicated together with attachments
|
// Namespace KeeShare attachments so they don't get deduplicated together with attachments
|
||||||
// from other databases. Prevents potential filesize side channels.
|
// from other databases. Prevents potential filesize side channels.
|
||||||
auto group = entry->group();
|
auto group = entry->group();
|
||||||
@ -121,7 +120,6 @@ void KdbxXmlWriter::fillBinaryIdxMap()
|
|||||||
} else {
|
} else {
|
||||||
hash.addData(m_db->uuid().toByteArray());
|
hash.addData(m_db->uuid().toByteArray());
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
hash.addData(data);
|
hash.addData(data);
|
||||||
|
|
||||||
const auto hashResult = hash.result();
|
const auto hashResult = hash.result();
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
|
|
||||||
#include "FileDialog.h"
|
#include "FileDialog.h"
|
||||||
#include "MessageBox.h"
|
#include "MessageBox.h"
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#include "browser/BrowserSettingsPage.h"
|
#include "browser/BrowserSettingsPage.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -100,7 +100,7 @@ ApplicationSettingsWidget::ApplicationSettingsWidget(QWidget* parent)
|
|||||||
m_generalUi->setupUi(m_generalWidget);
|
m_generalUi->setupUi(m_generalWidget);
|
||||||
addPage(tr("General"), icons()->icon("preferences-other"), m_generalWidget);
|
addPage(tr("General"), icons()->icon("preferences-other"), m_generalWidget);
|
||||||
addPage(tr("Security"), icons()->icon("security-high"), m_secWidget);
|
addPage(tr("Security"), icons()->icon("security-high"), m_secWidget);
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
addSettingsPage(new BrowserSettingsPage());
|
addSettingsPage(new BrowserSettingsPage());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -171,7 +171,7 @@ ApplicationSettingsWidget::ApplicationSettingsWidget(QWidget* parent)
|
|||||||
m_generalUi->languageComboBox->installEventFilter(mouseWheelFilter);
|
m_generalUi->languageComboBox->installEventFilter(mouseWheelFilter);
|
||||||
m_generalUi->trayIconAppearance->installEventFilter(mouseWheelFilter);
|
m_generalUi->trayIconAppearance->installEventFilter(mouseWheelFilter);
|
||||||
|
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef KPXC_FEATURE_UPDATES
|
||||||
connect(m_generalUi->checkForUpdatesOnStartupCheckBox, SIGNAL(toggled(bool)), SLOT(checkUpdatesToggled(bool)));
|
connect(m_generalUi->checkForUpdatesOnStartupCheckBox, SIGNAL(toggled(bool)), SLOT(checkUpdatesToggled(bool)));
|
||||||
#else
|
#else
|
||||||
m_generalUi->checkForUpdatesOnStartupCheckBox->setVisible(false);
|
m_generalUi->checkForUpdatesOnStartupCheckBox->setVisible(false);
|
||||||
@ -179,7 +179,7 @@ ApplicationSettingsWidget::ApplicationSettingsWidget(QWidget* parent)
|
|||||||
m_generalUi->checkUpdatesSpacer->changeSize(0, 0, QSizePolicy::Fixed, QSizePolicy::Fixed);
|
m_generalUi->checkUpdatesSpacer->changeSize(0, 0, QSizePolicy::Fixed, QSizePolicy::Fixed);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef WITH_XC_NETWORKING
|
#ifndef KPXC_FEATURE_NETWORK
|
||||||
m_secUi->privacy->setVisible(false);
|
m_secUi->privacy->setVisible(false);
|
||||||
m_generalUi->faviconTimeoutLabel->setVisible(false);
|
m_generalUi->faviconTimeoutLabel->setVisible(false);
|
||||||
m_generalUi->faviconTimeoutSpinBox->setVisible(false);
|
m_generalUi->faviconTimeoutSpinBox->setVisible(false);
|
||||||
|
@ -25,9 +25,7 @@
|
|||||||
#include "gui/MessageBox.h"
|
#include "gui/MessageBox.h"
|
||||||
#include "keys/ChallengeResponseKey.h"
|
#include "keys/ChallengeResponseKey.h"
|
||||||
#include "keys/FileKey.h"
|
#include "keys/FileKey.h"
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#include "keys/drivers/YubiKeyInterfaceUSB.h"
|
#include "keys/drivers/YubiKeyInterfaceUSB.h"
|
||||||
#endif
|
|
||||||
#include "quickunlock/QuickUnlockInterface.h"
|
#include "quickunlock/QuickUnlockInterface.h"
|
||||||
|
|
||||||
#include <QCheckBox>
|
#include <QCheckBox>
|
||||||
@ -52,9 +50,7 @@ DatabaseOpenWidget::DatabaseOpenWidget(QWidget* parent)
|
|||||||
: DialogyWidget(parent)
|
: DialogyWidget(parent)
|
||||||
, m_ui(new Ui::DatabaseOpenWidget())
|
, m_ui(new Ui::DatabaseOpenWidget())
|
||||||
, m_db(nullptr)
|
, m_db(nullptr)
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
, m_deviceListener(new DeviceListener(this))
|
, m_deviceListener(new DeviceListener(this))
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
m_ui->setupUi(this);
|
m_ui->setupUi(this);
|
||||||
|
|
||||||
@ -101,7 +97,6 @@ DatabaseOpenWidget::DatabaseOpenWidget(QWidget* parent)
|
|||||||
sp.setRetainSizeWhenHidden(true);
|
sp.setRetainSizeWhenHidden(true);
|
||||||
m_ui->hardwareKeyProgress->setSizePolicy(sp);
|
m_ui->hardwareKeyProgress->setSizePolicy(sp);
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
connect(m_deviceListener, &DeviceListener::devicePlugged, this, [this] { pollHardwareKey(false, 500); });
|
connect(m_deviceListener, &DeviceListener::devicePlugged, this, [this] { pollHardwareKey(false, 500); });
|
||||||
connect(YubiKey::instance(), SIGNAL(detectComplete(bool)), SLOT(hardwareKeyResponse(bool)), Qt::QueuedConnection);
|
connect(YubiKey::instance(), SIGNAL(detectComplete(bool)), SLOT(hardwareKeyResponse(bool)), Qt::QueuedConnection);
|
||||||
|
|
||||||
@ -122,10 +117,6 @@ DatabaseOpenWidget::DatabaseOpenWidget(QWidget* parent)
|
|||||||
connect(&m_hideNoHardwareKeysFoundTimer, &QTimer::timeout, this, [this] {
|
connect(&m_hideNoHardwareKeysFoundTimer, &QTimer::timeout, this, [this] {
|
||||||
m_ui->noHardwareKeysFoundLabel->setVisible(false);
|
m_ui->noHardwareKeysFoundLabel->setVisible(false);
|
||||||
});
|
});
|
||||||
#else
|
|
||||||
m_ui->noHardwareKeysFoundLabel->setVisible(false);
|
|
||||||
m_ui->refreshHardwareKeys->setVisible(false);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// QuickUnlock actions
|
// QuickUnlock actions
|
||||||
connect(m_ui->quickUnlockButton, &QPushButton::pressed, this, [this] { openDatabase(); });
|
connect(m_ui->quickUnlockButton, &QPushButton::pressed, this, [this] { openDatabase(); });
|
||||||
@ -172,7 +163,6 @@ bool DatabaseOpenWidget::event(QEvent* event)
|
|||||||
toggleQuickUnlockScreen();
|
toggleQuickUnlockScreen();
|
||||||
|
|
||||||
if (type == QEvent::Show) {
|
if (type == QEvent::Show) {
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
m_deviceListener->registerHotplugCallback(true,
|
m_deviceListener->registerHotplugCallback(true,
|
||||||
true,
|
true,
|
||||||
@ -187,7 +177,6 @@ bool DatabaseOpenWidget::event(QEvent* event)
|
|||||||
#else
|
#else
|
||||||
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::YUBICO_USB_VID);
|
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::YUBICO_USB_VID);
|
||||||
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::ONLYKEY_USB_VID);
|
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::ONLYKEY_USB_VID);
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -203,11 +192,9 @@ bool DatabaseOpenWidget::event(QEvent* event)
|
|||||||
m_hideTimer.start();
|
m_hideTimer.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
if (type == QEvent::Hide) {
|
if (type == QEvent::Hide) {
|
||||||
m_deviceListener->deregisterAllHotplugCallbacks();
|
m_deviceListener->deregisterAllHotplugCallbacks();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = true;
|
ret = true;
|
||||||
}
|
}
|
||||||
@ -267,10 +254,8 @@ void DatabaseOpenWidget::load(const QString& filename)
|
|||||||
|
|
||||||
toggleQuickUnlockScreen();
|
toggleQuickUnlockScreen();
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
// Do initial auto-poll
|
// Do initial auto-poll
|
||||||
pollHardwareKey();
|
pollHardwareKey();
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseOpenWidget::clearForms()
|
void DatabaseOpenWidget::clearForms()
|
||||||
@ -461,7 +446,6 @@ QSharedPointer<CompositeKey> DatabaseOpenWidget::buildDatabaseKey()
|
|||||||
config()->set(Config::LastKeyFiles, lastKeyFiles);
|
config()->set(Config::LastKeyFiles, lastKeyFiles);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
auto lastChallengeResponse = config()->get(Config::LastChallengeResponse).toHash();
|
auto lastChallengeResponse = config()->get(Config::LastChallengeResponse).toHash();
|
||||||
lastChallengeResponse.remove(m_filename);
|
lastChallengeResponse.remove(m_filename);
|
||||||
|
|
||||||
@ -478,7 +462,6 @@ QSharedPointer<CompositeKey> DatabaseOpenWidget::buildDatabaseKey()
|
|||||||
if (config()->get(Config::RememberLastKeyFiles).toBool()) {
|
if (config()->get(Config::RememberLastKeyFiles).toBool()) {
|
||||||
config()->set(Config::LastChallengeResponse, lastChallengeResponse);
|
config()->set(Config::LastChallengeResponse, lastChallengeResponse);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
return databaseKey;
|
return databaseKey;
|
||||||
}
|
}
|
||||||
|
@ -23,11 +23,8 @@
|
|||||||
#include <QScopedPointer>
|
#include <QScopedPointer>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
|
|
||||||
#include "config-keepassx.h"
|
|
||||||
#include "gui/DialogyWidget.h"
|
#include "gui/DialogyWidget.h"
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#include "osutils/DeviceListener.h"
|
#include "osutils/DeviceListener.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
class CompositeKey;
|
class CompositeKey;
|
||||||
class Database;
|
class Database;
|
||||||
@ -83,9 +80,7 @@ private slots:
|
|||||||
void hardwareKeyResponse(bool found);
|
void hardwareKeyResponse(bool found);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
QPointer<DeviceListener> m_deviceListener;
|
QPointer<DeviceListener> m_deviceListener;
|
||||||
#endif
|
|
||||||
bool m_pollingHardwareKey = false;
|
bool m_pollingHardwareKey = false;
|
||||||
bool m_manualHardwareKeyRefresh = false;
|
bool m_manualHardwareKeyRefresh = false;
|
||||||
bool m_blockQuickUnlock = false;
|
bool m_blockQuickUnlock = false;
|
||||||
|
@ -572,7 +572,6 @@ void DatabaseTabWidget::showDatabaseSecurity()
|
|||||||
currentDatabaseWidget()->switchToDatabaseSecurity();
|
currentDatabaseWidget()->switchToDatabaseSecurity();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
void DatabaseTabWidget::showPasskeys()
|
void DatabaseTabWidget::showPasskeys()
|
||||||
{
|
{
|
||||||
currentDatabaseWidget()->switchToPasskeys();
|
currentDatabaseWidget()->switchToPasskeys();
|
||||||
@ -592,7 +591,6 @@ void DatabaseTabWidget::removePasskeyFromEntry()
|
|||||||
{
|
{
|
||||||
currentDatabaseWidget()->removePasskeyFromEntry();
|
currentDatabaseWidget()->removePasskeyFromEntry();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
bool DatabaseTabWidget::isModified(int index) const
|
bool DatabaseTabWidget::isModified(int index) const
|
||||||
{
|
{
|
||||||
|
@ -86,12 +86,10 @@ public slots:
|
|||||||
void showDatabaseReports(bool state);
|
void showDatabaseReports(bool state);
|
||||||
void showDatabaseSettings(bool state);
|
void showDatabaseSettings(bool state);
|
||||||
void showDatabaseSecurity();
|
void showDatabaseSecurity();
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
void showPasskeys();
|
void showPasskeys();
|
||||||
void importPasskey();
|
void importPasskey();
|
||||||
void importPasskeyToEntry();
|
void importPasskeyToEntry();
|
||||||
void removePasskeyFromEntry();
|
void removePasskeyFromEntry();
|
||||||
#endif
|
|
||||||
void performGlobalAutoType(const QString& search);
|
void performGlobalAutoType(const QString& search);
|
||||||
void performBrowserUnlock();
|
void performBrowserUnlock();
|
||||||
|
|
||||||
|
@ -59,15 +59,15 @@
|
|||||||
#include "remote/RemoteHandler.h"
|
#include "remote/RemoteHandler.h"
|
||||||
#include "remote/RemoteSettings.h"
|
#include "remote/RemoteSettings.h"
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
#include "gui/IconDownloaderDialog.h"
|
#include "gui/IconDownloaderDialog.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
#include "sshagent/SSHAgent.h"
|
#include "sshagent/SSHAgent.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#include "gui/passkeys/PasskeyImporter.h"
|
#include "gui/passkeys/PasskeyImporter.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -135,9 +135,7 @@ DatabaseWidget::DatabaseWidget(QSharedPointer<Database> db, QWidget* parent)
|
|||||||
auto rightHandSideVBox = new QVBoxLayout();
|
auto rightHandSideVBox = new QVBoxLayout();
|
||||||
rightHandSideVBox->setMargin(0);
|
rightHandSideVBox->setMargin(0);
|
||||||
rightHandSideVBox->addWidget(m_searchingLabel);
|
rightHandSideVBox->addWidget(m_searchingLabel);
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
rightHandSideVBox->addWidget(m_shareLabel);
|
rightHandSideVBox->addWidget(m_shareLabel);
|
||||||
#endif
|
|
||||||
rightHandSideVBox->addWidget(m_previewSplitter);
|
rightHandSideVBox->addWidget(m_previewSplitter);
|
||||||
rightHandSideWidget->setLayout(rightHandSideVBox);
|
rightHandSideWidget->setLayout(rightHandSideVBox);
|
||||||
m_entryView = new EntryView(rightHandSideWidget);
|
m_entryView = new EntryView(rightHandSideWidget);
|
||||||
@ -167,12 +165,10 @@ DatabaseWidget::DatabaseWidget(QSharedPointer<Database> db, QWidget* parent)
|
|||||||
m_searchingLabel->setAlignment(Qt::AlignCenter);
|
m_searchingLabel->setAlignment(Qt::AlignCenter);
|
||||||
m_searchingLabel->setVisible(false);
|
m_searchingLabel->setVisible(false);
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
m_shareLabel->setObjectName("KeeShareBanner");
|
m_shareLabel->setObjectName("KeeShareBanner");
|
||||||
m_shareLabel->setRawText(tr("Shared group…"));
|
m_shareLabel->setRawText(tr("Shared group…"));
|
||||||
m_shareLabel->setAlignment(Qt::AlignCenter);
|
m_shareLabel->setAlignment(Qt::AlignCenter);
|
||||||
m_shareLabel->setVisible(false);
|
m_shareLabel->setVisible(false);
|
||||||
#endif
|
|
||||||
|
|
||||||
m_previewView->setObjectName("previewWidget");
|
m_previewView->setObjectName("previewWidget");
|
||||||
m_previewView->hide();
|
m_previewView->hide();
|
||||||
@ -232,11 +228,9 @@ DatabaseWidget::DatabaseWidget(QSharedPointer<Database> db, QWidget* parent)
|
|||||||
|
|
||||||
m_searchLimitGroup = config()->get(Config::SearchLimitGroup).toBool();
|
m_searchLimitGroup = config()->get(Config::SearchLimitGroup).toBool();
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
// We need to reregister the database to allow exports
|
// We need to reregister the database to allow exports
|
||||||
// from a newly created database
|
// from a newly created database
|
||||||
KeeShare::instance()->connectDatabase(m_db, {});
|
KeeShare::instance()->connectDatabase(m_db, {});
|
||||||
#endif
|
|
||||||
|
|
||||||
if (m_db->isInitialized()) {
|
if (m_db->isInitialized()) {
|
||||||
switchToMainView();
|
switchToMainView();
|
||||||
@ -501,12 +495,7 @@ void DatabaseWidget::replaceDatabase(QSharedPointer<Database> db)
|
|||||||
|
|
||||||
emit databaseReplaced(oldDb, m_db);
|
emit databaseReplaced(oldDb, m_db);
|
||||||
|
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
KeeShare::instance()->connectDatabase(m_db, oldDb);
|
KeeShare::instance()->connectDatabase(m_db, oldDb);
|
||||||
#else
|
|
||||||
// Keep the instance active till the end of this function
|
|
||||||
Q_UNUSED(oldDb);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
oldDb->releaseData();
|
oldDb->releaseData();
|
||||||
}
|
}
|
||||||
@ -806,7 +795,7 @@ void DatabaseWidget::setClipboardTextAndMinimize(const QString& text)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
void DatabaseWidget::addToAgent()
|
void DatabaseWidget::addToAgent()
|
||||||
{
|
{
|
||||||
Entry* currentEntry = m_entryView->currentEntry();
|
Entry* currentEntry = m_entryView->currentEntry();
|
||||||
@ -911,7 +900,7 @@ void DatabaseWidget::openUrl()
|
|||||||
|
|
||||||
void DatabaseWidget::downloadSelectedFavicons()
|
void DatabaseWidget::downloadSelectedFavicons()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
QList<Entry*> selectedEntries;
|
QList<Entry*> selectedEntries;
|
||||||
for (const auto& index : m_entryView->selectionModel()->selectedRows()) {
|
for (const auto& index : m_entryView->selectionModel()->selectedRows()) {
|
||||||
selectedEntries.append(m_entryView->entryFromIndex(index));
|
selectedEntries.append(m_entryView->entryFromIndex(index));
|
||||||
@ -924,7 +913,7 @@ void DatabaseWidget::downloadSelectedFavicons()
|
|||||||
|
|
||||||
void DatabaseWidget::downloadAllFavicons()
|
void DatabaseWidget::downloadAllFavicons()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
auto currentGroup = m_groupView->currentGroup();
|
auto currentGroup = m_groupView->currentGroup();
|
||||||
if (currentGroup) {
|
if (currentGroup) {
|
||||||
performIconDownloads(currentGroup->entries());
|
performIconDownloads(currentGroup->entries());
|
||||||
@ -934,7 +923,7 @@ void DatabaseWidget::downloadAllFavicons()
|
|||||||
|
|
||||||
void DatabaseWidget::downloadFaviconInBackground(Entry* entry)
|
void DatabaseWidget::downloadFaviconInBackground(Entry* entry)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
performIconDownloads({entry}, true, true);
|
performIconDownloads({entry}, true, true);
|
||||||
#else
|
#else
|
||||||
Q_UNUSED(entry);
|
Q_UNUSED(entry);
|
||||||
@ -943,7 +932,7 @@ void DatabaseWidget::downloadFaviconInBackground(Entry* entry)
|
|||||||
|
|
||||||
void DatabaseWidget::performIconDownloads(const QList<Entry*>& entries, bool force, bool downloadInBackground)
|
void DatabaseWidget::performIconDownloads(const QList<Entry*>& entries, bool force, bool downloadInBackground)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
auto* iconDownloaderDialog = new IconDownloaderDialog(this);
|
auto* iconDownloaderDialog = new IconDownloaderDialog(this);
|
||||||
connect(this, SIGNAL(databaseLockRequested()), iconDownloaderDialog, SLOT(close()));
|
connect(this, SIGNAL(databaseLockRequested()), iconDownloaderDialog, SLOT(close()));
|
||||||
|
|
||||||
@ -1319,7 +1308,7 @@ void DatabaseWidget::loadDatabase(bool accepted)
|
|||||||
m_entryBeforeLock = QUuid();
|
m_entryBeforeLock = QUuid();
|
||||||
m_saveAttempts = 0;
|
m_saveAttempts = 0;
|
||||||
emit databaseUnlocked();
|
emit databaseUnlocked();
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
sshAgent()->databaseUnlocked(m_db);
|
sshAgent()->databaseUnlocked(m_db);
|
||||||
#endif
|
#endif
|
||||||
if (config()->get(Config::MinimizeAfterUnlock).toBool()) {
|
if (config()->get(Config::MinimizeAfterUnlock).toBool()) {
|
||||||
@ -1470,7 +1459,7 @@ void DatabaseWidget::unlockDatabase(bool accepted)
|
|||||||
processAutoOpen();
|
processAutoOpen();
|
||||||
emit databaseUnlocked();
|
emit databaseUnlocked();
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
sshAgent()->databaseUnlocked(m_db);
|
sshAgent()->databaseUnlocked(m_db);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1618,7 +1607,7 @@ void DatabaseWidget::switchToRemoteSettings()
|
|||||||
m_databaseSettingDialog->showRemoteSettings();
|
m_databaseSettingDialog->showRemoteSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void DatabaseWidget::switchToPasskeys()
|
void DatabaseWidget::switchToPasskeys()
|
||||||
{
|
{
|
||||||
switchToDatabaseReports();
|
switchToDatabaseReports();
|
||||||
@ -1715,9 +1704,7 @@ void DatabaseWidget::search(const QString& searchtext)
|
|||||||
m_lastSearchText = searchtext;
|
m_lastSearchText = searchtext;
|
||||||
|
|
||||||
m_searchingLabel->setVisible(true);
|
m_searchingLabel->setVisible(true);
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
m_shareLabel->setVisible(false);
|
m_shareLabel->setVisible(false);
|
||||||
#endif
|
|
||||||
|
|
||||||
emit searchModeActivated();
|
emit searchModeActivated();
|
||||||
}
|
}
|
||||||
@ -1782,7 +1769,6 @@ void DatabaseWidget::onGroupChanged()
|
|||||||
|
|
||||||
m_previewView->setGroup(group);
|
m_previewView->setGroup(group);
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
auto shareLabel = KeeShare::sharingLabel(group);
|
auto shareLabel = KeeShare::sharingLabel(group);
|
||||||
if (!shareLabel.isEmpty()) {
|
if (!shareLabel.isEmpty()) {
|
||||||
m_shareLabel->setRawText(shareLabel);
|
m_shareLabel->setRawText(shareLabel);
|
||||||
@ -1790,7 +1776,6 @@ void DatabaseWidget::onGroupChanged()
|
|||||||
} else {
|
} else {
|
||||||
m_shareLabel->setVisible(false);
|
m_shareLabel->setVisible(false);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
emit groupChanged();
|
emit groupChanged();
|
||||||
}
|
}
|
||||||
@ -2057,7 +2042,7 @@ bool DatabaseWidget::lock()
|
|||||||
m_entryBeforeLock = currentEntry->uuid();
|
m_entryBeforeLock = currentEntry->uuid();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
sshAgent()->databaseLocked(m_db);
|
sshAgent()->databaseLocked(m_db);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2239,7 +2224,7 @@ bool DatabaseWidget::currentEntryHasTotp()
|
|||||||
return currentEntry->hasTotp();
|
return currentEntry->hasTotp();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
bool DatabaseWidget::currentEntryHasSshKey()
|
bool DatabaseWidget::currentEntryHasSshKey()
|
||||||
{
|
{
|
||||||
Entry* currentEntry = m_entryView->currentEntry();
|
Entry* currentEntry = m_entryView->currentEntry();
|
||||||
@ -2252,7 +2237,7 @@ bool DatabaseWidget::currentEntryHasSshKey()
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
bool DatabaseWidget::currentEntryHasPasskey()
|
bool DatabaseWidget::currentEntryHasPasskey()
|
||||||
{
|
{
|
||||||
auto currentEntry = m_entryView->currentEntry();
|
auto currentEntry = m_entryView->currentEntry();
|
||||||
|
@ -116,7 +116,7 @@ public:
|
|||||||
bool currentEntryHasUrl();
|
bool currentEntryHasUrl();
|
||||||
bool currentEntryHasNotes();
|
bool currentEntryHasNotes();
|
||||||
bool currentEntryHasTotp();
|
bool currentEntryHasTotp();
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
bool currentEntryHasSshKey();
|
bool currentEntryHasSshKey();
|
||||||
#endif
|
#endif
|
||||||
bool currentEntryHasAutoTypeEnabled();
|
bool currentEntryHasAutoTypeEnabled();
|
||||||
@ -201,7 +201,7 @@ public slots:
|
|||||||
void copyTotp();
|
void copyTotp();
|
||||||
void copyPasswordTotp();
|
void copyPasswordTotp();
|
||||||
void setupTotp();
|
void setupTotp();
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
void addToAgent();
|
void addToAgent();
|
||||||
void removeFromAgent();
|
void removeFromAgent();
|
||||||
#endif
|
#endif
|
||||||
@ -229,7 +229,7 @@ public slots:
|
|||||||
void switchToDatabaseReports();
|
void switchToDatabaseReports();
|
||||||
void switchToDatabaseSettings();
|
void switchToDatabaseSettings();
|
||||||
void switchToRemoteSettings();
|
void switchToRemoteSettings();
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void switchToPasskeys();
|
void switchToPasskeys();
|
||||||
void showImportPasskeyDialog(bool isEntry = false);
|
void showImportPasskeyDialog(bool isEntry = false);
|
||||||
void removePasskeyFromEntry();
|
void removePasskeyFromEntry();
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
#include "gui/IconModels.h"
|
#include "gui/IconModels.h"
|
||||||
#include "gui/Icons.h"
|
#include "gui/Icons.h"
|
||||||
#include "gui/MessageBox.h"
|
#include "gui/MessageBox.h"
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
#include "gui/IconDownloader.h"
|
#include "gui/IconDownloader.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -48,7 +48,7 @@ EditWidgetIcons::EditWidgetIcons(QWidget* parent)
|
|||||||
, m_applyIconTo(ApplyIconToOptions::THIS_ONLY)
|
, m_applyIconTo(ApplyIconToOptions::THIS_ONLY)
|
||||||
, m_defaultIconModel(new DefaultIconModel(this))
|
, m_defaultIconModel(new DefaultIconModel(this))
|
||||||
, m_customIconModel(new CustomIconModel(this))
|
, m_customIconModel(new CustomIconModel(this))
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
, m_downloader(new IconDownloader())
|
, m_downloader(new IconDownloader())
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
@ -73,14 +73,14 @@ EditWidgetIcons::EditWidgetIcons(QWidget* parent)
|
|||||||
this, SIGNAL(widgetUpdated()));
|
this, SIGNAL(widgetUpdated()));
|
||||||
connect(m_ui->customIconsView->selectionModel(), SIGNAL(selectionChanged(QItemSelection,QItemSelection)),
|
connect(m_ui->customIconsView->selectionModel(), SIGNAL(selectionChanged(QItemSelection,QItemSelection)),
|
||||||
this, SIGNAL(widgetUpdated()));
|
this, SIGNAL(widgetUpdated()));
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
connect(m_downloader.data(),
|
connect(m_downloader.data(),
|
||||||
SIGNAL(finished(const QString&, const QImage&)),
|
SIGNAL(finished(const QString&, const QImage&)),
|
||||||
SLOT(iconReceived(const QString&, const QImage&)));
|
SLOT(iconReceived(const QString&, const QImage&)));
|
||||||
#endif
|
#endif
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
#ifndef WITH_XC_NETWORKING
|
#ifndef KPXC_FEATURE_NETWORK
|
||||||
m_ui->faviconButton->setVisible(false);
|
m_ui->faviconButton->setVisible(false);
|
||||||
m_ui->faviconURL->setVisible(false);
|
m_ui->faviconURL->setVisible(false);
|
||||||
#endif
|
#endif
|
||||||
@ -188,7 +188,7 @@ void EditWidgetIcons::keyPressEvent(QKeyEvent* event)
|
|||||||
|
|
||||||
void EditWidgetIcons::setUrl(const QString& url)
|
void EditWidgetIcons::setUrl(const QString& url)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
QUrl urlCheck(url);
|
QUrl urlCheck(url);
|
||||||
if (urlCheck.scheme().startsWith("http")) {
|
if (urlCheck.scheme().startsWith("http")) {
|
||||||
m_ui->faviconURL->setText(urlCheck.url(QUrl::RemovePath | QUrl::RemoveQuery | QUrl::RemoveFragment));
|
m_ui->faviconURL->setText(urlCheck.url(QUrl::RemovePath | QUrl::RemoveQuery | QUrl::RemoveFragment));
|
||||||
@ -203,7 +203,7 @@ void EditWidgetIcons::setUrl(const QString& url)
|
|||||||
|
|
||||||
void EditWidgetIcons::downloadFavicon()
|
void EditWidgetIcons::downloadFavicon()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
auto url = m_ui->faviconURL->text();
|
auto url = m_ui->faviconURL->text();
|
||||||
if (!url.isEmpty()) {
|
if (!url.isEmpty()) {
|
||||||
m_downloader->setUrl(url);
|
m_downloader->setUrl(url);
|
||||||
@ -214,7 +214,7 @@ void EditWidgetIcons::downloadFavicon()
|
|||||||
|
|
||||||
void EditWidgetIcons::iconReceived(const QString& url, const QImage& icon)
|
void EditWidgetIcons::iconReceived(const QString& url, const QImage& icon)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
Q_UNUSED(url);
|
Q_UNUSED(url);
|
||||||
if (icon.isNull()) {
|
if (icon.isNull()) {
|
||||||
QString message(tr("Unable to fetch favicon."));
|
QString message(tr("Unable to fetch favicon."));
|
||||||
@ -237,7 +237,7 @@ void EditWidgetIcons::iconReceived(const QString& url, const QImage& icon)
|
|||||||
|
|
||||||
void EditWidgetIcons::abortRequests()
|
void EditWidgetIcons::abortRequests()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
if (m_downloader) {
|
if (m_downloader) {
|
||||||
m_downloader->abortDownload();
|
m_downloader->abortDownload();
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
class Database;
|
class Database;
|
||||||
class DefaultIconModel;
|
class DefaultIconModel;
|
||||||
class CustomIconModel;
|
class CustomIconModel;
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
class IconDownloader;
|
class IconDownloader;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -104,7 +104,7 @@ private:
|
|||||||
ApplyIconToOptions m_applyIconTo;
|
ApplyIconToOptions m_applyIconTo;
|
||||||
DefaultIconModel* const m_defaultIconModel;
|
DefaultIconModel* const m_defaultIconModel;
|
||||||
CustomIconModel* const m_customIconModel;
|
CustomIconModel* const m_customIconModel;
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
QSharedPointer<IconDownloader> m_downloader;
|
QSharedPointer<IconDownloader> m_downloader;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -25,10 +25,8 @@
|
|||||||
#include "core/Totp.h"
|
#include "core/Totp.h"
|
||||||
#include "gui/Font.h"
|
#include "gui/Font.h"
|
||||||
#include "gui/Icons.h"
|
#include "gui/Icons.h"
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
#include "keeshare/KeeShare.h"
|
#include "keeshare/KeeShare.h"
|
||||||
#include "keeshare/KeeShareSettings.h"
|
#include "keeshare/KeeShareSettings.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <QScrollBar>
|
#include <QScrollBar>
|
||||||
#include <QTabWidget>
|
#include <QTabWidget>
|
||||||
@ -105,10 +103,6 @@ EntryPreviewWidget::EntryPreviewWidget(QWidget* parent)
|
|||||||
connect(m_ui->groupTabWidget, SIGNAL(tabBarClicked(int)), SLOT(updateTabIndexes()), Qt::QueuedConnection);
|
connect(m_ui->groupTabWidget, SIGNAL(tabBarClicked(int)), SLOT(updateTabIndexes()), Qt::QueuedConnection);
|
||||||
|
|
||||||
setFocusProxy(m_ui->entryTabWidget);
|
setFocusProxy(m_ui->entryTabWidget);
|
||||||
|
|
||||||
#if !defined(WITH_XC_KEESHARE)
|
|
||||||
removeTab(m_ui->groupTabWidget, m_ui->groupShareTab);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EntryPreviewWidget::~EntryPreviewWidget() = default;
|
EntryPreviewWidget::~EntryPreviewWidget() = default;
|
||||||
@ -206,10 +200,7 @@ void EntryPreviewWidget::refresh()
|
|||||||
} else if (m_currentGroup) {
|
} else if (m_currentGroup) {
|
||||||
updateGroupHeaderLine();
|
updateGroupHeaderLine();
|
||||||
updateGroupGeneralTab();
|
updateGroupGeneralTab();
|
||||||
|
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
updateGroupSharingTab();
|
updateGroupSharingTab();
|
||||||
#endif
|
|
||||||
|
|
||||||
setVisible(!config()->get(Config::GUI_HidePreviewPanel).toBool());
|
setVisible(!config()->get(Config::GUI_HidePreviewPanel).toBool());
|
||||||
|
|
||||||
@ -530,7 +521,6 @@ void EntryPreviewWidget::updateGroupGeneralTab()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
void EntryPreviewWidget::updateGroupSharingTab()
|
void EntryPreviewWidget::updateGroupSharingTab()
|
||||||
{
|
{
|
||||||
Q_ASSERT(m_currentGroup);
|
Q_ASSERT(m_currentGroup);
|
||||||
@ -539,7 +529,6 @@ void EntryPreviewWidget::updateGroupSharingTab()
|
|||||||
m_ui->groupShareTypeLabel->setText(KeeShare::referenceTypeLabel(reference));
|
m_ui->groupShareTypeLabel->setText(KeeShare::referenceTypeLabel(reference));
|
||||||
m_ui->groupSharePathLabel->setText(reference.path);
|
m_ui->groupSharePathLabel->setText(reference.path);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
void EntryPreviewWidget::updateTotpLabel()
|
void EntryPreviewWidget::updateTotpLabel()
|
||||||
{
|
{
|
||||||
|
@ -65,9 +65,7 @@ private slots:
|
|||||||
|
|
||||||
void updateGroupHeaderLine();
|
void updateGroupHeaderLine();
|
||||||
void updateGroupGeneralTab();
|
void updateGroupGeneralTab();
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
void updateGroupSharingTab();
|
void updateGroupSharingTab();
|
||||||
#endif
|
|
||||||
|
|
||||||
void updateTotpLabel();
|
void updateTotpLabel();
|
||||||
void updateTabIndexes();
|
void updateTabIndexes();
|
||||||
|
@ -24,16 +24,12 @@
|
|||||||
#include <QPaintDevice>
|
#include <QPaintDevice>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
|
||||||
#include "config-keepassx.h"
|
|
||||||
#include "core/Config.h"
|
#include "core/Config.h"
|
||||||
#include "core/Database.h"
|
#include "core/Database.h"
|
||||||
#include "gui/DatabaseIcons.h"
|
#include "gui/DatabaseIcons.h"
|
||||||
#include "gui/MainWindow.h"
|
#include "gui/MainWindow.h"
|
||||||
#include "gui/osutils/OSUtils.h"
|
#include "gui/osutils/OSUtils.h"
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
#include "keeshare/KeeShare.h"
|
#include "keeshare/KeeShare.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
class AdaptiveIconEngine : public QIconEngine
|
class AdaptiveIconEngine : public QIconEngine
|
||||||
{
|
{
|
||||||
@ -263,12 +259,9 @@ QPixmap Icons::groupIconPixmap(const Group* group, IconSize size)
|
|||||||
|
|
||||||
if (group->isExpired()) {
|
if (group->isExpired()) {
|
||||||
icon = databaseIcons()->applyBadge(icon, DatabaseIcons::Badges::Expired);
|
icon = databaseIcons()->applyBadge(icon, DatabaseIcons::Badges::Expired);
|
||||||
}
|
} else if (KeeShare::isShared(group)) {
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
else if (KeeShare::isShared(group)) {
|
|
||||||
icon = KeeShare::indicatorBadge(group, icon);
|
icon = KeeShare::indicatorBadge(group, icon);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
return icon;
|
return icon;
|
||||||
}
|
}
|
||||||
|
@ -47,30 +47,25 @@
|
|||||||
#include "gui/entry/EntryView.h"
|
#include "gui/entry/EntryView.h"
|
||||||
#include "gui/osutils/OSUtils.h"
|
#include "gui/osutils/OSUtils.h"
|
||||||
#include "gui/remote/RemoteSettings.h"
|
#include "gui/remote/RemoteSettings.h"
|
||||||
|
#include "keeshare/KeeShare.h"
|
||||||
|
#include "keeshare/SettingsPageKeeShare.h"
|
||||||
|
#include "keys/drivers/YubiKey.h"
|
||||||
|
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef KPXC_FEATURE_UPDATES
|
||||||
#include "gui/UpdateCheckDialog.h"
|
#include "gui/UpdateCheckDialog.h"
|
||||||
#include "networking/UpdateChecker.h"
|
#include "networking/UpdateChecker.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
#include "sshagent/AgentSettingsPage.h"
|
#include "sshagent/AgentSettingsPage.h"
|
||||||
#include "sshagent/SSHAgent.h"
|
#include "sshagent/SSHAgent.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
#include "keeshare/KeeShare.h"
|
|
||||||
#include "keeshare/SettingsPageKeeShare.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#include "fdosecrets/FdoSecretsPlugin.h"
|
#include "fdosecrets/FdoSecretsPlugin.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#include "keys/drivers/YubiKey.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
|
||||||
#include "browser/BrowserService.h"
|
#include "browser/BrowserService.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -138,7 +133,7 @@ MainWindow::MainWindow()
|
|||||||
m_entryContextMenu->addSeparator();
|
m_entryContextMenu->addSeparator();
|
||||||
m_entryContextMenu->addAction(m_ui->actionEntryAutoType);
|
m_entryContextMenu->addAction(m_ui->actionEntryAutoType);
|
||||||
m_entryContextMenu->addSeparator();
|
m_entryContextMenu->addSeparator();
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
m_entryContextMenu->addAction(m_ui->actionEntryImportPasskey);
|
m_entryContextMenu->addAction(m_ui->actionEntryImportPasskey);
|
||||||
m_entryContextMenu->addAction(m_ui->actionEntryRemovePasskey);
|
m_entryContextMenu->addAction(m_ui->actionEntryRemovePasskey);
|
||||||
m_entryContextMenu->addSeparator();
|
m_entryContextMenu->addSeparator();
|
||||||
@ -202,26 +197,24 @@ MainWindow::MainWindow()
|
|||||||
|
|
||||||
m_ui->settingsWidget->addSettingsPage(new ShortcutSettingsPage());
|
m_ui->settingsWidget->addSettingsPage(new ShortcutSettingsPage());
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
connect(
|
connect(
|
||||||
browserService(), &BrowserService::requestUnlock, m_ui->tabWidget, &DatabaseTabWidget::performBrowserUnlock);
|
browserService(), &BrowserService::requestUnlock, m_ui->tabWidget, &DatabaseTabWidget::performBrowserUnlock);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
connect(sshAgent(), SIGNAL(error(QString)), this, SLOT(showErrorMessage(QString)));
|
connect(sshAgent(), SIGNAL(error(QString)), this, SLOT(showErrorMessage(QString)));
|
||||||
connect(sshAgent(), SIGNAL(enabledChanged(bool)), this, SLOT(agentEnabled(bool)));
|
connect(sshAgent(), SIGNAL(enabledChanged(bool)), this, SLOT(agentEnabled(bool)));
|
||||||
m_ui->settingsWidget->addSettingsPage(new AgentSettingsPage());
|
m_ui->settingsWidget->addSettingsPage(new AgentSettingsPage());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
KeeShare::init(this);
|
KeeShare::init(this);
|
||||||
m_ui->settingsWidget->addSettingsPage(new SettingsPageKeeShare(m_ui->tabWidget));
|
m_ui->settingsWidget->addSettingsPage(new SettingsPageKeeShare(m_ui->tabWidget));
|
||||||
connect(KeeShare::instance(),
|
connect(KeeShare::instance(),
|
||||||
SIGNAL(sharingMessage(QString, MessageWidget::MessageType)),
|
SIGNAL(sharingMessage(QString, MessageWidget::MessageType)),
|
||||||
SLOT(displayGlobalMessage(QString, MessageWidget::MessageType)));
|
SLOT(displayGlobalMessage(QString, MessageWidget::MessageType)));
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
auto fdoSS = new FdoSecretsPlugin(m_ui->tabWidget);
|
auto fdoSS = new FdoSecretsPlugin(m_ui->tabWidget);
|
||||||
connect(fdoSS, &FdoSecretsPlugin::error, this, &MainWindow::showErrorMessage);
|
connect(fdoSS, &FdoSecretsPlugin::error, this, &MainWindow::showErrorMessage);
|
||||||
connect(fdoSS, &FdoSecretsPlugin::requestSwitchToDatabases, this, &MainWindow::switchToDatabases);
|
connect(fdoSS, &FdoSecretsPlugin::requestSwitchToDatabases, this, &MainWindow::switchToDatabases);
|
||||||
@ -230,10 +223,8 @@ MainWindow::MainWindow()
|
|||||||
m_ui->settingsWidget->addSettingsPage(fdoSS);
|
m_ui->settingsWidget->addSettingsPage(fdoSS);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
connect(YubiKey::instance(), SIGNAL(userInteractionRequest()), SLOT(showYubiKeyPopup()), Qt::QueuedConnection);
|
connect(YubiKey::instance(), SIGNAL(userInteractionRequest()), SLOT(showYubiKeyPopup()), Qt::QueuedConnection);
|
||||||
connect(YubiKey::instance(), SIGNAL(challengeCompleted()), SLOT(hideYubiKeyPopup()), Qt::QueuedConnection);
|
connect(YubiKey::instance(), SIGNAL(challengeCompleted()), SLOT(hideYubiKeyPopup()), Qt::QueuedConnection);
|
||||||
#endif
|
|
||||||
|
|
||||||
setWindowIcon(icons()->applicationIcon());
|
setWindowIcon(icons()->applicationIcon());
|
||||||
m_ui->globalMessageWidget->hideMessage();
|
m_ui->globalMessageWidget->hideMessage();
|
||||||
@ -421,7 +412,7 @@ MainWindow::MainWindow()
|
|||||||
m_ui->actionKeyboardShortcuts->setIcon(icons()->icon("keyboard-shortcuts"));
|
m_ui->actionKeyboardShortcuts->setIcon(icons()->icon("keyboard-shortcuts"));
|
||||||
m_ui->actionCheckForUpdates->setIcon(icons()->icon("system-software-update"));
|
m_ui->actionCheckForUpdates->setIcon(icons()->icon("system-software-update"));
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
m_ui->actionPasskeys->setIcon(icons()->icon("passkey"));
|
m_ui->actionPasskeys->setIcon(icons()->icon("passkey"));
|
||||||
m_ui->actionImportPasskey->setIcon(icons()->icon("document-import"));
|
m_ui->actionImportPasskey->setIcon(icons()->icon("document-import"));
|
||||||
m_ui->actionEntryImportPasskey->setIcon(icons()->icon("document-import"));
|
m_ui->actionEntryImportPasskey->setIcon(icons()->icon("document-import"));
|
||||||
@ -471,8 +462,7 @@ MainWindow::MainWindow()
|
|||||||
connect(m_ui->actionDatabaseMerge, SIGNAL(triggered()), m_ui->tabWidget, SLOT(mergeDatabase()));
|
connect(m_ui->actionDatabaseMerge, SIGNAL(triggered()), m_ui->tabWidget, SLOT(mergeDatabase()));
|
||||||
connect(m_ui->actionDatabaseSettings, SIGNAL(toggled(bool)), m_ui->tabWidget, SLOT(showDatabaseSettings(bool)));
|
connect(m_ui->actionDatabaseSettings, SIGNAL(toggled(bool)), m_ui->tabWidget, SLOT(showDatabaseSettings(bool)));
|
||||||
connect(m_ui->actionDatabaseSecurity, SIGNAL(triggered()), m_ui->tabWidget, SLOT(showDatabaseSecurity()));
|
connect(m_ui->actionDatabaseSecurity, SIGNAL(triggered()), m_ui->tabWidget, SLOT(showDatabaseSecurity()));
|
||||||
connect(m_ui->actionReports, SIGNAL(toggled(bool)), m_ui->tabWidget, SLOT(showDatabaseReports(bool)));
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
connect(m_ui->actionPasskeys, SIGNAL(triggered()), m_ui->tabWidget, SLOT(showPasskeys()));
|
connect(m_ui->actionPasskeys, SIGNAL(triggered()), m_ui->tabWidget, SLOT(showPasskeys()));
|
||||||
connect(m_ui->actionImportPasskey, SIGNAL(triggered()), m_ui->tabWidget, SLOT(importPasskey()));
|
connect(m_ui->actionImportPasskey, SIGNAL(triggered()), m_ui->tabWidget, SLOT(importPasskey()));
|
||||||
connect(m_ui->actionEntryImportPasskey, SIGNAL(triggered()), m_ui->tabWidget, SLOT(importPasskeyToEntry()));
|
connect(m_ui->actionEntryImportPasskey, SIGNAL(triggered()), m_ui->tabWidget, SLOT(importPasskeyToEntry()));
|
||||||
@ -520,7 +510,7 @@ MainWindow::MainWindow()
|
|||||||
m_actionMultiplexer.connect(m_ui->actionEntryAutoTypeTOTP, SIGNAL(triggered()), SLOT(performAutoTypeTOTP()));
|
m_actionMultiplexer.connect(m_ui->actionEntryAutoTypeTOTP, SIGNAL(triggered()), SLOT(performAutoTypeTOTP()));
|
||||||
m_actionMultiplexer.connect(m_ui->actionEntryOpenUrl, SIGNAL(triggered()), SLOT(openUrl()));
|
m_actionMultiplexer.connect(m_ui->actionEntryOpenUrl, SIGNAL(triggered()), SLOT(openUrl()));
|
||||||
m_actionMultiplexer.connect(m_ui->actionEntryDownloadIcon, SIGNAL(triggered()), SLOT(downloadSelectedFavicons()));
|
m_actionMultiplexer.connect(m_ui->actionEntryDownloadIcon, SIGNAL(triggered()), SLOT(downloadSelectedFavicons()));
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
m_actionMultiplexer.connect(m_ui->actionEntryAddToAgent, SIGNAL(triggered()), SLOT(addToAgent()));
|
m_actionMultiplexer.connect(m_ui->actionEntryAddToAgent, SIGNAL(triggered()), SLOT(addToAgent()));
|
||||||
m_actionMultiplexer.connect(m_ui->actionEntryRemoveFromAgent, SIGNAL(triggered()), SLOT(removeFromAgent()));
|
m_actionMultiplexer.connect(m_ui->actionEntryRemoveFromAgent, SIGNAL(triggered()), SLOT(removeFromAgent()));
|
||||||
#endif
|
#endif
|
||||||
@ -568,7 +558,7 @@ MainWindow::MainWindow()
|
|||||||
setUnifiedTitleAndToolBarOnMac(true);
|
setUnifiedTitleAndToolBarOnMac(true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef KPXC_FEATURE_UPDATES
|
||||||
connect(m_ui->actionCheckForUpdates, SIGNAL(triggered()), SLOT(showUpdateCheckDialog()));
|
connect(m_ui->actionCheckForUpdates, SIGNAL(triggered()), SLOT(showUpdateCheckDialog()));
|
||||||
connect(UpdateChecker::instance(),
|
connect(UpdateChecker::instance(),
|
||||||
SIGNAL(updateCheckFinished(bool, QString, bool)),
|
SIGNAL(updateCheckFinished(bool, QString, bool)),
|
||||||
@ -582,11 +572,11 @@ MainWindow::MainWindow()
|
|||||||
m_ui->actionCheckForUpdates->setVisible(false);
|
m_ui->actionCheckForUpdates->setVisible(false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef WITH_XC_NETWORKING
|
#ifndef KPXC_FEATURE_NETWORK
|
||||||
m_ui->actionGroupDownloadFavicons->setVisible(false);
|
m_ui->actionGroupDownloadFavicons->setVisible(false);
|
||||||
m_ui->actionEntryDownloadIcon->setVisible(false);
|
m_ui->actionEntryDownloadIcon->setVisible(false);
|
||||||
#endif
|
#endif
|
||||||
#ifndef WITH_XC_DOCS
|
#ifndef KPXC_FEATURE_DOCS
|
||||||
m_ui->actionGettingStarted->setVisible(false);
|
m_ui->actionGettingStarted->setVisible(false);
|
||||||
m_ui->actionUserGuide->setVisible(false);
|
m_ui->actionUserGuide->setVisible(false);
|
||||||
m_ui->actionKeyboardShortcuts->setVisible(false);
|
m_ui->actionKeyboardShortcuts->setVisible(false);
|
||||||
@ -618,36 +608,27 @@ MainWindow::MainWindow()
|
|||||||
// Properly shutdown on logoff, restart, and shutdown
|
// Properly shutdown on logoff, restart, and shutdown
|
||||||
connect(qApp, &QGuiApplication::commitDataRequest, this, [this] { m_appExitCalled = true; });
|
connect(qApp, &QGuiApplication::commitDataRequest, this, [this] { m_appExitCalled = true; });
|
||||||
|
|
||||||
#if defined(KEEPASSXC_BUILD_TYPE_SNAPSHOT) || defined(KEEPASSXC_BUILD_TYPE_PRE_RELEASE)
|
#ifdef KEEPASSXC_BUILD_TYPE_SNAPSHOT
|
||||||
auto* hidePreRelWarn = new QAction(tr("Don't show again for this version"), m_ui->globalMessageWidget);
|
auto* hidePreRelWarn = new QAction(tr("Don't show again for this version"), m_ui->globalMessageWidget);
|
||||||
m_ui->globalMessageWidget->addAction(hidePreRelWarn);
|
m_ui->globalMessageWidget->addAction(hidePreRelWarn);
|
||||||
auto hidePreRelWarnConn = QSharedPointer<QMetaObject::Connection>::create();
|
auto hidePreRelWarnConn = QSharedPointer<QMetaObject::Connection>::create();
|
||||||
*hidePreRelWarnConn = connect(m_ui->globalMessageWidget, &KMessageWidget::hideAnimationFinished, [=] {
|
*hidePreRelWarnConn = connect(m_ui->globalMessageWidget, &MessageWidget::hideAnimationStarted, [=] {
|
||||||
m_ui->globalMessageWidget->removeAction(hidePreRelWarn);
|
m_ui->globalMessageWidget->removeAction(hidePreRelWarn);
|
||||||
disconnect(*hidePreRelWarnConn);
|
disconnect(*hidePreRelWarnConn);
|
||||||
hidePreRelWarn->deleteLater();
|
hidePreRelWarn->deleteLater();
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(hidePreRelWarn, &QAction::triggered, [=] {
|
connect(hidePreRelWarn, &QAction::triggered, [=] {
|
||||||
m_ui->globalMessageWidget->animatedHide();
|
m_ui->globalMessageWidget->hideMessage();
|
||||||
config()->set(Config::Messages_HidePreReleaseWarning, KEEPASSXC_VERSION);
|
config()->set(Config::Messages_HidePreReleaseWarning, KEEPASSXC_VERSION);
|
||||||
});
|
});
|
||||||
#endif
|
|
||||||
#if defined(KEEPASSXC_BUILD_TYPE_SNAPSHOT)
|
|
||||||
if (config()->get(Config::Messages_HidePreReleaseWarning) != KEEPASSXC_VERSION) {
|
if (config()->get(Config::Messages_HidePreReleaseWarning) != KEEPASSXC_VERSION) {
|
||||||
m_ui->globalMessageWidget->showMessage(
|
m_ui->globalMessageWidget->showMessage(tr("WARNING: You are using a development snapshot build of KeePassXC.\n"
|
||||||
tr("WARNING: You are using an unstable build of KeePassXC.\n"
|
"Maintain a backup of your databases in the event of unknown bugs.\n"
|
||||||
"There is a high risk of corruption, maintain a backup of your databases.\n"
|
"This version is not meant for production use."),
|
||||||
"This version is not meant for production use."),
|
MessageWidget::Warning,
|
||||||
MessageWidget::Warning,
|
-1);
|
||||||
-1);
|
|
||||||
}
|
|
||||||
#elif defined(KEEPASSXC_BUILD_TYPE_PRE_RELEASE)
|
|
||||||
if (config()->get(Config::Messages_HidePreReleaseWarning) != KEEPASSXC_VERSION) {
|
|
||||||
m_ui->globalMessageWidget->showMessage(
|
|
||||||
tr("NOTE: You are using a pre-release version of KeePassXC.\n"
|
|
||||||
"Expect some bugs and minor issues, this version is meant for testing purposes."),
|
|
||||||
MessageWidget::Information,
|
|
||||||
-1);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -688,7 +669,7 @@ MainWindow::MainWindow()
|
|||||||
|
|
||||||
MainWindow::~MainWindow()
|
MainWindow::~MainWindow()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
sshAgent()->removeAllIdentities();
|
sshAgent()->removeAllIdentities();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -740,11 +721,7 @@ void MainWindow::appExit()
|
|||||||
*/
|
*/
|
||||||
bool MainWindow::isHardwareKeySupported()
|
bool MainWindow::isHardwareKeySupported()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
return true;
|
return true;
|
||||||
#else
|
|
||||||
return false;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -756,7 +733,6 @@ bool MainWindow::isHardwareKeySupported()
|
|||||||
*/
|
*/
|
||||||
bool MainWindow::refreshHardwareKeys()
|
bool MainWindow::refreshHardwareKeys()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
auto yk = YubiKey::instance();
|
auto yk = YubiKey::instance();
|
||||||
// find keys sync to allow returning if any key was found
|
// find keys sync to allow returning if any key was found
|
||||||
bool found = yk->findValidKeys();
|
bool found = yk->findValidKeys();
|
||||||
@ -764,9 +740,6 @@ bool MainWindow::refreshHardwareKeys()
|
|||||||
// emit here manually because sync findValidKeys() cannot do that properly
|
// emit here manually because sync findValidKeys() cannot do that properly
|
||||||
emit yk->detectComplete(found);
|
emit yk->detectComplete(found);
|
||||||
return found;
|
return found;
|
||||||
#else
|
|
||||||
return false;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::updateLastDatabasesMenu()
|
void MainWindow::updateLastDatabasesMenu()
|
||||||
@ -953,13 +926,13 @@ void MainWindow::updateMenuActionState()
|
|||||||
m_ui->actionEntryTotpQRCode->setEnabled(singleEntrySelected && dbWidget->currentEntryHasTotp());
|
m_ui->actionEntryTotpQRCode->setEnabled(singleEntrySelected && dbWidget->currentEntryHasTotp());
|
||||||
m_ui->actionEntryDownloadIcon->setEnabled((multiEntrySelected && !singleEntrySelected)
|
m_ui->actionEntryDownloadIcon->setEnabled((multiEntrySelected && !singleEntrySelected)
|
||||||
|| (singleEntrySelected && dbWidget->currentEntryHasUrl()));
|
|| (singleEntrySelected && dbWidget->currentEntryHasUrl()));
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
m_ui->actionEntryImportPasskey->setVisible(singleEntrySelected);
|
m_ui->actionEntryImportPasskey->setVisible(singleEntrySelected);
|
||||||
m_ui->actionEntryImportPasskey->setEnabled(singleEntrySelected);
|
m_ui->actionEntryImportPasskey->setEnabled(singleEntrySelected);
|
||||||
m_ui->actionEntryRemovePasskey->setVisible(singleEntrySelected && dbWidget->currentEntryHasPasskey());
|
m_ui->actionEntryRemovePasskey->setVisible(singleEntrySelected && dbWidget->currentEntryHasPasskey());
|
||||||
m_ui->actionEntryRemovePasskey->setEnabled(singleEntrySelected && dbWidget->currentEntryHasPasskey());
|
m_ui->actionEntryRemovePasskey->setEnabled(singleEntrySelected && dbWidget->currentEntryHasPasskey());
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
bool hasSSHKey = singleEntrySelected && sshAgent()->isEnabled() && dbWidget->currentEntryHasSshKey();
|
bool hasSSHKey = singleEntrySelected && sshAgent()->isEnabled() && dbWidget->currentEntryHasSshKey();
|
||||||
m_ui->actionEntryAddToAgent->setVisible(hasSSHKey);
|
m_ui->actionEntryAddToAgent->setVisible(hasSSHKey);
|
||||||
m_ui->actionEntryAddToAgent->setEnabled(hasSSHKey);
|
m_ui->actionEntryAddToAgent->setEnabled(hasSSHKey);
|
||||||
@ -977,7 +950,7 @@ void MainWindow::updateMenuActionState()
|
|||||||
m_ui->actionGroupSortDesc->setEnabled(groupHasChildren);
|
m_ui->actionGroupSortDesc->setEnabled(groupHasChildren);
|
||||||
m_ui->actionGroupEmptyRecycleBin->setVisible(inRecycleBin);
|
m_ui->actionGroupEmptyRecycleBin->setVisible(inRecycleBin);
|
||||||
m_ui->actionGroupEmptyRecycleBin->setEnabled(inRecycleBin);
|
m_ui->actionGroupEmptyRecycleBin->setEnabled(inRecycleBin);
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
m_ui->actionGroupDownloadFavicons->setVisible(!inRecycleBin);
|
m_ui->actionGroupDownloadFavicons->setVisible(!inRecycleBin);
|
||||||
#endif
|
#endif
|
||||||
m_ui->actionGroupDownloadFavicons->setEnabled(groupSelected && groupHasEntries && !inRecycleBin);
|
m_ui->actionGroupDownloadFavicons->setEnabled(groupSelected && groupHasEntries && !inRecycleBin);
|
||||||
@ -996,7 +969,7 @@ void MainWindow::updateMenuActionState()
|
|||||||
m_ui->menuRemoteSync->setEnabled(inDatabase || inDatabaseSettings);
|
m_ui->menuRemoteSync->setEnabled(inDatabase || inDatabaseSettings);
|
||||||
m_ui->menuExport->setEnabled(inDatabase);
|
m_ui->menuExport->setEnabled(inDatabase);
|
||||||
m_ui->actionDatabaseMerge->setEnabled(inDatabase);
|
m_ui->actionDatabaseMerge->setEnabled(inDatabase);
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
m_ui->actionPasskeys->setEnabled(inDatabase || inReports);
|
m_ui->actionPasskeys->setEnabled(inDatabase || inReports);
|
||||||
m_ui->actionImportPasskey->setEnabled(inDatabase);
|
m_ui->actionImportPasskey->setEnabled(inDatabase);
|
||||||
#endif
|
#endif
|
||||||
@ -1076,7 +1049,7 @@ void MainWindow::showAboutDialog()
|
|||||||
|
|
||||||
void MainWindow::performUpdateCheck()
|
void MainWindow::performUpdateCheck()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef KPXC_FEATURE_UPDATES
|
||||||
if (!config()->get(Config::UpdateCheckMessageShown).toBool()) {
|
if (!config()->get(Config::UpdateCheckMessageShown).toBool()) {
|
||||||
auto result =
|
auto result =
|
||||||
MessageBox::question(this,
|
MessageBox::question(this,
|
||||||
@ -1099,7 +1072,7 @@ void MainWindow::performUpdateCheck()
|
|||||||
|
|
||||||
void MainWindow::hasUpdateAvailable(bool hasUpdate, const QString& version, bool isManuallyRequested)
|
void MainWindow::hasUpdateAvailable(bool hasUpdate, const QString& version, bool isManuallyRequested)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef KPXC_FEATURE_UPDATES
|
||||||
if (hasUpdate && !isManuallyRequested) {
|
if (hasUpdate && !isManuallyRequested) {
|
||||||
auto* updateCheckDialog = new UpdateCheckDialog(this);
|
auto* updateCheckDialog = new UpdateCheckDialog(this);
|
||||||
updateCheckDialog->showUpdateCheckResponse(hasUpdate, version);
|
updateCheckDialog->showUpdateCheckResponse(hasUpdate, version);
|
||||||
@ -1114,7 +1087,7 @@ void MainWindow::hasUpdateAvailable(bool hasUpdate, const QString& version, bool
|
|||||||
|
|
||||||
void MainWindow::showUpdateCheckDialog()
|
void MainWindow::showUpdateCheckDialog()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef KPXC_FEATURE_UPDATES
|
||||||
updateCheck()->checkForUpdates(true);
|
updateCheck()->checkForUpdates(true);
|
||||||
auto* updateCheckDialog = new UpdateCheckDialog(this);
|
auto* updateCheckDialog = new UpdateCheckDialog(this);
|
||||||
updateCheckDialog->show();
|
updateCheckDialog->show();
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "UrlTools.h"
|
#include "UrlTools.h"
|
||||||
#if defined(WITH_XC_NETWORKING) || defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_NETWORK) || defined(KPXC_FEATURE_BROWSER)
|
||||||
#include <QHostAddress>
|
#include <QHostAddress>
|
||||||
#include <QNetworkCookie>
|
#include <QNetworkCookie>
|
||||||
#include <QNetworkCookieJar>
|
#include <QNetworkCookieJar>
|
||||||
@ -40,7 +40,7 @@ QUrl UrlTools::convertVariantToUrl(const QVariant& var) const
|
|||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(WITH_XC_NETWORKING) || defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_NETWORK) || defined(KPXC_FEATURE_BROWSER)
|
||||||
QUrl UrlTools::getRedirectTarget(QNetworkReply* reply) const
|
QUrl UrlTools::getRedirectTarget(QNetworkReply* reply) const
|
||||||
{
|
{
|
||||||
QVariant var = reply->attribute(QNetworkRequest::RedirectionTargetAttribute);
|
QVariant var = reply->attribute(QNetworkRequest::RedirectionTargetAttribute);
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QUrl>
|
#include <QUrl>
|
||||||
#include <QVariant>
|
#include <QVariant>
|
||||||
#if defined(WITH_XC_NETWORKING) || defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_NETWORK) || defined(KPXC_FEATURE_BROWSER)
|
||||||
#include <QNetworkReply>
|
#include <QNetworkReply>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -34,7 +34,7 @@ public:
|
|||||||
explicit UrlTools() = default;
|
explicit UrlTools() = default;
|
||||||
static UrlTools* instance();
|
static UrlTools* instance();
|
||||||
|
|
||||||
#if defined(WITH_XC_NETWORKING) || defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_NETWORK) || defined(KPXC_FEATURE_BROWSER)
|
||||||
QUrl getRedirectTarget(QNetworkReply* reply) const;
|
QUrl getRedirectTarget(QNetworkReply* reply) const;
|
||||||
QString getBaseDomainFromUrl(const QString& url) const;
|
QString getBaseDomainFromUrl(const QString& url) const;
|
||||||
QString getTopLevelDomainFromUrl(const QString& url) const;
|
QString getTopLevelDomainFromUrl(const QString& url) const;
|
||||||
|
@ -24,22 +24,16 @@
|
|||||||
#include "gui/Icons.h"
|
#include "gui/Icons.h"
|
||||||
#include "keys/ChallengeResponseKey.h"
|
#include "keys/ChallengeResponseKey.h"
|
||||||
#include "keys/CompositeKey.h"
|
#include "keys/CompositeKey.h"
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#include "keys/drivers/YubiKeyInterfaceUSB.h"
|
#include "keys/drivers/YubiKeyInterfaceUSB.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
YubiKeyEditWidget::YubiKeyEditWidget(QWidget* parent)
|
YubiKeyEditWidget::YubiKeyEditWidget(QWidget* parent)
|
||||||
: KeyComponentWidget(parent)
|
: KeyComponentWidget(parent)
|
||||||
, m_compUi(new Ui::YubiKeyEditWidget())
|
, m_compUi(new Ui::YubiKeyEditWidget())
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
, m_deviceListener(new DeviceListener(this))
|
, m_deviceListener(new DeviceListener(this))
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
initComponent();
|
initComponent();
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
connect(YubiKey::instance(), SIGNAL(detectComplete(bool)), SLOT(hardwareKeyResponse(bool)), Qt::QueuedConnection);
|
connect(YubiKey::instance(), SIGNAL(detectComplete(bool)), SLOT(hardwareKeyResponse(bool)), Qt::QueuedConnection);
|
||||||
connect(m_deviceListener, &DeviceListener::devicePlugged, this, [&](bool, void*, void*) { pollYubikey(); });
|
connect(m_deviceListener, &DeviceListener::devicePlugged, this, [&](bool, void*, void*) { pollYubikey(); });
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
YubiKeyEditWidget::~YubiKeyEditWidget() = default;
|
YubiKeyEditWidget::~YubiKeyEditWidget() = default;
|
||||||
@ -90,7 +84,6 @@ void YubiKeyEditWidget::showEvent(QShowEvent* event)
|
|||||||
{
|
{
|
||||||
KeyComponentWidget::showEvent(event);
|
KeyComponentWidget::showEvent(event);
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
m_deviceListener->registerHotplugCallback(true,
|
m_deviceListener->registerHotplugCallback(true,
|
||||||
true,
|
true,
|
||||||
@ -106,15 +99,12 @@ void YubiKeyEditWidget::showEvent(QShowEvent* event)
|
|||||||
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::YUBICO_USB_VID);
|
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::YUBICO_USB_VID);
|
||||||
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::ONLYKEY_USB_VID);
|
m_deviceListener->registerHotplugCallback(true, true, YubiKeyInterfaceUSB::ONLYKEY_USB_VID);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void YubiKeyEditWidget::hideEvent(QHideEvent* event)
|
void YubiKeyEditWidget::hideEvent(QHideEvent* event)
|
||||||
{
|
{
|
||||||
KeyComponentWidget::hideEvent(event);
|
KeyComponentWidget::hideEvent(event);
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
m_deviceListener->deregisterAllHotplugCallbacks();
|
m_deviceListener->deregisterAllHotplugCallbacks();
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void YubiKeyEditWidget::initComponentEditWidget(QWidget* widget)
|
void YubiKeyEditWidget::initComponentEditWidget(QWidget* widget)
|
||||||
@ -146,7 +136,6 @@ void YubiKeyEditWidget::initComponent()
|
|||||||
|
|
||||||
void YubiKeyEditWidget::pollYubikey()
|
void YubiKeyEditWidget::pollYubikey()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
if (!m_compEditWidget) {
|
if (!m_compEditWidget) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -159,7 +148,6 @@ void YubiKeyEditWidget::pollYubikey()
|
|||||||
m_compUi->refreshHardwareKeys->setEnabled(false);
|
m_compUi->refreshHardwareKeys->setEnabled(false);
|
||||||
|
|
||||||
YubiKey::instance()->findValidKeysAsync();
|
YubiKey::instance()->findValidKeysAsync();
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void YubiKeyEditWidget::hardwareKeyResponse(bool found)
|
void YubiKeyEditWidget::hardwareKeyResponse(bool found)
|
||||||
|
@ -19,10 +19,7 @@
|
|||||||
#define KEEPASSXC_YUBIKEYEDITWIDGET_H
|
#define KEEPASSXC_YUBIKEYEDITWIDGET_H
|
||||||
|
|
||||||
#include "KeyComponentWidget.h"
|
#include "KeyComponentWidget.h"
|
||||||
#include "config-keepassx.h"
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
#include "gui/osutils/DeviceListener.h"
|
#include "gui/osutils/DeviceListener.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace Ui
|
namespace Ui
|
||||||
{
|
{
|
||||||
@ -57,9 +54,7 @@ private slots:
|
|||||||
private:
|
private:
|
||||||
const QScopedPointer<Ui::YubiKeyEditWidget> m_compUi;
|
const QScopedPointer<Ui::YubiKeyEditWidget> m_compUi;
|
||||||
QPointer<QWidget> m_compEditWidget;
|
QPointer<QWidget> m_compEditWidget;
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
QPointer<DeviceListener> m_deviceListener;
|
QPointer<DeviceListener> m_deviceListener;
|
||||||
#endif
|
|
||||||
bool m_isDetected = false;
|
bool m_isDetected = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -20,15 +20,13 @@
|
|||||||
#include "DatabaseSettingsWidgetDatabaseKey.h"
|
#include "DatabaseSettingsWidgetDatabaseKey.h"
|
||||||
#include "DatabaseSettingsWidgetEncryption.h"
|
#include "DatabaseSettingsWidgetEncryption.h"
|
||||||
#include "DatabaseSettingsWidgetGeneral.h"
|
#include "DatabaseSettingsWidgetGeneral.h"
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#include "DatabaseSettingsWidgetBrowser.h"
|
#include "DatabaseSettingsWidgetBrowser.h"
|
||||||
#endif
|
#endif
|
||||||
#include "../remote/DatabaseSettingsWidgetRemote.h"
|
#include "../remote/DatabaseSettingsWidgetRemote.h"
|
||||||
#include "DatabaseSettingsWidgetMaintenance.h"
|
#include "DatabaseSettingsWidgetMaintenance.h"
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
#include "keeshare/DatabaseSettingsWidgetKeeShare.h"
|
#include "keeshare/DatabaseSettingsWidgetKeeShare.h"
|
||||||
#endif
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
|
||||||
#include "fdosecrets/widgets/DatabaseSettingsWidgetFdoSecrets.h"
|
#include "fdosecrets/widgets/DatabaseSettingsWidgetFdoSecrets.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -44,13 +42,11 @@ DatabaseSettingsDialog::DatabaseSettingsDialog(QWidget* parent)
|
|||||||
, m_securityTabWidget(new QTabWidget(this))
|
, m_securityTabWidget(new QTabWidget(this))
|
||||||
, m_databaseKeyWidget(new DatabaseSettingsWidgetDatabaseKey(this))
|
, m_databaseKeyWidget(new DatabaseSettingsWidgetDatabaseKey(this))
|
||||||
, m_encryptionWidget(new DatabaseSettingsWidgetEncryption(this))
|
, m_encryptionWidget(new DatabaseSettingsWidgetEncryption(this))
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
, m_browserWidget(new DatabaseSettingsWidgetBrowser(this))
|
, m_browserWidget(new DatabaseSettingsWidgetBrowser(this))
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
, m_keeShareWidget(new DatabaseSettingsWidgetKeeShare(this))
|
, m_keeShareWidget(new DatabaseSettingsWidgetKeeShare(this))
|
||||||
#endif
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
|
||||||
, m_fdoSecretsWidget(new DatabaseSettingsWidgetFdoSecrets(this))
|
, m_fdoSecretsWidget(new DatabaseSettingsWidgetFdoSecrets(this))
|
||||||
#endif
|
#endif
|
||||||
, m_maintenanceWidget(new DatabaseSettingsWidgetMaintenance(this))
|
, m_maintenanceWidget(new DatabaseSettingsWidgetMaintenance(this))
|
||||||
@ -78,15 +74,13 @@ DatabaseSettingsDialog::DatabaseSettingsDialog(QWidget* parent)
|
|||||||
|
|
||||||
addPage(tr("Remote Sync"), icons()->icon("remote-sync"), m_remoteWidget);
|
addPage(tr("Remote Sync"), icons()->icon("remote-sync"), m_remoteWidget);
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
addPage(tr("Browser Integration"), icons()->icon("internet-web-browser"), m_browserWidget);
|
addPage(tr("Browser Integration"), icons()->icon("internet-web-browser"), m_browserWidget);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
addPage(tr("KeeShare"), icons()->icon("preferences-system-network-sharing"), m_keeShareWidget);
|
addPage(tr("KeeShare"), icons()->icon("preferences-system-network-sharing"), m_keeShareWidget);
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
addPage(tr("Secret Service Integration"), icons()->icon(QStringLiteral("freedesktop")), m_fdoSecretsWidget);
|
addPage(tr("Secret Service Integration"), icons()->icon(QStringLiteral("freedesktop")), m_fdoSecretsWidget);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -105,13 +99,11 @@ void DatabaseSettingsDialog::load(const QSharedPointer<Database>& db)
|
|||||||
m_databaseKeyWidget->loadSettings(db);
|
m_databaseKeyWidget->loadSettings(db);
|
||||||
m_encryptionWidget->loadSettings(db);
|
m_encryptionWidget->loadSettings(db);
|
||||||
m_remoteWidget->loadSettings(db);
|
m_remoteWidget->loadSettings(db);
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
m_browserWidget->loadSettings(db);
|
m_browserWidget->loadSettings(db);
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
m_keeShareWidget->loadSettings(db);
|
m_keeShareWidget->loadSettings(db);
|
||||||
#endif
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
|
||||||
m_fdoSecretsWidget->loadSettings(db);
|
m_fdoSecretsWidget->loadSettings(db);
|
||||||
#endif
|
#endif
|
||||||
m_maintenanceWidget->loadSettings(db);
|
m_maintenanceWidget->loadSettings(db);
|
||||||
@ -159,10 +151,8 @@ void DatabaseSettingsDialog::save()
|
|||||||
|
|
||||||
// Browser settings don't have anything to save
|
// Browser settings don't have anything to save
|
||||||
|
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
m_keeShareWidget->saveSettings();
|
m_keeShareWidget->saveSettings();
|
||||||
#endif
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
|
||||||
m_fdoSecretsWidget->saveSettings();
|
m_fdoSecretsWidget->saveSettings();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -175,7 +165,7 @@ void DatabaseSettingsDialog::reject()
|
|||||||
m_databaseKeyWidget->discard();
|
m_databaseKeyWidget->discard();
|
||||||
m_encryptionWidget->discard();
|
m_encryptionWidget->discard();
|
||||||
m_remoteWidget->discard();
|
m_remoteWidget->discard();
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
m_browserWidget->discard();
|
m_browserWidget->discard();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -28,13 +28,11 @@ class Database;
|
|||||||
class DatabaseSettingsWidgetGeneral;
|
class DatabaseSettingsWidgetGeneral;
|
||||||
class DatabaseSettingsWidgetEncryption;
|
class DatabaseSettingsWidgetEncryption;
|
||||||
class DatabaseSettingsWidgetDatabaseKey;
|
class DatabaseSettingsWidgetDatabaseKey;
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
class DatabaseSettingsWidgetBrowser;
|
class DatabaseSettingsWidgetBrowser;
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
class DatabaseSettingsWidgetKeeShare;
|
class DatabaseSettingsWidgetKeeShare;
|
||||||
#endif
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
|
||||||
class DatabaseSettingsWidgetFdoSecrets;
|
class DatabaseSettingsWidgetFdoSecrets;
|
||||||
#endif
|
#endif
|
||||||
class DatabaseSettingsWidgetMaintenance;
|
class DatabaseSettingsWidgetMaintenance;
|
||||||
@ -67,13 +65,11 @@ private:
|
|||||||
QPointer<QTabWidget> m_securityTabWidget;
|
QPointer<QTabWidget> m_securityTabWidget;
|
||||||
QPointer<DatabaseSettingsWidgetDatabaseKey> m_databaseKeyWidget;
|
QPointer<DatabaseSettingsWidgetDatabaseKey> m_databaseKeyWidget;
|
||||||
QPointer<DatabaseSettingsWidgetEncryption> m_encryptionWidget;
|
QPointer<DatabaseSettingsWidgetEncryption> m_encryptionWidget;
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
QPointer<DatabaseSettingsWidgetBrowser> m_browserWidget;
|
QPointer<DatabaseSettingsWidgetBrowser> m_browserWidget;
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_KEESHARE
|
|
||||||
QPointer<DatabaseSettingsWidgetKeeShare> m_keeShareWidget;
|
QPointer<DatabaseSettingsWidgetKeeShare> m_keeShareWidget;
|
||||||
#endif
|
#ifdef KPXC_FEATURE_FDOSECRETS
|
||||||
#ifdef WITH_XC_FDOSECRETS
|
|
||||||
QPointer<DatabaseSettingsWidgetFdoSecrets> m_fdoSecretsWidget;
|
QPointer<DatabaseSettingsWidgetFdoSecrets> m_fdoSecretsWidget;
|
||||||
#endif
|
#endif
|
||||||
QPointer<DatabaseSettingsWidgetMaintenance> m_maintenanceWidget;
|
QPointer<DatabaseSettingsWidgetMaintenance> m_maintenanceWidget;
|
||||||
|
@ -38,9 +38,7 @@ DatabaseSettingsWidgetDatabaseKey::DatabaseSettingsWidgetDatabaseKey(QWidget* pa
|
|||||||
, m_additionalKeyOptions(new QWidget(this))
|
, m_additionalKeyOptions(new QWidget(this))
|
||||||
, m_passwordEditWidget(new PasswordEditWidget(this))
|
, m_passwordEditWidget(new PasswordEditWidget(this))
|
||||||
, m_keyFileEditWidget(new KeyFileEditWidget(this))
|
, m_keyFileEditWidget(new KeyFileEditWidget(this))
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
, m_yubiKeyEditWidget(new YubiKeyEditWidget(this))
|
, m_yubiKeyEditWidget(new YubiKeyEditWidget(this))
|
||||||
#endif
|
|
||||||
{
|
{
|
||||||
auto* vbox = new QVBoxLayout(this);
|
auto* vbox = new QVBoxLayout(this);
|
||||||
vbox->setSizeConstraint(QLayout::SetMinimumSize);
|
vbox->setSizeConstraint(QLayout::SetMinimumSize);
|
||||||
@ -58,9 +56,7 @@ DatabaseSettingsWidgetDatabaseKey::DatabaseSettingsWidgetDatabaseKey(QWidget* pa
|
|||||||
m_additionalKeyOptions->layout()->setMargin(0);
|
m_additionalKeyOptions->layout()->setMargin(0);
|
||||||
m_additionalKeyOptions->layout()->setSpacing(20);
|
m_additionalKeyOptions->layout()->setSpacing(20);
|
||||||
m_additionalKeyOptions->layout()->addWidget(m_keyFileEditWidget);
|
m_additionalKeyOptions->layout()->addWidget(m_keyFileEditWidget);
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
m_additionalKeyOptions->layout()->addWidget(m_yubiKeyEditWidget);
|
m_additionalKeyOptions->layout()->addWidget(m_yubiKeyEditWidget);
|
||||||
#endif
|
|
||||||
m_additionalKeyOptions->setVisible(false);
|
m_additionalKeyOptions->setVisible(false);
|
||||||
|
|
||||||
connect(m_additionalKeyOptionsToggle, SIGNAL(clicked()), SLOT(showAdditionalKeyOptions()));
|
connect(m_additionalKeyOptionsToggle, SIGNAL(clicked()), SLOT(showAdditionalKeyOptions()));
|
||||||
@ -91,23 +87,19 @@ void DatabaseSettingsWidgetDatabaseKey::loadSettings(QSharedPointer<Database> db
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
for (const auto& key : m_db->key()->challengeResponseKeys()) {
|
for (const auto& key : m_db->key()->challengeResponseKeys()) {
|
||||||
if (key->uuid() == ChallengeResponseKey::UUID) {
|
if (key->uuid() == ChallengeResponseKey::UUID) {
|
||||||
m_yubiKeyEditWidget->setComponentAdded(true);
|
m_yubiKeyEditWidget->setComponentAdded(true);
|
||||||
hasAdditionalKeys = true;
|
hasAdditionalKeys = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
setAdditionalKeyOptionsVisible(hasAdditionalKeys);
|
setAdditionalKeyOptionsVisible(hasAdditionalKeys);
|
||||||
}
|
}
|
||||||
|
|
||||||
connect(m_passwordEditWidget->findChild<QPushButton*>("removeButton"), SIGNAL(clicked()), SLOT(markDirty()));
|
connect(m_passwordEditWidget->findChild<QPushButton*>("removeButton"), SIGNAL(clicked()), SLOT(markDirty()));
|
||||||
connect(m_keyFileEditWidget->findChild<QPushButton*>("removeButton"), SIGNAL(clicked()), SLOT(markDirty()));
|
connect(m_keyFileEditWidget->findChild<QPushButton*>("removeButton"), SIGNAL(clicked()), SLOT(markDirty()));
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
connect(m_yubiKeyEditWidget->findChild<QPushButton*>("removeButton"), SIGNAL(clicked()), SLOT(markDirty()));
|
connect(m_yubiKeyEditWidget->findChild<QPushButton*>("removeButton"), SIGNAL(clicked()), SLOT(markDirty()));
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseSettingsWidgetDatabaseKey::initialize()
|
void DatabaseSettingsWidgetDatabaseKey::initialize()
|
||||||
@ -115,9 +107,7 @@ void DatabaseSettingsWidgetDatabaseKey::initialize()
|
|||||||
bool blocked = blockSignals(true);
|
bool blocked = blockSignals(true);
|
||||||
m_passwordEditWidget->setComponentAdded(false);
|
m_passwordEditWidget->setComponentAdded(false);
|
||||||
m_keyFileEditWidget->setComponentAdded(false);
|
m_keyFileEditWidget->setComponentAdded(false);
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
m_yubiKeyEditWidget->setComponentAdded(false);
|
m_yubiKeyEditWidget->setComponentAdded(false);
|
||||||
#endif
|
|
||||||
blockSignals(blocked);
|
blockSignals(blocked);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,9 +119,7 @@ bool DatabaseSettingsWidgetDatabaseKey::saveSettings()
|
|||||||
{
|
{
|
||||||
m_isDirty |= (m_passwordEditWidget->visiblePage() == KeyComponentWidget::Page::Edit);
|
m_isDirty |= (m_passwordEditWidget->visiblePage() == KeyComponentWidget::Page::Edit);
|
||||||
m_isDirty |= (m_keyFileEditWidget->visiblePage() == KeyComponentWidget::Page::Edit);
|
m_isDirty |= (m_keyFileEditWidget->visiblePage() == KeyComponentWidget::Page::Edit);
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
m_isDirty |= (m_yubiKeyEditWidget->visiblePage() == KeyComponentWidget::Page::Edit);
|
m_isDirty |= (m_yubiKeyEditWidget->visiblePage() == KeyComponentWidget::Page::Edit);
|
||||||
#endif
|
|
||||||
|
|
||||||
if (m_db->key() && !m_db->key()->keys().isEmpty() && !m_isDirty) {
|
if (m_db->key() && !m_db->key()->keys().isEmpty() && !m_isDirty) {
|
||||||
// Key unchanged
|
// Key unchanged
|
||||||
@ -212,11 +200,9 @@ bool DatabaseSettingsWidgetDatabaseKey::saveSettings()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
if (!addToCompositeKey(m_yubiKeyEditWidget, newKey, oldChallengeResponse)) {
|
if (!addToCompositeKey(m_yubiKeyEditWidget, newKey, oldChallengeResponse)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
if (newKey->keys().isEmpty() && newKey->challengeResponseKeys().isEmpty()) {
|
if (newKey->keys().isEmpty() && newKey->challengeResponseKeys().isEmpty()) {
|
||||||
MessageBox::critical(this,
|
MessageBox::critical(this,
|
||||||
|
@ -19,7 +19,6 @@
|
|||||||
#define KEEPASSXC_DATABASESETTINGSWIDGETDATABASEKEY_H
|
#define KEEPASSXC_DATABASESETTINGSWIDGETDATABASEKEY_H
|
||||||
|
|
||||||
#include "DatabaseSettingsWidget.h"
|
#include "DatabaseSettingsWidget.h"
|
||||||
#include "config-keepassx.h"
|
|
||||||
|
|
||||||
#include <QPointer>
|
#include <QPointer>
|
||||||
|
|
||||||
@ -72,9 +71,7 @@ private:
|
|||||||
const QPointer<QWidget> m_additionalKeyOptions;
|
const QPointer<QWidget> m_additionalKeyOptions;
|
||||||
const QPointer<PasswordEditWidget> m_passwordEditWidget;
|
const QPointer<PasswordEditWidget> m_passwordEditWidget;
|
||||||
const QPointer<KeyFileEditWidget> m_keyFileEditWidget;
|
const QPointer<KeyFileEditWidget> m_keyFileEditWidget;
|
||||||
#ifdef WITH_XC_YUBIKEY
|
|
||||||
const QPointer<YubiKeyEditWidget> m_yubiKeyEditWidget;
|
const QPointer<YubiKeyEditWidget> m_yubiKeyEditWidget;
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // KEEPASSXC_DATABASESETTINGSWIDGETDATABASEKEY_H
|
#endif // KEEPASSXC_DATABASESETTINGSWIDGETDATABASEKEY_H
|
||||||
|
@ -39,12 +39,12 @@
|
|||||||
#include "core/Group.h"
|
#include "core/Group.h"
|
||||||
#include "core/Metadata.h"
|
#include "core/Metadata.h"
|
||||||
#include "core/TimeDelta.h"
|
#include "core/TimeDelta.h"
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
#include "sshagent/OpenSSHKey.h"
|
#include "sshagent/OpenSSHKey.h"
|
||||||
#include "sshagent/OpenSSHKeyGenDialog.h"
|
#include "sshagent/OpenSSHKeyGenDialog.h"
|
||||||
#include "sshagent/SSHAgent.h"
|
#include "sshagent/SSHAgent.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#include "EntryURLModel.h"
|
#include "EntryURLModel.h"
|
||||||
#include "browser/BrowserService.h"
|
#include "browser/BrowserService.h"
|
||||||
#endif
|
#endif
|
||||||
@ -74,10 +74,10 @@ EditEntryWidget::EditEntryWidget(QWidget* parent)
|
|||||||
, m_advancedWidget(new QWidget(this))
|
, m_advancedWidget(new QWidget(this))
|
||||||
, m_iconsWidget(new EditWidgetIcons(this))
|
, m_iconsWidget(new EditWidgetIcons(this))
|
||||||
, m_autoTypeWidget(new QWidget(this))
|
, m_autoTypeWidget(new QWidget(this))
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
, m_sshAgentWidget(new QWidget(this))
|
, m_sshAgentWidget(new QWidget(this))
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
, m_browserSettingsChanged(false)
|
, m_browserSettingsChanged(false)
|
||||||
, m_browserWidget(new QWidget(this))
|
, m_browserWidget(new QWidget(this))
|
||||||
, m_additionalURLsDataModel(new EntryURLModel(this))
|
, m_additionalURLsDataModel(new EntryURLModel(this))
|
||||||
@ -100,11 +100,11 @@ EditEntryWidget::EditEntryWidget(QWidget* parent)
|
|||||||
setupIcon();
|
setupIcon();
|
||||||
setupAutoType();
|
setupAutoType();
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
setupSSHAgent();
|
setupSSHAgent();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
setupBrowser();
|
setupBrowser();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -191,19 +191,19 @@ void EditEntryWidget::setupMain()
|
|||||||
m_usernameCompleter->setModel(m_usernameCompleterModel);
|
m_usernameCompleter->setModel(m_usernameCompleterModel);
|
||||||
m_mainUi->usernameComboBox->setCompleter(m_usernameCompleter);
|
m_mainUi->usernameComboBox->setCompleter(m_usernameCompleter);
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
m_mainUi->fetchFaviconButton->setIcon(icons()->icon("favicon-download"));
|
m_mainUi->fetchFaviconButton->setIcon(icons()->icon("favicon-download"));
|
||||||
m_mainUi->fetchFaviconButton->setDisabled(true);
|
m_mainUi->fetchFaviconButton->setDisabled(true);
|
||||||
#else
|
#else
|
||||||
m_mainUi->fetchFaviconButton->setVisible(false);
|
m_mainUi->fetchFaviconButton->setVisible(false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
connect(m_mainUi->fetchFaviconButton, SIGNAL(clicked()), m_iconsWidget, SLOT(downloadFavicon()));
|
connect(m_mainUi->fetchFaviconButton, SIGNAL(clicked()), m_iconsWidget, SLOT(downloadFavicon()));
|
||||||
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), m_iconsWidget, SLOT(setUrl(QString)));
|
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), m_iconsWidget, SLOT(setUrl(QString)));
|
||||||
m_mainUi->urlEdit->enableVerifyMode();
|
m_mainUi->urlEdit->enableVerifyMode();
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), this, SLOT(entryURLEdited(const QString&)));
|
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), this, SLOT(entryURLEdited(const QString&)));
|
||||||
#endif
|
#endif
|
||||||
connect(m_mainUi->expireCheck, &QCheckBox::toggled, [&](bool enabled) {
|
connect(m_mainUi->expireCheck, &QCheckBox::toggled, [&](bool enabled) {
|
||||||
@ -298,7 +298,7 @@ void EditEntryWidget::setupAutoType()
|
|||||||
// clang-format on
|
// clang-format on
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void EditEntryWidget::setupBrowser()
|
void EditEntryWidget::setupBrowser()
|
||||||
{
|
{
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
@ -489,7 +489,7 @@ void EditEntryWidget::setupEntryUpdate()
|
|||||||
connect(m_mainUi->usernameComboBox->lineEdit(), SIGNAL(textChanged(QString)), this, SLOT(setModified()));
|
connect(m_mainUi->usernameComboBox->lineEdit(), SIGNAL(textChanged(QString)), this, SLOT(setModified()));
|
||||||
connect(m_mainUi->passwordEdit, SIGNAL(textChanged(QString)), this, SLOT(setModified()));
|
connect(m_mainUi->passwordEdit, SIGNAL(textChanged(QString)), this, SLOT(setModified()));
|
||||||
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), this, SLOT(setModified()));
|
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), this, SLOT(setModified()));
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), this, SLOT(updateFaviconButtonEnable(QString)));
|
connect(m_mainUi->urlEdit, SIGNAL(textChanged(QString)), this, SLOT(updateFaviconButtonEnable(QString)));
|
||||||
#endif
|
#endif
|
||||||
connect(m_mainUi->tagsList, SIGNAL(tagsEdited()), this, SLOT(setModified()));
|
connect(m_mainUi->tagsList, SIGNAL(tagsEdited()), this, SLOT(setModified()));
|
||||||
@ -520,7 +520,7 @@ void EditEntryWidget::setupEntryUpdate()
|
|||||||
|
|
||||||
// Properties and History tabs don't need extra connections
|
// Properties and History tabs don't need extra connections
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
// SSH Agent tab
|
// SSH Agent tab
|
||||||
if (sshAgent()->isEnabled()) {
|
if (sshAgent()->isEnabled()) {
|
||||||
connect(m_sshAgentUi->attachmentRadioButton, SIGNAL(toggled(bool)), this, SLOT(setModified()));
|
connect(m_sshAgentUi->attachmentRadioButton, SIGNAL(toggled(bool)), this, SLOT(setModified()));
|
||||||
@ -536,7 +536,7 @@ void EditEntryWidget::setupEntryUpdate()
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
connect(m_browserUi->skipAutoSubmitCheckbox, SIGNAL(toggled(bool)), SLOT(setModified()));
|
connect(m_browserUi->skipAutoSubmitCheckbox, SIGNAL(toggled(bool)), SLOT(setModified()));
|
||||||
connect(m_browserUi->hideEntryCheckbox, SIGNAL(toggled(bool)), SLOT(setModified()));
|
connect(m_browserUi->hideEntryCheckbox, SIGNAL(toggled(bool)), SLOT(setModified()));
|
||||||
@ -584,7 +584,7 @@ void EditEntryWidget::updateHistoryButtons(const QModelIndex& current, const QMo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
void EditEntryWidget::setupSSHAgent()
|
void EditEntryWidget::setupSSHAgent()
|
||||||
{
|
{
|
||||||
m_pendingPrivateKey = "";
|
m_pendingPrivateKey = "";
|
||||||
@ -929,7 +929,7 @@ void EditEntryWidget::loadEntry(Entry* entry,
|
|||||||
|
|
||||||
switchToPage(Page::Main);
|
switchToPage(Page::Main);
|
||||||
setPageHidden(m_historyWidget, m_history || m_entry->historyItems().count() < 1);
|
setPageHidden(m_historyWidget, m_history || m_entry->historyItems().count() < 1);
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
setPageHidden(m_sshAgentWidget, !sshAgent()->isEnabled());
|
setPageHidden(m_sshAgentWidget, !sshAgent()->isEnabled());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1045,13 +1045,13 @@ void EditEntryWidget::setForms(Entry* entry, bool restore)
|
|||||||
}
|
}
|
||||||
updateAutoTypeEnabled();
|
updateAutoTypeEnabled();
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
if (sshAgent()->isEnabled()) {
|
if (sshAgent()->isEnabled()) {
|
||||||
updateSSHAgent();
|
updateSSHAgent();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
if (!hasPage(m_browserWidget)) {
|
if (!hasPage(m_browserWidget)) {
|
||||||
setupBrowser();
|
setupBrowser();
|
||||||
@ -1207,7 +1207,7 @@ bool EditEntryWidget::commitEntry()
|
|||||||
|
|
||||||
m_autoTypeAssoc->removeEmpty();
|
m_autoTypeAssoc->removeEmpty();
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
toKeeAgentSettings(m_sshAgentSettings);
|
toKeeAgentSettings(m_sshAgentSettings);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1216,7 +1216,7 @@ bool EditEntryWidget::commitEntry()
|
|||||||
m_entry->beginUpdate();
|
m_entry->beginUpdate();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
updateBrowser();
|
updateBrowser();
|
||||||
}
|
}
|
||||||
@ -1304,7 +1304,7 @@ void EditEntryWidget::updateEntryData(Entry* entry) const
|
|||||||
|
|
||||||
entry->autoTypeAssociations()->copyDataFrom(m_autoTypeAssoc);
|
entry->autoTypeAssociations()->copyDataFrom(m_autoTypeAssoc);
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
if (sshAgent()->isEnabled()) {
|
if (sshAgent()->isEnabled()) {
|
||||||
m_sshAgentSettings.toEntry(entry);
|
m_sshAgentSettings.toEntry(entry);
|
||||||
}
|
}
|
||||||
@ -1390,7 +1390,7 @@ void EditEntryWidget::clear()
|
|||||||
hideMessage();
|
hideMessage();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
void EditEntryWidget::updateFaviconButtonEnable(const QString& url)
|
void EditEntryWidget::updateFaviconButtonEnable(const QString& url)
|
||||||
{
|
{
|
||||||
m_mainUi->fetchFaviconButton->setDisabled(url.isEmpty());
|
m_mainUi->fetchFaviconButton->setDisabled(url.isEmpty());
|
||||||
|
@ -44,11 +44,11 @@ class QMenu;
|
|||||||
class QScrollArea;
|
class QScrollArea;
|
||||||
class QSortFilterProxyModel;
|
class QSortFilterProxyModel;
|
||||||
class QStringListModel;
|
class QStringListModel;
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
#include "sshagent/KeeAgentSettings.h"
|
#include "sshagent/KeeAgentSettings.h"
|
||||||
class OpenSSHKey;
|
class OpenSSHKey;
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
class EntryURLModel;
|
class EntryURLModel;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -98,7 +98,7 @@ private slots:
|
|||||||
void acceptEntry();
|
void acceptEntry();
|
||||||
bool commitEntry();
|
bool commitEntry();
|
||||||
void cancel();
|
void cancel();
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
void updateFaviconButtonEnable(const QString& url);
|
void updateFaviconButtonEnable(const QString& url);
|
||||||
#endif
|
#endif
|
||||||
void insertAttribute();
|
void insertAttribute();
|
||||||
@ -124,7 +124,7 @@ private slots:
|
|||||||
void useExpiryPreset(QAction* action);
|
void useExpiryPreset(QAction* action);
|
||||||
void toggleHideNotes(bool visible);
|
void toggleHideNotes(bool visible);
|
||||||
void pickColor();
|
void pickColor();
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
void toKeeAgentSettings(KeeAgentSettings& settings) const;
|
void toKeeAgentSettings(KeeAgentSettings& settings) const;
|
||||||
void setSSHAgentSettings();
|
void setSSHAgentSettings();
|
||||||
void updateSSHAgent();
|
void updateSSHAgent();
|
||||||
@ -139,7 +139,7 @@ private slots:
|
|||||||
void copyPublicKey();
|
void copyPublicKey();
|
||||||
void generatePrivateKey();
|
void generatePrivateKey();
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void updateBrowserModified();
|
void updateBrowserModified();
|
||||||
void updateBrowser();
|
void updateBrowser();
|
||||||
void insertURL();
|
void insertURL();
|
||||||
@ -154,10 +154,10 @@ private:
|
|||||||
void setupAdvanced();
|
void setupAdvanced();
|
||||||
void setupIcon();
|
void setupIcon();
|
||||||
void setupAutoType();
|
void setupAutoType();
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void setupBrowser();
|
void setupBrowser();
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
void setupSSHAgent();
|
void setupSSHAgent();
|
||||||
#endif
|
#endif
|
||||||
void setupProperties();
|
void setupProperties();
|
||||||
@ -169,7 +169,7 @@ private:
|
|||||||
QMenu* createPresetsMenu();
|
QMenu* createPresetsMenu();
|
||||||
void updateEntryData(Entry* entry) const;
|
void updateEntryData(Entry* entry) const;
|
||||||
void updateBrowserIntegrationCheckbox(QCheckBox* checkBox, bool enabled, bool value, const QString& option);
|
void updateBrowserIntegrationCheckbox(QCheckBox* checkBox, bool enabled, bool value, const QString& option);
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
bool getOpenSSHKey(OpenSSHKey& key, bool decrypt = false);
|
bool getOpenSSHKey(OpenSSHKey& key, bool decrypt = false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -182,7 +182,7 @@ private:
|
|||||||
|
|
||||||
bool m_create;
|
bool m_create;
|
||||||
bool m_history;
|
bool m_history;
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
KeeAgentSettings m_sshAgentSettings;
|
KeeAgentSettings m_sshAgentSettings;
|
||||||
QString m_pendingPrivateKey;
|
QString m_pendingPrivateKey;
|
||||||
#endif
|
#endif
|
||||||
@ -199,10 +199,10 @@ private:
|
|||||||
QWidget* const m_advancedWidget;
|
QWidget* const m_advancedWidget;
|
||||||
EditWidgetIcons* const m_iconsWidget;
|
EditWidgetIcons* const m_iconsWidget;
|
||||||
QWidget* const m_autoTypeWidget;
|
QWidget* const m_autoTypeWidget;
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef KPXC_FEATURE_SSHAGENT
|
||||||
QWidget* const m_sshAgentWidget;
|
QWidget* const m_sshAgentWidget;
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
bool m_browserSettingsChanged;
|
bool m_browserSettingsChanged;
|
||||||
QWidget* const m_browserWidget;
|
QWidget* const m_browserWidget;
|
||||||
EntryURLModel* const m_additionalURLsDataModel;
|
EntryURLModel* const m_additionalURLsDataModel;
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
|
|
||||||
#include "EditGroupWidget.h"
|
#include "EditGroupWidget.h"
|
||||||
#include "ui_EditGroupWidgetMain.h"
|
#include "ui_EditGroupWidgetMain.h"
|
||||||
#if defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_BROWSER)
|
||||||
#include "browser/BrowserService.h"
|
#include "browser/BrowserService.h"
|
||||||
#include "ui_EditGroupWidgetBrowser.h"
|
#include "ui_EditGroupWidgetBrowser.h"
|
||||||
#endif
|
#endif
|
||||||
@ -30,10 +30,7 @@
|
|||||||
#include "gui/Font.h"
|
#include "gui/Font.h"
|
||||||
#include "gui/Icons.h"
|
#include "gui/Icons.h"
|
||||||
#include "gui/MessageBox.h"
|
#include "gui/MessageBox.h"
|
||||||
|
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
#include "keeshare/group/EditGroupPageKeeShare.h"
|
#include "keeshare/group/EditGroupPageKeeShare.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
class EditGroupWidget::ExtraPage
|
class EditGroupWidget::ExtraPage
|
||||||
{
|
{
|
||||||
@ -70,7 +67,7 @@ EditGroupWidget::EditGroupWidget(QWidget* parent)
|
|||||||
, m_editGroupWidgetMain(new QScrollArea())
|
, m_editGroupWidgetMain(new QScrollArea())
|
||||||
, m_editGroupWidgetIcons(new EditWidgetIcons())
|
, m_editGroupWidgetIcons(new EditWidgetIcons())
|
||||||
, m_editWidgetProperties(new EditWidgetProperties())
|
, m_editWidgetProperties(new EditWidgetProperties())
|
||||||
#if defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_BROWSER)
|
||||||
, m_browserSettingsChanged(false)
|
, m_browserSettingsChanged(false)
|
||||||
, m_browserUi(new Ui::EditGroupWidgetBrowser())
|
, m_browserUi(new Ui::EditGroupWidgetBrowser())
|
||||||
, m_browserWidget(new QWidget(this))
|
, m_browserWidget(new QWidget(this))
|
||||||
@ -81,14 +78,12 @@ EditGroupWidget::EditGroupWidget(QWidget* parent)
|
|||||||
|
|
||||||
addPage(tr("Group"), icons()->icon("document-edit"), m_editGroupWidgetMain);
|
addPage(tr("Group"), icons()->icon("document-edit"), m_editGroupWidgetMain);
|
||||||
addPage(tr("Icon"), icons()->icon("preferences-desktop-icons"), m_editGroupWidgetIcons);
|
addPage(tr("Icon"), icons()->icon("preferences-desktop-icons"), m_editGroupWidgetIcons);
|
||||||
#if defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_BROWSER)
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
initializeBrowserPage();
|
initializeBrowserPage();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
addEditPage(new EditGroupPageKeeShare(this));
|
addEditPage(new EditGroupPageKeeShare(this));
|
||||||
#endif
|
|
||||||
addPage(tr("Properties"), icons()->icon("document-properties"), m_editWidgetProperties);
|
addPage(tr("Properties"), icons()->icon("document-properties"), m_editWidgetProperties);
|
||||||
|
|
||||||
connect(m_mainUi->expireCheck, SIGNAL(toggled(bool)), m_mainUi->expireDatePicker, SLOT(setEnabled(bool)));
|
connect(m_mainUi->expireCheck, SIGNAL(toggled(bool)), m_mainUi->expireDatePicker, SLOT(setEnabled(bool)));
|
||||||
@ -130,7 +125,7 @@ void EditGroupWidget::setupModifiedTracking()
|
|||||||
// Icon tab
|
// Icon tab
|
||||||
connect(m_editGroupWidgetIcons, SIGNAL(widgetUpdated()), SLOT(setModified()));
|
connect(m_editGroupWidgetIcons, SIGNAL(widgetUpdated()), SLOT(setModified()));
|
||||||
|
|
||||||
#if defined(WITH_XC_BROWSER)
|
#if defined(KPXC_FEATURE_BROWSER)
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
setupBrowserModifiedTracking();
|
setupBrowserModifiedTracking();
|
||||||
}
|
}
|
||||||
@ -189,7 +184,7 @@ void EditGroupWidget::loadGroup(Group* group, bool create, const QSharedPointer<
|
|||||||
page.set(m_temporaryGroup.data(), m_db);
|
page.set(m_temporaryGroup.data(), m_db);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
auto inheritHideEntries = false;
|
auto inheritHideEntries = false;
|
||||||
auto inheritSkipSubmit = false;
|
auto inheritSkipSubmit = false;
|
||||||
@ -286,7 +281,7 @@ void EditGroupWidget::apply()
|
|||||||
page.assign();
|
page.assign();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
if (config()->get(Config::Browser_Enabled).toBool()) {
|
if (config()->get(Config::Browser_Enabled).toBool()) {
|
||||||
if (!m_browserSettingsChanged) {
|
if (!m_browserSettingsChanged) {
|
||||||
return;
|
return;
|
||||||
@ -353,7 +348,7 @@ void EditGroupWidget::cancel()
|
|||||||
emit editFinished(false);
|
emit editFinished(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void EditGroupWidget::initializeBrowserPage()
|
void EditGroupWidget::initializeBrowserPage()
|
||||||
{
|
{
|
||||||
addPage(tr("Browser Integration"), icons()->icon("internet-web-browser"), m_browserWidget);
|
addPage(tr("Browser Integration"), icons()->icon("internet-web-browser"), m_browserWidget);
|
||||||
@ -450,7 +445,7 @@ Group::TriState EditGroupWidget::triStateFromIndex(int index)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void EditGroupWidget::addRestrictKeyComboBoxItems(QStringList const& keyList, QString inheritValue)
|
void EditGroupWidget::addRestrictKeyComboBoxItems(QStringList const& keyList, QString inheritValue)
|
||||||
{
|
{
|
||||||
auto comboBox = m_browserUi->browserIntegrationRestrictKeyCombobox;
|
auto comboBox = m_browserUi->browserIntegrationRestrictKeyCombobox;
|
||||||
|
@ -69,7 +69,7 @@ private slots:
|
|||||||
void apply();
|
void apply();
|
||||||
void save();
|
void save();
|
||||||
void cancel();
|
void cancel();
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void initializeBrowserPage();
|
void initializeBrowserPage();
|
||||||
void setupBrowserModifiedTracking();
|
void setupBrowserModifiedTracking();
|
||||||
void updateBrowserModified();
|
void updateBrowserModified();
|
||||||
@ -90,7 +90,7 @@ private:
|
|||||||
QPointer<QScrollArea> m_editGroupWidgetMain;
|
QPointer<QScrollArea> m_editGroupWidgetMain;
|
||||||
QPointer<EditWidgetIcons> m_editGroupWidgetIcons;
|
QPointer<EditWidgetIcons> m_editGroupWidgetIcons;
|
||||||
QPointer<EditWidgetProperties> m_editWidgetProperties;
|
QPointer<EditWidgetProperties> m_editWidgetProperties;
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
bool m_browserSettingsChanged;
|
bool m_browserSettingsChanged;
|
||||||
const QScopedPointer<Ui::EditGroupWidgetBrowser> m_browserUi;
|
const QScopedPointer<Ui::EditGroupWidgetBrowser> m_browserUi;
|
||||||
QWidget* const m_browserWidget;
|
QWidget* const m_browserWidget;
|
||||||
|
@ -125,9 +125,7 @@ QVariant GroupModel::data(const QModelIndex& index, int role) const
|
|||||||
|
|
||||||
if (role == Qt::DisplayRole) {
|
if (role == Qt::DisplayRole) {
|
||||||
QString nameTemplate = "%1";
|
QString nameTemplate = "%1";
|
||||||
#if defined(WITH_XC_KEESHARE)
|
|
||||||
nameTemplate = KeeShare::indicatorSuffix(group, nameTemplate);
|
nameTemplate = KeeShare::indicatorSuffix(group, nameTemplate);
|
||||||
#endif
|
|
||||||
return nameTemplate.arg(group->name());
|
return nameTemplate.arg(group->name());
|
||||||
} else if (role == Qt::DecorationRole) {
|
} else if (role == Qt::DecorationRole) {
|
||||||
return Icons::groupIconPixmap(group);
|
return Icons::groupIconPixmap(group);
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#include <QStandardPaths>
|
#include <QStandardPaths>
|
||||||
#include <QStyle>
|
#include <QStyle>
|
||||||
#include <QTextStream>
|
#include <QTextStream>
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
#include <QX11Info>
|
#include <QX11Info>
|
||||||
|
|
||||||
#include <qpa/qplatformnativeinterface.h>
|
#include <qpa/qplatformnativeinterface.h>
|
||||||
@ -67,7 +67,7 @@ NixUtils* NixUtils::instance()
|
|||||||
NixUtils::NixUtils(QObject* parent)
|
NixUtils::NixUtils(QObject* parent)
|
||||||
: OSUtilsBase(parent)
|
: OSUtilsBase(parent)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
dpy = QX11Info::display();
|
dpy = QX11Info::display();
|
||||||
rootWindow = QX11Info::appRootWindow();
|
rootWindow = QX11Info::appRootWindow();
|
||||||
#endif
|
#endif
|
||||||
@ -214,7 +214,7 @@ void NixUtils::launchAtStartupRequested(uint response, const QVariantMap& result
|
|||||||
|
|
||||||
bool NixUtils::isCapslockEnabled()
|
bool NixUtils::isCapslockEnabled()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
QPlatformNativeInterface* native = QGuiApplication::platformNativeInterface();
|
QPlatformNativeInterface* native = QGuiApplication::platformNativeInterface();
|
||||||
auto* display = native->nativeResourceForWindow("display", nullptr);
|
auto* display = native->nativeResourceForWindow("display", nullptr);
|
||||||
if (!display) {
|
if (!display) {
|
||||||
@ -242,7 +242,7 @@ void NixUtils::registerNativeEventFilter()
|
|||||||
|
|
||||||
bool NixUtils::nativeEventFilter(const QByteArray& eventType, void* message, long*)
|
bool NixUtils::nativeEventFilter(const QByteArray& eventType, void* message, long*)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
if (eventType != QByteArrayLiteral("xcb_generic_event_t")) {
|
if (eventType != QByteArrayLiteral("xcb_generic_event_t")) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -264,7 +264,7 @@ bool NixUtils::nativeEventFilter(const QByteArray& eventType, void* message, lon
|
|||||||
|
|
||||||
bool NixUtils::triggerGlobalShortcut(uint keycode, uint modifiers)
|
bool NixUtils::triggerGlobalShortcut(uint keycode, uint modifiers)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
QHashIterator<QString, QSharedPointer<globalShortcut>> i(m_globalShortcuts);
|
QHashIterator<QString, QSharedPointer<globalShortcut>> i(m_globalShortcuts);
|
||||||
while (i.hasNext()) {
|
while (i.hasNext()) {
|
||||||
i.next();
|
i.next();
|
||||||
@ -282,7 +282,7 @@ bool NixUtils::triggerGlobalShortcut(uint keycode, uint modifiers)
|
|||||||
|
|
||||||
bool NixUtils::registerGlobalShortcut(const QString& name, Qt::Key key, Qt::KeyboardModifiers modifiers, QString* error)
|
bool NixUtils::registerGlobalShortcut(const QString& name, Qt::Key key, Qt::KeyboardModifiers modifiers, QString* error)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
auto keycode = XKeysymToKeycode(dpy, qcharToNativeKeyCode(key));
|
auto keycode = XKeysymToKeycode(dpy, qcharToNativeKeyCode(key));
|
||||||
auto modifierscode = qtToNativeModifiers(modifiers);
|
auto modifierscode = qtToNativeModifiers(modifiers);
|
||||||
|
|
||||||
@ -334,7 +334,7 @@ bool NixUtils::registerGlobalShortcut(const QString& name, Qt::Key key, Qt::Keyb
|
|||||||
|
|
||||||
bool NixUtils::unregisterGlobalShortcut(const QString& name)
|
bool NixUtils::unregisterGlobalShortcut(const QString& name)
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_X11
|
#ifdef WITH_X11
|
||||||
if (!m_globalShortcuts.contains(name)) {
|
if (!m_globalShortcuts.contains(name)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -21,11 +21,9 @@
|
|||||||
#include "ReportsPageHealthcheck.h"
|
#include "ReportsPageHealthcheck.h"
|
||||||
#include "ReportsPageHibp.h"
|
#include "ReportsPageHibp.h"
|
||||||
#include "ReportsPageStatistics.h"
|
#include "ReportsPageStatistics.h"
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
#include "ReportsPageBrowserStatistics.h"
|
#include "ReportsPageBrowserStatistics.h"
|
||||||
#include "ReportsWidgetBrowserStatistics.h"
|
#include "ReportsWidgetBrowserStatistics.h"
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
#include "ReportsPagePasskeys.h"
|
#include "ReportsPagePasskeys.h"
|
||||||
#include "ReportsWidgetPasskeys.h"
|
#include "ReportsWidgetPasskeys.h"
|
||||||
#endif
|
#endif
|
||||||
@ -63,10 +61,8 @@ ReportsDialog::ReportsDialog(QWidget* parent)
|
|||||||
, m_healthPage(new ReportsPageHealthcheck())
|
, m_healthPage(new ReportsPageHealthcheck())
|
||||||
, m_hibpPage(new ReportsPageHibp())
|
, m_hibpPage(new ReportsPageHibp())
|
||||||
, m_statPage(new ReportsPageStatistics())
|
, m_statPage(new ReportsPageStatistics())
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
, m_browserStatPage(new ReportsPageBrowserStatistics())
|
, m_browserStatPage(new ReportsPageBrowserStatistics())
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
, m_passkeysPage(new ReportsPagePasskeys())
|
, m_passkeysPage(new ReportsPagePasskeys())
|
||||||
#endif
|
#endif
|
||||||
, m_editEntryWidget(new EditEntryWidget(this))
|
, m_editEntryWidget(new EditEntryWidget(this))
|
||||||
@ -76,10 +72,8 @@ ReportsDialog::ReportsDialog(QWidget* parent)
|
|||||||
connect(m_ui->buttonBox, SIGNAL(rejected()), SLOT(reject()));
|
connect(m_ui->buttonBox, SIGNAL(rejected()), SLOT(reject()));
|
||||||
addPage(m_statPage);
|
addPage(m_statPage);
|
||||||
addPage(m_healthPage);
|
addPage(m_healthPage);
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
addPage(m_passkeysPage);
|
addPage(m_passkeysPage);
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER
|
|
||||||
addPage(m_browserStatPage);
|
addPage(m_browserStatPage);
|
||||||
#endif
|
#endif
|
||||||
addPage(m_hibpPage);
|
addPage(m_hibpPage);
|
||||||
@ -94,12 +88,10 @@ ReportsDialog::ReportsDialog(QWidget* parent)
|
|||||||
connect(m_ui->categoryList, SIGNAL(categoryChanged(int)), m_ui->stackedWidget, SLOT(setCurrentIndex(int)));
|
connect(m_ui->categoryList, SIGNAL(categoryChanged(int)), m_ui->stackedWidget, SLOT(setCurrentIndex(int)));
|
||||||
connect(m_healthPage->m_healthWidget, SIGNAL(entryActivated(Entry*)), SLOT(entryActivationSignalReceived(Entry*)));
|
connect(m_healthPage->m_healthWidget, SIGNAL(entryActivated(Entry*)), SLOT(entryActivationSignalReceived(Entry*)));
|
||||||
connect(m_hibpPage->m_hibpWidget, SIGNAL(entryActivated(Entry*)), SLOT(entryActivationSignalReceived(Entry*)));
|
connect(m_hibpPage->m_hibpWidget, SIGNAL(entryActivated(Entry*)), SLOT(entryActivationSignalReceived(Entry*)));
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
connect(m_browserStatPage->m_browserWidget,
|
connect(m_browserStatPage->m_browserWidget,
|
||||||
SIGNAL(entryActivated(Entry*)),
|
SIGNAL(entryActivated(Entry*)),
|
||||||
SLOT(entryActivationSignalReceived(Entry*)));
|
SLOT(entryActivationSignalReceived(Entry*)));
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
connect(
|
connect(
|
||||||
m_passkeysPage->m_passkeysWidget, SIGNAL(entryActivated(Entry*)), SLOT(entryActivationSignalReceived(Entry*)));
|
m_passkeysPage->m_passkeysWidget, SIGNAL(entryActivated(Entry*)), SLOT(entryActivationSignalReceived(Entry*)));
|
||||||
#endif
|
#endif
|
||||||
@ -128,23 +120,19 @@ void ReportsDialog::addPage(QSharedPointer<IReportsPage> page)
|
|||||||
m_ui->categoryList->setCurrentCategory(category);
|
m_ui->categoryList->setCurrentCategory(category);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void ReportsDialog::activatePasskeysPage()
|
void ReportsDialog::activatePasskeysPage()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
m_ui->stackedWidget->setCurrentWidget(m_passkeysPage->m_passkeysWidget);
|
m_ui->stackedWidget->setCurrentWidget(m_passkeysPage->m_passkeysWidget);
|
||||||
auto index = m_ui->stackedWidget->currentIndex();
|
auto index = m_ui->stackedWidget->currentIndex();
|
||||||
m_ui->categoryList->setCurrentCategory(index);
|
m_ui->categoryList->setCurrentCategory(index);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ReportsDialog::onPassKeysPage()
|
bool ReportsDialog::onPassKeysPage()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
return m_ui->stackedWidget->currentWidget() == m_passkeysPage->m_passkeysWidget;
|
return m_ui->stackedWidget->currentWidget() == m_passkeysPage->m_passkeysWidget;
|
||||||
#else
|
|
||||||
return false;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void ReportsDialog::reject()
|
void ReportsDialog::reject()
|
||||||
{
|
{
|
||||||
@ -176,12 +164,11 @@ void ReportsDialog::switchToMainView(bool previousDialogAccepted)
|
|||||||
} else if (m_sender == m_hibpPage->m_hibpWidget) {
|
} else if (m_sender == m_hibpPage->m_hibpWidget) {
|
||||||
m_hibpPage->m_hibpWidget->refreshAfterEdit();
|
m_hibpPage->m_hibpWidget->refreshAfterEdit();
|
||||||
}
|
}
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
if (m_sender == m_browserStatPage->m_browserWidget) {
|
if (m_sender == m_browserStatPage->m_browserWidget) {
|
||||||
m_browserStatPage->m_browserWidget->calculateBrowserStatistics();
|
m_browserStatPage->m_browserWidget->calculateBrowserStatistics();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
if (m_sender == m_passkeysPage->m_passkeysWidget) {
|
if (m_sender == m_passkeysPage->m_passkeysWidget) {
|
||||||
m_passkeysPage->m_passkeysWidget->updateEntries();
|
m_passkeysPage->m_passkeysWidget->updateEntries();
|
||||||
}
|
}
|
||||||
|
@ -29,10 +29,8 @@ class QTabWidget;
|
|||||||
class ReportsPageHealthcheck;
|
class ReportsPageHealthcheck;
|
||||||
class ReportsPageHibp;
|
class ReportsPageHibp;
|
||||||
class ReportsPageStatistics;
|
class ReportsPageStatistics;
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
class ReportsPageBrowserStatistics;
|
class ReportsPageBrowserStatistics;
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
class ReportsPagePasskeys;
|
class ReportsPagePasskeys;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -63,8 +61,11 @@ public:
|
|||||||
|
|
||||||
void load(const QSharedPointer<Database>& db);
|
void load(const QSharedPointer<Database>& db);
|
||||||
void addPage(QSharedPointer<IReportsPage> page);
|
void addPage(QSharedPointer<IReportsPage> page);
|
||||||
|
|
||||||
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
void activatePasskeysPage();
|
void activatePasskeysPage();
|
||||||
bool onPassKeysPage();
|
bool onPassKeysPage();
|
||||||
|
#endif
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void editFinished(bool accepted);
|
void editFinished(bool accepted);
|
||||||
@ -80,10 +81,8 @@ private:
|
|||||||
const QSharedPointer<ReportsPageHealthcheck> m_healthPage;
|
const QSharedPointer<ReportsPageHealthcheck> m_healthPage;
|
||||||
const QSharedPointer<ReportsPageHibp> m_hibpPage;
|
const QSharedPointer<ReportsPageHibp> m_hibpPage;
|
||||||
const QSharedPointer<ReportsPageStatistics> m_statPage;
|
const QSharedPointer<ReportsPageStatistics> m_statPage;
|
||||||
#ifdef WITH_XC_BROWSER
|
#ifdef KPXC_FEATURE_BROWSER
|
||||||
const QSharedPointer<ReportsPageBrowserStatistics> m_browserStatPage;
|
const QSharedPointer<ReportsPageBrowserStatistics> m_browserStatPage;
|
||||||
#endif
|
|
||||||
#ifdef WITH_XC_BROWSER_PASSKEYS
|
|
||||||
const QSharedPointer<ReportsPagePasskeys> m_passkeysPage;
|
const QSharedPointer<ReportsPagePasskeys> m_passkeysPage;
|
||||||
#endif
|
#endif
|
||||||
QPointer<EditEntryWidget> m_editEntryWidget;
|
QPointer<EditEntryWidget> m_editEntryWidget;
|
||||||
|
@ -71,7 +71,7 @@ ReportsWidgetHibp::ReportsWidgetHibp(QWidget* parent)
|
|||||||
connect(m_ui->hibpTableView, SIGNAL(doubleClicked(QModelIndex)), SLOT(emitEntryActivated(QModelIndex)));
|
connect(m_ui->hibpTableView, SIGNAL(doubleClicked(QModelIndex)), SLOT(emitEntryActivated(QModelIndex)));
|
||||||
connect(m_ui->hibpTableView, SIGNAL(customContextMenuRequested(QPoint)), SLOT(customMenuRequested(QPoint)));
|
connect(m_ui->hibpTableView, SIGNAL(customContextMenuRequested(QPoint)), SLOT(customMenuRequested(QPoint)));
|
||||||
connect(m_ui->showKnownBadCheckBox, SIGNAL(stateChanged(int)), this, SLOT(makeHibpTable()));
|
connect(m_ui->showKnownBadCheckBox, SIGNAL(stateChanged(int)), this, SLOT(makeHibpTable()));
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
connect(&m_downloader, SIGNAL(hibpResult(QString, int)), SLOT(addHibpResult(QString, int)));
|
connect(&m_downloader, SIGNAL(hibpResult(QString, int)), SLOT(addHibpResult(QString, int)));
|
||||||
connect(&m_downloader, SIGNAL(fetchFailed(QString)), SLOT(fetchFailed(QString)));
|
connect(&m_downloader, SIGNAL(fetchFailed(QString)), SLOT(fetchFailed(QString)));
|
||||||
|
|
||||||
@ -92,7 +92,7 @@ void ReportsWidgetHibp::loadSettings(QSharedPointer<Database> db)
|
|||||||
m_error.clear();
|
m_error.clear();
|
||||||
m_rowToEntry.clear();
|
m_rowToEntry.clear();
|
||||||
m_editedEntry = nullptr;
|
m_editedEntry = nullptr;
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
m_ui->stackedWidget->setCurrentIndex(0);
|
m_ui->stackedWidget->setCurrentIndex(0);
|
||||||
m_ui->validationButton->setEnabled(true);
|
m_ui->validationButton->setEnabled(true);
|
||||||
m_ui->progressBar->hide();
|
m_ui->progressBar->hide();
|
||||||
@ -188,7 +188,7 @@ void ReportsWidgetHibp::makeHibpTable()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// If we're done and everything is good, display a motivational message
|
// If we're done and everything is good, display a motivational message
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
if (m_downloader.passwordsRemaining() == 0 && m_pwndPasswords.isEmpty() && m_error.isEmpty()) {
|
if (m_downloader.passwordsRemaining() == 0 && m_pwndPasswords.isEmpty() && m_error.isEmpty()) {
|
||||||
m_referencesModel->clear();
|
m_referencesModel->clear();
|
||||||
m_referencesModel->setHorizontalHeaderLabels(QStringList() << tr("Congratulations, no exposed passwords!"));
|
m_referencesModel->setHorizontalHeaderLabels(QStringList() << tr("Congratulations, no exposed passwords!"));
|
||||||
@ -219,7 +219,7 @@ void ReportsWidgetHibp::addHibpResult(const QString& password, int count)
|
|||||||
m_pwndPasswords[password] = count;
|
m_pwndPasswords[password] = count;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
// Update the progress bar
|
// Update the progress bar
|
||||||
int remaining = m_downloader.passwordsRemaining();
|
int remaining = m_downloader.passwordsRemaining();
|
||||||
if (remaining > 0) {
|
if (remaining > 0) {
|
||||||
@ -249,7 +249,7 @@ void ReportsWidgetHibp::fetchFailed(const QString& error)
|
|||||||
*/
|
*/
|
||||||
void ReportsWidgetHibp::startValidation()
|
void ReportsWidgetHibp::startValidation()
|
||||||
{
|
{
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
// Collect all passwords in the database (unless recycled, and
|
// Collect all passwords in the database (unless recycled, and
|
||||||
// unless empty, and unless marked as "known bad") and submit them
|
// unless empty, and unless marked as "known bad") and submit them
|
||||||
// to the downloader.
|
// to the downloader.
|
||||||
@ -345,7 +345,7 @@ void ReportsWidgetHibp::refreshAfterEdit()
|
|||||||
m_pwndPasswords.remove(m_editedPassword);
|
m_pwndPasswords.remove(m_editedPassword);
|
||||||
|
|
||||||
// Validate the new password against HIBP
|
// Validate the new password against HIBP
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
m_downloader.add(m_editedEntry->password());
|
m_downloader.add(m_editedEntry->password());
|
||||||
m_downloader.validate();
|
m_downloader.validate();
|
||||||
#endif
|
#endif
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
#include "networking/HibpDownloader.h"
|
#include "networking/HibpDownloader.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -76,7 +76,7 @@ private:
|
|||||||
QString m_editedPassword; // The old password of the entry we're editing
|
QString m_editedPassword; // The old password of the entry we're editing
|
||||||
bool m_editedExcluded; // The old "known bad" flag of the entry we're editing
|
bool m_editedExcluded; // The old "known bad" flag of the entry we're editing
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
HibpDownloader m_downloader; // This performs the actual HIBP online query
|
HibpDownloader m_downloader; // This performs the actual HIBP online query
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
@ -1,18 +1,16 @@
|
|||||||
if(WITH_XC_KEESHARE)
|
set(keeshare_SOURCES
|
||||||
set(keeshare_SOURCES
|
SettingsPageKeeShare.cpp
|
||||||
SettingsPageKeeShare.cpp
|
SettingsWidgetKeeShare.cpp
|
||||||
SettingsWidgetKeeShare.cpp
|
DatabaseSettingsWidgetKeeShare.cpp
|
||||||
DatabaseSettingsWidgetKeeShare.cpp
|
group/EditGroupWidgetKeeShare.cpp
|
||||||
group/EditGroupWidgetKeeShare.cpp
|
group/EditGroupPageKeeShare.cpp
|
||||||
group/EditGroupPageKeeShare.cpp
|
KeeShare.cpp
|
||||||
KeeShare.cpp
|
KeeShareSettings.cpp
|
||||||
KeeShareSettings.cpp
|
ShareImport.cpp
|
||||||
ShareImport.cpp
|
ShareExport.cpp
|
||||||
ShareExport.cpp
|
ShareObserver.cpp
|
||||||
ShareObserver.cpp
|
)
|
||||||
)
|
|
||||||
|
|
||||||
add_library(keeshare STATIC ${keeshare_SOURCES})
|
add_library(keeshare STATIC ${keeshare_SOURCES})
|
||||||
target_link_libraries(keeshare PUBLIC Qt5::Core Qt5::Widgets ${BOTAN_LIBRARIES} ${ZLIB_LIBRARIES} PRIVATE ${MINIZIP_LIBRARIES})
|
target_link_libraries(keeshare PUBLIC Qt5::Core Qt5::Widgets ${BOTAN_LIBRARIES} ${ZLIB_LIBRARIES} PRIVATE ${MINIZIP_LIBRARIES})
|
||||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
endif(WITH_XC_KEESHARE)
|
|
||||||
|
@ -1,77 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2014 Kyle Manna <kyle@kylemanna.com>
|
|
||||||
* Copyright (C) 2017-2021 KeePassXC Team <team@keepassxc.org>
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 2 or (at your option)
|
|
||||||
* version 3 of the License.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "YubiKey.h"
|
|
||||||
|
|
||||||
YubiKey::YubiKey() = default;
|
|
||||||
|
|
||||||
YubiKey* YubiKey::m_instance(Q_NULLPTR);
|
|
||||||
|
|
||||||
YubiKey* YubiKey::instance()
|
|
||||||
{
|
|
||||||
if (!m_instance) {
|
|
||||||
m_instance = new YubiKey();
|
|
||||||
}
|
|
||||||
|
|
||||||
return m_instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool YubiKey::isInitialized()
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool YubiKey::findValidKeys()
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void YubiKey::findValidKeysAsync()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
YubiKey::KeyMap YubiKey::foundKeys()
|
|
||||||
{
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
|
|
||||||
int YubiKey::connectedKeys()
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
QString YubiKey::errorMessage()
|
|
||||||
{
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
|
|
||||||
bool YubiKey::testChallenge(YubiKeySlot slot, bool* wouldBlock)
|
|
||||||
{
|
|
||||||
Q_UNUSED(slot);
|
|
||||||
Q_UNUSED(wouldBlock);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
YubiKey::ChallengeResult YubiKey::challenge(YubiKeySlot slot, const QByteArray& chal, Botan::secure_vector<char>& resp)
|
|
||||||
{
|
|
||||||
Q_UNUSED(slot);
|
|
||||||
Q_UNUSED(chal);
|
|
||||||
Q_UNUSED(resp);
|
|
||||||
|
|
||||||
return YubiKey::ChallengeResult::YCR_ERROR;
|
|
||||||
}
|
|
@ -22,7 +22,7 @@
|
|||||||
#include <QHash>
|
#include <QHash>
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
|
||||||
#ifndef WITH_XC_NETWORKING
|
#ifndef KPXC_FEATURE_NETWORK
|
||||||
#error This file requires KeePassXC to be built with network support.
|
#error This file requires KeePassXC to be built with network support.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
#include "config-keepassx.h"
|
#include "config-keepassx.h"
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
|
|
||||||
#include "NetworkManager.h"
|
#include "NetworkManager.h"
|
||||||
|
|
||||||
|
@ -20,13 +20,13 @@
|
|||||||
|
|
||||||
#include "config-keepassx.h"
|
#include "config-keepassx.h"
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef KPXC_FEATURE_NETWORK
|
||||||
|
|
||||||
class QNetworkAccessManager;
|
class QNetworkAccessManager;
|
||||||
|
|
||||||
QNetworkAccessManager* getNetMgr();
|
QNetworkAccessManager* getNetMgr();
|
||||||
#else
|
#else
|
||||||
Q_STATIC_ASSERT_X(false, "Qt Networking used when WITH_XC_NETWORKING is disabled!");
|
Q_STATIC_ASSERT_X(false, "Qt Networking used when KPXC_FEATURE_NETWORK is disabled!");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif // KEEPASSXC_NETWORKMANAGER_H
|
#endif // KEEPASSXC_NETWORKMANAGER_H
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
if(WITH_XC_BROWSER)
|
if(KPXC_FEATURE_BROWSER)
|
||||||
set(proxy_SOURCES
|
set(proxy_SOURCES
|
||||||
../browser/BrowserShared.cpp
|
../browser/BrowserShared.cpp
|
||||||
keepassxc-proxy.cpp
|
keepassxc-proxy.cpp
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
if(WITH_XC_SSHAGENT)
|
if(KPXC_FEATURE_SSHAGENT)
|
||||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
set(sshagent_SOURCES
|
set(sshagent_SOURCES
|
||||||
|
@ -127,7 +127,7 @@ namespace OpenSSHKeyGen
|
|||||||
QByteArray privateData;
|
QByteArray privateData;
|
||||||
BinaryStream privateStream(&privateData);
|
BinaryStream privateStream(&privateData);
|
||||||
vectorToStream(ed25519Key.get_public_key(), privateStream);
|
vectorToStream(ed25519Key.get_public_key(), privateStream);
|
||||||
#ifdef WITH_XC_BOTAN3
|
#ifdef WITH_BOTAN3
|
||||||
vectorToStream(ed25519Key.raw_private_key_bits(), privateStream);
|
vectorToStream(ed25519Key.raw_private_key_bits(), privateStream);
|
||||||
#else
|
#else
|
||||||
vectorToStream(ed25519Key.get_private_key(), privateStream);
|
vectorToStream(ed25519Key.get_private_key(), privateStream);
|
||||||
|
6
src/thirdparty/CMakeLists.txt
vendored
6
src/thirdparty/CMakeLists.txt
vendored
@ -13,7 +13,5 @@
|
|||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
if(WITH_XC_YUBIKEY)
|
add_subdirectory(ykcore)
|
||||||
add_subdirectory(ykcore)
|
set(thirdparty_LIBRARIES ${thirdparty_LIBRARIES} ykcore PARENT_SCOPE)
|
||||||
set(thirdparty_LIBRARIES ${thirdparty_LIBRARIES} ykcore PARENT_SCOPE)
|
|
||||||
endif()
|
|
||||||
|
@ -76,18 +76,6 @@ macro(add_unit_test)
|
|||||||
endif(KDE4_TEST_OUTPUT STREQUAL "xml")
|
endif(KDE4_TEST_OUTPUT STREQUAL "xml")
|
||||||
|
|
||||||
set_tests_properties(${_test_NAME} PROPERTIES ENVIRONMENT "LANG=en_US.UTF-8")
|
set_tests_properties(${_test_NAME} PROPERTIES ENVIRONMENT "LANG=en_US.UTF-8")
|
||||||
|
|
||||||
if(NOT MSVC_IDE) #not needed for the ide
|
|
||||||
# if the tests are EXCLUDE_FROM_ALL, add a target "buildtests" to build all tests
|
|
||||||
if(NOT WITH_TESTS)
|
|
||||||
get_directory_property(_buildtestsAdded BUILDTESTS_ADDED)
|
|
||||||
if(NOT _buildtestsAdded)
|
|
||||||
add_custom_target(buildtests)
|
|
||||||
set_directory_properties(PROPERTIES BUILDTESTS_ADDED TRUE)
|
|
||||||
endif()
|
|
||||||
add_dependencies(buildtests ${_test_NAME})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endmacro(add_unit_test)
|
endmacro(add_unit_test)
|
||||||
|
|
||||||
set(TEST_LIBRARIES keepassxc_gui Qt5::Test)
|
set(TEST_LIBRARIES keepassxc_gui Qt5::Test)
|
||||||
@ -145,27 +133,9 @@ add_unit_test(NAME testkeepass1reader SOURCES TestKeePass1Reader.cpp
|
|||||||
add_unit_test(NAME testimports SOURCES TestImports.cpp
|
add_unit_test(NAME testimports SOURCES TestImports.cpp
|
||||||
LIBS ${TEST_LIBRARIES})
|
LIBS ${TEST_LIBRARIES})
|
||||||
|
|
||||||
if(WITH_XC_NETWORKING)
|
add_unit_test(NAME testautotype SOURCES TestAutoType.cpp
|
||||||
add_unit_test(NAME testupdatecheck SOURCES TestUpdateCheck.cpp
|
LIBS ${TEST_LIBRARIES})
|
||||||
LIBS ${TEST_LIBRARIES})
|
set_target_properties(testautotype PROPERTIES ENABLE_EXPORTS ON)
|
||||||
|
|
||||||
add_unit_test(NAME testicondownloader SOURCES TestIconDownloader.cpp LIBS ${TEST_LIBRARIES})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_AUTOTYPE)
|
|
||||||
add_unit_test(NAME testautotype SOURCES TestAutoType.cpp
|
|
||||||
LIBS ${TEST_LIBRARIES})
|
|
||||||
set_target_properties(testautotype PROPERTIES ENABLE_EXPORTS ON)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_SSHAGENT)
|
|
||||||
add_unit_test(NAME testopensshkey SOURCES TestOpenSSHKey.cpp
|
|
||||||
LIBS sshagent ${TEST_LIBRARIES})
|
|
||||||
if(NOT WIN32)
|
|
||||||
add_unit_test(NAME testsshagent SOURCES TestSSHAgent.cpp
|
|
||||||
LIBS sshagent ${TEST_LIBRARIES})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_unit_test(NAME testentry SOURCES TestEntry.cpp
|
add_unit_test(NAME testentry SOURCES TestEntry.cpp
|
||||||
LIBS ${TEST_LIBRARIES})
|
LIBS ${TEST_LIBRARIES})
|
||||||
@ -203,16 +173,11 @@ add_unit_test(NAME testentrysearcher SOURCES TestEntrySearcher.cpp
|
|||||||
add_unit_test(NAME testcsvexporter SOURCES TestCsvExporter.cpp
|
add_unit_test(NAME testcsvexporter SOURCES TestCsvExporter.cpp
|
||||||
LIBS ${TEST_LIBRARIES})
|
LIBS ${TEST_LIBRARIES})
|
||||||
|
|
||||||
if(WITH_XC_YUBIKEY)
|
add_unit_test(NAME testykchallengeresponsekey SOURCES TestYkChallengeResponseKey.cpp
|
||||||
add_unit_test(NAME testykchallengeresponsekey
|
|
||||||
SOURCES TestYkChallengeResponseKey.cpp
|
|
||||||
LIBS ${TEST_LIBRARIES})
|
LIBS ${TEST_LIBRARIES})
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_KEESHARE)
|
add_unit_test(NAME testsharing SOURCES TestSharing.cpp
|
||||||
add_unit_test(NAME testsharing SOURCES TestSharing.cpp
|
|
||||||
LIBS testsupport ${TEST_LIBRARIES})
|
LIBS testsupport ${TEST_LIBRARIES})
|
||||||
endif()
|
|
||||||
|
|
||||||
add_unit_test(NAME testdatabase SOURCES TestDatabase.cpp
|
add_unit_test(NAME testdatabase SOURCES TestDatabase.cpp
|
||||||
LIBS testsupport ${TEST_LIBRARIES})
|
LIBS testsupport ${TEST_LIBRARIES})
|
||||||
@ -223,29 +188,44 @@ add_unit_test(NAME testtools SOURCES TestTools.cpp
|
|||||||
add_unit_test(NAME testconfig SOURCES TestConfig.cpp
|
add_unit_test(NAME testconfig SOURCES TestConfig.cpp
|
||||||
LIBS testsupport ${TEST_LIBRARIES})
|
LIBS testsupport ${TEST_LIBRARIES})
|
||||||
|
|
||||||
if(WITH_XC_FDOSECRETS)
|
|
||||||
add_unit_test(NAME testfdosecrets SOURCES TestFdoSecrets.cpp
|
|
||||||
LIBS testsupport fdosecrets ${TEST_LIBRARIES})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_BROWSER)
|
|
||||||
add_unit_test(NAME testbrowser SOURCES TestBrowser.cpp
|
|
||||||
LIBS browser ${TEST_LIBRARIES})
|
|
||||||
|
|
||||||
if(WITH_XC_BROWSER_PASSKEYS)
|
|
||||||
add_unit_test(NAME testpasskeys SOURCES TestPasskeys.cpp
|
|
||||||
LIBS browser ${TEST_LIBRARIES})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WITH_XC_NETWORKING OR WITH_XC_BROWSER)
|
|
||||||
add_unit_test(NAME testurltools SOURCES TestUrlTools.cpp LIBS ${TEST_LIBRARIES})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_unit_test(NAME testcli SOURCES TestCli.cpp
|
add_unit_test(NAME testcli SOURCES TestCli.cpp
|
||||||
LIBS testsupport cli ${ZXCVBN_LIBRARIES} ${TEST_LIBRARIES})
|
LIBS testsupport cli ${ZXCVBN_LIBRARIES} ${TEST_LIBRARIES})
|
||||||
target_compile_definitions(testcli PRIVATE KEEPASSX_CLI_PATH="$<TARGET_FILE:keepassxc-cli>")
|
target_compile_definitions(testcli PRIVATE KEEPASSX_CLI_PATH="$<TARGET_FILE:keepassxc-cli>")
|
||||||
|
|
||||||
|
if(KPXC_FEATURE_SSHAGENT)
|
||||||
|
add_unit_test(NAME testopensshkey SOURCES TestOpenSSHKey.cpp
|
||||||
|
LIBS sshagent ${TEST_LIBRARIES})
|
||||||
|
if(NOT WIN32)
|
||||||
|
add_unit_test(NAME testsshagent SOURCES TestSSHAgent.cpp
|
||||||
|
LIBS sshagent ${TEST_LIBRARIES})
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(KPXC_FEATURE_FDOSECRETS)
|
||||||
|
add_unit_test(NAME testfdosecrets SOURCES TestFdoSecrets.cpp
|
||||||
|
LIBS testsupport fdosecrets ${TEST_LIBRARIES})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(KPXC_FEATURE_BROWSER)
|
||||||
|
add_unit_test(NAME testbrowser SOURCES TestBrowser.cpp
|
||||||
|
LIBS browser ${TEST_LIBRARIES})
|
||||||
|
|
||||||
|
add_unit_test(NAME testpasskeys SOURCES TestPasskeys.cpp
|
||||||
|
LIBS browser ${TEST_LIBRARIES})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(KPXC_FEATURE_NETWORK OR KPXC_FEATURE_BROWSER)
|
||||||
|
add_unit_test(NAME testurltools SOURCES TestUrlTools.cpp LIBS ${TEST_LIBRARIES})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(KPXC_FEATURE_NETWORK)
|
||||||
|
add_unit_test(NAME testupdatecheck SOURCES TestUpdateCheck.cpp
|
||||||
|
LIBS ${TEST_LIBRARIES})
|
||||||
|
|
||||||
|
add_unit_test(NAME testicondownloader SOURCES TestIconDownloader.cpp
|
||||||
|
LIBS ${TEST_LIBRARIES})
|
||||||
|
endif()
|
||||||
|
|
||||||
if(WITH_GUI_TESTS)
|
if(WITH_GUI_TESTS)
|
||||||
add_subdirectory(gui)
|
add_subdirectory(gui)
|
||||||
endif(WITH_GUI_TESTS)
|
endif()
|
||||||
|
@ -5,7 +5,4 @@
|
|||||||
|
|
||||||
#define KEEPASSX_TEST_DATA_DIR "${KEEPASSX_TEST_DATA_DIR}"
|
#define KEEPASSX_TEST_DATA_DIR "${KEEPASSX_TEST_DATA_DIR}"
|
||||||
|
|
||||||
#cmakedefine WITH_XC_AUTOTYPE
|
|
||||||
#cmakedefine WITH_XC_YUBIKEY
|
|
||||||
|
|
||||||
#endif // KEEPASSX_CONFIG_TESTS_H
|
#endif // KEEPASSX_CONFIG_TESTS_H
|
||||||
|
@ -18,11 +18,11 @@ include_directories(${CMAKE_CURRENT_SOURCE_DIR}/..)
|
|||||||
add_unit_test(NAME testgui SOURCES TestGui.cpp ../util/TemporaryFile.cpp ../mock/MockRemoteProcess.cpp LIBS ${TEST_LIBRARIES})
|
add_unit_test(NAME testgui SOURCES TestGui.cpp ../util/TemporaryFile.cpp ../mock/MockRemoteProcess.cpp LIBS ${TEST_LIBRARIES})
|
||||||
add_unit_test(NAME testguipixmaps SOURCES TestGuiPixmaps.cpp LIBS ${TEST_LIBRARIES})
|
add_unit_test(NAME testguipixmaps SOURCES TestGuiPixmaps.cpp LIBS ${TEST_LIBRARIES})
|
||||||
|
|
||||||
if(WITH_XC_BROWSER)
|
if(KPXC_FEATURE_BROWSER)
|
||||||
add_unit_test(NAME testguibrowser SOURCES TestGuiBrowser.cpp ../util/TemporaryFile.cpp LIBS ${TEST_LIBRARIES})
|
add_unit_test(NAME testguibrowser SOURCES TestGuiBrowser.cpp ../util/TemporaryFile.cpp LIBS ${TEST_LIBRARIES})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WITH_XC_FDOSECRETS)
|
if(KPXC_FEATURE_FDOSECRETS)
|
||||||
add_unit_test(NAME testguifdosecrets
|
add_unit_test(NAME testguifdosecrets
|
||||||
SOURCES TestGuiFdoSecrets.cpp ../util/TemporaryFile.cpp ../util/FdoSecretsProxy.cpp
|
SOURCES TestGuiFdoSecrets.cpp ../util/TemporaryFile.cpp ../util/FdoSecretsProxy.cpp
|
||||||
LIBS ${TEST_LIBRARIES}
|
LIBS ${TEST_LIBRARIES}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user