Files
server/shared/lib/Files/Service/IServiceEntityMutable.php
2026-02-10 18:46:11 -05:00

159 lines
5.5 KiB
PHP

<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: Sebastian Krupinski <krupinski01@gmail.com>
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace KTXF\Files\Service;
use KTXF\Files\Node\INodeEntityBase;
use KTXF\Files\Node\INodeEntityMutable;
interface IServiceEntityMutable extends IServiceBase {
public const CAPABILITY_ENTITY_CREATE = 'EntityCreate';
public const CAPABILITY_ENTITY_MODIFY = 'EntityModify';
public const CAPABILITY_ENTITY_DESTROY = 'EntityDestroy';
public const CAPABILITY_ENTITY_COPY = 'EntityCopy';
public const CAPABILITY_ENTITY_MOVE = 'EntityMove';
public const CAPABILITY_ENTITY_WRITE = 'EntityWrite';
public const CAPABILITY_ENTITY_WRITE_STREAM = 'EntityWriteStream';
public const CAPABILITY_ENTITY_WRITE_CHUNK = 'EntityWriteChunk';
/**
* Creates a new, empty entity node
*
* @since 2025.11.01
*/
public function entityFresh(): INodeEntityMutable;
/**
* Creates a new entity in the specified collection
*
* @since 2025.11.01
*
* @param string|int|null $collection Collection identifier, null for root
* @param INodeEntityMutable $entity The entity to create
* @param array $options Additional options
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityCreate(string|int|null $collection, INodeEntityMutable $entity, array $options = []): INodeEntityBase;
/**
* Modifies an existing entity in the specified collection
*
* @since 2025.11.01
*
* @param string|int|null $collection Collection identifier
* @param string|int $identifier Entity identifier
* @param INodeEntityMutable $entity The entity with modifications
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityModify(string|int|null $collection, string|int $identifier, INodeEntityMutable $entity): INodeEntityBase;
/**
* Destroys an existing entity in the specified collection
*
* @since 2025.11.01
*
* @param string|int|null $collection Collection identifier
* @param string|int $identifier Entity identifier
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityDestroy(string|int|null $collection, string|int $identifier): bool;
/**
* Copies an existing entity to a new collection
*
* @since 2025.11.01
*
* @param string|int|null $collection Source collection identifier
* @param string|int $identifier Entity identifier
* @param string|int|null $destination Destination collection identifier, null for root
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityCopy(string|int|null $collection, string|int $identifier, string|int|null $destination): INodeEntityBase;
/**
* Moves an existing entity to a new collection
*
* @since 2025.11.01
*
* @param string|int|null $collection Source collection identifier
* @param string|int $identifier Entity identifier
* @param string|int|null $destination Destination collection identifier, null for root
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityMove(string|int|null $collection, string|int $identifier, string|int|null $destination): INodeEntityBase;
/**
* Writes the entire content of an entity from a string
*
* @since 2025.11.01
*
* @param string|int|null $collection Collection identifier
* @param string|int $identifier Entity identifier
* @param string $data Content to write
*
* @return int Number of bytes written
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityWrite(string|int|null $collection, string|int $identifier, string $data): int;
/**
* Opens a stream to write the content of an entity
*
* @since 2025.11.01
*
* @param string|int|null $collection Collection identifier
* @param string|int $identifier Entity identifier
*
* @return resource Stream resource for writing
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityWriteStream(string|int|null $collection, string|int $identifier);
/**
* Writes a chunk of content to an entity at a specific position
*
* @since 2025.11.01
*
* @param string|int|null $collection Collection identifier
* @param string|int $identifier Entity identifier
* @param int $offset Starting byte position (0-indexed)
* @param string $data Chunk content to write
*
* @return int Number of bytes written
*
* @throws \KTXF\Resource\Exceptions\InvalidArgumentException
* @throws \KTXF\Resource\Exceptions\UnsupportedException
* @throws \KTXF\Resource\Exceptions\UnauthorizedException
*/
public function entityWriteChunk(string|int|null $collection, string|int $identifier, int $offset, string $data): int;
}