121 regels
3.1 KiB
PHP

2024-12-20 23:46:30 +01:00
<?php
2024-12-29 00:47:30 +01:00
/**
* Copyright (c) D3 Data Development (Inh. Thomas Dartsch)
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*
* https://www.d3data.de
*
* @copyright (C) D3 Data Development (Inh. Thomas Dartsch)
* @author D3 Data Development - Daniel Seifert <info@shopmodule.com>
* @link https://www.oxidmodule.com
*/
2025-01-05 15:20:56 +01:00
declare(strict_types=1);
2024-12-20 23:46:30 +01:00
namespace D3\KlicktippPhpClient\Resources;
use D3\KlicktippPhpClient\Entities\Tag as TagEntity;
use D3\KlicktippPhpClient\Entities\TagList;
2025-01-08 15:29:20 +01:00
use D3\KlicktippPhpClient\Exceptions\CommunicationException;
use D3\KlicktippPhpClient\Exceptions\ResponseContentException;
use GuzzleHttp\RequestOptions;
2024-12-20 23:46:30 +01:00
class Tag extends Model
{
2025-01-03 00:05:00 +01:00
public const ID = 'tagid';
public const NAME = 'name';
public const TEXT = 'text';
2024-12-20 23:46:30 +01:00
/**
2025-01-08 15:29:20 +01:00
* @throws CommunicationException
* @throws ResponseContentException
2024-12-20 23:46:30 +01:00
*/
public function index(): TagList
2024-12-20 23:46:30 +01:00
{
$data = $this->connection->requestAndParse(
2024-12-20 23:46:30 +01:00
'GET',
2024-12-29 23:33:09 +01:00
'tag.json'
2024-12-20 23:46:30 +01:00
);
return new TagList($data);
2024-12-20 23:46:30 +01:00
}
/**
2025-01-08 15:29:20 +01:00
* @throws CommunicationException
* @throws ResponseContentException
2024-12-20 23:46:30 +01:00
*/
public function get(string $tagId): array
2024-12-20 23:46:30 +01:00
{
return $this->connection->requestAndParse(
2024-12-20 23:46:30 +01:00
'GET',
2024-12-29 23:33:09 +01:00
'tag/'.urlencode(trim($tagId)).'.json'
2024-12-22 13:54:42 +01:00
);
}
2024-12-22 13:54:42 +01:00
/**
2025-01-08 15:29:20 +01:00
* @throws CommunicationException
* @throws ResponseContentException
*/
public function getEntity(string $tagId): TagEntity
{
return new TagEntity($this->get($tagId), $this);
2024-12-22 13:54:42 +01:00
}
/**
2024-12-29 23:33:09 +01:00
* @return string - new tag id
2025-01-08 15:29:20 +01:00
* @throws CommunicationException
* @throws ResponseContentException
2024-12-22 13:54:42 +01:00
*/
2024-12-29 23:33:09 +01:00
public function create(string $name): string
2024-12-22 13:54:42 +01:00
{
2025-01-05 15:20:56 +01:00
return (string) current(
2024-12-29 23:33:09 +01:00
$this->connection->requestAndParse(
'POST',
'tag.json',
[
RequestOptions::FORM_PARAMS => [
2025-01-03 00:05:00 +01:00
self::NAME => trim($name),
2024-12-29 23:33:09 +01:00
],
]
)
2024-12-22 13:54:42 +01:00
);
}
/**
2025-01-08 15:29:20 +01:00
* @throws CommunicationException
* @throws ResponseContentException
2024-12-22 13:54:42 +01:00
*/
public function update(string $tagId, ?string $name = null, ?string $text = null): bool
2024-12-22 13:54:42 +01:00
{
2024-12-29 23:33:09 +01:00
return (bool) current(
$this->connection->requestAndParse(
'PUT',
'tag/'.urlencode(trim($tagId)).'.json',
[
RequestOptions::FORM_PARAMS => array_filter([
2025-01-03 00:05:00 +01:00
self::NAME => trim($name ?? ''),
self::TEXT => trim($text ?? ''),
]),
2024-12-29 23:33:09 +01:00
]
)
2024-12-20 23:46:30 +01:00
);
2024-12-22 13:54:42 +01:00
}
2024-12-20 23:46:30 +01:00
2024-12-22 13:54:42 +01:00
/**
2025-01-08 15:29:20 +01:00
* @throws CommunicationException
* @throws ResponseContentException
2024-12-22 13:54:42 +01:00
*/
2024-12-29 23:33:09 +01:00
public function delete(string $tagId): bool
2024-12-22 13:54:42 +01:00
{
2024-12-29 23:33:09 +01:00
return (bool) current(
$this->connection->requestAndParse(
'DELETE',
'tag/'.urlencode(trim($tagId)).'.json'
)
2024-12-22 13:54:42 +01:00
);
2024-12-20 23:46:30 +01:00
}
}