forked from facebookarchive/wordpress
-
Notifications
You must be signed in to change notification settings - Fork 0
/
facebook-user.php
357 lines (314 loc) · 12.6 KB
/
facebook-user.php
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
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
<?php
/**
* Functions related to a Facebook user in the WordPress user system
*
* @since 1.1
*/
class Facebook_User {
/**
* Allow WordPress publishers to interrupt the get_user_meta process
*
* @since 1.1
* @uses get_user_meta()
* @link http://codex.wordpress.org/Function_Reference/get_user_meta
*
* @param int $user_id WordPress user identifier
* @param string $meta_key Optional. The meta key to retrieve. By default, returns data for all keys.
* @param bool $single Whether to return a single value.
* @return mixed Will be an array if $single is false. Will be value of meta data field if $single is true.
*/
public static function get_user_meta( $user_id, $meta_key, $single = false ) {
/**
* Allow sites to override user data requests.
*
* Allow WordPress hosts to implement a custom user meta system by passing data through a custom filter.
*
* @since 1.0
*
* @param bool false default state to test if the filter received a new value
* @param int $user_id WordPress user identifier
* @param string $meta_key the user meta key requested
* @param bool $single if true return value of the meta data field
*/
$override = apply_filters( 'fb_get_user_meta', false, $user_id, $meta_key, $single );
if ( false !== $override )
return $override;
return get_user_meta( $user_id, $meta_key, $single );
}
/**
* Allow WordPress publishers to interrupt the update_user_meta process
* Improves cache integration for some publishers
*
* @since 1.1
* @uses update_user_meta()
* @link http://codex.wordpress.org/Function_Reference/update_user_meta
*
* @param int $user_id WordPress user identifier
* @param string $meta_key The meta key to update
* @param mixed $meta_value new desired value of $meta_key
* @param mixed $prev_value Optional. Previous value to check before removing.
* @return bool False on failure, true if success.
*/
public static function update_user_meta( $user_id, $meta_key, $meta_value, $prev_value = '' ) {
/**
* Allow sites to override user data updates
*
* Allow WordPress hosts to implement a custom user meta system by passing data through a custom filter.
*
* @since 1.0
*
* @param bool false default state to test if the filter received a new value
* @param int $user_id WordPress user identifier
* @param string $meta_key the user meta key to be updated
* @param mixed $meta_value The new desired value of the meta_key, which must be different from the existing value. Arrays and objects will be automatically serialized
* @param mixed $prev_value Previous value to check before removing
*/
$override = apply_filters( 'fb_update_user_meta', false, $user_id, $meta_key, $meta_value, $prev_value );
if ( false !== $override )
return $override;
return update_user_meta( $user_id, $meta_key, $meta_value, $prev_value );
}
/**
* Allow WordPress publishers to interrupt the delete_user_meta process
* Improves cache integration for some publishers
*
* @since 1.1
* @uses delete_user_meta()
* @link http://codex.wordpress.org/Function_Reference/delete_user_meta
*
* @param int $user_id WordPress user identifier
* @param string $meta_key The user meta key to depete
* @param mixed $meta_value Optional. Delete a specific value
* @return bool False for failure. True for success.
*/
public static function delete_user_meta( $user_id, $meta_key, $meta_value = '' ) {
/**
* Allow sites to override user data deletes
*
* Allow WordPress hosts to implement a custom user meta system by passing data through a custom filter.
*
* @since 1.0
*
* @param bool false default state to test if the filter received a new value
* @param int $user_id WordPress user identifier
* @param string $meta_key the user meta key to be deleted
* @param mixed $meta_value Delete a specific value
*/
$override = apply_filters( 'fb_delete_user_meta', false, $user_id, $meta_key, $meta_value );
if ( false !== $override )
return $override;
return delete_user_meta( $user_id, $meta_key, $meta_value );
}
/**
* Extend our access token usage time through the Facebook SDK for PHP
*
* @since 1.0
*
* @global Facebook_WP_Extend $facebook a possible existing instance of the Facebook SDK for PHP
* @global Facebook_Loader $facebook_loader load the Facebook SDK for PHP if not already loaded
* @return void
*/
public static function extend_access_token() {
global $facebook, $facebook_loader;
if ( isset( $facebook ) || ( isset( $facebook_loader ) && $facebook_loader->load_php_sdk() ) )
$facebook->setExtendedAccessToken();
}
/**
* Does the current WordPress user have Facebook data stored?
*
* Has the current viewer authorized the current application to post on his or her behalf?
*
* @since 1.1
* @param int $wordpress_user_id WordPress user identifier. Optional. Uses current user id if not passed
* @param bool $check_publish_override test for the ability to publish to Facebook disabled by the given $wordpress_user_id
* @return bool True if Facebook information present for current user and publish permissions exist
*/
public static function can_publish_to_facebook( $wordpress_user_id = 0, $check_publish_override = true ) {
if ( ! $wordpress_user_id )
$wordpress_user_id = get_current_user_id();
if ( ! $wordpress_user_id )
return false;
// get associated Facebook account
$facebook_profile_id = self::get_facebook_profile_id( $wordpress_user_id );
if ( ! $facebook_profile_id )
return false;
// treat a disabled publish to Timeline preference the same as no publish_actions
if ( $check_publish_override && self::get_user_meta( $wordpress_user_id, 'facebook_timeline_disabled', true ) )
return false;
// Facebook HTTP helper functions
if ( ! class_exists( 'Facebook_WP_Extend' ) )
require_once( dirname(__FILE__) . '/includes/facebook-php-sdk/class-facebook-wp.php' );
// test for publish permissions
$permissions = Facebook_WP_Extend::get_permissions_by_facebook_user_id( $facebook_profile_id );
if ( ! ( is_array( $permissions ) && ! empty( $permissions ) && isset( $permissions['publish_actions'] ) ) )
return false;
return true;
}
/**
* Retrieve a list of all WordPress users for the current site with the given capability.
*
* Divide a site's WordPress users into a group with an associated Facebook account and a group without an account
*
* @since 1.1.6
* @param string $capability WordPress capability. default: edit_posts
* @return array associative array with Facebook-enabled users (fb key) and other users (wp key) {
* WordPress users with the given $capability grouped into users with Facebook accounts and users without
*
* @type string fb array of WP_User objects with Facebook account data accessible via the fb_data property
* @type string wp array of WP_User objects without Facebook account data stored
* }
*/
public static function get_wordpress_users_associated_with_facebook_accounts( $capability = 'edit_posts' ) {
$authors = array(
'fb' => array(),
'wp' => array()
);
if ( ! $capability )
return $authors;
$site_users = get_users( array(
'fields' => array( 'id', 'display_name', 'user_registered' ),
'orderby' => 'display_name',
'order' => 'ASC'
) );
foreach( $site_users as $user ) {
// test for requested capability
if ( ! ( isset( $user->id ) && user_can( $user->id, $capability ) ) )
continue;
$facebook_user_data = self::get_user_meta( $user->id, 'fb_data', true );
if ( is_array( $facebook_user_data ) && isset( $facebook_user_data['fb_uid'] ) ) {
$user->fb_data = $facebook_user_data;
$authors['fb'][] = $user;
} else {
$authors['wp'][] = $user;
}
unset( $facebook_user_data );
}
return $authors;
}
/**
* Gets and returns a specific Facebook user.
*
* Requires basic_info read access for the account. Customize fields to request exactly what you expect to use.
*
* @since 1.5
*
* @link https://developers.facebook.com/docs/reference/api/user/ Facebook User fields
* @param string $facebook_id Facebook user identifier
* @param array $fields User fields to include in the result
* @return array a json_decode()d User response from the Facebook Graph API for the requested user and fields
*/
public static function get_facebook_user( $facebook_id, $fields = array() ) {
// Facebook HTTP helper functions
if ( ! class_exists( 'Facebook_WP_Extend' ) )
require_once( dirname(__FILE__) . '/includes/facebook-php-sdk/class-facebook-wp.php' );
$response = Facebook_WP_Extend::graph_api_with_app_access_token( $facebook_id, 'GET', $fields );
if ( is_array( $response ) ) {
return $response;
}
return array();
}
/**
* Get a list of publishable Facebook pages for the currently authenticated Facebook account.
*
* @since 1.5
*
* @link https://www.facebook.com/help/www/289207354498410 Facebook Page admin roles
* @global Facebook_WP_Extend $facebook a possible existing instance of the Facebook SDK for PHP
* @global Facebook_Loader $facebook_loader load the Facebook SDK for PHP if not already loaded
* @param string $permission page permission
* @return array {
* Associative array of pages with the given permission.
*
* @type string Facebook Page id
* @type array associative array of name, link, access token
* }
*/
public static function get_permissioned_pages( $permission = '' ) {
global $facebook, $facebook_loader;
$pages = array();
if ( ! isset( $facebook ) && ! ( isset( $facebook_loader ) && $facebook_loader->load_php_sdk() ) )
return $pages;
$allowed_permissions = array(
'ADMINISTER' => true,
'EDIT_PROFILE' => true,
'CREATE_CONTENT' => true,
'MODERATE_CONTENT' => true,
'CREATE_ADS' => true,
'BASIC_ADMIN' => true
);
$fields = 'id,name,link,is_published,access_token';
if ( is_string( $permission ) && $permission && isset( $allowed_permissions[$permission] ) )
$fields .= ',perms';
else
$permission = '';
try {
// refresh token if needed
self::extend_access_token();
$accounts = $facebook->api( '/me/accounts', 'GET', array( 'fields' => $fields, 'ref' => 'fbwpp' ) );
} catch (WP_FacebookApiException $e) {}
if ( ! ( isset( $accounts ) && is_array( $accounts['data'] ) ) )
return $pages;
$accounts = $accounts['data'];
foreach ( $accounts as $account ) {
// limit to published pages
if ( ! ( isset( $account['is_published'] ) && $account['is_published'] === true ) )
continue;
// check the specified permission exists for the user accessing the page
if ( $permission && ! ( is_array( $account['perms'] ) && in_array( $permission, $account['perms'], true ) ) )
continue;
// add page if necessary fields exist
if ( empty( $account['id'] ) || empty( $account['name'] ) || empty( $account['access_token'] ) )
continue;
$page = array(
'name' => $account['name'],
'access_token' => $account['access_token']
);
if ( isset( $account['link'] ) && $account['link'] )
$page['link'] = $account['link'];
$pages[ $account['id'] ] = $page;
unset( $page );
}
return $pages;
}
/**
* Get the Facebook user identifier associated with the given WordPress user identifier, if one exists.
*
* @since 1.2
*
* @param int $wordpress_user_id WordPress user identifier
* @return string Facebook user identifier
*/
public static function get_facebook_profile_id( $wordpress_user_id ) {
if ( ! ( is_int( $wordpress_user_id ) && $wordpress_user_id ) )
return '';
$facebook_user_data = self::get_user_meta( $wordpress_user_id, 'fb_data', true );
if ( is_array( $facebook_user_data ) && isset( $facebook_user_data['fb_uid'] ) )
return $facebook_user_data['fb_uid'];
return '';
}
/**
* Build a link to a Facebook profile based on stored Facebook metadata.
*
* @since 1.5
*
* @param array $facebook_user_data {
* fb_data user metadata
*
* @type string 'fb_uid' Facebook User identifier.
* @type string 'link' Absolute URL to a Facebook profile.
* @type string 'username' Vanity Facebook username.
* }
* @return string Facebook profile URL or blank of not enough data exists
*/
public static function facebook_profile_link( $facebook_user_data ) {
if ( ! ( is_array( $facebook_user_data ) && isset( $facebook_user_data['fb_uid'] ) ) )
return '';
if ( isset( $facebook_user_data['link'] ) )
return $facebook_user_data['link'];
else if ( isset( $facebook_user_data['username'] ) )
return 'https://www.facebook.com/' . $facebook_user_data['username'];
else
return 'https://www.facebook.com/profile.php?' . http_build_query( array( 'id' => $facebook_user_data['fb_uid'] ), '', '&' );
}
}
?>