BP_REST_Media_Endpoint::update_item( WP_REST_Request $request )
Update a media.
Description
Parameters
- $request
-
(Required) Full details about the request.
Return
(WP_REST_Response) | WP_Error
Source
File: bp-media/classes/class-bp-rest-media-endpoint.php
public function update_item( $request ) { $id = $request['id']; $medias = $this->assemble_response_data( array( 'media_ids' => array( $id ) ) ); if ( empty( $medias['medias'] ) ) { return new WP_Error( 'bp_rest_media_id', __( 'Invalid media ID.', 'buddyboss' ), array( 'status' => 404, ) ); } $media = end( $medias['medias'] ); $args = array( 'id' => $media->id, 'privacy' => $media->privacy, 'attachment_id' => $media->attachment_id, 'group_id' => $media->group_id, 'album_id' => $media->album_id, ); if ( isset( $request['group_id'] ) && ! empty( $request['group_id'] ) ) { $args['group_id'] = $request['group_id']; } if ( isset( $request['privacy'] ) && ! empty( $request['privacy'] ) ) { $args['privacy'] = $request['privacy']; } if ( isset( $request['album_id'] ) && ! empty( $request['album_id'] ) ) { $args['album_id'] = $request['album_id']; } if ( isset( $request['content'] ) && ! empty( $request['content'] ) ) { $args['content'] = $request['content']; } /** * Filter the query arguments for the request. * * @param array $args Key value array of query var to query value. * @param WP_REST_Request $request The request sent to the API. * * @since 0.1.0 */ $args = apply_filters( 'bp_rest_media_update_items_query_args', $args, $request ); $id = $this->bp_rest_create_media( $args ); $status = true; if ( is_wp_error( $id ) ) { return $id; } if ( empty( $id ) ) { $status = false; } $medias = $this->assemble_response_data( array( 'media_ids' => array( $request['id'] ) ) ); $retval = ''; foreach ( $medias['medias'] as $media ) { $retval = $this->prepare_response_for_collection( $this->prepare_item_for_response( $media, $request ) ); } $response = new WP_REST_Response(); $response->set_data( array( 'updated' => $status, 'data' => $retval, ) ); /** * Fires after an activity is updated via the REST API. * * @param BP_Activity_Activity $activity The updated activity. * @param WP_REST_Response $response The response data. * @param WP_REST_Request $request The request sent to the API. * * @since 0.1.0 */ do_action( 'bp_rest_activity_update_item', $response, $request ); return $response; }
Changelog
Version | Description |
---|---|
0.1.0 | Introduced. |
Questions?
We're always happy to help with code or other questions you might have! Search our developer docs, contact support, or connect with our sales team.