summaryrefslogtreecommitdiff
path: root/libpurple/purplecredentialmanager.h
blob: e99eda86c82696b1e641ebf2f9b858efe69639f9 (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
/*
 * Purple - Internet Messaging Library
 * Copyright (C) Pidgin Developers <devel@pidgin.im>
 *
 * 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 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 <https://www.gnu.org/licenses/>.
 */

#if !defined(PURPLE_GLOBAL_HEADER_INSIDE) && !defined(PURPLE_COMPILATION)
# error "only <purple.h> may be included directly"
#endif

#ifndef PURPLE_CREDENTIAL_MANAGER_H
#define PURPLE_CREDENTIAL_MANAGER_H

#include <glib.h>
#include <glib-object.h>

#include "account.h"
#include <purplecredentialprovider.h>

G_BEGIN_DECLS

/**
 * PURPLE_CREDENTIAL_MANAGER_DOMAIN:
 *
 * A #GError domain for errors from #PurpleCredentialManager.
 *
 * Since: 3.0.0
 */
#define PURPLE_CREDENTIAL_MANAGER_DOMAIN (g_quark_from_static_string("purple-credential-manager"))

#define PURPLE_TYPE_CREDENTIAL_MANAGER (purple_credential_manager_get_type())
G_DECLARE_FINAL_TYPE(PurpleCredentialManager, purple_credential_manager,
                     PURPLE, CREDENTIAL_MANAGER, GObject)

/**
 * PurpleCredentialManager:
 *
 * Purple Credential Manager is the main API access to different credential
 * providers. Providers register themselves with the manager and then the user
 * can choose which provider to use.
 *
 * Once a provider is selected, all credential access will be directed to that
 * provider.
 *
 * Since: 3.0.0
 */

/**
 * PurpleCredentialManagerForeachFunc:
 * @provider: The #PurpleCredentialProvider instance.
 * @data: User supplied data.
 *
 * A function to be used as a callback with purple_credential_manager_foreach().
 *
 * Since: 3.0.0
 */
typedef void (*PurpleCredentialManagerForeachFunc)(PurpleCredentialProvider *provider, gpointer data);

/**
 * purple_credential_manager_get_default:
 *
 * Gets the default #PurpleCredentialManager instance.
 *
 * Returns: (transfer none): The default #PurpleCredentialManager instance.
 *
 * Since: 3.0.0
 */
PurpleCredentialManager *purple_credential_manager_get_default(void);

/**
 * purple_credential_manager_register:
 * @manager: The #PurpleCredentialManager instance.
 * @provider: The #PurpleCredentialProvider to register.
 * @error: Return address for a #GError, or %NULL.
 *
 * Registers @provider with @manager.
 *
 * Returns: %TRUE if @provider was successfully registered with @manager, %FALSE
 *          otherwise.
 *
 * Since: 3.0.0
 */
gboolean purple_credential_manager_register(PurpleCredentialManager *manager, PurpleCredentialProvider *provider, GError **error);

/**
 * purple_credential_manager_unregister:
 * @manager: The #PurpleCredentialManager instance.
 * @provider: The #PurpleCredentialProvider to unregister.
 * @error: Return address for a #GError, or %NULL.
 *
 * Unregisters @provider from @manager.
 *
 * Returns: %TRUE if @provider was successfully unregistered from @provider,
 *          %FALSE otherwise.
 *
 * Since: 3.0.0
 */
gboolean purple_credential_manager_unregister(PurpleCredentialManager *manager, PurpleCredentialProvider *provider, GError **error);

/**
 * purple_credential_manager_set_active:
 * @manager: The #PurpleCredentialManager instance.
 * @id: The id of the #PurpleCredentialProvider to use or %NULL to disable the
 *      active provider.
 * @error: Return address for a #GError, or %NULL.
 *
 * Changes the active #PurpleCredentialProvider of @manager to provider with an
 * id of @id.
 *
 * If @id is %NULL, it is assumed that the process is shutting down and that
 * the active provider setting will be left intact. If you want to disable the
 * active provider and keep running, you should set the active provider to
 * [class@Purple.NoopCredentialProvider].
 *
 * Returns: %TRUE on success or %FALSE with @error set on failure.
 *
 * Since: 3.0.0
 */
gboolean purple_credential_manager_set_active(PurpleCredentialManager *manager, const gchar *id, GError **error);

/**
 * purple_credential_manager_get_active:
 * @manager: The #PurpleCredentialManager instance.
 *
 * Gets the currently active #PurpleCredentialProvider or %NULL if there is no
 * active provider.
 *
 * Returns: (transfer none): The active #PurpleCredentialProvider.
 *
 * Since: 3.0.0
 */
PurpleCredentialProvider *purple_credential_manager_get_active(PurpleCredentialManager *manager);

/**
 * purple_credential_manager_read_password_async:
 * @manager: The #PurpleCredentialManager instance.
 * @account: The #PurpleAccount whose password to read.
 * @cancellable: (nullable): optional GCancellable object, %NULL to ignore.
 * @callback: (scope async): a #GAsyncReadyCallback to call when the request is
 *            satisfied.
 * @data: User data to pass to @callback.
 *
 * Reads the password for @account using the active #PurpleCredentialProvider of
 * @manager.
 *
 * Since: 3.0.0
 */
void purple_credential_manager_read_password_async(PurpleCredentialManager *manager, PurpleAccount *account, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer data);

/**
 * purple_credential_manager_read_password_finish:
 * @manager: The #PurpleCredentialManager instance.
 * @result: The #GAsyncResult from the previous
 *          purple_credential_manager_read_password_async() call.
 * @error: Return address for a #GError, or %NULL.
 *
 * Finishes a previous call to purple_credential_manager_read_password_async().
 *
 * Returns: (transfer full): The password or %NULL if successful, otherwise
 *                           %NULL with @error set on failure.
 *
 * Since: 3.0.0
 */
gchar *purple_credential_manager_read_password_finish(PurpleCredentialManager *manager, GAsyncResult *result, GError **error);

/**
 * purple_credential_manager_write_password_async:
 * @manager: The #PurpleCredentialManager instance.
 * @account: The #PurpleAccount whose password to write.
 * @password: The password to write.
 * @cancellable: (nullable): optional GCancellable object, %NULL to ignore.
 * @callback: (scope async): a #GAsyncReadyCallback to call when the request is
 *            satisfied.
 * @data: User data to pass to @callback.
 *
 * Writes @password for @account to the active #PurpleCredentialProvider of
 * @manager.
 *
 * Since: 3.0.0
 */
void purple_credential_manager_write_password_async(PurpleCredentialManager *manager, PurpleAccount *account, const gchar *password, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer data);

/**
 * purple_credential_manager_write_password_finish:
 * @manager: The #PurpleCredentialManager instance.
 * @result: The #GAsyncResult from the previous
 *          purple_credential_provider_write_password_async() call.
 * @error: Return address for a #GError, or %NULL.
 *
 * Finishes a previous call to purple_credential_manager_write_password_async().
 *
 * Returns: %TRUE if the password was written successfully, otherwise %FALSE
 *          with @error set.
 *
 * Since: 3.0.0
 */
gboolean purple_credential_manager_write_password_finish(PurpleCredentialManager *manager, GAsyncResult *result, GError **error);

/**
 * purple_credential_manager_clear_password_async:
 * @manager: The #PurpleCredentialManager instance.
 * @account: The #PurpleAccount whose password to clear.
 * @cancellable: (nullable): optional #GCancellable object, or %NULL to ignore.
 * @callback: (scope async): a #GAsyncReadyCallback to call when the request is
 *            satisfied.
 * @data: User data to pass to @callback.
 *
 * Clears the password for @account from the active #PurpleCredentialProvider
 * of @manager.
 *
 * Since: 3.0.0
 */
void purple_credential_manager_clear_password_async(PurpleCredentialManager *manager, PurpleAccount *account, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer data);

/**
 * purple_credential_manager_clear_password_finish:
 * @manager: The #PurpleCredentialManager instance.
 * @result: The #GAsyncResult from the previous
 *          purple_credential_provider_clear_password_async() call.
 * @error: Return address for a #GError, or %NULL.
 *
 * Finishes a previous call to
 * purple_credential_provider_clear_password_async().
 *
 * Returns: %TRUE if the password didn't exist or was cleared successfully,
 *          otherwise %FALSE with @error set.
 *
 * Since: 3.0.0
 */
gboolean purple_credential_manager_clear_password_finish(PurpleCredentialManager *manager, GAsyncResult *result, GError **error);

/**
 * purple_credential_manager_foreach:
 * @manager: The #PurpleCredentialManager instance.
 * @func: (scope call): The #PurpleCredentialManagerForeachFunc to call.
 * @data: User data to pass to @func.
 *
 * Calls @func for each #PurpleCredentialProvider that @manager knows about.
 *
 * Since: 3.0.0
 */
void purple_credential_manager_foreach(PurpleCredentialManager *manager, PurpleCredentialManagerForeachFunc func, gpointer data);

G_END_DECLS

#endif /* PURPLE_CREDENTIAL_MANAGER_H */