mirror of
https://github.com/grocy/grocy.git
synced 2025-10-15 01:37:13 +00:00
Applied PHP formatting rules
This commit is contained in:
@@ -5,8 +5,70 @@ 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';
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
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;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return boolean
|
||||
*/
|
||||
@@ -19,14 +81,15 @@ class ApiKeyService extends BaseService
|
||||
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
|
||||
// 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(array(
|
||||
$apiKeyRow->update([
|
||||
'last_used' => date('Y-m-d H:i:s', time())
|
||||
));
|
||||
]);
|
||||
$this->getDatabaseService()->SetDbChangedTime($dbModTime);
|
||||
|
||||
return true;
|
||||
@@ -35,25 +98,9 @@ class ApiKeyService extends BaseService
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function CreateApiKey($keyType = self::API_KEY_TYPE_DEFAULT)
|
||||
{
|
||||
$newApiKey = $this->GenerateApiKey();
|
||||
|
||||
$apiKeyRow = $this->getDatabase()->api_keys()->createRow(array(
|
||||
'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 RemoveApiKey($apiKey)
|
||||
@@ -61,46 +108,9 @@ class ApiKeyService extends BaseService
|
||||
$this->getDatabase()->api_keys()->where('api_key', $apiKey)->delete();
|
||||
}
|
||||
|
||||
public function GetApiKeyId($apiKey)
|
||||
{
|
||||
$apiKey = $this->getDatabase()->api_keys()->where('api_key', $apiKey)->fetch();
|
||||
return $apiKey->id;
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
||||
|
||||
// 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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private function GenerateApiKey()
|
||||
{
|
||||
return RandomString(50);
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user