blob: e89846fa986d339b0cb0ea001e56733b47b53e50 [file] [log] [blame]
<?php
/**
* Class WC_REST_Stripe_Locations_Controller
*/
defined( 'ABSPATH' ) || exit;
/**
* REST controller for terminal locations.
*/
class WC_REST_Stripe_Locations_Controller extends WC_Stripe_REST_Base_Controller {
/**
* Endpoint path.
*
* @var string
*/
protected $rest_base = 'wc_stripe/terminal/locations';
/**
* Configure REST API routes.
*/
public function register_routes() {
register_rest_route(
$this->namespace,
'/' . $this->rest_base,
[
'methods' => WP_REST_Server::CREATABLE,
'callback' => [ $this, 'create_location' ],
'permission_callback' => [ $this, 'check_permission' ],
'args' => [
'display_name' => [
'type' => 'string',
'required' => true,
],
'address' => [
'type' => 'object',
'required' => true,
],
],
]
);
register_rest_route(
$this->namespace,
'/' . $this->rest_base,
[
'methods' => WP_REST_Server::READABLE,
'callback' => [ $this, 'get_all_locations' ],
'permission_callback' => [ $this, 'check_permission' ],
'args' => [
'ending_before' => [
'type' => 'string',
'required' => false,
],
'limit' => [
'type' => 'integer',
'required' => false,
],
'starting_after' => [
'type' => 'string',
'required' => false,
],
],
]
);
register_rest_route(
$this->namespace,
'/' . $this->rest_base . '/store',
[
'methods' => WP_REST_Server::READABLE,
'callback' => [ $this, 'get_store_location' ],
'permission_callback' => [ $this, 'check_permission' ],
]
);
register_rest_route(
$this->namespace,
'/' . $this->rest_base . '/(?P<location_id>\w+)',
[
'methods' => WP_REST_Server::DELETABLE,
'callback' => [ $this, 'delete_location' ],
'permission_callback' => [ $this, 'check_permission' ],
]
);
register_rest_route(
$this->namespace,
'/' . $this->rest_base . '/(?P<location_id>\w+)',
[
'methods' => WP_REST_Server::READABLE,
'callback' => [ $this, 'get_location' ],
'permission_callback' => [ $this, 'check_permission' ],
]
);
register_rest_route(
$this->namespace,
'/' . $this->rest_base . '/(?P<location_id>\w+)',
[
'methods' => WP_REST_Server::CREATABLE,
'callback' => [ $this, 'update_location' ],
'permission_callback' => [ $this, 'check_permission' ],
'args' => [
'display_name' => [
'type' => 'string',
'required' => false,
],
'address' => [
'type' => 'object',
'required' => false,
],
],
]
);
}
/**
* Create a terminal location via Stripe API.
*
* @param WP_REST_Request $request Full data about the request.
*/
public function create_location( $request ) {
try {
$response = WC_Stripe_API::request(
[
'display_name' => $request['display_name'],
'address' => $request['address'],
],
'terminal/locations'
);
return rest_ensure_response( $response );
} catch ( WC_Stripe_Exception $e ) {
return rest_ensure_response( new WP_Error( 'stripe_error', $e->getMessage() ) );
}
}
/**
* Get all terminal locations via Stripe API.
*
* @param WP_REST_Request $request Full data about the request.
*/
public function get_all_locations( $request ) {
try {
return rest_ensure_response( $this->fetch_locations() );
} catch ( WC_Stripe_Exception $e ) {
return rest_ensure_response( new WP_Error( 'stripe_error', $e->getMessage() ) );
}
}
/**
* Delete a terminal location via Stripe API.
*
* @param WP_REST_Request $request Full data about the request.
*/
public function delete_location( $request ) {
try {
$response = WC_Stripe_API::request( [], 'terminal/locations/' . urlencode( $request['location_id'] ), 'DELETE' );
return rest_ensure_response( $response );
} catch ( WC_Stripe_Exception $e ) {
return rest_ensure_response( new WP_Error( 'stripe_error', $e->getMessage() ) );
}
}
/**
* Get a terminal location via Stripe API.
*
* @param WP_REST_Request $request Full data about the request.
*/
public function get_location( $request ) {
try {
$response = WC_Stripe_API::request( [], 'terminal/locations/' . urlencode( $request['location_id'] ), 'GET' );
return rest_ensure_response( $response );
} catch ( WC_Stripe_Exception $e ) {
return rest_ensure_response( new WP_Error( 'stripe_error', $e->getMessage() ) );
}
}
/**
* Get default terminal location.
*
* @param WP_REST_Request $request Full data about the request.
*/
public function get_store_location( $request ) {
// Originally `get_bloginfo` was used for location name, later switched to `site_url` as the former may be blank.
$store_hostname = str_replace( [ 'https://', 'http://' ], '', get_site_url() );
$possible_names = [ get_bloginfo(), $store_hostname ];
$store_address = WC()->countries;
$address = array_filter(
[
'city' => $store_address->get_base_city(),
'country' => $store_address->get_base_country(),
'line1' => $store_address->get_base_address(),
'line2' => $store_address->get_base_address_2(),
'postal_code' => $store_address->get_base_postcode(),
'state' => $store_address->get_base_state(),
]
);
// Return an error if store doesn't have a location.
$is_address_populated = isset( $address['country'], $address['city'], $address['postal_code'], $address['line1'] );
if ( ! $is_address_populated ) {
return rest_ensure_response(
new WP_Error(
'store_address_is_incomplete',
admin_url(
add_query_arg(
[
'page' => 'wc-settings',
'tab' => 'general',
],
'admin.php'
)
)
)
);
}
try {
foreach ( $this->fetch_locations() as $location ) {
if (
in_array( $location->display_name, $possible_names, true )
&& count( array_intersect( (array) $location->address, $address ) ) === count( $address )
) {
return rest_ensure_response( $location );
}
}
// Create new location if no location matches display name and address.
$response = WC_Stripe_API::request(
[
'display_name' => $store_hostname,
'address' => $address,
],
'terminal/locations'
);
return rest_ensure_response( $response );
} catch ( WC_Stripe_Exception $e ) {
return rest_ensure_response( new WP_Error( 'stripe_error', $e->getMessage() ) );
}
}
/**
* Update a terminal location via Stripe API.
*
* @param WP_REST_Request $request Full data about the request.
*/
public function update_location( $request ) {
$body = [];
if ( isset( $request['display_name'] ) ) {
$body['display_name'] = $request['display_name'];
}
if ( isset( $request['address'] ) ) {
$body['address'] = $request['address'];
}
try {
$response = WC_Stripe_API::request( $body, 'terminal/locations/' . urlencode( $request['location_id'] ), 'POST' );
return rest_ensure_response( $response );
} catch ( WC_Stripe_Exception $e ) {
return rest_ensure_response( new WP_Error( 'stripe_error', $e->getMessage() ) );
}
}
/**
* Fetch terminal locations from Stripe API.
*/
private function fetch_locations() {
$response = (array) WC_Stripe_API::request( [], 'terminal/locations', 'GET' );
return $response['data'];
}
}