<?php
/**
 * Open controller class.
 *
 * @since 5.25
 */

namespace CiviCRM_WP_REST\Controller;

class Open extends Base {

  /**
   * @var string
   * The base route.
   * @since 5.25
   */
  protected $rest_base = 'open';

  /**
   * Registers routes.
   *
   * @since 5.25
   */
  public function register_routes() {

    register_rest_route($this->get_namespace(), $this->get_rest_base(), [
      [
        'methods' => \WP_REST_Server::READABLE,
        'callback' => [$this, 'get_item'],
        'permission_callback' => '__return_true',
        'args' => $this->get_item_args(),
      ],
      'schema' => [$this, 'get_item_schema'],
    ]);

  }

  /**
   * Get item.
   *
   * @since 5.25
   *
   * @param WP_REST_Request $request
   */
  public function get_item($request) {

    $queue_id = $request->get_param('q');

    // Track open.
    \CRM_Mailing_Event_BAO_MailingEventOpened::open($queue_id);

    // Serve tracker file.
    add_filter('rest_pre_serve_request', [$this, 'serve_tracker_file'], 10, 4);

  }

  /**
   * Serves the tracker gif file.
   *
   * @since 5.25
   *
   * @param bool $served Whether the request has been served.
   * @param WP_REST_Response $result
   * @param WP_REST_Request $request
   * @param WP_REST_Server $server
   * @return bool $served Whether the request has been served.
   */
  public function serve_tracker_file($served, $result, $request, $server) {

    // Tracker file path.
    $file = CIVICRM_PLUGIN_DIR . 'civicrm/i/tracker.gif';

    // Set headers.
    $server->send_header('Content-type', 'image/gif');
    $server->send_header('Cache-Control', 'must-revalidate, post-check=0, pre-check=0');
    $server->send_header('Content-Description', 'File Transfer');
    $server->send_header('Content-Disposition', 'inline; filename=tracker.gif');
    $server->send_header('Content-Length', filesize($file));

    $buffer = readfile($file);

    return TRUE;

  }

  /**
   * Item schema.
   *
   * @since 5.25
   *
   * @return array $schema
   */
  public function get_item_schema() {

    return [
      '$schema' => 'http://json-schema.org/draft-04/schema#',
      'title' => 'civicrm/v3/open',
      'description' => __('CiviCRM Open endpoint', 'civicrm'),
      'type' => 'object',
      'required' => ['q'],
      'properties' => [
        'q' => [
          'type' => 'integer',
        ],
      ],
    ];

  }

  /**
   * Item arguments.
   *
   * @since 5.25
   *
   * @return array $arguments
   */
  public function get_item_args() {

    return [
      'q' => [
        'type' => 'integer',
        'required' => TRUE,
        'validate_callback' => function($value, $request, $key) {
          return is_numeric($value);
        },
      ],
    ];

  }

}