summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/jetpack/json-endpoints/class.wpcom-json-api-site-user-endpoint.php')
-rw-r--r--plugins/jetpack/json-endpoints/class.wpcom-json-api-site-user-endpoint.php107
1 files changed, 107 insertions, 0 deletions
diff --git a/plugins/jetpack/json-endpoints/class.wpcom-json-api-site-user-endpoint.php b/plugins/jetpack/json-endpoints/class.wpcom-json-api-site-user-endpoint.php
new file mode 100644
index 00000000..84a83849
--- /dev/null
+++ b/plugins/jetpack/json-endpoints/class.wpcom-json-api-site-user-endpoint.php
@@ -0,0 +1,107 @@
+<?php
+
+class WPCOM_JSON_API_Site_User_Endpoint extends WPCOM_JSON_API_Endpoint {
+
+ public static $user_format = array(
+ 'ID' => '(int) The ID of the user',
+ 'login' => '(string) The login username of the user',
+ 'email' => '(string) The email of the user',
+ 'name' => '(string) The name to display for the user',
+ 'first_name' => '(string) The first name of the user',
+ 'last_name' => '(string) The last name of the user',
+ 'nice_name' => '(string) The nice_name to display for the user',
+ 'URL' => '(string) The primary blog of the user',
+ 'avatar_URL' => '(url) Gravatar image URL',
+ 'profile_URL' => '(url) Gravatar Profile URL',
+ 'site_ID' => '(int) ID of the user\'s primary blog',
+ 'roles' => '(array) The roles of the user',
+ );
+
+ // /sites/%s/users/%d -> $blog_id, $user_id
+ function callback( $path = '', $blog_id = 0, $user_id = 0 ) {
+ $blog_id = $this->api->switch_to_blog_and_validate_user( $this->api->get_blog_id( $blog_id ) );
+ if ( is_wp_error( $blog_id ) ) {
+ return $blog_id;
+ }
+ if ( ! current_user_can_for_blog( $blog_id, 'list_users' ) ) {
+ return new WP_Error( 'unauthorized', 'User cannot view users for specified site', 403 );
+ }
+
+ // Get the user by ID or login
+ $get_by = false !== strpos( $path, '/users/login:' ) ? 'login' : 'id';
+ $user = get_user_by( $get_by, $user_id );
+
+ if ( ! $user ) {
+ return new WP_Error( 'unknown_user', 'Unknown user', 404 );
+ }
+
+ if ( ! is_user_member_of_blog( $user->ID, $blog_id ) ) {
+ return new WP_Error( 'unknown_user_for_site', 'Unknown user for site', 404 );
+ }
+
+ if ( 'GET' === $this->api->method ) {
+ return $this->get_user( $user->ID );
+ } else if ( 'POST' === $this->api->method ) {
+ if ( ! current_user_can_for_blog( $blog_id, 'promote_users' ) ) {
+ return new WP_Error( 'unauthorized', 'User cannot promote users for specified site', 403 );
+ }
+ if ( get_current_user_id() == $user_id ) {
+ return new WP_Error( 'unauthorized', 'You cannot change your own role', 403 );
+ }
+ return $this->update_user( $user_id );
+ } else {
+ return new WP_Error( 'bad_request', 'An unsupported request method was used.' );
+ }
+ }
+
+ public function get_user( $user_id ) {
+ $the_user = $this->get_author( $user_id, true );
+ if ( $the_user && ! is_wp_error( $the_user ) ) {
+ $userdata = get_userdata( $user_id );
+ $the_user->roles = ! is_wp_error( $userdata ) ? $userdata->roles : array();
+ }
+
+ return $the_user;
+ }
+
+ /**
+ * Updates user data
+ *
+ * @return (array)
+ */
+ public function update_user( $user_id ) {
+ $input = $this->input();
+ $user['ID'] = $user_id;
+ if ( ! ( defined( 'IS_WPCOM' ) && IS_WPCOM ) ) {
+ foreach ( $input as $key => $value ) {
+ if ( ! is_array( $value ) ) {
+ $value = trim( $value );
+ }
+ $value = wp_unslash( $value );
+ switch ( $key ) {
+ case 'first_name':
+ case 'last_name':
+ $user[ $key ] = $value;
+ break;
+ case 'display_name':
+ case 'name':
+ $user[ 'display_name' ] = $value;
+ break;
+ }
+ }
+ }
+ if ( isset( $input[ 'roles' ] ) ) {
+ if ( is_array( $input['roles'] ) ) {
+ $user['role'] = $input['roles'][0];
+ } else {
+ $user['role'] = $input['roles'];
+ }
+ }
+ $result = wp_update_user( $user );
+ if ( is_wp_error( $result ) ) {
+ return $result;
+ }
+ return $this->get_user( $user_id );
+ }
+
+}