mirror of
https://github.com/grocy/grocy.git
synced 2025-04-29 01:32:38 +00:00
106 lines
2.4 KiB
PHP
106 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace Grocy\Services;
|
|
|
|
class ApiKeyService extends BaseService
|
|
{
|
|
const API_KEY_TYPE_DEFAULT = 'default';
|
|
|
|
const API_KEY_TYPE_SPECIAL_PURPOSE_CALENDAR_ICAL = 'special-purpose-calendar-ical';
|
|
|
|
public function CreateApiKey($keyType = self::API_KEY_TYPE_DEFAULT)
|
|
{
|
|
$newApiKey = $this->GenerateApiKey();
|
|
|
|
$apiKeyRow = $this->getDatabase()->api_keys()->createRow([
|
|
'api_key' => $newApiKey,
|
|
'user_id' => GROCY_USER_ID,
|
|
'expires' => '2999-12-31 23:59:59', // Default is that API keys expire never
|
|
'key_type' => $keyType
|
|
]);
|
|
$apiKeyRow->save();
|
|
|
|
return $newApiKey;
|
|
}
|
|
|
|
public function GetApiKeyId($apiKey)
|
|
{
|
|
$apiKey = $this->getDatabase()->api_keys()->where('api_key', $apiKey)->fetch();
|
|
return $apiKey->id;
|
|
}
|
|
|
|
// Returns any valid key for $keyType,
|
|
// not allowed for key type "default"
|
|
public function GetOrCreateApiKey($keyType)
|
|
{
|
|
if ($keyType === self::API_KEY_TYPE_DEFAULT)
|
|
{
|
|
return null;
|
|
}
|
|
else
|
|
{
|
|
$apiKeyRow = $this->getDatabase()->api_keys()->where('key_type = :1 AND expires > :2', $keyType, date('Y-m-d H:i:s', time()))->fetch();
|
|
|
|
if ($apiKeyRow !== null)
|
|
{
|
|
return $apiKeyRow->api_key;
|
|
}
|
|
else
|
|
{
|
|
return $this->CreateApiKey($keyType);
|
|
}
|
|
}
|
|
}
|
|
|
|
public function GetUserByApiKey($apiKey)
|
|
{
|
|
$apiKeyRow = $this->getDatabase()->api_keys()->where('api_key', $apiKey)->fetch();
|
|
|
|
if ($apiKeyRow !== null)
|
|
{
|
|
return $this->getDatabase()->users($apiKeyRow->user_id);
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
public function IsValidApiKey($apiKey, $keyType = self::API_KEY_TYPE_DEFAULT)
|
|
{
|
|
if ($apiKey === null || empty($apiKey))
|
|
{
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
$apiKeyRow = $this->getDatabase()->api_keys()->where('api_key = :1 AND expires > :2 AND key_type = :3', $apiKey, date('Y-m-d H:i:s', time()), $keyType)->fetch();
|
|
|
|
if ($apiKeyRow !== null)
|
|
{
|
|
// This should not change the database file modification time as this is used
|
|
// to determine if REALLY something has changed
|
|
$dbModTime = $this->getDatabaseService()->GetDbChangedTime();
|
|
$apiKeyRow->update([
|
|
'last_used' => date('Y-m-d H:i:s', time())
|
|
]);
|
|
$this->getDatabaseService()->SetDbChangedTime($dbModTime);
|
|
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
public function RemoveApiKey($apiKey)
|
|
{
|
|
$this->getDatabase()->api_keys()->where('api_key', $apiKey)->delete();
|
|
}
|
|
|
|
private function GenerateApiKey()
|
|
{
|
|
return RandomString(50);
|
|
}
|
|
}
|