Cluster pool is now working
[poolifier.git] / src / pools / pool.ts
index 0c9b232f2bca650dc6f7aed065f15e6e0061a99d..f96e5c0cbff3ed84afe5d06c6ac8f2097539ba9f 100644 (file)
@@ -1,9 +1,19 @@
-export interface IPool<
-  // eslint-disable-next-line @typescript-eslint/no-explicit-any
-  Data = any,
-  // eslint-disable-next-line @typescript-eslint/no-explicit-any
-  Response = any
-> {
-  destroy(): Promise<void>
+/**
+ * Contract definition for a poolifier pool.
+ *
+ * @template Data Type of data sent to the worker.
+ * @template Response Type of response of execution.
+ */
+export interface IPool<Data = unknown, Response = unknown> {
+  /**
+   * Perform the task specified in the constructor with the data parameter.
+   *
+   * @param data The input for the specified task.
+   * @returns Promise that will be resolved when the task is successfully completed.
+   */
   execute(data: Data): Promise<Response>
+  /**
+   * Shut down every current worker in this pool.
+   */
+  destroy(): Promise<void>
 }