aboutsummaryrefslogtreecommitdiffstats
path: root/lib/public/TaskProcessing/IProvider.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/public/TaskProcessing/IProvider.php')
-rw-r--r--lib/public/TaskProcessing/IProvider.php109
1 files changed, 109 insertions, 0 deletions
diff --git a/lib/public/TaskProcessing/IProvider.php b/lib/public/TaskProcessing/IProvider.php
new file mode 100644
index 00000000000..a4e752216c7
--- /dev/null
+++ b/lib/public/TaskProcessing/IProvider.php
@@ -0,0 +1,109 @@
+<?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;
+}