safePasswords #36
@ -1,7 +1,6 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
## Squawk 0.1.4 (UNRELEASED)
|
## Squawk 0.1.4 (UNRELEASED)
|
||||||
------------------------------
|
|
||||||
### New features
|
### New features
|
||||||
- several ways to manage your account password:
|
- several ways to manage your account password:
|
||||||
- store it in plain text with the config (like it always was)
|
- store it in plain text with the config (like it always was)
|
||||||
@ -14,7 +13,6 @@
|
|||||||
|
|
||||||
|
|
||||||
## Squawk 0.1.3 (Mar 31, 2020)
|
## Squawk 0.1.3 (Mar 31, 2020)
|
||||||
------------------------------
|
|
||||||
### New features
|
### New features
|
||||||
- delivery states for the messages
|
- delivery states for the messages
|
||||||
- delivery receipts now work for real
|
- delivery receipts now work for real
|
||||||
@ -32,7 +30,6 @@
|
|||||||
|
|
||||||
|
|
||||||
## Squawk 0.1.2 (Dec 25, 2019)
|
## Squawk 0.1.2 (Dec 25, 2019)
|
||||||
------------------------------
|
|
||||||
### New features
|
### New features
|
||||||
- icons in roster for conferences
|
- icons in roster for conferences
|
||||||
- pal avatar in dialog window
|
- pal avatar in dialog window
|
||||||
@ -50,7 +47,6 @@
|
|||||||
|
|
||||||
|
|
||||||
## Squawk 0.1.1 (Nov 16, 2019)
|
## Squawk 0.1.1 (Nov 16, 2019)
|
||||||
------------------------------
|
|
||||||
A lot of bug fixes, memory leaks fixes
|
A lot of bug fixes, memory leaks fixes
|
||||||
### New features
|
### New features
|
||||||
- exchange files via HTTP File Upload
|
- exchange files via HTTP File Upload
|
||||||
@ -60,7 +56,6 @@ A lot of bug fixes, memory leaks fixes
|
|||||||
|
|
||||||
|
|
||||||
## Squawk 0.0.5 (Oct 10, 2019)
|
## Squawk 0.0.5 (Oct 10, 2019)
|
||||||
------------------------------
|
|
||||||
### Features
|
### Features
|
||||||
- chat directly
|
- chat directly
|
||||||
- have multiple accounts
|
- have multiple accounts
|
||||||
|
@ -23,13 +23,14 @@ set(squawkCORE_SRC
|
|||||||
# Tell CMake to create the helloworld executable
|
# Tell CMake to create the helloworld executable
|
||||||
add_library(squawkCORE ${squawkCORE_SRC})
|
add_library(squawkCORE ${squawkCORE_SRC})
|
||||||
|
|
||||||
|
add_subdirectory(passwordStorageEngines)
|
||||||
|
|
||||||
if(SYSTEM_QXMPP)
|
if(SYSTEM_QXMPP)
|
||||||
find_package(QXmpp CONFIG REQUIRED)
|
find_package(QXmpp CONFIG REQUIRED)
|
||||||
get_target_property(QXMPP_INTERFACE_INCLUDE_DIRECTORIES QXmpp::QXmpp INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(QXMPP_INTERFACE_INCLUDE_DIRECTORIES QXmpp::QXmpp INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
target_include_directories(squawkCORE PUBLIC ${QXMPP_INTERFACE_INCLUDE_DIRECTORIES})
|
target_include_directories(squawkCORE PUBLIC ${QXMPP_INTERFACE_INCLUDE_DIRECTORIES})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
# Use the Widgets module from Qt 5.
|
# Use the Widgets module from Qt 5.
|
||||||
target_link_libraries(squawkCORE Qt5::Core)
|
target_link_libraries(squawkCORE Qt5::Core)
|
||||||
target_link_libraries(squawkCORE Qt5::Network)
|
target_link_libraries(squawkCORE Qt5::Network)
|
||||||
@ -38,3 +39,4 @@ target_link_libraries(squawkCORE Qt5::Xml)
|
|||||||
target_link_libraries(squawkCORE qxmpp)
|
target_link_libraries(squawkCORE qxmpp)
|
||||||
target_link_libraries(squawkCORE lmdb)
|
target_link_libraries(squawkCORE lmdb)
|
||||||
target_link_libraries(squawkCORE simpleCrypt)
|
target_link_libraries(squawkCORE simpleCrypt)
|
||||||
|
target_link_libraries(squawkCORE kwalletPSE)
|
||||||
|
36
core/passwordStorageEngines/CMakeLists.txt
Normal file
36
core/passwordStorageEngines/CMakeLists.txt
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.0)
|
||||||
|
project(pse)
|
||||||
|
|
||||||
|
set(CMAKE_AUTOMOC ON)
|
||||||
|
|
||||||
|
find_package(Qt5Core CONFIG REQUIRED)
|
||||||
|
find_package(Qt5Gui CONFIG REQUIRED)
|
||||||
|
find_package(KF5Wallet CONFIG REQUIRED)
|
||||||
|
|
||||||
|
get_target_property(KWALLET_INTERFACE_INCLUDE_DIRECTORIES KF5::Wallet INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
|
get_target_property(Qt5GUI_INTERFACE_INCLUDE_DIRECTORIES Qt5::Gui INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
|
|
||||||
|
set(kwalletPSE_SRC
|
||||||
|
kwallet.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(kwalletPSE ${kwalletPSE_SRC})
|
||||||
|
|
||||||
|
target_include_directories(kwalletPSE PUBLIC ${KWALLET_INTERFACE_INCLUDE_DIRECTORIES})
|
||||||
|
target_include_directories(kwalletPSE PUBLIC ${Qt5GUI_INTERFACE_INCLUDE_DIRECTORIES})
|
||||||
|
|
||||||
|
target_link_libraries(kwalletPSE Qt5::Core)
|
||||||
|
|
||||||
|
set(kwalletW_SRC
|
||||||
|
wrappers/kwallet.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(kwalletWrapper SHARED ${kwalletW_SRC})
|
||||||
|
|
||||||
|
target_include_directories(kwalletWrapper PUBLIC ${KWALLET_INTERFACE_INCLUDE_DIRECTORIES})
|
||||||
|
target_include_directories(kwalletWrapper PUBLIC ${Qt5GUI_INTERFACE_INCLUDE_DIRECTORIES})
|
||||||
|
|
||||||
|
target_link_libraries(kwalletWrapper KF5::Wallet)
|
||||||
|
target_link_libraries(kwalletWrapper Qt5::Core)
|
||||||
|
|
||||||
|
install(TARGETS kwalletWrapper DESTINATION ${CMAKE_INSTALL_LIBDIR})
|
227
core/passwordStorageEngines/kwallet.cpp
Normal file
227
core/passwordStorageEngines/kwallet.cpp
Normal file
@ -0,0 +1,227 @@
|
|||||||
|
/*
|
||||||
|
* Squawk messenger.
|
||||||
|
* Copyright (C) 2019 Yury Gubich <blue@macaw.me>
|
||||||
|
*
|
||||||
|
* 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 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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 "kwallet.h"
|
||||||
|
|
||||||
|
Core::PSE::KWallet::OpenWallet Core::PSE::KWallet::openWallet = 0;
|
||||||
|
Core::PSE::KWallet::NetworkWallet Core::PSE::KWallet::networkWallet = 0;
|
||||||
|
Core::PSE::KWallet::DeleteWallet Core::PSE::KWallet::deleteWallet = 0;
|
||||||
|
Core::PSE::KWallet::ReadPassword Core::PSE::KWallet::readPassword = 0;
|
||||||
|
Core::PSE::KWallet::WritePassword Core::PSE::KWallet::writePassword = 0;
|
||||||
|
Core::PSE::KWallet::HasFolder Core::PSE::KWallet::hasFolder = 0;
|
||||||
|
Core::PSE::KWallet::CreateFolder Core::PSE::KWallet::createFolder = 0;
|
||||||
|
Core::PSE::KWallet::SetFolder Core::PSE::KWallet::setFolder = 0;
|
||||||
|
|
||||||
|
Core::PSE::KWallet::SupportState Core::PSE::KWallet::sState = Core::PSE::KWallet::initial;
|
||||||
|
QLibrary Core::PSE::KWallet::lib("./libkwalletWrapper.so");
|
||||||
|
|
||||||
|
Core::PSE::KWallet::KWallet():
|
||||||
|
QObject(),
|
||||||
|
cState(disconnected),
|
||||||
|
everError(false),
|
||||||
|
wallet(0),
|
||||||
|
readRequest(),
|
||||||
|
writeRequest()
|
||||||
|
{
|
||||||
|
if (sState == initial) {
|
||||||
|
lib.load();
|
||||||
|
|
||||||
|
if (lib.isLoaded()) {
|
||||||
|
openWallet = (OpenWallet) lib.resolve("openWallet");
|
||||||
|
networkWallet = (NetworkWallet) lib.resolve("networkWallet");
|
||||||
|
deleteWallet = (DeleteWallet) lib.resolve("deleteWallet");
|
||||||
|
readPassword = (ReadPassword) lib.resolve("readPassword");
|
||||||
|
writePassword = (WritePassword) lib.resolve("writePassword");
|
||||||
|
hasFolder = (HasFolder) lib.resolve("hasFolder");
|
||||||
|
createFolder = (CreateFolder) lib.resolve("createFolder");
|
||||||
|
setFolder = (SetFolder) lib.resolve("setFolder");
|
||||||
|
|
||||||
|
if (openWallet
|
||||||
|
&& networkWallet
|
||||||
|
&& deleteWallet
|
||||||
|
&& readPassword
|
||||||
|
&& writePassword
|
||||||
|
) {
|
||||||
|
sState = success;
|
||||||
|
} else {
|
||||||
|
sState = failure;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sState = failure;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Core::PSE::KWallet::~KWallet()
|
||||||
|
{
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::open()
|
||||||
|
{
|
||||||
|
if (sState == success) {
|
||||||
|
if (cState == disconnected) {
|
||||||
|
wallet = openWallet(networkWallet(), 0, ::KWallet::Wallet::Asynchronous);
|
||||||
|
if (wallet) {
|
||||||
|
cState = connecting;
|
||||||
|
connect(wallet, SIGNAL(walletOpened(bool)), this, SLOT(onWalletOpened(bool)));
|
||||||
|
connect(wallet, SIGNAL(walletClosed()), this, SLOT(onWalletClosed()));
|
||||||
|
} else {
|
||||||
|
everError = true;
|
||||||
|
emit opened(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Core::PSE::KWallet::ConnectionState Core::PSE::KWallet::connectionState()
|
||||||
|
{
|
||||||
|
return cState;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::close()
|
||||||
|
{
|
||||||
|
if (sState == success) {
|
||||||
|
if (cState != disconnected) {
|
||||||
|
deleteWallet(wallet);
|
||||||
|
wallet = 0;
|
||||||
|
}
|
||||||
|
rejectPending();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::onWalletClosed()
|
||||||
|
{
|
||||||
|
cState = disconnected;
|
||||||
|
deleteWallet(wallet);
|
||||||
|
wallet = 0;
|
||||||
|
emit closed();
|
||||||
|
rejectPending();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::onWalletOpened(bool success)
|
||||||
|
{
|
||||||
|
emit opened(success);
|
||||||
|
if (success) {
|
||||||
|
QString appName = QCoreApplication::applicationName();
|
||||||
|
if (!hasFolder(wallet, appName)) {
|
||||||
|
createFolder(wallet, appName);
|
||||||
|
}
|
||||||
|
setFolder(wallet, appName);
|
||||||
|
cState = connected;
|
||||||
|
readPending();
|
||||||
|
} else {
|
||||||
|
everError = true;
|
||||||
|
cState = disconnected;
|
||||||
|
deleteWallet(wallet);
|
||||||
|
wallet = 0;
|
||||||
|
rejectPending();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Core::PSE::KWallet::SupportState Core::PSE::KWallet::supportState()
|
||||||
|
{
|
||||||
|
return sState;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Core::PSE::KWallet::everHadError() const
|
||||||
|
{
|
||||||
|
return everError;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::resetEverHadError()
|
||||||
|
{
|
||||||
|
everError = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::requestReadPassword(const QString& login, bool askAgain)
|
||||||
|
{
|
||||||
|
if (sState == success) {
|
||||||
|
readRequest.insert(login);
|
||||||
|
readSwitch(askAgain);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::requestWritePassword(const QString& login, const QString& password, bool askAgain)
|
||||||
|
{
|
||||||
|
if (sState == success) {
|
||||||
|
std::map<QString, QString>::iterator itr = writeRequest.find(login);
|
||||||
|
if (itr == writeRequest.end()) {
|
||||||
|
writeRequest.insert(std::make_pair(login, password));
|
||||||
|
} else {
|
||||||
|
itr->second = password;
|
||||||
|
}
|
||||||
|
readSwitch(askAgain);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::readSwitch(bool askAgain)
|
||||||
|
{
|
||||||
|
switch (cState) {
|
||||||
|
case connected:
|
||||||
|
readPending();
|
||||||
|
break;
|
||||||
|
case connecting:
|
||||||
|
break;
|
||||||
|
case disconnected:
|
||||||
|
if (!everError || askAgain) {
|
||||||
|
open();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::rejectPending()
|
||||||
|
{
|
||||||
|
writeRequest.clear();
|
||||||
|
std::set<QString>::const_iterator i = readRequest.begin();
|
||||||
|
while (i != readRequest.end()) {
|
||||||
|
emit rejectPassword(*i);
|
||||||
|
readRequest.erase(i);
|
||||||
|
i = readRequest.begin();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::PSE::KWallet::readPending()
|
||||||
|
{
|
||||||
|
std::map<QString, QString>::const_iterator itr = writeRequest.begin();
|
||||||
|
while (itr != writeRequest.end()) {
|
||||||
|
int result = writePassword(wallet, itr->first, itr->second);
|
||||||
|
if (result == 0) {
|
||||||
|
qDebug() << "Successfully saved password for user" << itr->first;
|
||||||
|
} else {
|
||||||
|
qDebug() << "Error writing password for user" << itr->first << ":" << result;
|
||||||
|
}
|
||||||
|
writeRequest.erase(itr);
|
||||||
|
itr = writeRequest.begin();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::set<QString>::const_iterator i = readRequest.begin();
|
||||||
|
while (i != readRequest.end()) {
|
||||||
|
QString password;
|
||||||
|
int result = readPassword(wallet, *i, password);
|
||||||
|
if (result == 0 && password.size() > 0) { //even though it's written that the error is supposed to be returned in case there were no password
|
||||||
|
emit responsePassword(*i, password); //it doesn't do so. I assume empty password as a lack of password in KWallet
|
||||||
|
} else {
|
||||||
|
emit rejectPassword(*i);
|
||||||
|
}
|
||||||
|
readRequest.erase(i);
|
||||||
|
i = readRequest.begin();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
112
core/passwordStorageEngines/kwallet.h
Normal file
112
core/passwordStorageEngines/kwallet.h
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
/*
|
||||||
|
* Squawk messenger.
|
||||||
|
* Copyright (C) 2019 Yury Gubich <blue@macaw.me>
|
||||||
|
*
|
||||||
|
* 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 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef CORE_PSE_KWALLET_H
|
||||||
|
#define CORE_PSE_KWALLET_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QLibrary>
|
||||||
|
#include <QDebug>
|
||||||
|
#include <QCoreApplication>
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <set>
|
||||||
|
|
||||||
|
#include <KF5/KWallet/KWallet>
|
||||||
|
|
||||||
|
namespace Core {
|
||||||
|
namespace PSE {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @todo write docs
|
||||||
|
*/
|
||||||
|
class KWallet : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
enum SupportState {
|
||||||
|
initial,
|
||||||
|
success,
|
||||||
|
failure
|
||||||
|
};
|
||||||
|
enum ConnectionState {
|
||||||
|
disconnected,
|
||||||
|
connecting,
|
||||||
|
connected
|
||||||
|
};
|
||||||
|
|
||||||
|
KWallet();
|
||||||
|
~KWallet();
|
||||||
|
|
||||||
|
static SupportState supportState();
|
||||||
|
void open();
|
||||||
|
void close();
|
||||||
|
ConnectionState connectionState();
|
||||||
|
bool everHadError() const;
|
||||||
|
void resetEverHadError();
|
||||||
|
void requestReadPassword(const QString& login, bool askAgain = false);
|
||||||
|
void requestWritePassword(const QString& login, const QString& password, bool askAgain = false);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void opened(bool success);
|
||||||
|
void closed();
|
||||||
|
void responsePassword(const QString& login, const QString& password);
|
||||||
|
void rejectPassword(const QString& login);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void onWalletOpened(bool success);
|
||||||
|
void onWalletClosed();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void readSwitch(bool askAgain);
|
||||||
|
void readPending();
|
||||||
|
void rejectPending();
|
||||||
|
|
||||||
|
private:
|
||||||
|
typedef ::KWallet::Wallet* (*OpenWallet)(const QString &, WId, ::KWallet::Wallet::OpenType);
|
||||||
|
typedef const char* (*NetworkWallet)();
|
||||||
|
typedef void (*DeleteWallet)(::KWallet::Wallet*);
|
||||||
|
typedef int (*ReadPassword)(::KWallet::Wallet*, const QString&, QString&);
|
||||||
|
typedef int (*WritePassword)(::KWallet::Wallet*, const QString&, const QString&);
|
||||||
|
typedef bool (*HasFolder)(::KWallet::Wallet* w, const QString &f);
|
||||||
|
typedef bool (*CreateFolder)(::KWallet::Wallet* w, const QString &f);
|
||||||
|
typedef bool (*SetFolder)(::KWallet::Wallet* w, const QString &f);
|
||||||
|
|
||||||
|
static OpenWallet openWallet;
|
||||||
|
static NetworkWallet networkWallet;
|
||||||
|
static DeleteWallet deleteWallet;
|
||||||
|
static ReadPassword readPassword;
|
||||||
|
static WritePassword writePassword;
|
||||||
|
static HasFolder hasFolder;
|
||||||
|
static CreateFolder createFolder;
|
||||||
|
static SetFolder setFolder;
|
||||||
|
|
||||||
|
static SupportState sState;
|
||||||
|
static QLibrary lib;
|
||||||
|
|
||||||
|
ConnectionState cState;
|
||||||
|
bool everError;
|
||||||
|
::KWallet::Wallet* wallet;
|
||||||
|
|
||||||
|
std::set<QString> readRequest;
|
||||||
|
std::map<QString, QString> writeRequest;
|
||||||
|
};
|
||||||
|
|
||||||
|
}}
|
||||||
|
|
||||||
|
#endif // CORE_PSE_KWALLET_H
|
33
core/passwordStorageEngines/wrappers/kwallet.cpp
Normal file
33
core/passwordStorageEngines/wrappers/kwallet.cpp
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
#include <KF5/KWallet/KWallet>
|
||||||
|
|
||||||
|
extern "C" KWallet::Wallet* openWallet(const QString &name, WId w, KWallet::Wallet::OpenType ot = KWallet::Wallet::Synchronous) {
|
||||||
|
return KWallet::Wallet::openWallet(name, w, ot);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" void deleteWallet(KWallet::Wallet* w) {
|
||||||
|
w->deleteLater();
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" const char* networkWallet() {
|
||||||
|
return KWallet::Wallet::NetworkWallet().toStdString().c_str();
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int readPassword(KWallet::Wallet* w, const QString &key, QString &value) {
|
||||||
|
return w->readPassword(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int writePassword(KWallet::Wallet* w, const QString &key, const QString &value) {
|
||||||
|
return w->writePassword(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" bool hasFolder(KWallet::Wallet* w, const QString &f) {
|
||||||
|
return w->hasFolder(f);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" bool createFolder(KWallet::Wallet* w, const QString &f) {
|
||||||
|
return w->createFolder(f);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" bool setFolder(KWallet::Wallet* w, const QString &f) {
|
||||||
|
return w->setFolder(f);
|
||||||
|
}
|
@ -27,13 +27,22 @@ Core::Squawk::Squawk(QObject* parent):
|
|||||||
accounts(),
|
accounts(),
|
||||||
amap(),
|
amap(),
|
||||||
network(),
|
network(),
|
||||||
waitingForAccounts(0)
|
waitingForAccounts(0),
|
||||||
|
kwallet()
|
||||||
{
|
{
|
||||||
connect(&network, &NetworkAccess::fileLocalPathResponse, this, &Squawk::fileLocalPathResponse);
|
connect(&network, &NetworkAccess::fileLocalPathResponse, this, &Squawk::fileLocalPathResponse);
|
||||||
connect(&network, &NetworkAccess::downloadFileProgress, this, &Squawk::downloadFileProgress);
|
connect(&network, &NetworkAccess::downloadFileProgress, this, &Squawk::downloadFileProgress);
|
||||||
connect(&network, &NetworkAccess::downloadFileError, this, &Squawk::downloadFileError);
|
connect(&network, &NetworkAccess::downloadFileError, this, &Squawk::downloadFileError);
|
||||||
connect(&network, &NetworkAccess::uploadFileProgress, this, &Squawk::uploadFileProgress);
|
connect(&network, &NetworkAccess::uploadFileProgress, this, &Squawk::uploadFileProgress);
|
||||||
connect(&network, &NetworkAccess::uploadFileError, this, &Squawk::uploadFileError);
|
connect(&network, &NetworkAccess::uploadFileError, this, &Squawk::uploadFileError);
|
||||||
|
|
||||||
|
|
||||||
|
if (kwallet.supportState() == PSE::KWallet::success) {
|
||||||
|
qDebug() << "KWallet support detected";
|
||||||
|
connect(&kwallet, &PSE::KWallet::opened, this, &Squawk::onWalletOpened);
|
||||||
|
connect(&kwallet, &PSE::KWallet::rejectPassword, this, &Squawk::onWalletRejectPassword);
|
||||||
|
connect(&kwallet, &PSE::KWallet::responsePassword, this, &Squawk::onWalletResponsePassword);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Core::Squawk::~Squawk()
|
Core::Squawk::~Squawk()
|
||||||
@ -45,6 +54,11 @@ Core::Squawk::~Squawk()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Core::Squawk::onWalletOpened(bool success)
|
||||||
|
{
|
||||||
|
qDebug() << "KWallet opened: " << success;
|
||||||
|
}
|
||||||
|
|
||||||
void Core::Squawk::stop()
|
void Core::Squawk::stop()
|
||||||
{
|
{
|
||||||
qDebug("Stopping squawk core..");
|
qDebug("Stopping squawk core..");
|
||||||
@ -207,17 +221,27 @@ void Core::Squawk::onAccountConnectionStateChanged(Shared::ConnectionState p_sta
|
|||||||
Account* acc = static_cast<Account*>(sender());
|
Account* acc = static_cast<Account*>(sender());
|
||||||
emit changeAccount(acc->getName(), {{"state", QVariant::fromValue(p_state)}});
|
emit changeAccount(acc->getName(), {{"state", QVariant::fromValue(p_state)}});
|
||||||
|
|
||||||
if (p_state == Shared::ConnectionState::disconnected) {
|
switch (p_state) {
|
||||||
bool equals = true;
|
case Shared::ConnectionState::disconnected: {
|
||||||
for (Accounts::const_iterator itr = accounts.begin(), end = accounts.end(); itr != end; itr++) {
|
bool equals = true;
|
||||||
if ((*itr)->getState() != Shared::ConnectionState::disconnected) {
|
for (Accounts::const_iterator itr = accounts.begin(), end = accounts.end(); itr != end; itr++) {
|
||||||
equals = false;
|
if ((*itr)->getState() != Shared::ConnectionState::disconnected) {
|
||||||
|
equals = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (equals && state != Shared::Availability::offline) {
|
||||||
|
state = Shared::Availability::offline;
|
||||||
|
emit stateChanged(state);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
break;
|
||||||
if (equals && state != Shared::Availability::offline) {
|
case Shared::ConnectionState::connected:
|
||||||
state = Shared::Availability::offline;
|
if (acc->getPasswordType() == Shared::AccountPassword::kwallet && kwallet.supportState() == PSE::KWallet::success) {
|
||||||
emit stateChanged(state);
|
kwallet.requestWritePassword(acc->getName(), acc->getPassword(), true);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -391,6 +415,13 @@ void Core::Squawk::modifyAccountRequest(const QString& name, const QMap<QString,
|
|||||||
acc->setPasswordType(Shared::Global::fromInt<Shared::AccountPassword>(mItr->toInt()));
|
acc->setPasswordType(Shared::Global::fromInt<Shared::AccountPassword>(mItr->toInt()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (acc->getPasswordType() == Shared::AccountPassword::kwallet
|
||||||
|
&& kwallet.supportState() == PSE::KWallet::success
|
||||||
|
&& !needToReconnect
|
||||||
|
) {
|
||||||
|
kwallet.requestWritePassword(acc->getName(), acc->getPassword(), true);
|
||||||
|
}
|
||||||
|
|
||||||
emit changeAccount(name, map);
|
emit changeAccount(name, map);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -683,5 +714,29 @@ void Core::Squawk::parseAccount(
|
|||||||
addAccount(login, server, QString(), name, resource, passwordType);
|
addAccount(login, server, QString(), name, resource, passwordType);
|
||||||
emit requestPassword(name);
|
emit requestPassword(name);
|
||||||
break;
|
break;
|
||||||
|
case Shared::AccountPassword::kwallet: {
|
||||||
|
addAccount(login, server, QString(), name, resource, passwordType);
|
||||||
|
if (kwallet.supportState() == PSE::KWallet::success) {
|
||||||
|
kwallet.requestReadPassword(name);
|
||||||
|
} else {
|
||||||
|
emit requestPassword(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Core::Squawk::onWalletRejectPassword(const QString& login)
|
||||||
|
{
|
||||||
|
emit requestPassword(login);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Core::Squawk::onWalletResponsePassword(const QString& login, const QString& password)
|
||||||
|
{
|
||||||
|
AccountsMap::const_iterator itr = amap.find(login);
|
||||||
|
if (itr == amap.end()) {
|
||||||
|
qDebug() << "An attempt to set password to non existing account" << login << ", skipping";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
itr->second->setPassword(password);
|
||||||
|
accountReady();
|
||||||
|
}
|
||||||
|
@ -34,6 +34,8 @@
|
|||||||
#include "networkaccess.h"
|
#include "networkaccess.h"
|
||||||
#include "external/simpleCrypt/simplecrypt.h"
|
#include "external/simpleCrypt/simplecrypt.h"
|
||||||
|
|
||||||
|
#include "passwordStorageEngines/kwallet.h"
|
||||||
|
|
||||||
namespace Core
|
namespace Core
|
||||||
{
|
{
|
||||||
class Squawk : public QObject
|
class Squawk : public QObject
|
||||||
@ -114,6 +116,7 @@ private:
|
|||||||
Shared::Availability state;
|
Shared::Availability state;
|
||||||
NetworkAccess network;
|
NetworkAccess network;
|
||||||
uint8_t waitingForAccounts;
|
uint8_t waitingForAccounts;
|
||||||
|
PSE::KWallet kwallet;
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void addAccount(
|
void addAccount(
|
||||||
@ -147,6 +150,10 @@ private slots:
|
|||||||
void onAccountRemoveRoomPresence(const QString& jid, const QString& nick);
|
void onAccountRemoveRoomPresence(const QString& jid, const QString& nick);
|
||||||
void onAccountChangeMessage(const QString& jid, const QString& id, const QMap<QString, QVariant>& data);
|
void onAccountChangeMessage(const QString& jid, const QString& id, const QMap<QString, QVariant>& data);
|
||||||
|
|
||||||
|
void onWalletOpened(bool success);
|
||||||
|
void onWalletResponsePassword(const QString& login, const QString& password);
|
||||||
|
void onWalletRejectPassword(const QString& login);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void readSettings();
|
void readSettings();
|
||||||
void accountReady();
|
void accountReady();
|
||||||
|
Loading…
Reference in New Issue
Block a user