1
|
|
|
<?php |
2
|
|
|
/** |
3
|
|
|
* Plugin Options. |
4
|
|
|
* |
5
|
|
|
* @package WP_To_Diaspora\Options |
6
|
|
|
* @since 1.3.0 |
7
|
|
|
*/ |
8
|
|
|
|
9
|
|
|
// Exit if accessed directly. |
10
|
|
|
defined( 'ABSPATH' ) || exit; |
11
|
|
|
|
12
|
|
|
/** |
13
|
|
|
* Class to manage the settings using the Settings API. |
14
|
|
|
*/ |
15
|
|
|
class WP2D_Options { |
16
|
|
|
|
17
|
|
|
/** |
18
|
|
|
* Only instance of this class. |
19
|
|
|
* |
20
|
|
|
* @var WP2D_Options |
21
|
|
|
*/ |
22
|
|
|
private static $instance; |
23
|
|
|
|
24
|
|
|
/** |
25
|
|
|
* All default plugin options. |
26
|
|
|
* |
27
|
|
|
* @var array |
28
|
|
|
*/ |
29
|
|
|
private static $default_options = [ |
30
|
|
|
'aspects_list' => [], |
31
|
|
|
'services_list' => [], |
32
|
|
|
'post_to_diaspora' => true, |
33
|
|
|
'enabled_post_types' => [ 'post' ], |
34
|
|
|
'fullentrylink' => true, |
35
|
|
|
'display' => 'full', |
36
|
|
|
'tags_to_post' => [ 'global', 'custom', 'post' ], |
37
|
|
|
'global_tags' => '', |
38
|
|
|
'aspects' => [ 'public' ], |
39
|
|
|
'services' => [], |
40
|
|
|
'auth_key_hash' => '', |
41
|
|
|
'version' => WP2D_VERSION, |
42
|
|
|
]; |
43
|
|
|
|
44
|
|
|
/** |
45
|
|
|
* Valid values for select fields. |
46
|
|
|
* |
47
|
|
|
* @var array |
48
|
|
|
*/ |
49
|
|
|
private static $valid_values = [ |
50
|
|
|
'display' => [ 'full', 'excerpt', 'none' ], |
51
|
|
|
'tags_to_post' => [ 'global', 'custom', 'post' ], |
52
|
|
|
]; |
53
|
|
|
|
54
|
|
|
/** |
55
|
|
|
* All plugin options. |
56
|
|
|
* |
57
|
|
|
* @var array |
58
|
|
|
*/ |
59
|
|
|
private static $options; |
60
|
|
|
|
61
|
|
|
/** Singleton, keep private. */ |
62
|
|
|
final private function __clone() { |
63
|
|
|
} |
64
|
|
|
|
65
|
|
|
/** Singleton, keep private. */ |
66
|
|
|
final private function __construct() { |
67
|
|
|
} |
68
|
|
|
|
69
|
|
|
/** |
70
|
|
|
* Create / Get the instance of this class. |
71
|
|
|
* |
72
|
|
|
* @return WP2D_Options Instance of this class. |
73
|
|
|
*/ |
74
|
|
|
public static function instance() { |
75
|
|
|
if ( null === self::$instance ) { |
76
|
|
|
self::$instance = new self(); |
77
|
|
|
self::$instance->setup(); |
78
|
|
|
} |
79
|
|
|
|
80
|
|
|
return self::$instance; |
81
|
|
|
} |
82
|
|
|
|
83
|
|
|
/** |
84
|
|
|
* Set up the options menu. |
85
|
|
|
*/ |
86
|
|
|
private function setup() { |
87
|
|
|
|
88
|
|
|
// Populate options array. |
89
|
|
|
$this->get_option(); |
90
|
|
|
|
91
|
|
|
// Setup Options page and Contextual Help. |
92
|
|
|
add_action( 'admin_menu', [ $this, 'setup_wpadmin_pages' ] ); |
93
|
|
|
|
94
|
|
|
// Register all settings. |
95
|
|
|
add_action( 'admin_init', [ $this, 'register_settings' ] ); |
96
|
|
|
} |
97
|
|
|
|
98
|
|
|
|
99
|
|
|
/** |
100
|
|
|
* Get the currently selected tab. |
101
|
|
|
* |
102
|
|
|
* @todo Multi-level if statement to make it look prettier. |
103
|
|
|
* |
104
|
|
|
* @param string $default Tab to select if the current selection is invalid. |
105
|
|
|
* |
106
|
|
|
* @return string Return the currently selected tab. |
107
|
|
|
*/ |
108
|
|
|
private function current_tab( $default = 'defaults' ) { |
109
|
|
|
$tab = sanitize_key( $_GET['tab'] ?? $default ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended |
110
|
|
|
|
111
|
|
|
// If the pod settings aren't configured yet, open the 'Setup' tab. |
112
|
|
|
if ( ! $this->is_pod_set_up() ) { |
113
|
|
|
$tab = 'setup'; |
114
|
|
|
} |
115
|
|
|
|
116
|
|
|
return $tab; |
117
|
|
|
} |
118
|
|
|
|
119
|
|
|
/** |
120
|
|
|
* Output all options tabs and return an array of them all, if requested by $return. |
121
|
|
|
* |
122
|
|
|
* @param bool $return Define if the options tabs should be returned. |
123
|
|
|
* |
124
|
|
|
* @return array (If requested) An array of the outputted options tabs. |
125
|
|
|
*/ |
126
|
|
|
private function options_page_tabs( $return = false ) { |
127
|
|
|
// The array defining all options sections to be shown as tabs. |
128
|
|
|
$tabs = []; |
129
|
|
|
if ( $this->is_pod_set_up() ) { |
130
|
|
|
$tabs['defaults'] = __( 'Defaults', 'wp-to-diaspora' ); |
131
|
|
|
} |
132
|
|
|
|
133
|
|
|
// Add the 'Setup' tab to the end of the list. |
134
|
|
|
$tabs['setup'] = __( 'Setup', 'wp-to-diaspora' ) . '<span id="pod-connection-status" class="dashicons-before hidden"></span><span class="spinner"></span>'; |
135
|
|
|
|
136
|
|
|
// Container for all options tabs. |
137
|
|
|
$out = '<h2 id="options-tabs" class="nav-tab-wrapper">'; |
138
|
|
|
foreach ( $tabs as $tab => $name ) { |
139
|
|
|
// The tab link. |
140
|
|
|
$out .= '<a class="nav-tab' . ( $this->current_tab() === $tab ? ' nav-tab-active' : '' ) . '" href="?page=wp_to_diaspora&tab=' . $tab . '">' . $name . '</a>'; |
141
|
|
|
} |
142
|
|
|
$out .= '</h2>'; |
143
|
|
|
|
144
|
|
|
// Output the container with all tabs. |
145
|
|
|
echo $out; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped |
146
|
|
|
|
147
|
|
|
// Check if the tabs should be returned. |
148
|
|
|
if ( $return ) { |
149
|
|
|
return $tabs; |
150
|
|
|
} |
151
|
|
|
|
152
|
|
|
return []; |
153
|
|
|
} |
154
|
|
|
|
155
|
|
|
|
156
|
|
|
/** |
157
|
|
|
* Set up admin options page. |
158
|
|
|
*/ |
159
|
|
|
public function admin_options_page() { |
160
|
|
|
?> |
161
|
|
|
<div class="wrap"> |
162
|
|
|
<h2>WP to diaspora*</h2> |
163
|
|
|
|
164
|
|
|
<div id="wp2d-message" class="notice hidden" <?php echo defined( 'WP2D_DEBUGGING' ) ? ' data-debugging' : ''; ?>></div> |
165
|
|
|
|
166
|
|
|
<?php |
167
|
|
|
// Check the connection status to diaspora. |
168
|
|
|
if ( ! $this->is_pod_set_up() ) { |
169
|
|
|
add_settings_error( |
170
|
|
|
'wp_to_diaspora_settings', |
171
|
|
|
'wp_to_diaspora_connected', |
172
|
|
|
__( 'First of all, set up the connection to your pod below.', 'wp-to-diaspora' ), |
173
|
|
|
'updated' |
174
|
|
|
); |
175
|
|
|
} else { |
176
|
|
|
// Get initial aspects list and connected services. |
177
|
|
|
// DON'T check for empty services list here!! |
178
|
|
|
// It could always be empty, resulting in this code being run every time the page is loaded. |
179
|
|
|
// The aspects will at least have a "Public" entry after the initial fetch. |
180
|
|
|
$aspects_list = $this->get_option( 'aspects_list' ); |
181
|
|
|
if ( ( $force = get_transient( 'wp2d_no_js_force_refetch' ) ) || empty( $aspects_list ) ) { |
182
|
|
|
|
183
|
|
|
// Set up the connection to diaspora*. |
184
|
|
|
$api = WP2D_Helpers::api_quick_connect(); |
185
|
|
|
if ( ! $api->has_last_error() ) { |
186
|
|
|
// Get the loaded aspects. |
187
|
|
|
if ( is_array( $aspects = $api->get_aspects() ) ) { |
188
|
|
|
// Save the new list of aspects. |
189
|
|
|
$this->set_option( 'aspects_list', $aspects ); |
190
|
|
|
} |
191
|
|
|
|
192
|
|
|
// Get the loaded services. |
193
|
|
|
if ( is_array( $services = $api->get_services() ) ) { |
194
|
|
|
// Save the new list of services. |
195
|
|
|
$this->set_option( 'services_list', $services ); |
196
|
|
|
} |
197
|
|
|
|
198
|
|
|
$this->save(); |
199
|
|
|
} |
200
|
|
|
|
201
|
|
|
if ( $force ) { |
202
|
|
|
delete_transient( 'wp2d_no_js_force_refetch' ); |
203
|
|
|
$message = ( ! $api->has_last_error() ) ? __( 'Connection successful.', 'wp-to-diaspora' ) : $api->get_last_error(); |
204
|
|
|
add_settings_error( |
205
|
|
|
'wp_to_diaspora_settings', |
206
|
|
|
'wp_to_diaspora_connected', |
207
|
|
|
$message, |
208
|
|
|
$api->has_last_error() ? 'error' : 'updated' |
209
|
|
|
); |
210
|
|
|
} |
211
|
|
|
} |
212
|
|
|
} |
213
|
|
|
|
214
|
|
|
// Output success or error message. |
215
|
|
|
settings_errors( 'wp_to_diaspora_settings' ); |
216
|
|
|
?> |
217
|
|
|
|
218
|
|
|
<?php $page_tabs = array_keys( $this->options_page_tabs( true ) ); ?> |
219
|
|
|
|
220
|
|
|
<form action="<?php echo esc_url( admin_url( 'options.php' ) ); ?>" method="post"> |
221
|
|
|
<input id="wp2d_no_js" type="hidden" name="wp_to_diaspora_settings[no_js]" value="1"> |
222
|
|
|
<?php |
223
|
|
|
// Load the settings fields. |
224
|
|
|
settings_fields( 'wp_to_diaspora_settings' ); |
225
|
|
|
do_settings_sections( 'wp_to_diaspora_settings' ); |
226
|
|
|
|
227
|
|
|
// Get the name of the current tab, if set, else take the first one from the list. |
228
|
|
|
$tab = $this->current_tab( $page_tabs[0] ); |
229
|
|
|
|
230
|
|
|
// Add Save and Reset buttons. |
231
|
|
|
echo '<input id="submit-' . esc_attr( $tab ) . '" name="wp_to_diaspora_settings[submit_' . esc_attr( $tab ) . ']" type="submit" class="button-primary" value="' . esc_attr__( 'Save Changes', 'wp-to-diaspora' ) . '" /> '; |
232
|
|
|
if ( 'setup' !== $tab ) { |
233
|
|
|
echo '<input id="reset-' . esc_attr( $tab ) . '" name="wp_to_diaspora_settings[reset_' . esc_attr( $tab ) . ']" type="submit" class="button-secondary" value="' . esc_attr__( 'Reset Defaults', 'wp-to-diaspora' ) . '" />'; |
234
|
|
|
} |
235
|
|
|
?> |
236
|
|
|
|
237
|
|
|
</form> |
238
|
|
|
</div> |
239
|
|
|
|
240
|
|
|
<?php |
241
|
|
|
} |
242
|
|
|
|
243
|
|
|
/** |
244
|
|
|
* Return if the settings for the pod setup have been entered. |
245
|
|
|
* |
246
|
|
|
* @return bool If the setup for the pod has been done. |
247
|
|
|
*/ |
248
|
|
|
public function is_pod_set_up() { |
249
|
|
|
return ( $this->get_option( 'pod' ) && $this->get_option( 'username' ) && $this->get_option( 'password' ) ); |
250
|
|
|
} |
251
|
|
|
|
252
|
|
|
/** |
253
|
|
|
* Setup Contextual Help and Options pages. |
254
|
|
|
*/ |
255
|
|
|
public function setup_wpadmin_pages() { |
256
|
|
|
// Add options page. |
257
|
|
|
$hook = add_options_page( 'WP to diaspora*', 'WP to diaspora*', 'manage_options', 'wp_to_diaspora', [ $this, 'admin_options_page' ] ); |
258
|
|
|
|
259
|
|
|
// Setup the contextual help menu after the options page has been loaded. |
260
|
|
|
add_action( 'load-' . $hook, [ 'WP2D_Contextual_Help', 'instance' ] ); |
261
|
|
|
|
262
|
|
|
// Setup the contextual help menu tab for post types. Checks are made there! |
263
|
|
|
add_action( 'load-post.php', [ 'WP2D_Contextual_Help', 'instance' ] ); |
264
|
|
|
add_action( 'load-post-new.php', [ 'WP2D_Contextual_Help', 'instance' ] ); |
265
|
|
|
} |
266
|
|
|
|
267
|
|
|
/** |
268
|
|
|
* Initialise the settings sections and fields of the currently selected tab. |
269
|
|
|
*/ |
270
|
|
|
public function register_settings() { |
271
|
|
|
// Register the settings with validation callback. |
272
|
|
|
register_setting( 'wp_to_diaspora_settings', 'wp_to_diaspora_settings', [ $this, 'validate_settings' ] ); |
273
|
|
|
|
274
|
|
|
// Load only the sections of the selected tab. |
275
|
|
|
switch ( $this->current_tab() ) { |
276
|
|
|
case 'defaults': |
277
|
|
|
// Add a "Defaults" section that contains all posting settings to be used by default. |
278
|
|
|
add_settings_section( 'wp_to_diaspora_defaults_section', __( 'Posting Defaults', 'wp-to-diaspora' ), [ $this, 'defaults_section' ], 'wp_to_diaspora_settings' ); |
279
|
|
|
break; |
280
|
|
|
case 'setup': |
281
|
|
|
// Add a "Setup" section that contains the Pod domain, Username and Password. |
282
|
|
|
add_settings_section( 'wp_to_diaspora_setup_section', __( 'diaspora* Setup', 'wp-to-diaspora' ), [ $this, 'setup_section' ], 'wp_to_diaspora_settings' ); |
283
|
|
|
break; |
284
|
|
|
} |
285
|
|
|
} |
286
|
|
|
|
287
|
|
|
|
288
|
|
|
/** |
289
|
|
|
* Callback for the "Setup" section. |
290
|
|
|
*/ |
291
|
|
|
public function setup_section() { |
292
|
|
|
esc_html_e( 'Set up the connection to your diaspora* account.', 'wp-to-diaspora' ); |
293
|
|
|
|
294
|
|
|
// Pod entry field. |
295
|
|
|
add_settings_field( 'pod', __( 'Diaspora* Pod', 'wp-to-diaspora' ), [ $this, 'pod_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_setup_section' ); |
296
|
|
|
|
297
|
|
|
// Username entry field. |
298
|
|
|
add_settings_field( 'username', __( 'Username', 'wp-to-diaspora' ), [ $this, 'username_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_setup_section' ); |
299
|
|
|
|
300
|
|
|
// Password entry field. |
301
|
|
|
add_settings_field( 'password', __( 'Password', 'wp-to-diaspora' ), [ $this, 'password_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_setup_section' ); |
302
|
|
|
} |
303
|
|
|
|
304
|
|
|
/** |
305
|
|
|
* Render the "Pod" field. |
306
|
|
|
*/ |
307
|
|
|
public function pod_render() { |
308
|
|
|
/** |
309
|
|
|
* Update entries: |
310
|
|
|
* curl -G 'https://the-federation.info/graphql?raw' --data-urlencode 'query={nodes(platform:"diaspora"){host}}' | jq '.data.nodes[].host' |
311
|
|
|
*/ |
312
|
|
|
|
313
|
|
|
$pod_list = [ |
314
|
|
|
'20190827.club', |
315
|
|
|
'a.grumpy.world', |
316
|
|
|
'azazel.ultragreen.net', |
317
|
|
|
'berlinspora.de', |
318
|
|
|
'bobspora.com', |
319
|
|
|
'borg.zbkbie.com', |
320
|
|
|
'brighton.social', |
321
|
|
|
'catpod.cat.scot', |
322
|
|
|
'd-resources.hopto.org', |
323
|
|
|
'd.consumium.org', |
324
|
|
|
'd.kretschmann.social', |
325
|
|
|
'deko.cloud', |
326
|
|
|
'despora.de', |
327
|
|
|
'dia.delaregula.fr', |
328
|
|
|
'dia.goexchange.de', |
329
|
|
|
'dia.gordons.gen.nz', |
330
|
|
|
'diapod.org', |
331
|
|
|
'diasp.de', |
332
|
|
|
'diasp.eu', |
333
|
|
|
'diasp.eu.com', |
334
|
|
|
'diasp.in', |
335
|
|
|
'diasp.nl', |
336
|
|
|
'diasp.org', |
337
|
|
|
'diaspod.de', |
338
|
|
|
'diaspora-fr.org', |
339
|
|
|
'diaspora.animalnet.de', |
340
|
|
|
'diaspora.anjara.eu', |
341
|
|
|
'diaspora.asrun.eu', |
342
|
|
|
'diaspora.baucum.me', |
343
|
|
|
'diaspora.club', |
344
|
|
|
'diaspora.conxtor.com', |
345
|
|
|
'diaspora.counterspin.org.nz', |
346
|
|
|
'diaspora.cyber-tribal.com', |
347
|
|
|
'diaspora.flyar.net', |
348
|
|
|
'diaspora.gegeweb.eu', |
349
|
|
|
'diaspora.goethe12.de', |
350
|
|
|
'diaspora.goethe20.de', |
351
|
|
|
'diaspora.hofud.com', |
352
|
|
|
'diaspora.immae.eu', |
353
|
|
|
'diaspora.itopie.ch', |
354
|
|
|
'diaspora.koehn.com', |
355
|
|
|
'diaspora.laka.lv', |
356
|
|
|
'diaspora.lamsade.fr', |
357
|
|
|
'diaspora.mathematicon.com', |
358
|
|
|
'diaspora.microdata.co.uk', |
359
|
|
|
'diaspora.mifritscher.de', |
360
|
|
|
'diaspora.normandie-libre.fr', |
361
|
|
|
'diaspora.odat.xyz', |
362
|
|
|
'diaspora.ofstad.xyz', |
363
|
|
|
'diaspora.permutationsofchaos.com', |
364
|
|
|
'diaspora.psyco.fr', |
365
|
|
|
'diaspora.ruhrmail.de', |
366
|
|
|
'diaspora.sceal.ie', |
367
|
|
|
'diaspora.schoenf.de', |
368
|
|
|
'diaspora.snakenode.eu', |
369
|
|
|
'diaspora.solusar.de', |
370
|
|
|
'diaspora.somethinghub.com', |
371
|
|
|
'diaspora.stevesullam.com', |
372
|
|
|
'diaspora.thus.ch', |
373
|
|
|
'diaspora.town', |
374
|
|
|
'diaspora.trancart.eu', |
375
|
|
|
'diaspora.vrije-mens.org', |
376
|
|
|
'diaspora.williamsonday.org', |
377
|
|
|
'diaspora.willispickering.com', |
378
|
|
|
'diaspora.yuais.net', |
379
|
|
|
'diasporabr.com.br', |
380
|
|
|
'diasporapod.no', |
381
|
|
|
'diasporing.ch', |
382
|
|
|
'dicespora.net', |
383
|
|
|
'dorf-post.de', |
384
|
|
|
'expod.de', |
385
|
|
|
'eyepod.oksocial.net', |
386
|
|
|
'failure.net', |
387
|
|
|
'federatica.space', |
388
|
|
|
'framasphere.org', |
389
|
|
|
'freehuman.fr', |
390
|
|
|
'friendsmeet.win', |
391
|
|
|
'iitians.xyz', |
392
|
|
|
'iliketoast.net', |
393
|
|
|
'ingtech.net', |
394
|
|
|
'jardin.umaneti.net', |
395
|
|
|
'jochem.name', |
396
|
|
|
'joindiaspora.com', |
397
|
|
|
'kitsune.click', |
398
|
|
|
'lanx.fr', |
399
|
|
|
'librenet.gr', |
400
|
|
|
'livepods.net', |
401
|
|
|
'lstoll-diaspora.herokuapp.com', |
402
|
|
|
'manapod.space', |
403
|
|
|
'mastodon.webseed.com', |
404
|
|
|
'mindfeed.herokuapp.com', |
405
|
|
|
'mondiaspora.net', |
406
|
|
|
'mondiaspora.org', |
407
|
|
|
'nerdpol.ch', |
408
|
|
|
'nodewatch.ninja', |
409
|
|
|
'nota.404.mn', |
410
|
|
|
'parlote.facil.services', |
411
|
|
|
'paxation.org', |
412
|
|
|
'pekospora.pekoyama.com', |
413
|
|
|
'pluspora.com', |
414
|
|
|
'pod.aevl.us', |
415
|
|
|
'pod.afox.me', |
416
|
|
|
'pod.alhague.net', |
417
|
|
|
'pod.asap-soft.com', |
418
|
|
|
'pod.automat.one', |
419
|
|
|
'pod.buergi.lugs.ch', |
420
|
|
|
'pod.chabotsi.fr', |
421
|
|
|
'pod.dapor.net', |
422
|
|
|
'pod.ddna.co', |
423
|
|
|
'pod.diaspora.software', |
424
|
|
|
'pod.dukun.de', |
425
|
|
|
'pod.fab-l3.org', |
426
|
|
|
'pod.ferner-online.de', |
427
|
|
|
'pod.fulll.name', |
428
|
|
|
'pod.g3l.org', |
429
|
|
|
'pod.geraspora.de', |
430
|
|
|
'pod.gothic.net.au', |
431
|
|
|
'pod.haxxors.com', |
432
|
|
|
'pod.hoizi.net', |
433
|
|
|
'pod.interlin.nl', |
434
|
|
|
'pod.jamidisi-edu.de', |
435
|
|
|
'pod.jns.im', |
436
|
|
|
'pod.jotoma.de', |
437
|
|
|
'pod.libreplanetbr.org', |
438
|
|
|
'pod.mttv.it', |
439
|
|
|
'pod.omgsrsly.net', |
440
|
|
|
'pod.orkz.net', |
441
|
|
|
'pod.pc-tiede.de', |
442
|
|
|
'pod.reckord.de', |
443
|
|
|
'pod.redfish.ca', |
444
|
|
|
'pod.rusa.fr', |
445
|
|
|
'pod.tchncs.de', |
446
|
|
|
'pod.thing.org', |
447
|
|
|
'podbay.net', |
448
|
|
|
'poddery.com', |
449
|
|
|
'podington.oksocial.net', |
450
|
|
|
'podling.oksocial.net', |
451
|
|
|
'podricing.pw', |
452
|
|
|
'protagio.social', |
453
|
|
|
'pubpod.alqualonde.org', |
454
|
|
|
'revreso.de', |
455
|
|
|
'rhizome.hfbk.net', |
456
|
|
|
'ruhrspora.de', |
457
|
|
|
'sechat.org', |
458
|
|
|
'shrekislove.us', |
459
|
|
|
'sn.xxz.su', |
460
|
|
|
'social.blackrosehosting.com', |
461
|
|
|
'social.cooleysekula.net', |
462
|
|
|
'social.daxbau.net', |
463
|
|
|
'social.dbernhardt.com', |
464
|
|
|
'social.elinux.org', |
465
|
|
|
'social.gibberfish.org', |
466
|
|
|
'social.hiernaux.eu', |
467
|
|
|
'social.milhousfamily.com', |
468
|
|
|
'social.mrzyx.de', |
469
|
|
|
'social.prien.xyz', |
470
|
|
|
'social.sejourne.info', |
471
|
|
|
'social.sip247.com', |
472
|
|
|
'spora.grin.hu', |
473
|
|
|
'spyurk.am', |
474
|
|
|
'sysad.org', |
475
|
|
|
'test.poddery.com', |
476
|
|
|
'tovari.ch', |
477
|
|
|
'twitt-dev.opencaribbean.org', |
478
|
|
|
'tyrell.marway.org', |
479
|
|
|
'wertier.de', |
480
|
|
|
'wgserv.eu', |
481
|
|
|
'whatsnewz.com', |
482
|
|
|
'wk3.org', |
483
|
|
|
'www.diasporaix.de', |
484
|
|
|
'www.fessebouc.fr', |
485
|
|
|
'www.reteasociala.ro', |
486
|
|
|
'xn--b1aafeapdba0ada1es.xn--p1ai', |
487
|
|
|
]; |
488
|
|
|
?> |
489
|
|
|
https://<input type="text" name="wp_to_diaspora_settings[pod]" value="<?php echo esc_attr( $this->get_option( 'pod' ) ); ?>" placeholder="e.g. joindiaspora.com" autocomplete="on" list="pod-list" required> |
490
|
|
|
<datalist id="pod-list"> |
491
|
|
|
<?php foreach ( $pod_list as $pod ) : ?> |
492
|
|
|
<option value="<?php echo esc_attr( $pod ); ?>"></option> |
493
|
|
|
<?php endforeach; ?> |
494
|
|
|
</datalist> |
495
|
|
|
<?php |
496
|
|
|
} |
497
|
|
|
|
498
|
|
|
/** |
499
|
|
|
* Render the "Username" field. |
500
|
|
|
*/ |
501
|
|
|
public function username_render() { |
502
|
|
|
?> |
503
|
|
|
<input type="text" name="wp_to_diaspora_settings[username]" value="<?php echo esc_attr( $this->get_option( 'username' ) ); ?>" placeholder="<?php esc_attr_e( 'Username', 'wp-to-diaspora' ); ?>" required> |
504
|
|
|
<?php |
505
|
|
|
} |
506
|
|
|
|
507
|
|
|
/** |
508
|
|
|
* Render the "Password" field. |
509
|
|
|
*/ |
510
|
|
|
public function password_render() { |
511
|
|
|
// Special case if we already have a password. |
512
|
|
|
$has_password = ( '' !== $this->get_option( 'password', '' ) ); |
513
|
|
|
$placeholder = $has_password ? __( 'Password already set.', 'wp-to-diaspora' ) : __( 'Password', 'wp-to-diaspora' ); |
514
|
|
|
$required = $has_password ? '' : ' required'; |
515
|
|
|
?> |
516
|
|
|
<input type="password" name="wp_to_diaspora_settings[password]" value="" placeholder="<?php echo esc_attr( $placeholder ); ?>"<?php echo esc_attr( $required ); ?>> |
517
|
|
|
<?php if ( $has_password ) : ?> |
518
|
|
|
<p class="description"><?php esc_html_e( 'If you would like to change the password type a new one. Otherwise leave this blank.', 'wp-to-diaspora' ); ?></p> |
519
|
|
|
<?php endif; |
520
|
|
|
} |
521
|
|
|
|
522
|
|
|
|
523
|
|
|
/** |
524
|
|
|
* Callback for the "Defaults" section. |
525
|
|
|
*/ |
526
|
|
|
public function defaults_section() { |
527
|
|
|
esc_html_e( 'Define the default posting behaviour for all posts here. These settings can be modified for each post individually, by changing the values in the "WP to diaspora*" meta box, which gets displayed in your post edit screen.', 'wp-to-diaspora' ); |
528
|
|
|
|
529
|
|
|
// Post types field. |
530
|
|
|
add_settings_field( 'enabled_post_types', __( 'Post types', 'wp-to-diaspora' ), [ $this, 'post_types_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section' ); |
531
|
|
|
|
532
|
|
|
// Post to diaspora* checkbox. |
533
|
|
|
add_settings_field( 'post_to_diaspora', __( 'Post to diaspora*', 'wp-to-diaspora' ), [ $this, 'post_to_diaspora_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', $this->get_option( 'post_to_diaspora' ) ); |
534
|
|
|
|
535
|
|
|
// Full entry link checkbox. |
536
|
|
|
add_settings_field( 'fullentrylink', __( 'Show "Posted at" link?', 'wp-to-diaspora' ), [ $this, 'fullentrylink_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', $this->get_option( 'fullentrylink' ) ); |
537
|
|
|
|
538
|
|
|
// Full text, excerpt or none radio buttons. |
539
|
|
|
add_settings_field( 'display', __( 'Display', 'wp-to-diaspora' ), [ $this, 'display_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', $this->get_option( 'display' ) ); |
540
|
|
|
|
541
|
|
|
// Tags to post dropdown. |
542
|
|
|
add_settings_field( 'tags_to_post', __( 'Tags to post', 'wp-to-diaspora' ), [ $this, 'tags_to_post_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', $this->get_option( 'tags_to_post', 'gc' ) ); |
543
|
|
|
|
544
|
|
|
// Global tags field. |
545
|
|
|
add_settings_field( 'global_tags', __( 'Global tags', 'wp-to-diaspora' ), [ $this, 'global_tags_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', $this->get_option( 'global_tags' ) ); |
546
|
|
|
|
547
|
|
|
// Aspects checkboxes. |
548
|
|
|
add_settings_field( 'aspects', __( 'Aspects', 'wp-to-diaspora' ), [ $this, 'aspects_services_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', [ 'aspects', $this->get_option( 'aspects' ) ] ); |
549
|
|
|
|
550
|
|
|
// Services checkboxes. |
551
|
|
|
add_settings_field( 'services', __( 'Services', 'wp-to-diaspora' ), [ $this, 'aspects_services_render' ], 'wp_to_diaspora_settings', 'wp_to_diaspora_defaults_section', [ 'services', $this->get_option( 'services' ) ] ); |
552
|
|
|
} |
553
|
|
|
|
554
|
|
|
/** |
555
|
|
|
* Render the "Post types" checkboxes. |
556
|
|
|
*/ |
557
|
|
|
public function post_types_render() { |
558
|
|
|
$post_types = get_post_types( [ 'public' => true ], 'objects' ); |
559
|
|
|
|
560
|
|
|
// Remove excluded post types from the list. |
561
|
|
|
$excluded_post_types = [ 'attachment', 'nav_menu_item', 'revision' ]; |
562
|
|
|
foreach ( $excluded_post_types as $excluded ) { |
563
|
|
|
unset( $post_types[ $excluded ] ); |
564
|
|
|
} |
565
|
|
|
?> |
566
|
|
|
|
567
|
|
|
<select id="enabled-post-types" multiple data-placeholder="<?php esc_attr_e( 'None', 'wp-to-diaspora' ); ?>" class="chosen" name="wp_to_diaspora_settings[enabled_post_types][]"> |
568
|
|
|
<?php foreach ( $post_types as $post_type ) : ?> |
569
|
|
|
<option value="<?php echo esc_attr( $post_type->name ); ?>" <?php selected( in_array( $post_type->name, $this->get_option( 'enabled_post_types' ), true ) ); ?>><?php echo esc_html( $post_type->label ); ?></option> |
570
|
|
|
<?php endforeach; ?> |
571
|
|
|
</select> |
572
|
|
|
|
573
|
|
|
<p class="description"><?php esc_html_e( 'Choose which post types can be posted to diaspora*.', 'wp-to-diaspora' ); ?></p> |
574
|
|
|
|
575
|
|
|
<?php |
576
|
|
|
} |
577
|
|
|
|
578
|
|
|
/** |
579
|
|
|
* Render the "Post to diaspora*" checkbox. |
580
|
|
|
* |
581
|
|
|
* @param bool $post_to_diaspora If this checkbox is checked or not. |
582
|
|
|
*/ |
583
|
|
|
public function post_to_diaspora_render( $post_to_diaspora ) { |
584
|
|
|
$label = ( 'settings_page_wp_to_diaspora' === get_current_screen()->id ) ? __( 'Yes', 'wp-to-diaspora' ) : __( 'Post to diaspora*', 'wp-to-diaspora' ); |
585
|
|
|
?> |
586
|
|
|
<label><input type="checkbox" id="post-to-diaspora" name="wp_to_diaspora_settings[post_to_diaspora]" value="1" <?php checked( $post_to_diaspora ); ?>><?php echo esc_html( $label ); ?></label> |
587
|
|
|
<?php |
588
|
|
|
} |
589
|
|
|
|
590
|
|
|
/** |
591
|
|
|
* Render the "Show 'Posted at' link" checkbox. |
592
|
|
|
* |
593
|
|
|
* @param bool $show_link If the checkbox is checked or not. |
594
|
|
|
*/ |
595
|
|
|
public function fullentrylink_render( $show_link ) { |
596
|
|
|
$description = __( 'Include a link back to your original post.', 'wp-to-diaspora' ); |
597
|
|
|
$checkbox = '<input type="checkbox" id="fullentrylink" name="wp_to_diaspora_settings[fullentrylink]" value="1"' . checked( $show_link, true, false ) . '>'; |
598
|
|
|
|
599
|
|
|
if ( 'settings_page_wp_to_diaspora' === get_current_screen()->id ) : ?> |
600
|
|
|
<label><?php echo $checkbox; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?><?php esc_html_e( 'Yes', 'wp-to-diaspora' ); ?></label> |
601
|
|
|
<p class="description"><?php echo esc_html( $description ); ?></p> |
602
|
|
|
<?php else : ?> |
603
|
|
|
<label title="<?php echo esc_attr( $description ); ?>"><?php echo $checkbox; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?><?php esc_html_e( 'Show "Posted at" link?', 'wp-to-diaspora' ); ?></label> |
604
|
|
|
<?php endif; |
605
|
|
|
} |
606
|
|
|
|
607
|
|
|
/** |
608
|
|
|
* Render the "Display" radio buttons. |
609
|
|
|
* |
610
|
|
|
* @param string $display The selected radio button. |
611
|
|
|
*/ |
612
|
|
|
public function display_render( $display ) { |
613
|
|
|
?> |
614
|
|
|
<label><input type="radio" name="wp_to_diaspora_settings[display]" value="full" <?php checked( $display, 'full' ); ?>><?php esc_html_e( 'Full Post', 'wp-to-diaspora' ); ?></label><br/> |
615
|
|
|
<label><input type="radio" name="wp_to_diaspora_settings[display]" value="excerpt" <?php checked( $display, 'excerpt' ); ?>><?php esc_html_e( 'Excerpt', 'wp-to-diaspora' ); ?></label><br/> |
616
|
|
|
<label><input type="radio" name="wp_to_diaspora_settings[display]" value="none" <?php checked( $display, 'none' ); ?>><?php esc_html_e( 'None', 'wp-to-diaspora' ); ?></label> |
617
|
|
|
<?php |
618
|
|
|
} |
619
|
|
|
|
620
|
|
|
/** |
621
|
|
|
* Render the "Tags to post" field. |
622
|
|
|
* |
623
|
|
|
* @param array $tags_to_post The types of tags to be posted. |
624
|
|
|
*/ |
625
|
|
|
public function tags_to_post_render( $tags_to_post ) { |
626
|
|
|
$on_settings_page = ( 'settings_page_wp_to_diaspora' === get_current_screen()->id ); |
627
|
|
|
$description = esc_html__( 'Choose which tags should be posted to diaspora*.', 'wp-to-diaspora' ); |
628
|
|
|
|
629
|
|
|
if ( ! $on_settings_page ) { |
630
|
|
|
echo '<label>' . esc_html( $description ); |
631
|
|
|
} |
632
|
|
|
|
633
|
|
|
?> |
634
|
|
|
<select id="tags-to-post" multiple data-placeholder="<?php esc_attr_e( 'No tags', 'wp-to-diaspora' ); ?>" class="chosen" name="wp_to_diaspora_settings[tags_to_post][]"> |
635
|
|
|
<option value="global" <?php selected( in_array( 'global', $tags_to_post, true ) ); ?>><?php esc_html_e( 'Global tags', 'wp-to-diaspora' ); ?></option> |
636
|
|
|
<option value="custom" <?php selected( in_array( 'custom', $tags_to_post, true ) ); ?>><?php esc_html_e( 'Custom tags', 'wp-to-diaspora' ); ?></option> |
637
|
|
|
<option value="post" <?php selected( in_array( 'post', $tags_to_post, true ) ); ?>><?php esc_html_e( 'Post tags', 'wp-to-diaspora' ); ?></option> |
638
|
|
|
</select> |
639
|
|
|
|
640
|
|
|
<?php if ( $on_settings_page ) : ?> |
641
|
|
|
<p class="description"><?php echo esc_html( $description ); ?></p> |
642
|
|
|
<?php else : ?> |
643
|
|
|
</label> |
644
|
|
|
<?php endif; |
645
|
|
|
} |
646
|
|
|
|
647
|
|
|
/** |
648
|
|
|
* Render the "Global tags" field. |
649
|
|
|
* |
650
|
|
|
* @param array $tags The global tags to be posted. |
651
|
|
|
*/ |
652
|
|
|
public function global_tags_render( $tags ) { |
653
|
|
|
WP2D_Helpers::arr_to_str( $tags ); |
654
|
|
|
?> |
655
|
|
|
<input type="text" class="regular-text wp2d-tags" name="wp_to_diaspora_settings[global_tags]" value="<?php echo esc_attr( $tags ); ?>" placeholder="<?php esc_attr_e( 'Global tags', 'wp-to-diaspora' ); ?>"> |
656
|
|
|
<p class="description"><?php esc_html_e( 'Custom tags to add to all posts being posted to diaspora*.', 'wp-to-diaspora' ); ?></p> |
657
|
|
|
<?php |
658
|
|
|
} |
659
|
|
|
|
660
|
|
|
/** |
661
|
|
|
* Render the "Custom tags" field. |
662
|
|
|
* |
663
|
|
|
* @param array $tags The custom tags to be posted. |
664
|
|
|
*/ |
665
|
|
|
public function custom_tags_render( $tags ) { |
666
|
|
|
WP2D_Helpers::arr_to_str( $tags ); |
667
|
|
|
?> |
668
|
|
|
<label title="<?php esc_attr_e( 'Custom tags to add to this post when it\'s posted to diaspora*.', 'wp-to-diaspora' ); ?>"> |
669
|
|
|
<?php esc_html_e( 'Custom tags', 'wp-to-diaspora' ); ?> |
670
|
|
|
<input type="text" class="widefat wp2d-tags" name="wp_to_diaspora_settings[custom_tags]" value="<?php echo esc_attr( $tags ); ?>"> |
671
|
|
|
</label> |
672
|
|
|
<p class="description"><?php esc_html_e( 'Separate tags with commas', 'wp-to-diaspora' ); ?></p> |
673
|
|
|
<?php |
674
|
|
|
} |
675
|
|
|
|
676
|
|
|
/** |
677
|
|
|
* Render the "Aspects" and "Services" checkboxes. |
678
|
|
|
* |
679
|
|
|
* @param array $args Array containing the type and items to output as checkboxes. |
680
|
|
|
*/ |
681
|
|
|
public function aspects_services_render( $args ) { |
682
|
|
|
[ $type, $items ] = $args; |
|
|
|
|
683
|
|
|
|
684
|
|
|
// This is where the 2 types show their differences. |
685
|
|
|
switch ( $type ) { |
686
|
|
|
case 'aspects': |
687
|
|
|
$refresh_button = __( 'Refresh Aspects', 'wp-to-diaspora' ); |
688
|
|
|
$description = esc_html__( 'Choose which aspects to share to.', 'wp-to-diaspora' ); |
689
|
|
|
$empty_label = '<input type="checkbox" name="wp_to_diaspora_settings[aspects][]" value="public" checked="checked">' . esc_html__( 'Public', 'wp-to-diaspora' ); |
690
|
|
|
break; |
691
|
|
|
|
692
|
|
|
case 'services': |
693
|
|
|
$refresh_button = __( 'Refresh Services', 'wp-to-diaspora' ); |
694
|
|
|
$description = sprintf( |
695
|
|
|
'%1$s<br><a href="%2$s" target="_blank">%3$s</a>', |
696
|
|
|
esc_html__( 'Choose which services to share to.', 'wp-to-diaspora' ), |
697
|
|
|
esc_url( 'https://' . $this->get_option( 'pod' ) . '/services' ), |
698
|
|
|
esc_html__( 'Show available services on my pod.', 'wp-to-diaspora' ) |
699
|
|
|
); |
700
|
|
|
$empty_label = esc_html__( 'No services connected yet.', 'wp-to-diaspora' ); |
701
|
|
|
break; |
702
|
|
|
|
703
|
|
|
default: |
704
|
|
|
return; |
705
|
|
|
} |
706
|
|
|
|
707
|
|
|
$items = array_filter( (array) $items ) ?: []; |
|
|
|
|
708
|
|
|
|
709
|
|
|
// Special case for this field if it's displayed on the settings page. |
710
|
|
|
$on_settings_page = ( 'settings_page_wp_to_diaspora' === get_current_screen()->id ); |
711
|
|
|
|
712
|
|
|
if ( ! $on_settings_page ) { |
713
|
|
|
echo $description; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped |
714
|
|
|
$description = ''; |
715
|
|
|
} |
716
|
|
|
|
717
|
|
|
?> |
718
|
|
|
<div id="<?php echo esc_attr( $type ); ?>-container" data-<?php echo esc_attr( $type ); ?>-selected="<?php echo esc_attr( implode( ',', $items ) ); ?>"> |
719
|
|
|
<?php if ( $list = (array) $this->get_option( $type . '_list' ) ) : ?> |
720
|
|
|
<?php foreach ( $list as $id => $name ) : ?> |
721
|
|
|
<label><input type="checkbox" name="wp_to_diaspora_settings[<?php echo esc_attr( $type ); ?>][]" value="<?php echo esc_attr( $id ); ?>" <?php checked( in_array( $id, $items, false ) ); // phpcs:ignore WordPress.PHP.StrictInArray.FoundNonStrictFalse ?>><?php echo esc_html( $name ); ?></label> |
722
|
|
|
<?php endforeach; ?> |
723
|
|
|
<?php else : ?> |
724
|
|
|
<label><?php echo $empty_label; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?></label> |
725
|
|
|
<?php endif; ?> |
726
|
|
|
</div> |
727
|
|
|
<p class="description"> |
728
|
|
|
<?php echo $description; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?> |
729
|
|
|
<a id="refresh-<?php echo esc_attr( $type ); ?>-list" class="button hide-if-no-js"><?php echo esc_html( $refresh_button ); ?></a> |
730
|
|
|
<span class="spinner"></span> |
731
|
|
|
<span class="hide-if-js"><?php printf( esc_html_x( 'To update this list, %1$sre-save your login info%2$s.', 'placeholders are link tags to the settings page.', 'wp-to-diaspora' ), '<a href="' . esc_url( admin_url( 'options-general.php?page=wp_to_diaspora' ) ) . '&tab=setup" target="_blank">', '</a>' ); ?></span> |
732
|
|
|
</p> |
733
|
|
|
<?php |
734
|
|
|
} |
735
|
|
|
|
736
|
|
|
|
737
|
|
|
/** |
738
|
|
|
* Get a specific option. |
739
|
|
|
* |
740
|
|
|
* @param null|string $option ID of option to get. |
741
|
|
|
* @param mixed $default Override default value if option not found. |
742
|
|
|
* |
743
|
|
|
* @return mixed Requested option value. |
744
|
|
|
*/ |
745
|
|
|
public function get_option( $option = null, $default = null ) { |
746
|
|
|
if ( null === self::$options ) { |
747
|
|
|
self::$options = get_option( 'wp_to_diaspora_settings', self::$default_options ); |
748
|
|
|
} |
749
|
|
|
if ( null !== $option ) { |
750
|
|
|
if ( isset( self::$options[ $option ] ) ) { |
751
|
|
|
// Return found option value. |
752
|
|
|
return self::$options[ $option ]; |
753
|
|
|
} elseif ( null !== $default ) { |
754
|
|
|
// Return overridden default value. |
755
|
|
|
return $default; |
756
|
|
|
} elseif ( isset( self::$default_options[ $option ] ) ) { |
757
|
|
|
// Return default option value. |
758
|
|
|
return self::$default_options[ $option ]; |
759
|
|
|
} |
760
|
|
|
} |
761
|
|
|
|
762
|
|
|
return $default; |
763
|
|
|
} |
764
|
|
|
|
765
|
|
|
/** |
766
|
|
|
* Get all options. |
767
|
|
|
* |
768
|
|
|
* @return array All the options. |
769
|
|
|
*/ |
770
|
|
|
public function get_options() { |
771
|
|
|
return self::$options; |
772
|
|
|
} |
773
|
|
|
|
774
|
|
|
/** |
775
|
|
|
* Set a certain option. |
776
|
|
|
* |
777
|
|
|
* @param string $option ID of option to get. |
778
|
|
|
* @param array|string $value Value to be set for the passed option. |
779
|
|
|
* @param bool $save Save the options immediately after setting them. |
780
|
|
|
*/ |
781
|
|
|
public function set_option( $option, $value, $save = false ) { |
782
|
|
|
if ( null !== $option ) { |
783
|
|
|
if ( null !== $value ) { |
784
|
|
|
self::$options[ $option ] = $value; |
785
|
|
|
} else { |
786
|
|
|
unset( self::$options[ $option ] ); |
787
|
|
|
} |
788
|
|
|
} |
789
|
|
|
|
790
|
|
|
$save && $this->save(); |
791
|
|
|
} |
792
|
|
|
|
793
|
|
|
/** |
794
|
|
|
* Save the options. |
795
|
|
|
*/ |
796
|
|
|
public function save() { |
797
|
|
|
update_option( 'wp_to_diaspora_settings', self::$options ); |
798
|
|
|
} |
799
|
|
|
|
800
|
|
|
/** |
801
|
|
|
* Get all valid input values for the passed field. |
802
|
|
|
* |
803
|
|
|
* @param string $field Field to get the valid values for. |
804
|
|
|
* |
805
|
|
|
* @return array List of valid values. |
806
|
|
|
*/ |
807
|
|
|
public function get_valid_values( $field ) { |
808
|
|
|
if ( array_key_exists( $field, self::$valid_values ) ) { |
809
|
|
|
return self::$valid_values[ $field ]; |
810
|
|
|
} |
811
|
|
|
} |
812
|
|
|
|
813
|
|
|
/** |
814
|
|
|
* Check if a value is valid for the passed field. |
815
|
|
|
* |
816
|
|
|
* @param string $field Field to check the valid value for. |
817
|
|
|
* @param mixed $value Value to check validity. |
818
|
|
|
* |
819
|
|
|
* @return bool If the passed value is valid. |
820
|
|
|
*/ |
821
|
|
|
public function is_valid_value( $field, $value ) { |
822
|
|
|
if ( $valids = $this->get_valid_values( $field ) ) { |
823
|
|
|
return in_array( $value, $valids, true ); |
824
|
|
|
} |
825
|
|
|
|
826
|
|
|
return false; |
827
|
|
|
} |
828
|
|
|
|
829
|
|
|
/** |
830
|
|
|
* Attempt to upgrade the password from using AUTH_KEY to using WP2D_AUTH_KEY. |
831
|
|
|
* |
832
|
|
|
* @since 2.2.0 |
833
|
|
|
* |
834
|
|
|
* @param bool $save If the password should be saved to the options immediately. |
835
|
|
|
*/ |
836
|
|
|
public function attempt_password_upgrade( $save = false ) { |
837
|
|
|
if ( AUTH_KEY !== WP2D_ENC_KEY ) { |
838
|
|
|
$old_pw = WP2D_Helpers::decrypt( (string) $this->get_option( 'password' ), AUTH_KEY ); |
839
|
|
|
if ( null !== $old_pw ) { |
840
|
|
|
$new_pw = WP2D_Helpers::encrypt( $old_pw, WP2D_ENC_KEY ); |
841
|
|
|
$this->set_option( 'password', $new_pw, $save ); |
842
|
|
|
} |
843
|
|
|
} |
844
|
|
|
} |
845
|
|
|
|
846
|
|
|
/** |
847
|
|
|
* Validate all settings. |
848
|
|
|
* |
849
|
|
|
* @param array $input RAW input values. |
850
|
|
|
* |
851
|
|
|
* @return array Validated input values. |
852
|
|
|
*/ |
853
|
|
|
public function validate_settings( $input ) { |
854
|
|
|
/* Validate all settings before saving to the database. */ |
855
|
|
|
|
856
|
|
|
// Saving the pod setup details. |
857
|
|
|
if ( isset( $input['submit_setup'] ) ) { |
858
|
|
|
$input['pod'] = trim( sanitize_text_field( $input['pod'] ), ' /' ); |
859
|
|
|
$input['username'] = sanitize_text_field( $input['username'] ); |
860
|
|
|
$input['password'] = sanitize_text_field( $input['password'] ); |
861
|
|
|
|
862
|
|
|
// If password is blank, it hasn't been changed. |
863
|
|
|
// If new password is equal to the encrypted password already saved, it was just passed again. It happens everytime update_option('wp_to_diaspora_settings') is called. |
864
|
|
|
if ( '' === $input['password'] || $this->get_option( 'password' ) === $input['password'] ) { |
865
|
|
|
// Attempt a password upgrade if applicable. |
866
|
|
|
$this->attempt_password_upgrade( true ); |
867
|
|
|
$input['password'] = $this->get_option( 'password' ); |
868
|
|
|
} else { |
869
|
|
|
$input['password'] = WP2D_Helpers::encrypt( $input['password'] ); |
870
|
|
|
} |
871
|
|
|
|
872
|
|
|
// Keep a note of the current AUTH_KEY. |
873
|
|
|
$this->set_option( 'auth_key_hash', md5( AUTH_KEY ), true ); |
874
|
|
|
|
875
|
|
|
// This is for when JS in not enabled, to make sure that the aspects and services |
876
|
|
|
// are re-fetched when displaying the options page after saving. |
877
|
|
|
if ( isset( $input['no_js'] ) ) { |
878
|
|
|
set_transient( 'wp2d_no_js_force_refetch', true ); |
879
|
|
|
} |
880
|
|
|
} |
881
|
|
|
|
882
|
|
|
// Saving the default options. |
883
|
|
|
if ( isset( $input['submit_defaults'] ) ) { |
884
|
|
|
if ( ! isset( $input['enabled_post_types'] ) ) { |
885
|
|
|
$input['enabled_post_types'] = []; |
886
|
|
|
} |
887
|
|
|
|
888
|
|
|
// Checkboxes. |
889
|
|
|
$this->validate_checkboxes( [ 'post_to_diaspora', 'fullentrylink' ], $input ); |
890
|
|
|
|
891
|
|
|
// Single Selects. |
892
|
|
|
$this->validate_single_selects( 'display', $input ); |
893
|
|
|
|
894
|
|
|
// Multiple Selects. |
895
|
|
|
$this->validate_multi_selects( 'tags_to_post', $input ); |
896
|
|
|
|
897
|
|
|
// Get unique, non-empty, trimmed tags and clean them up. |
898
|
|
|
$this->validate_tags( $input['global_tags'] ); |
899
|
|
|
|
900
|
|
|
// Clean up the list of aspects. If the list is empty, only use the 'Public' aspect. |
901
|
|
|
$this->validate_aspects_services( $input['aspects'], [ 'public' ] ); |
902
|
|
|
|
903
|
|
|
// Clean up the list of services. |
904
|
|
|
$this->validate_aspects_services( $input['services'] ); |
905
|
|
|
} |
906
|
|
|
|
907
|
|
|
// Reset to defaults. |
908
|
|
|
if ( isset( $input['reset_defaults'] ) ) { |
909
|
|
|
// Set the input to the default options. |
910
|
|
|
$input = self::$default_options; |
911
|
|
|
|
912
|
|
|
// Don't reset the fetched lists of aspects and services. |
913
|
|
|
unset( $input['pod_list'], $input['aspects_list'], $input['services_list'] ); |
914
|
|
|
} |
915
|
|
|
|
916
|
|
|
// Unset all unused input fields. |
917
|
|
|
unset( $input['submit_defaults'], $input['reset_defaults'], $input['submit_setup'] ); |
918
|
|
|
|
919
|
|
|
// Parse inputs with default options and return. |
920
|
|
|
return wp_parse_args( $input, array_merge( self::$default_options, self::$options ) ); |
921
|
|
|
} |
922
|
|
|
|
923
|
|
|
/** |
924
|
|
|
* Validate checkboxes, make them either true or false. |
925
|
|
|
* |
926
|
|
|
* @param string|array $checkboxes Checkboxes to validate. |
927
|
|
|
* @param array $options Options values themselves. |
928
|
|
|
* |
929
|
|
|
* @return array The validated options. |
930
|
|
|
*/ |
931
|
|
|
public function validate_checkboxes( $checkboxes, &$options ) { |
932
|
|
|
foreach ( WP2D_Helpers::str_to_arr( $checkboxes ) as $checkbox ) { |
|
|
|
|
933
|
|
|
$options[ $checkbox ] = isset( $options[ $checkbox ] ); |
934
|
|
|
} |
935
|
|
|
|
936
|
|
|
return $options; |
937
|
|
|
} |
938
|
|
|
|
939
|
|
|
/** |
940
|
|
|
* Validate single-select fields and make sure their selected value are valid. |
941
|
|
|
* |
942
|
|
|
* @param string|array $selects Name(s) of the select fields. |
943
|
|
|
* @param array $options Options values themselves. |
944
|
|
|
* |
945
|
|
|
* @return array The validated options. |
946
|
|
|
*/ |
947
|
|
|
public function validate_single_selects( $selects, &$options ) { |
948
|
|
|
foreach ( WP2D_Helpers::str_to_arr( $selects ) as $select ) { |
|
|
|
|
949
|
|
|
if ( isset( $options[ $select ] ) && ! $this->is_valid_value( $select, $options[ $select ] ) ) { |
950
|
|
|
unset( $options[ $select ] ); |
951
|
|
|
} |
952
|
|
|
} |
953
|
|
|
|
954
|
|
|
return $options; |
955
|
|
|
} |
956
|
|
|
|
957
|
|
|
/** |
958
|
|
|
* Validate multi-select fields and make sure their selected values are valid. |
959
|
|
|
* |
960
|
|
|
* @param string|array $selects Name(s) of the select fields. |
961
|
|
|
* @param array $options Options values themselves. |
962
|
|
|
* |
963
|
|
|
* @return array The validated options. |
964
|
|
|
*/ |
965
|
|
|
public function validate_multi_selects( $selects, &$options ) { |
966
|
|
|
foreach ( WP2D_Helpers::str_to_arr( $selects ) as $select ) { |
|
|
|
|
967
|
|
|
if ( isset( $options[ $select ] ) ) { |
968
|
|
|
foreach ( (array) $options[ $select ] as $option_value ) { |
969
|
|
|
if ( ! $this->is_valid_value( $select, $option_value ) ) { |
970
|
|
|
unset( $options[ $select ] ); |
971
|
|
|
break; |
972
|
|
|
} |
973
|
|
|
} |
974
|
|
|
} else { |
975
|
|
|
$options[ $select ] = []; |
976
|
|
|
} |
977
|
|
|
} |
978
|
|
|
|
979
|
|
|
return $options; |
980
|
|
|
} |
981
|
|
|
|
982
|
|
|
/** |
983
|
|
|
* Clean up the passed tags. Keep only alphanumeric, hyphen and underscore characters. |
984
|
|
|
* |
985
|
|
|
* @param array|string $tags Tags to be cleaned as array or comma seperated values. |
986
|
|
|
* |
987
|
|
|
* @return array The cleaned tags. |
988
|
|
|
*/ |
989
|
|
|
public function validate_tags( &$tags ) { |
990
|
|
|
WP2D_Helpers::str_to_arr( $tags ); |
991
|
|
|
|
992
|
|
|
$tags = array_map( [ $this, 'validate_tag' ], |
993
|
|
|
array_unique( |
994
|
|
|
array_filter( $tags, 'trim' ) |
995
|
|
|
) |
996
|
|
|
); |
997
|
|
|
|
998
|
|
|
return $tags; |
999
|
|
|
} |
1000
|
|
|
|
1001
|
|
|
/** |
1002
|
|
|
* Clean up the passed tag. Keep only alphanumeric, hyphen and underscore characters. |
1003
|
|
|
* |
1004
|
|
|
* @todo What about eastern characters? (chinese, indian, etc.) |
1005
|
|
|
* |
1006
|
|
|
* @param string $tag Tag to be cleaned. |
1007
|
|
|
* |
1008
|
|
|
* @return string The clean tag. |
1009
|
|
|
*/ |
1010
|
|
|
public function validate_tag( &$tag ) { |
1011
|
|
|
$tag = preg_replace( '/[^\w $\-]/u', '', str_replace( ' ', '-', trim( $tag ) ) ); |
1012
|
|
|
|
1013
|
|
|
return $tag; |
1014
|
|
|
} |
1015
|
|
|
|
1016
|
|
|
/** |
1017
|
|
|
* Validate the passed aspects or services. |
1018
|
|
|
* |
1019
|
|
|
* @param array $aspects_services List of aspects or services that need to be validated. |
1020
|
|
|
* @param array $default Default value if not valid. |
1021
|
|
|
* |
1022
|
|
|
* @return array The validated list of aspects or services. |
1023
|
|
|
*/ |
1024
|
|
|
public function validate_aspects_services( &$aspects_services, array $default = [] ) { |
1025
|
|
|
if ( empty( $aspects_services ) || ! is_array( $aspects_services ) ) { |
1026
|
|
|
$aspects_services = $default; |
1027
|
|
|
} else { |
1028
|
|
|
array_walk( $aspects_services, 'sanitize_text_field' ); |
1029
|
|
|
} |
1030
|
|
|
|
1031
|
|
|
return $aspects_services; |
1032
|
|
|
} |
1033
|
|
|
} |
1034
|
|
|
|
This check marks access to variables or properties that have not been declared yet. While PHP has no explicit notion of declaring a variable, accessing it before a value is assigned to it is most likely a bug.