HEX
Server: LiteSpeed
System: Linux d8 4.18.0-553.121.1.lve.el8.x86_64 #1 SMP Thu Apr 30 16:40:41 UTC 2026 x86_64
User: wbwebdes (3015)
PHP: 8.1.31
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/wbwebdes/domains/files.wb-cloud.nl/public_html/lib/public/TaskProcessing/IProvider.php
<?php

declare(strict_types=1);

/**
 * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */


namespace OCP\TaskProcessing;

/**
 * This is the interface that is implemented by apps that
 * implement a task processing provider
 * @since 30.0.0
 */
interface IProvider {
	/**
	 * The unique id of this provider
	 * @since 30.0.0
	 */
	public function getId(): string;

	/**
	 * The localized name of this provider
	 * @since 30.0.0
	 */
	public function getName(): string;

	/**
	 * Returns the task type id of the task type, that this
	 * provider handles
	 *
	 * @since 30.0.0
	 * @return string
	 */
	public function getTaskTypeId(): string;

	/**
	 * @return int The expected average runtime of a task in seconds
	 * @since 30.0.0
	 */
	public function getExpectedRuntime(): int;

	/**
	 * Returns the shape of optional input parameters
	 *
	 * @since 30.0.0
	 * @psalm-return ShapeDescriptor[]
	 */
	public function getOptionalInputShape(): array;

	/**
	 * Returns the shape of optional output parameters
	 *
	 * @since 30.0.0
	 * @psalm-return ShapeDescriptor[]
	 */
	public function getOptionalOutputShape(): array;

	/**
	 * Returns the option list for each input shape ENUM slot
	 *
	 * @since 30.0.0
	 * @psalm-return ShapeEnumValue[][]
	 */
	public function getInputShapeEnumValues(): array;

	/**
	 * Returns the default values for input shape slots
	 *
	 * @since 30.0.0
	 * @psalm-return array<array-key, string|numeric>
	 */
	public function getInputShapeDefaults(): array;

	/**
	 * Returns the option list for each optional input shape ENUM slot
	 *
	 * @since 30.0.0
	 * @psalm-return ShapeEnumValue[][]
	 */
	public function getOptionalInputShapeEnumValues(): array;

	/**
	 * Returns the default values for optional input shape slots
	 *
	 * @since 30.0.0
	 * @psalm-return array<array-key, string|numeric>
	 */
	public function getOptionalInputShapeDefaults(): array;

	/**
	 * Returns the option list for each output shape ENUM slot
	 *
	 * @since 30.0.0
	 * @psalm-return ShapeEnumValue[][]
	 */
	public function getOutputShapeEnumValues(): array;

	/**
	 * Returns the option list for each optional output shape ENUM slot
	 *
	 * @since 30.0.0
	 * @psalm-return ShapeEnumValue[][]
	 */
	public function getOptionalOutputShapeEnumValues(): array;
}