import type { temporal } from '@temporalio/proto';
import { Workflow } from './interfaces';
import { RetryPolicy } from './retry-policy';
import { Duration } from './time';
import { SearchAttributePair, SearchAttributes, TypedSearchAttributes } from './search-attributes';
import { Priority } from './priority';
import { WorkflowFunctionWithOptions } from './workflow-definition-options';
/**
 * Defines what happens when trying to start a Workflow with the same ID as a *Closed* Workflow.
 *
 * See {@link WorkflowOptions.workflowIdConflictPolicy} for what happens when trying to start a
 * Workflow with the same ID as a *Running* Workflow.
 *
 * Concept: {@link https://docs.temporal.io/concepts/what-is-a-workflow-id-reuse-policy/ | Workflow Id Reuse Policy}
 *
 * *Note: It is not possible to have two actively running Workflows with the same ID.*
 *
 */
export declare const WorkflowIdReusePolicy: {
    /**
     * The Workflow can be started if the previous Workflow is in a Closed state.
     * @default
     */
    readonly ALLOW_DUPLICATE: "ALLOW_DUPLICATE";
    /**
     * The Workflow can be started if the previous Workflow is in a Closed state that is not Completed.
     */
    readonly ALLOW_DUPLICATE_FAILED_ONLY: "ALLOW_DUPLICATE_FAILED_ONLY";
    /**
     * The Workflow cannot be started.
     */
    readonly REJECT_DUPLICATE: "REJECT_DUPLICATE";
    /**
     * Terminate the current Workflow if one is already running; otherwise allow reusing the Workflow ID.
     *
     * @deprecated Use {@link WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE} instead, and
     *             set `WorkflowOptions.workflowIdConflictPolicy` to
     *             {@link WorkflowIdConflictPolicy.WORKFLOW_ID_CONFLICT_POLICY_TERMINATE_EXISTING}.
     *             When using this option, `WorkflowOptions.workflowIdConflictPolicy` must be left unspecified.
     */
    readonly TERMINATE_IF_RUNNING: "TERMINATE_IF_RUNNING";
    /**
     * No need to use this. If a `WorkflowIdReusePolicy` is set to this, or is not set at all, the default value will be used.
     *
     * @deprecated Either leave property `undefined`, or use {@link ALLOW_DUPLICATE} instead.
     */
    readonly WORKFLOW_ID_REUSE_POLICY_UNSPECIFIED: undefined;
    /** @deprecated Use {@link ALLOW_DUPLICATE} instead. */
    readonly WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE: "ALLOW_DUPLICATE";
    /** @deprecated Use {@link ALLOW_DUPLICATE_FAILED_ONLY} instead. */
    readonly WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE_FAILED_ONLY: "ALLOW_DUPLICATE_FAILED_ONLY";
    /** @deprecated Use {@link REJECT_DUPLICATE} instead. */
    readonly WORKFLOW_ID_REUSE_POLICY_REJECT_DUPLICATE: "REJECT_DUPLICATE";
    /** @deprecated Use {@link TERMINATE_IF_RUNNING} instead. */
    readonly WORKFLOW_ID_REUSE_POLICY_TERMINATE_IF_RUNNING: "TERMINATE_IF_RUNNING";
};
export type WorkflowIdReusePolicy = (typeof WorkflowIdReusePolicy)[keyof typeof WorkflowIdReusePolicy];
export declare const encodeWorkflowIdReusePolicy: (input: "ALLOW_DUPLICATE" | "ALLOW_DUPLICATE_FAILED_ONLY" | "REJECT_DUPLICATE" | "TERMINATE_IF_RUNNING" | "WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE" | "WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE_FAILED_ONLY" | "WORKFLOW_ID_REUSE_POLICY_REJECT_DUPLICATE" | "WORKFLOW_ID_REUSE_POLICY_TERMINATE_IF_RUNNING" | temporal.api.enums.v1.WorkflowIdReusePolicy | null | undefined) => temporal.api.enums.v1.WorkflowIdReusePolicy | undefined, decodeWorkflowIdReusePolicy: (input: temporal.api.enums.v1.WorkflowIdReusePolicy | null | undefined) => "ALLOW_DUPLICATE" | "ALLOW_DUPLICATE_FAILED_ONLY" | "REJECT_DUPLICATE" | "TERMINATE_IF_RUNNING" | undefined;
/**
 * Defines what happens when trying to start a Workflow with the same ID as a *Running* Workflow.
 *
 * See {@link WorkflowOptions.workflowIdReusePolicy} for what happens when trying to start a Workflow
 * with the same ID as a *Closed* Workflow.
 *
 * *Note: It is never possible to have two _actively running_ Workflows with the same ID.*
 */
export declare const WorkflowIdConflictPolicy: {
    /**
     * Do not start a new Workflow. Instead raise a `WorkflowExecutionAlreadyStartedError`.
     */
    readonly FAIL: "FAIL";
    /**
     * Do not start a new Workflow. Instead return a Workflow Handle for the already Running Workflow.
     */
    readonly USE_EXISTING: "USE_EXISTING";
    /**
     * Start a new Workflow, terminating the current workflow if one is already running.
     */
    readonly TERMINATE_EXISTING: "TERMINATE_EXISTING";
};
export type WorkflowIdConflictPolicy = (typeof WorkflowIdConflictPolicy)[keyof typeof WorkflowIdConflictPolicy];
export declare const encodeWorkflowIdConflictPolicy: (input: "FAIL" | "USE_EXISTING" | "TERMINATE_EXISTING" | temporal.api.enums.v1.WorkflowIdConflictPolicy | "WORKFLOW_ID_CONFLICT_POLICY_FAIL" | "WORKFLOW_ID_CONFLICT_POLICY_USE_EXISTING" | "WORKFLOW_ID_CONFLICT_POLICY_TERMINATE_EXISTING" | null | undefined) => temporal.api.enums.v1.WorkflowIdConflictPolicy | undefined, decodeWorkflowIdConflictPolicy: (input: temporal.api.enums.v1.WorkflowIdConflictPolicy | null | undefined) => "FAIL" | "USE_EXISTING" | "TERMINATE_EXISTING" | undefined;
export interface BaseWorkflowOptions {
    /**
     * Defines what happens when trying to start a Workflow with the same ID as a *Closed* Workflow.
     *
     * *Note: It is not possible to have two actively running Workflows with the same ID.*
     *
     * @default WorkflowIdReusePolicy.WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE
     */
    workflowIdReusePolicy?: WorkflowIdReusePolicy;
    /**
     * Defines what happens when trying to start a Workflow with the same ID as a *Running* Workflow.
     *
     * *Note: It is not possible to have two actively running Workflows with the same ID.*
     *
     * @default WorkflowIdConflictPolicy.WORKFLOW_ID_CONFLICT_POLICY_UNSPECIFIED
     */
    workflowIdConflictPolicy?: WorkflowIdConflictPolicy;
    /**
     * Controls how a Workflow Execution is retried.
     *
     * By default, Workflow Executions are not retried. Do not override this behavior unless you know what you're doing.
     * {@link https://docs.temporal.io/concepts/what-is-a-retry-policy/ | More information}.
     */
    retry?: RetryPolicy;
    /**
     * Optional cron schedule for Workflow. If a cron schedule is specified, the Workflow will run as a cron based on the
     * schedule. The scheduling will be based on UTC time. The schedule for the next run only happens after the current
     * run is completed/failed/timeout. If a RetryPolicy is also supplied, and the Workflow failed or timed out, the
     * Workflow will be retried based on the retry policy. While the Workflow is retrying, it won't schedule its next run.
     * If the next schedule is due while the Workflow is running (or retrying), then it will skip that schedule. Cron
     * Workflow will not stop until it is terminated or cancelled (by returning temporal.CanceledError).
     * https://crontab.guru/ is useful for testing your cron expressions.
     */
    cronSchedule?: string;
    /**
     * Specifies additional non-indexed information to attach to the Workflow Execution. The values can be anything that
     * is serializable by {@link DataConverter}.
     */
    memo?: Record<string, unknown>;
    /**
     * Specifies additional indexed information to attach to the Workflow Execution. More info:
     * https://docs.temporal.io/docs/typescript/search-attributes
     *
     * Values are always converted using {@link JsonPayloadConverter}, even when a custom data converter is provided.
     *
     * @deprecated Use {@link typedSearchAttributes} instead.
     */
    searchAttributes?: SearchAttributes;
    /**
     * Specifies additional indexed information to attach to the Workflow Execution. More info:
     * https://docs.temporal.io/docs/typescript/search-attributes
     *
     * Values are always converted using {@link JsonPayloadConverter}, even when a custom data converter is provided.
     * Note that search attributes are not encoded, as such, do not include any sensitive information.
     *
     * If both {@link searchAttributes} and {@link typedSearchAttributes} are provided, conflicting keys will be overwritten
     * by {@link typedSearchAttributes}.
     */
    typedSearchAttributes?: SearchAttributePair[] | TypedSearchAttributes;
    /**
     * General fixed details for this workflow execution that may appear in UI/CLI.
     * This can be in Temporal markdown format and can span multiple lines.
     *
     * @experimental User metadata is a new API and susceptible to change.
     */
    staticDetails?: string;
    /**
     * A single-line fixed summary for this workflow execution that may appear in the UI/CLI.
     * This can be in single-line Temporal markdown format.
     *
     * @experimental User metadata is a new API and susceptible to change.
     */
    staticSummary?: string;
    /**
     * Priority of a workflow
     */
    priority?: Priority;
}
export type WithWorkflowArgs<W extends Workflow, T> = T & (Parameters<W> extends [any, ...any[]] ? {
    /**
     * Arguments to pass to the Workflow
     */
    args: Parameters<W> | Readonly<Parameters<W>>;
} : {
    /**
     * Arguments to pass to the Workflow
     */
    args?: Parameters<W> | Readonly<Parameters<W>>;
});
export interface WorkflowDurationOptions {
    /**
     * The time after which workflow run is automatically terminated by Temporal service. Do not
     * rely on run timeout for business level timeouts. It is preferred to use in workflow timers
     * for this purpose.
     *
     * @format number of milliseconds or {@link https://www.npmjs.com/package/ms | ms-formatted string}
     */
    workflowRunTimeout?: Duration;
    /**
     *
     * The time after which workflow execution (which includes run retries and continue as new) is
     * automatically terminated by Temporal service. Do not rely on execution timeout for business
     * level timeouts. It is preferred to use in workflow timers for this purpose.
     *
     * @format number of milliseconds or {@link https://www.npmjs.com/package/ms | ms-formatted string}
     */
    workflowExecutionTimeout?: Duration;
    /**
     * Maximum execution time of a single workflow task. Default is 10 seconds.
     *
     * @format number of milliseconds or {@link https://www.npmjs.com/package/ms | ms-formatted string}
     */
    workflowTaskTimeout?: Duration;
}
export type CommonWorkflowOptions = BaseWorkflowOptions & WorkflowDurationOptions;
export declare function extractWorkflowType<T extends Workflow>(workflowTypeOrFunc: string | T | WorkflowFunctionWithOptions<any[], any>): string;
