blob: fcaeb422a4f74a8ed677500101cfa55b6e93f156 (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
 | /*
 * Copyright (c) 2010 Kevin Smith
 * Licensed under the GNU General Public License v3.
 * See Documentation/Licenses/GPLv3.txt for more information.
 */
#pragma once
#include "Swiften/Base/boost_bsignals.h"
#include <boost/shared_ptr.hpp>
#include <string>
#include <Swiften/TLS/Certificate.h>
namespace Swift {
	class MainWindow;
	class LoginWindow {
		public:
			virtual ~LoginWindow() {};
			virtual void selectUser(const std::string&) = 0;
			virtual void morphInto(MainWindow *mainWindow) = 0;
			virtual void loggedOut() = 0;
			virtual void setMessage(const std::string&) = 0;
			virtual void setIsLoggingIn(bool loggingIn) = 0;
			virtual void addAvailableAccount(const std::string& defaultJID, const std::string& defaultPassword, const std::string& defaultCertificate) = 0;
			virtual void removeAvailableAccount(const std::string& jid) = 0;
			boost::signal<void (const std::string&, const std::string&, const std::string& /* certificateFile */, bool /* remember password*/, bool /* login automatically */)> onLoginRequest;
			virtual void setLoginAutomatically(bool loginAutomatically) = 0;
			virtual void quit() = 0;
			/** Disable any GUI elements that suggest saving of passwords. */
			virtual void setRememberingAllowed(bool allowed) = 0;
			/** Blocking request whether a cert should be permanently trusted.*/
			virtual bool askUserToTrustCertificatePermanently(const std::string& message, Certificate::ref) = 0;
			boost::signal<void ()> onCancelLoginRequest;
			boost::signal<void ()> onQuitRequest;
			boost::signal<void (const std::string&)> onPurgeSavedLoginRequest;
	};
}
 |