radar-wp/radar.inc.php

204 lines
5.7 KiB
PHP
Raw Normal View History

2015-02-24 16:25:12 +01:00
<?php
/**
* @file
* Functions to actually parse and retrieve shortcode.
*/
require 'vendor/autoload.php';
use Radar\Connect\Connect;
use Radar\Connect\Filter;
use Guzzle\Http\Client;
use Doctrine\Common\Cache\FilesystemCache;
use Guzzle\Cache\DoctrineCacheAdapter;
use Guzzle\Plugin\Cache\CachePlugin;
use Guzzle\Plugin\Cache\DefaultCacheStorage;
/**
* Radar Connect functions.
*/
function radar_retrieve_events($settings) {
$client = radar_client();
// API field names.
$settings['fields'] = _radar_field_name_mapping($settings['fields']);
$filter = radar_filter($settings);
$request = $client->prepareEventsRequest($filter, $settings['fields'], $settings['max_count']);
$response = $client->retrieveResponse($request);
$events = $client->parseResponse($response);
return $events;
2015-02-24 16:25:12 +01:00
}
2017-06-09 15:28:57 +01:00
function radar_retrieve_entities($entities) {
if (!is_array($entities)) {
$entities = [$entities];
}
2015-02-24 16:25:12 +01:00
$client = radar_client();
return $client->retrieveEntityMultiple($entities);
}
function radar_client() {
static $connect = NULL;
if (is_null($connect)) {
$guzzle = new Client();
$cachePlugin = new CachePlugin(array(
'storage' => new DefaultCacheStorage(
new DoctrineCacheAdapter(
new FilesystemCache(get_temp_dir() . '/wp-radar')
)
)
));
// Add the cache plugin to the client object
$guzzle->addSubscriber($cachePlugin);
$connect = new Connect($guzzle);
}
return $connect;
}
function radar_filter($settings) {
$filter = new \Radar\Connect\Filter;
if (!empty($settings['city'])) {
$filter->addCity($settings['city']);
}
if (!empty($settings['group'])) {
$filter->addGroup($settings['group']);
}
2015-04-14 11:55:14 +02:00
if (!empty($settings['country'])) {
$filter->addCountry($settings['country']);
}
2015-02-24 16:25:12 +01:00
return $filter;
}
/**
* Internal WP plugin functions.
*/
/**
* Collapses subfields, simplifies field list.
*/
function _radar_field_collect_subfields(&$fields) {
2015-04-08 17:50:42 +02:00
$entity_fields = array();
2015-02-24 16:25:12 +01:00
foreach ($fields as $delta => $listed_field) {
2015-04-08 17:50:42 +02:00
list($field, $subfield) = array_pad(explode(':', $listed_field, 2), 2, null);
2015-02-24 16:25:12 +01:00
if (!empty($subfield)) {
// A field with subfields.
if (!empty($entity_fields[$field])) {
// Field previously seen, subfields we collect together.
$entity_fields[$field][] = $subfield;
unset($fields[$delta]);
}
else {
// Not seen before, add base field name to fields.
$entity_fields[$field][] = $subfield;
$fields[$delta] = $field;
}
}
}
return $entity_fields;
}
/**
* Mapping for user friendly field names to internal API names.
*/
function _radar_field_name_mapping($fields) {
// Replace the nice entity names with (exposed) internal field names.
2015-02-24 20:27:10 +01:00
$nice_names = array('date', 'group', 'location');
$ugly_names = array('date_time', 'og_group_ref', 'offline');
2015-02-24 16:25:12 +01:00
return str_replace($nice_names, $ugly_names, $fields);
}
/**
* Recursively pull the content for fields into an array.
*/
function _radar_parse_items($type, $items, $fields, $subfields = array()) {
$content = array();
foreach ((array) $items as $item) {
if (!is_object($item)) {
error_log('_radar_parse_items called with empty item');
continue;
}
2015-02-24 16:25:12 +01:00
$current_content = array();
// Cycle through the fields in best order that we can.
foreach ($fields as $field_name) {
if (!$method = _radar_method_lookup($type, $field_name)) {
$current_content[] = array('field' => 'error', 'value' => sprintf( __('Unknown field: %s', 'radar_textdomain'), esc_attr($field_name)));
continue;
}
$current_field = $item->$method();
if (!empty($current_field) && !empty($subfields[$field_name])) {
2015-02-24 16:25:12 +01:00
$current_field = radar_retrieve_entities($current_field);
$current_subfields = $subfields[$field_name];
$current_sub_subfields = _radar_field_collect_subfields($current_subfields);
$current_content[] = array('entity' => $field_name, 'value' => _radar_parse_items($field_name, $current_field, $current_subfields, $current_sub_subfields));
}
else {
$current_content[] = array('field' => $field_name, 'value' => $current_field);
}
}
$content[] = $current_content;
}
return $content;
}
function _radar_method_lookup($type, $field) {
$lookup = array(
'event' => array(
'title' => 'getTitle',
'date' => 'getDates',
'body' => 'getBody',
'url' => 'getUrlView',
2017-06-09 15:28:57 +01:00
'image' => 'getImage',
2015-02-24 16:25:12 +01:00
'price' => 'getPrice',
'price_category' => 'getPriceCategory',
2015-02-24 16:25:12 +01:00
'email' => 'getEmail',
'link' => 'getLink',
'phone' => 'getPhone',
'group' => 'getGroups',
'location' => 'getLocations',
'category' => 'getCategories',
'topic' => 'getTopics',
'created' => 'getCreated',
'updated' => 'getUpdated',
),
'location' => array(
'title' => 'getTitle',
'address' => 'getAddress',
'directions' => 'getDirections',
'location' => 'getLocation',
),
'topic' => array(
'title' => 'getTitle',
),
'category' => array(
'title' => 'getTitle',
),
'price_category' => array(
'title' => 'getTitle',
),
2015-02-24 16:25:12 +01:00
'group' => array(
'title' => 'getTitle',
'body' => 'getBody',
'category' => 'getCategories',
'topic' => 'getTopics',
'location' => 'getLocations',
'url' => 'getUrlView',
'group_logo' => 'getGroupLogoRaw',
'email' => 'getEmail',
'link' => 'getLink',
'phone' => 'getPhone',
'opening_times' => 'getOpeningTimes',
2017-06-09 15:28:57 +01:00
),
'image' => array(
'title' => 'getTitle',
'mime' => 'getMime',
'url' => 'getUrl',
'size' => 'getSize',
),
2015-02-24 16:25:12 +01:00
);
return !empty($lookup[$type][$field]) ? $lookup[$type][$field] : FALSE;
}