PATH:
var
/
softaculous
/
sitepad
/
editor
/
site-data
/
plugins
/
kkart-pro
/
includes
/
rest-api
/
Controllers
/
Version3
<?php /** * REST API Order Notes controller * * Handles requests to the /orders/<order_id>/notes endpoint. * * @package Kkart\RestApi * @since 2.6.0 */ defined( 'ABSPATH' ) || exit; /** * REST API Order Notes controller class. * * @package Kkart\RestApi * @extends KKART_REST_Order_Notes_V2_Controller */ class KKART_REST_Order_Notes_Controller extends KKART_REST_Order_Notes_V2_Controller { /** * Endpoint namespace. * * @var string */ protected $namespace = 'kkart/v3'; /** * Prepare a single order note output for response. * * @param WP_Comment $note Order note object. * @param WP_REST_Request $request Request object. * @return WP_REST_Response $response Response data. */ public function prepare_item_for_response( $note, $request ) { $data = array( 'id' => (int) $note->comment_ID, 'author' => __( 'kkart', 'kkart' ) === $note->comment_author ? 'system' : $note->comment_author, 'date_created' => kkart_rest_prepare_date_response( $note->comment_date ), 'date_created_gmt' => kkart_rest_prepare_date_response( $note->comment_date_gmt ), 'note' => $note->comment_content, 'customer_note' => (bool) get_comment_meta( $note->comment_ID, 'is_customer_note', true ), ); $context = ! empty( $request['context'] ) ? $request['context'] : 'view'; $data = $this->add_additional_fields_to_object( $data, $request ); $data = $this->filter_response_by_context( $data, $context ); // Wrap the data in a response object. $response = rest_ensure_response( $data ); $response->add_links( $this->prepare_links( $note ) ); /** * Filter order note object returned from the REST API. * * @param WP_REST_Response $response The response object. * @param WP_Comment $note Order note object used to create response. * @param WP_REST_Request $request Request object. */ return apply_filters( 'kkart_rest_prepare_order_note', $response, $note, $request ); } /** * Create a single order note. * * @param WP_REST_Request $request Full details about the request. * @return WP_Error|WP_REST_Response */ public function create_item( $request ) { if ( ! empty( $request['id'] ) ) { /* translators: %s: post type */ return new WP_Error( "kkart_rest_{$this->post_type}_exists", sprintf( __( 'Cannot create existing %s.', 'kkart' ), $this->post_type ), array( 'status' => 400 ) ); } $order = kkart_get_order( (int) $request['order_id'] ); if ( ! $order || $this->post_type !== $order->get_type() ) { return new WP_Error( 'kkart_rest_order_invalid_id', __( 'Invalid order ID.', 'kkart' ), array( 'status' => 404 ) ); } // Create the note. $note_id = $order->add_order_note( $request['note'], $request['customer_note'], $request['added_by_user'] ); if ( ! $note_id ) { return new WP_Error( 'kkart_api_cannot_create_order_note', __( 'Cannot create order note, please try again.', 'kkart' ), array( 'status' => 500 ) ); } $note = get_comment( $note_id ); $this->update_additional_fields_for_object( $note, $request ); /** * Fires after a order note is created or updated via the REST API. * * @param WP_Comment $note New order note object. * @param WP_REST_Request $request Request object. * @param boolean $creating True when creating item, false when updating. */ do_action( 'kkart_rest_insert_order_note', $note, $request, true ); $request->set_param( 'context', 'edit' ); $response = $this->prepare_item_for_response( $note, $request ); $response = rest_ensure_response( $response ); $response->set_status( 201 ); $response->header( 'Location', rest_url( sprintf( '/%s/%s/%d', $this->namespace, str_replace( '(?P<order_id>[\d]+)', $order->get_id(), $this->rest_base ), $note_id ) ) ); return $response; } /** * Get the Order Notes schema, conforming to JSON Schema. * * @return array */ public function get_item_schema() { $schema = array( '$schema' => 'http://json-schema.org/draft-04/schema#', 'title' => 'order_note', 'type' => 'object', 'properties' => array( 'id' => array( 'description' => __( 'Unique identifier for the resource.', 'kkart' ), 'type' => 'integer', 'context' => array( 'view', 'edit' ), 'readonly' => true, ), 'author' => array( 'description' => __( 'Order note author.', 'kkart' ), 'type' => 'string', 'context' => array( 'view', 'edit' ), 'readonly' => true, ), 'date_created' => array( 'description' => __( "The date the order note was created, in the site's timezone.", 'kkart' ), 'type' => 'date-time', 'context' => array( 'view', 'edit' ), 'readonly' => true, ), 'date_created_gmt' => array( 'description' => __( 'The date the order note was created, as GMT.', 'kkart' ), 'type' => 'date-time', 'context' => array( 'view', 'edit' ), 'readonly' => true, ), 'note' => array( 'description' => __( 'Order note content.', 'kkart' ), 'type' => 'string', 'context' => array( 'view', 'edit' ), ), 'customer_note' => array( 'description' => __( 'If true, the note will be shown to customers and they will be notified. If false, the note will be for admin reference only.', 'kkart' ), 'type' => 'boolean', 'default' => false, 'context' => array( 'view', 'edit' ), ), 'added_by_user' => array( 'description' => __( 'If true, this note will be attributed to the current user. If false, the note will be attributed to the system.', 'kkart' ), 'type' => 'boolean', 'default' => false, 'context' => array( 'edit' ), ), ), ); return $this->add_additional_fields_schema( $schema ); } }
[-] class-kkart-rest-shipping-zones-controller-base.php
[edit]
[-] class-kkart-rest-crud-controller.php
[edit]
[-] class-kkart-rest-product-attribute-terms-controller.php
[edit]
[-] class-kkart-rest-network-orders-controller.php
[edit]
[-] class-kkart-rest-webhooks-controller.php
[edit]
[-] class-kkart-rest-customer-downloads-controller.php
[edit]
[-] class-kkart-rest-data-controller.php
[edit]
[-] class-kkart-rest-system-status-controller.php
[edit]
[-] class-kkart-rest-product-tags-controller.php
[edit]
[-] class-kkart-rest-report-top-sellers-controller.php
[edit]
[-] class-kkart-rest-report-sales-controller.php
[edit]
[-] class-kkart-rest-tax-classes-controller.php
[edit]
[-] class-kkart-rest-order-refunds-controller.php
[edit]
[-] class-kkart-rest-shipping-zone-methods-controller.php
[edit]
[-] class-kkart-rest-shipping-zone-locations-controller.php
[edit]
[+]
..
[-] class-kkart-rest-report-reviews-totals-controller.php
[edit]
[-] class-kkart-rest-controller.php
[edit]
[-] class-kkart-rest-posts-controller.php
[edit]
[-] class-kkart-rest-report-customers-totals-controller.php
[edit]
[-] class-kkart-rest-product-attributes-controller.php
[edit]
[-] class-kkart-rest-report-orders-totals-controller.php
[edit]
[-] class-kkart-rest-data-continents-controller.php
[edit]
[-] class-kkart-rest-system-status-tools-controller.php
[edit]
[-] class-kkart-rest-product-variations-controller.php
[edit]
[-] class-kkart-rest-orders-controller.php
[edit]
[-] class-kkart-rest-terms-controller.php
[edit]
[-] class-kkart-rest-payment-gateways-controller.php
[edit]
[-] class-kkart-rest-product-categories-controller.php
[edit]
[-] class-kkart-rest-product-shipping-classes-controller.php
[edit]
[-] class-kkart-rest-shipping-zones-controller.php
[edit]
[-] class-kkart-rest-taxes-controller.php
[edit]
[-] class-kkart-rest-customers-controller.php
[edit]
[-] class-kkart-rest-reports-controller.php
[edit]
[-] class-kkart-rest-data-countries-controller.php
[edit]
[-] class-kkart-rest-settings-controller.php
[edit]
[-] class-kkart-rest-report-products-totals-controller.php
[edit]
[-] class-kkart-rest-order-notes-controller.php
[edit]
[-] class-kkart-rest-product-reviews-controller.php
[edit]
[-] class-kkart-rest-report-coupons-totals-controller.php
[edit]
[-] class-kkart-rest-shipping-methods-controller.php
[edit]
[-] class-kkart-rest-products-controller.php
[edit]
[-] class-kkart-rest-data-currencies-controller.php
[edit]
[-] class-kkart-rest-setting-options-controller.php
[edit]
[-] class-kkart-rest-coupons-controller.php
[edit]