Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

jsarnowski / jsarnowski/jet-engine   php

Repository URL to install this package:

Version: 2.7.7 

/ components / relations / rest-api / edit-relation.php

<?php
/**
 * Add/Update tax endpoint
 */

class Jet_Engine_CPT_Rest_Edit_Relation extends Jet_Engine_Base_API_Endpoint {

	/**
	 * Returns route name
	 *
	 * @return string
	 */
	public function get_name() {
		return 'edit-relation';
	}

	public function safe_get( $args, $group, $key, $default = false ) {
		return isset( $args[ $group ][ $key ] ) ? $args[ $group ][ $key ] : $default;
	}

	/**
	 * API callback
	 *
	 * @return void
	 */
	public function callback( $request ) {

		$params = $request->get_params();

		if ( empty( $params['id'] ) ) {

			jet_engine()->relations->add_notice(
				'error',
				__( 'Item ID not found in request', 'jet-engine' )
			);

			return rest_ensure_response( array(
				'success' => false,
				'notices' => jet_engine()->relations->get_notices(),
			) );

		}

		jet_engine()->relations->data->set_request( array(
			'id'                  => $params['id'],
			'name'                => $this->safe_get( $params, 'general_settings', 'name' ),
			'post_type_1'         => $this->safe_get( $params, 'general_settings', 'post_type_1' ),
			'post_type_2'         => $this->safe_get( $params, 'general_settings', 'post_type_2' ),
			'type'                => $this->safe_get( $params, 'general_settings', 'type' ),
			'parent_relation'     => $this->safe_get( $params, 'general_settings', 'parent_relation' ),
			'post_type_1_control' => $this->safe_get( $params, 'advanced_settings', 'post_type_1_control' ),
			'post_type_2_control' => $this->safe_get( $params, 'advanced_settings', 'post_type_2_control' ),
		) );

		$updated = jet_engine()->relations->data->edit_item( false );

		return rest_ensure_response( array(
			'success' => $updated,
			'notices' => jet_engine()->relations->get_notices(),
		) );

	}

	/**
	 * Returns endpoint request method - GET/POST/PUT/DELTE
	 *
	 * @return string
	 */
	public function get_method() {
		return 'POST';
	}

	/**
	 * Check user access to current end-popint
	 *
	 * @return bool
	 */
	public function permission_callback( $request ) {
		return current_user_can( 'manage_options' );
	}

	/**
	 * Get query param. Regex with query parameters
	 *
	 * @return string
	 */
	public function get_query_params() {
		return '(?P<id>[a-z\-\d]+)';
	}

}