/** * This file is part of GpgFrontend. * * GpgFrontend 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. * * Foobar 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 Foobar. If not, see . * * The initial version of the source code is inherited from gpg4usb-team. * Their source code version also complies with GNU General Public License. * * The source code version of this software was modified and released * by Saturneric starting on May 12, 2021. * */ #ifndef __KEYLIST_H__ #define __KEYLIST_H__ #include #include "gpg/GpgContext.h" #include "ui/KeyImportDetailDialog.h" class Ui_KeyList; namespace GpgFrontend::UI { struct KeyListRow { using KeyType = unsigned int; static const KeyType SECRET_OR_PUBLIC_KEY = 0; static const KeyType ONLY_SECRET_KEY = 1; }; struct KeyListColumn { using InfoType = unsigned int; static constexpr InfoType ALL = ~0; static constexpr InfoType TYPE = 1 << 0; static constexpr InfoType NAME = 1 << 1; static constexpr InfoType EmailAddress = 1 << 2; static constexpr InfoType Usage = 1 << 3; static constexpr InfoType Validity = 1 << 4; static constexpr InfoType FingerPrint = 1 << 5; }; struct KeyTable { QTableWidget* key_list; KeyListRow::KeyType select_type; KeyListColumn::InfoType info_type; std::vector buffered_keys; std::function filter; KeyTable( QTableWidget* _key_list, KeyListRow::KeyType _select_type, KeyListColumn::InfoType _info_type, std::function _filter = [](const GpgKey&) -> bool { return true; }) : key_list(_key_list), select_type(_select_type), info_type(_info_type), filter(std::move(_filter)) {} void Refresh(KeyLinkListPtr m_keys = nullptr); KeyIdArgsListPtr GetChecked(); void SetChecked(const KeyIdArgsListPtr& key_ids); }; class KeyList : public QWidget { Q_OBJECT public: explicit KeyList(bool menu, QWidget* parent = nullptr); void addListGroupTab( const QString& name, KeyListRow::KeyType selectType = KeyListRow::SECRET_OR_PUBLIC_KEY, KeyListColumn::InfoType infoType = KeyListColumn::ALL, const std::function& filter = [](const GpgKey&) -> bool { return true; }); void setDoubleClickedAction( std::function action); void setColumnWidth(int row, int size); void addMenuAction(QAction* act); void addSeparator(); KeyIdArgsListPtr getChecked(); static KeyIdArgsListPtr getChecked(const KeyTable& key_table); KeyIdArgsListPtr getPrivateChecked(); KeyIdArgsListPtr getAllPrivateKeys(); void setChecked(const KeyIdArgsListPtr& keyIds); static void setChecked(const KeyIdArgsListPtr& keyIds, const KeyTable& key_table); KeyIdArgsListPtr getSelected(); std::string getSelectedKey(); [[maybe_unused]] static void markKeys(QStringList* keyIds); [[maybe_unused]] bool containsPrivateKeys(); signals: void signalRefreshStatusBar(const QString& message, int timeout); void signalRefreshDatabase(); public slots: void slotRefresh(); private: void init(); void importKeys(const QByteArray& inBuffer); static int key_list_id; int _m_key_list_id; std::mutex buffered_key_list_mutex; std::shared_ptr ui; QTableWidget* mKeyList{}; std::vector mKeyTables; QMenu* popupMenu{}; GpgFrontend::KeyLinkListPtr _buffered_keys_list; std::function mAction = nullptr; bool menu_status = false; private slots: void slotDoubleClicked(const QModelIndex& index); void slotRefreshUI(); void slotSyncWithKeyServer(); protected: void contextMenuEvent(QContextMenuEvent* event) override; void dragEnterEvent(QDragEnterEvent* event) override; void dropEvent(QDropEvent* event) override; }; } // namespace GpgFrontend::UI #endif // __KEYLIST_H__