feat: add command to get object metadata
Signed-off-by: Robin Appelman <robin@icewind.nl>pull/52866/head
parent
9a52cfc25e
commit
a324dbec2e
@ -0,0 +1,79 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
/**
|
||||
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
|
||||
namespace OCA\Files\Command\Object;
|
||||
|
||||
use OC\Core\Command\Base;
|
||||
use OCP\Files\IMimeTypeDetector;
|
||||
use OCP\Files\ObjectStore\IObjectStoreMetaData;
|
||||
use Symfony\Component\Console\Input\InputArgument;
|
||||
use Symfony\Component\Console\Input\InputInterface;
|
||||
use Symfony\Component\Console\Input\InputOption;
|
||||
use Symfony\Component\Console\Output\OutputInterface;
|
||||
|
||||
class Info extends Base {
|
||||
public function __construct(
|
||||
private ObjectUtil $objectUtils,
|
||||
private IMimeTypeDetector $mimeTypeDetector,
|
||||
) {
|
||||
parent::__construct();
|
||||
}
|
||||
|
||||
protected function configure(): void {
|
||||
parent::configure();
|
||||
$this
|
||||
->setName('files:object:info')
|
||||
->setDescription('Get the metadata of an object')
|
||||
->addArgument('object', InputArgument::REQUIRED, 'Object to get')
|
||||
->addOption('bucket', 'b', InputOption::VALUE_REQUIRED, "Bucket to get the object from, only required in cases where it can't be determined from the config");
|
||||
}
|
||||
|
||||
public function execute(InputInterface $input, OutputInterface $output): int {
|
||||
$object = $input->getArgument('object');
|
||||
$objectStore = $this->objectUtils->getObjectStore($input->getOption('bucket'), $output);
|
||||
if (!$objectStore) {
|
||||
return self::FAILURE;
|
||||
}
|
||||
|
||||
if (!$objectStore instanceof IObjectStoreMetaData) {
|
||||
$output->writeln('<error>Configured object store does currently not support retrieve metadata</error>');
|
||||
return self::FAILURE;
|
||||
}
|
||||
|
||||
if (!$objectStore->objectExists($object)) {
|
||||
$output->writeln("<error>Object $object does not exist</error>");
|
||||
return self::FAILURE;
|
||||
}
|
||||
|
||||
try {
|
||||
$meta = $objectStore->getObjectMetaData($object);
|
||||
} catch (\Exception $e) {
|
||||
$msg = $e->getMessage();
|
||||
$output->writeln("<error>Failed to read $object from object store: $msg</error>");
|
||||
return self::FAILURE;
|
||||
}
|
||||
|
||||
if ($input->getOption('output') === 'plain' && isset($meta['size'])) {
|
||||
$meta['size'] = \OC_Helper::humanFileSize($meta['size']);
|
||||
}
|
||||
if (isset($meta['mtime'])) {
|
||||
$meta['mtime'] = $meta['mtime']->format(\DateTimeImmutable::ATOM);
|
||||
}
|
||||
if (!isset($meta['mimetype'])) {
|
||||
$handle = $objectStore->readObject($object);
|
||||
$head = fread($handle, 8192);
|
||||
fclose($handle);
|
||||
$meta['mimetype'] = $this->mimeTypeDetector->detectString($head);
|
||||
}
|
||||
|
||||
$this->writeArrayInOutputFormat($input, $output, $meta);
|
||||
|
||||
return self::SUCCESS;
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,36 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-only
|
||||
*/
|
||||
namespace OCP\Files\ObjectStore;
|
||||
|
||||
/**
|
||||
* Interface IObjectStoreMetaData
|
||||
*
|
||||
* @psalm-type ObjectMetaData = array{mtime?: \DateTime, etag?: string, size?: int, mimetype?: string, filename?: string}
|
||||
*
|
||||
* @since 32.0.0
|
||||
*/
|
||||
interface IObjectStoreMetaData {
|
||||
/**
|
||||
* Get metadata for an object.
|
||||
*
|
||||
* @param string $urn
|
||||
* @return ObjectMetaData
|
||||
*
|
||||
* @since 32.0.0
|
||||
*/
|
||||
public function getObjectMetaData(string $urn): array;
|
||||
|
||||
/**
|
||||
* List all objects in the object store.
|
||||
*
|
||||
* If the object store implementation can do it efficiently, the metadata for each object is also included.
|
||||
*
|
||||
* @param string $prefix
|
||||
* @return \Iterator<array{urn: string, meta: ?ObjectMetaData}>
|
||||
*/
|
||||
public function listObjects(string $prefix = ''): \Iterator;
|
||||
}
|
||||
Loading…
Reference in New Issue