1
0
mirror of https://github.com/beestat/app.git synced 2025-10-25 15:22:25 -04:00
beestat/api/cora/api_cache.php
Jon Ziebell 790aaf354e Fixed #265 - Change logging from push to pull
Deceptively simple commit message. This is a massive change that completely reworks the most fundamental part of the API. Not only does it remove the push logging, it also restructures logging to give better insight into what happens during an API call.
2020-03-15 08:12:28 -04:00

103 lines
2.8 KiB
PHP

<?php
namespace cora;
/**
* The API cache can be used to cache API calls for rapid response.
*
* @author Jon Ziebell
*/
class api_cache extends crud {
/**
* Insert an item into the current resource with the provided attributes.
* Setting of the primary key column is not allowed and will be overwritten
* if you try.
*
* @param array $attributes An array of attributes to set for this item
*
* @return mixed The id of the inserted row.
*/
public function create($attributes) {
unset($attributes['created_at']);
return parent::create($attributes);
}
/**
* Create an entry in the api_cache table. Generates a unique key based off
* of the resource, method, arguments, and session user_id if set.
*
* @param $api_call The API call to cache.
* @param $response_data Response to cache.
* @param $duration Duration in seconds to cache for.
*
* @return array The inserted row.
*/
public function cache($api_call, $response_data, $duration) {
$key = $this->generate_key($api_call);
$cache_hits = $this->read(['key' => $key]);
if(count($cache_hits) === 0) {
$attributes = [];
$attributes['key'] = $key;
$attributes['expires_at'] = date('Y-m-d H:i:s', time() + $duration);
$attributes['response_data'] = $response_data;
return $this->create($attributes);
}
else {
$cache_hit = $cache_hits[0];
$attributes = [];
$attributes['expires_at'] = date('Y-m-d H:i:s', time() + $duration);
$attributes['response_data'] = $response_data;
$attributes['api_cache_id'] = $cache_hit['api_cache_id'];
return $this->update($attributes);
}
}
/**
* Retrieve a cache entry with a matching key that is not expired.
*
* @param $api_call The API call to retrieve.
*
* @return mixed The api_cache row if found, else null.
*/
public function retrieve($api_call) {
$cache_hits = $this->read([
'key' => $this->generate_key($api_call)
]);
foreach($cache_hits as $cache_hit) {
if(time() < strtotime($cache_hit['expires_at'])) {
return $cache_hit;
}
}
return null;
}
/**
* Generate a cache key.
*
* @param $api_call The API call to generate the key for.
*
* @return string The cache key.
*/
private function generate_key($api_call) {
return sha1(
'resource=' . $api_call->get_resource() .
'method=' . $api_call->get_method() .
'arguments=' . (
$api_call->get_arguments() !== null ?
json_encode($api_call->get_arguments()) : ''
) .
'user_id=' . (
$this->session->get_user_id() !== null ?
$this->session->get_user_id() : ''
)
);
}
}