File indexing completed on 2024-09-08 12:18:39

0001 /*
0002     This file is part of the KDE libraries
0003     SPDX-FileCopyrightText: 2009 Michael Leupold <lemma@confuego.org>
0004 
0005     SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
0006 */
0007 
0008 #ifndef KPASSWDSERVERCLIENT_H
0009 #define KPASSWDSERVERCLIENT_H
0010 
0011 #include <kiocore_export.h>
0012 #include <qglobal.h>
0013 
0014 #include <memory>
0015 
0016 class QString;
0017 class OrgKdeKPasswdServerInterface;
0018 
0019 namespace KIO
0020 {
0021 class AuthInfo;
0022 }
0023 
0024 class KPasswdServerClientPrivate;
0025 
0026 /**
0027  * @class KPasswdServerClient kpasswdserverclient.h <KPasswdServerClient>
0028  *
0029  * Interface class for kpasswdserver.
0030  * KIO workers should not use this directly but via the WorkerBase API.
0031  * @since 5.30
0032  */
0033 class KIOCORE_EXPORT KPasswdServerClient
0034 {
0035 public:
0036     /**
0037      * Creates a client instance for kpasswdserver.
0038      * The instance should be kept for the lifetime of the process, not created for each request.
0039      */
0040     KPasswdServerClient();
0041     /**
0042      * Destructor.
0043      */
0044     ~KPasswdServerClient();
0045 
0046     KPasswdServerClient(const KPasswdServerClient &) = delete;
0047     KPasswdServerClient &operator=(const KPasswdServerClient &) = delete;
0048 
0049     /**
0050      * Check if kpasswdserver has cached authentication information regarding
0051      * an AuthInfo object.
0052      * @param info information to check cache for
0053      * @param windowId used as parent for dialogs, comes from QWidget::winId() on the toplevel widget
0054      * @param usertime the X11 user time from the calling application, so that any dialog
0055      *                 (e.g. wallet password) respects focus-prevention rules.
0056      *                 Use KUserTimestamp::userTimestamp in the GUI application from which the request originates.
0057      * @return true if kpasswdserver provided cached information, false if not
0058      * @remarks info will contain the results of the check. To see if
0059      *          information was retrieved, check info.isModified().
0060      */
0061     bool checkAuthInfo(KIO::AuthInfo *info, qlonglong windowId, qlonglong usertime);
0062 
0063     /**
0064      * Let kpasswdserver ask the user for authentication information.
0065      * @param info information to query the user for
0066      * @param errorMsg error message that will be displayed to the user
0067      * @param windowId used as parent for dialogs, comes from QWidget::winId() on the toplevel widget
0068      * @param usertime the X11 user time from the calling application, so that the dialog
0069      *                 (e.g. wallet password) respects focus-prevention rules.
0070      *                 Use KUserTimestamp::userTimestamp in the GUI application from which the request originates.
0071      * @return a KIO error code: KJob::NoError (0) on success, otherwise ERR_USER_CANCELED if the user canceled,
0072      *  or ERR_PASSWD_SERVER if we couldn't communicate with kpasswdserver.
0073      * @remarks If NoError is returned, then @p info will contain the authentication information that was retrieved.
0074      */
0075     int queryAuthInfo(KIO::AuthInfo *info, const QString &errorMsg, qlonglong windowId, qlonglong usertime);
0076 
0077     /**
0078      * Manually add authentication information to kpasswdserver's cache.
0079      * @param info information to add
0080      * @param windowId used as parent window for dialogs, comes from QWidget::winId() on the toplevel widget
0081      */
0082     void addAuthInfo(const KIO::AuthInfo &info, qlonglong windowId);
0083 
0084     /**
0085      * Manually remove authentication information from kpasswdserver's cache.
0086      * @param host hostname of the information to remove
0087      * @param protocol protocol to remove information for
0088      * @param user username to remove information for
0089      */
0090     void removeAuthInfo(const QString &host, const QString &protocol, const QString &user);
0091 
0092 private:
0093     OrgKdeKPasswdServerInterface *m_interface;
0094     std::unique_ptr<KPasswdServerClientPrivate> d;
0095 };
0096 
0097 #endif