mirror of
https://github.com/daledavies/jump.git
synced 2026-02-26 00:00:46 +01:00
Issue #36: Improve use of cache to avoid waiting for lock timeout
This commit is contained in:
@@ -14,10 +14,10 @@ $cache = new Jump\Cache($config);
|
||||
|
||||
// If this script is run via CLI then clear the cache and repopulate it,
|
||||
// otherwise if run via web then get image data from cache and run this
|
||||
// script asynchronously to refresh the cahce for next time.
|
||||
// script asynchronously to refresh the cache for next time.
|
||||
if (http_response_code() === false) {
|
||||
$cache->clear('unsplash');
|
||||
load_cache_unsplash_data();
|
||||
$unsplashdata = load_cache_unsplash_data($config);
|
||||
$cache->save(cachename: 'unsplash', data: $unsplashdata);
|
||||
die('Cached data from Unsplash');
|
||||
}
|
||||
|
||||
@@ -45,44 +45,46 @@ if (!$token || !hash_equals($csrfsection->get('token'), $token)) {
|
||||
die(json_encode(['error' => 'API token is incorrect or missing']));
|
||||
}
|
||||
|
||||
$unsplashdata = load_cache_unsplash_data();
|
||||
$unsplashdata = $cache->load(cachename: 'unsplash');
|
||||
if ($unsplashdata == null) {
|
||||
$unsplashdata = load_cache_unsplash_data($config);
|
||||
$cache->save(cachename: 'unsplash', data: $unsplashdata);
|
||||
}
|
||||
|
||||
echo json_encode($unsplashdata);
|
||||
|
||||
shell_exec('/usr/bin/nohup /usr/bin/php -f unsplashdata.php >/dev/null 2>&1 &');
|
||||
|
||||
function load_cache_unsplash_data() {
|
||||
global $cache, $config;
|
||||
return $cache->load(cachename: 'unsplash', callback: function() use ($config) {
|
||||
Crew\Unsplash\HttpClient::init([
|
||||
'utmSource' => 'jump_startpage',
|
||||
'applicationId' => $config->get('unsplashapikey'),
|
||||
function load_cache_unsplash_data($config) {
|
||||
Crew\Unsplash\HttpClient::init([
|
||||
'utmSource' => 'jump_startpage',
|
||||
'applicationId' => $config->get('unsplashapikey'),
|
||||
]);
|
||||
// Try to get a random image via the API.
|
||||
try {
|
||||
$photo = Crew\Unsplash\Photo::random([
|
||||
'collections' => $config->get('unsplashcollections', false),
|
||||
]);
|
||||
// Try to get a random image via the API.
|
||||
try {
|
||||
$photo = Crew\Unsplash\Photo::random([
|
||||
'collections' => $config->get('unsplashcollections', false),
|
||||
]);
|
||||
} catch (Exception $e) {
|
||||
http_response_code(500);
|
||||
die(json_encode(['error' => json_decode($e->getMessage())]));
|
||||
}
|
||||
// Download the image data from Unsplash.
|
||||
$ch = curl_init();
|
||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||
curl_setopt($ch, CURLOPT_URL, $photo->urls['raw'].'&auto=compress&w=1920');
|
||||
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
|
||||
curl_setopt($ch, CURLOPT_FAILONERROR, true);
|
||||
$response = curl_exec($ch);
|
||||
// Create the response and return it.
|
||||
$description = 'Photo';
|
||||
if ($photo->description !== null &&
|
||||
strlen($photo->description) <= 45) {
|
||||
$description = $photo->description;
|
||||
}
|
||||
$unsplashdata = new stdClass();
|
||||
$unsplashdata->color = $photo->color;
|
||||
$unsplashdata->attribution = '<a target="_blank" rel="noopener" href="'.$photo->links['html'].'">'.$description.' by '.$photo->user['name'].'</a>';
|
||||
$unsplashdata->imagedatauri = 'data: '.(new finfo(FILEINFO_MIME_TYPE))->buffer($response).';base64,'.base64_encode($response);
|
||||
return $unsplashdata;
|
||||
});
|
||||
} catch (Exception $e) {
|
||||
http_response_code(500);
|
||||
die(json_encode(['error' => json_decode($e->getMessage())]));
|
||||
}
|
||||
// Download the image data from Unsplash.
|
||||
$ch = curl_init();
|
||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||
curl_setopt($ch, CURLOPT_URL, $photo->urls['raw'].'&auto=compress&w=1920');
|
||||
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
|
||||
curl_setopt($ch, CURLOPT_FAILONERROR, true);
|
||||
$response = curl_exec($ch);
|
||||
// Create the response and return it.
|
||||
$description = 'Photo';
|
||||
if ($photo->description !== null &&
|
||||
strlen($photo->description) <= 45) {
|
||||
$description = $photo->description;
|
||||
}
|
||||
$unsplashdata = new stdClass();
|
||||
$unsplashdata->color = $photo->color;
|
||||
$unsplashdata->attribution = '<a target="_blank" rel="noopener" href="'.$photo->links['html'].'">'.$description.' by '.$photo->user['name'].'</a>';
|
||||
$unsplashdata->imagedatauri = 'data: '.(new finfo(FILEINFO_MIME_TYPE))->buffer($response).';base64,'.base64_encode($response);
|
||||
return $unsplashdata;
|
||||
}
|
||||
|
||||
@@ -124,6 +124,21 @@ class Cache {
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Save data into the specified cache item.
|
||||
*
|
||||
* @param string $cachename The name of a cache, must match a key in $caches definition.
|
||||
* @param string|null $key A key used to represent an object within a cache.
|
||||
* @param mixed $data
|
||||
* @return void
|
||||
*/
|
||||
public function save(string $cachename, ?string $key = 'default', mixed $data) {
|
||||
$this->init_cache($cachename, $key);
|
||||
$dependencies = [$this->caches[$cachename]['expirationtype'] => $this->caches[$cachename]['expirationparams']];
|
||||
// Retrieve the initialised cache object from $caches.
|
||||
return $this->caches[$cachename]['cache'][$key]->save($cachename.'/'.$key, $data, $dependencies);
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified item from the cache.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user