Flows for APEX API Package (flows_api_pkg)

Package flow_api_pkg

The flow_api_pkg package gives you access to the Flows for APEX engine, and allows you to perform:

  • Flow Instance Operations, allowing you to Create, Start, Reset, Terminate and Delete a Process Instance.
  • Flow Step Operations, allowing you to Complete, Reserve, Release, or signal Starting a Process Step.

Flow Instance Operations:

These API functions allow you to control a process instance, i.e., one operation of the process defined in its process model / process diagram. These commands allow you to:

  • Create a process instance
  • Start an instance
  • Terminate an instance (stop all processing of an instance)
  • Reset an instance back to its newly created state
  • Delete an instance
  • Set the Instance priority
  • Set the Instance Due On timestamp.

Flow Step Operations:

These API functions allow you to control individual steps in a process instance. These commands allow you to:

  • Complete a Step, and move to the next process step
  • Reserve a Step
  • Release a reserved step
  • record that you are Starting work on a Step
  • Reschedule a step that is waiting on a timer

Application Helper Functions:

These API functions are provided as Application Helper functions from the Flows for APEX API. these commands allow you to:

  • get the URL of the current userTask
  • get an engine Error Message in a supported language
  • return the result of an APEX Approval task to its Flows for APEX process instance upon completion

SIGNATURE

package flow_api_pkg
   authid definer as

Type t_task_list_item

Type: flows_api_pkg.task_list_item.

This type definition is matches the apex_approval.task_list_item type definition, so that Flows for APEX Tasks can easily br incorporated into the APEX Task List.

SIGNATURE

type t_task_list_item is record 
   ( manager                 varchar2( 20)
   , app_id                  number
   , task_id                 number
   , task_def_id             number
   , task_def_name           varchar2( 255)
   , task_def_static_id      varchar2( 255)
   , subject                 varchar2(1000)
   , task_type               varchar2(  32)
   , details_app_id          number
   , details_app_name        varchar2( 255)
   , details_link_target     varchar2(4000)
   , due_on                  timestamp with time zone
   , due_in_hours            number
   , due_in                  varchar2( 255)
   , due_code                varchar2(  32)
   , priority                number(1)
   , priority_level          varchar2( 255)
   , initiator               varchar2( 255)
   , initiator_lower         varchar2( 255)
   , actual_owner            varchar2( 255)
   , actual_owner_lower      varchar2( 255)
   , potential_owners        varchar2(4000)
   , potential_groups        varchar2(4000)
   , excluded_owners         varchar2(4000)
   , state_code              varchar2(  32)
   , state                   varchar2( 255)
   , is_completed            varchar2(   1)
   , outcome_code            varchar2(  32)
   , outcome                 varchar2( 255)
   , badge_css_classes       varchar2( 255)
   , badge_text              varchar2( 255)
   , created_ago_hours       number
   , created_ago             varchar2( 255)
   , created_by              varchar2( 255)
   , created_on              timestamp with time zone
   , last_updated_by         varchar2( 255)
   , last_updated_on         timestamp with time zone
   , process_id              number
   , subflow_id              number
   , step_key                varchar2(20)
);

Type t_task_list_items

Type: t_task_list_items is a table of task_list_item

This gives you a Task List, and can be used for a pipeline function table.

SIGNATURE

type t_task_list_items is table of t_task_list_item;

Function flow_create

Function flow_create - Signature 1 This function creates a new process instance based on a diagram name and version (process specification) If the version is not specified, first lookup is to use dgrm_status = ‘released’ second lookup is to use dgrm_version = ‘0’ and dgrm_status = ‘draft’ If nothing is found based on above rules an exception will be raised. For accuracy, it is recommended that you specify a version or use the form of flow_create specifying dgrm_id directly.

This function returns the Process ID of the newly created process.

EXAMPLE

This example will create a new process instance called “My Instance Name” based on the model “My Model” in version “0”.

declare
   l_prcs_id flow_processes.prcs_id%type;
begin
   l_prcs_id := flow_api_pkg.flow_create(
        pi_dgrm_name    => 'My Model'
      , pi_dgrm_version => '0'
      , pi_prcs_name    => 'My Instance Name'
   );
end;

SIGNATURE

function flow_create (
      pi_dgrm_name in flow_diagrams.dgrm_name%type -- Name of the model to instanciate
,
      pi_dgrm_version in flow_diagrams.dgrm_version%type default null -- Version of the model to instanciate (optional)
,
      pi_prcs_name in flow_processes.prcs_name%type -- Name of the process instance to create
   ) return flow_processes.prcs_id%type;

Function flow_create

Function flow_create - Signature 2 This function creates a new process instance based on a diagram id (process specification) and returns the Process ID of the newly created process

EXAMPLE

This example will create a new process instance called “My Instance Name” based on the model ID 1.

declare
   l_prcs_id flow_processes.prcs_id%type;
begin
   l_prcs_id := flow_api_pkg.flow_create (
        pi_dgrm_id    => 1
      , pi_prcs_name    => 'My Instance Name'
   );
end;

SIGNATURE

function flow_create (
      pi_dgrm_id in flow_diagrams.dgrm_id%type -- ID of the model to instanciate
,
      pi_prcs_name in flow_processes.prcs_name%type -- Name of the process instance to create
   ) return flow_processes.prcs_id%type;

Procedure flow_create

Procedure flow_create - Signature 1 Creates a new process instance based on a diagram name and version (process specification).

If the version is not specified:

  • first lookup is to use dgrm_status = ‘released’
  • second lookup is to use dgrm_version = ‘0’ and dgrm_status = ‘draft’

If nothing is found based on above rules an exception will be raised. For accuracy, it’s recommended that you specify a version or use the form of flow_create specifying dgrm_id directly.

EXAMPLE

This example will create a new process instance called “My Instance Name” based on the model “My Model” in version “0”.

begin
   flow_api_pkg.flow_create(
        pi_dgrm_name    => 'My Model'
      , pi_dgrm_version => '0'
      , pi_prcs_name    => 'My Instance Name'
   );
end;

SIGNATURE

procedure flow_create (
      pi_dgrm_name in flow_diagrams.dgrm_name%type -- Name of the model to instanciate
,
      pi_dgrm_version in flow_diagrams.dgrm_version%type default null -- Version of the model to instanciate (optional)
,
      pi_prcs_name in flow_processes.prcs_name%type -- Name of the process instance to create
   );

Procedure flow_create

Procedure flow_create - Signature 2

This procedure creates a new process instance based on a diagram id and version (process specification)

EXAMPLE

This example will create a new process instance called “My Instance Name” based on the model ID 1.

begin
   flow_api_pkg.flow_create(
         pi_dgrm_id    => 1
      , pi_prcs_name    => 'My Instance Name'
   );
end;

SIGNATURE

procedure flow_create (
      pi_dgrm_id in flow_diagrams.dgrm_id%type -- ID of the model to instanciate
,
      pi_prcs_name in flow_processes.prcs_name%type -- Name of the process instance to create
   );

Procedure flow_start

Procedure flow_start

This procedure is use to start a process that was previously created by flow_create. It will will find the none Start event in the Flow diagram, and step the instance forward from the Start event.

EXAMPLE

This example will create a new process instance called “My Instance Name” based on the model “My Model” in version “0” and start it.

declare
   l_prcs_id flow_processes.prcs_id%type;
begin
   l_prcs_id := flow_api_pkg.flow_create(
        pi_dgrm_name    => 'My Model'
      , pi_dgrm_version => '0'
      , pi_prcs_name    => 'My Instance Name'
   );

   flow_api_pkg.flow_start(
      p_process_id => l_prcs_id
   );
end;

SIGNATURE

procedure flow_start (
      p_process_id in flow_processes.prcs_id%type -- Process ID to start
   );

Procedure flow_reset

Procedure flow_reset This procedure is used, typically during model development and testing only, to reset an existing Instance to the state it would be at after it was created, but not yet started. All Process Variables, except built-ins, are deleted. This is not meant for use in Production Systems.

EXAMPLE

This example will reset the process instance that have the ID 1.

begin
   flow_api_pkg.flow_reset(
        p_process_id   => 1
      , p_comment      => 'Reset Process Instance using the PL/SQL API'
   );
end;

SIGNATURE

procedure flow_reset (
      p_process_id in flow_processes.prcs_id%type -- Process ID to reset
,
      p_comment in flow_instance_event_log.lgpr_comment%type default null -- Optional comment to be added to the instance event logs
   );

Procedure flow_terminate

Procedure flow_terminate This procedure is used, typically by an administrator, to permanently stop processing of the Instance (which will be lefty in a status of terminated).

EXAMPLE

This example will terminate the process instance that have the ID 1.

begin
   flow_api_pkg.flow_terminate(
        p_process_id    => 1
      , p_comment => 'Process Instance Terminated using the PL/SQL API'
   );
end;

SIGNATURE

procedure flow_terminate (
      p_process_id in flow_processes.prcs_id%type -- Process ID to terminate
,
      p_comment in flow_instance_event_log.lgpr_comment%type default null -- Optional comment to be added to the instance event logs
   );

Procedure flow_delete

Procedure flow_delete This procedure is used to remove an Instance from the system. All instances, subflows, and variables are deleted from the operational system. If event logging was enabled while the process was running, records in the event logs are maintained for auditting purposes.

EXAMPLE

This example will delete the process instance that have the ID 1.

begin
   flow_api_pkg.flow_delete(
        p_process_id => 1
      , p_comment    => 'Delete Process Instance using the PL/SQL API'
   );
end;

SIGNATURE

procedure flow_delete (
      p_process_id in flow_processes.prcs_id%type -- Process ID to delete
,
      p_comment in flow_instance_event_log.lgpr_comment%type default null -- Optional comment to be added to the instance event logs
   );

Procedure flow_set_priority

Procedure flow_set_priority. This procedure is used to update the priority of a process instance. The initial process priority will be set from the process diagram definition, but this procedure can be used to reset the priority while the instance is running. Values from 1 (highest priority) to 5 (lowest priority)

EXAMPLE

This example will update the process instance priority to 1 (most urgent) for process instance 345.

begin
   flow_api_pkg.flow_reset(
        p_process_id => 345
      , p_priority   => 1
   );
end;

SIGNATURE

procedure flow_set_priority (
      p_process_id in flow_processes.prcs_id%type       -- Process ID to update,
,
      p_priority   in flow_processes.prcs_priority%type -- New Instance Priority ( values 1 (highest) to 5 (lowest).)
   );

Procedure flow_set_due_on

Procedure flow_set_due_on This procedure is used to update the Due On timestamp of a process instance. The initial process Due On date (actually a timestamp with time zone) will be set from the process diagram definition, but this procedure can be used to reset the Due On while the instance is running. Due On date values should be a Timestamp with Time Zone.

EXAMPLE

This example will update the process instance due_on timestamp to 31 Dec 2027 at 14:30 GMT for process instance 345.

begin
   flow_api_pkg.flow_reset(
        p_process_id => 345
      , p_due_on     => to_timestamp_tz ( '31-DEC-2027 14:30:00 GMT', 'DD-MON-YYYY HH24:MI:SS TZR')
   );
end;

SIGNATURE

procedure flow_set_due_on (
      p_process_id in flow_processes.prcs_id%type     -- Process ID to update
,
      p_due_on     in flow_processes.prcs_due_on%type -- New Instance Due On timestamp
   );

Procedure flow_start_step

Procedure flow_start_step This procedure is an optional command that can be used in applications to signal that a user is about to start working on a task. This is only used to differentiate ‘waiting’ time from ‘processing’ time in system logs to aid process management and statistics. A ‘good-practice’ app would issue this call when work is about to start on a task, for example, from a page loading process.

EXAMPLE

This example will use this procedure to indicate that the work is started for the task that have the subflow ID 3 in the process ID 1.

begin
   flow_api_pkg.flow_start_step(
        p_process_id => 1
      , p_subflow_id => 3 
      , p_step_key   => 'NqOiEHUbAF'
   );
end;

SIGNATURE

procedure flow_start_step (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
   );

Procedure flow_reserve_step

Procedure flow_reserve_step This procedure is used to signal to other users that a user is going to handle this task (see the documentation on reservations).

EXAMPLE

This example will reserve the step in proces ID 1 and subflow ID 3 for the current user.

begin
   flow_api_pkg.flow_reserve_step(
        p_process_id  => 1
      , p_subflow_id  => 3 
      , p_step_key    => 'NqOiEHUbAF'
      , p_reservation => :APP_USER
   );
end;

SIGNATURE

procedure flow_reserve_step (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
,
      p_reservation in flow_subflows.sbfl_reservation%type -- Value of the reservation, typically the username
   );

Procedure flow_release_step

Procedure flow_release_step This procedure is used to remove a reservation (see the documentation on reservations).

EXAMPLE

This example will release the reservation for a step in proces ID 1 and subflow ID 3 for the current user.

begin
   flow_api_pkg.flow_release_step(
        p_process_id => 1
      , p_subflow_id => 3 
      , p_step_key   => 'NqOiEHUbAF'
   );
end;

SIGNATURE

procedure flow_release_step (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
   );

Procedure flow_complete_step

Procedure flow_complete_step This procedure is used to tell the flow engine that the current step is complete, and to move the instance forward to the next step.

EXAMPLE

This example will complete a step in proces ID 1 and subflow ID 3 for the current user.

begin
   flow_api_pkg.flow_complete_step(
        p_process_id  => 1
      , p_subflow_id  => 3 
      , p_step_key    => 'NqOiEHUbAF'
   );
end;

SIGNATURE

procedure flow_complete_step (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
   );

Procedure flow_restart_step

Procedure flow_restart_step This procedure is designed to be called by an administrator to restart, for example, a scriptTask or serviceTask that has failed due to an error. The intended usage is that the adminstrator can fix the script or edit the process data that caused the task to fail, and then restart the task using this call. A comment can optionally be provided, which will be added to the task event log entry. It should only be used on a subflow having a status of ‘error’

EXAMPLE

This example will restart a step in proces ID 1 and subflow ID 3.

begin
   flow_api_pkg.flow_restart_step(
        p_process_id  => 1
      , p_subflow_id  => 3
      , p_step_key    => 'NqOiEHUbAF' 
   );
end;

SIGNATURE

procedure flow_restart_step (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
,
      p_comment in flow_instance_event_log.lgpr_comment%type default null -- Optional comment to be added to the instance event logs
   );

Procedure flow_reschedule_timer

Procedure flow_reschedule_timer flow_reschedule_timer can be called to change the next scheduled time of a timer on a running timer. It can change the currently scheduled time to a future time, or can instruct the timer to fire immediately. If the Timer event is a single event timer (timer types Date or Duration), it will change the time at which the event is scheduled to occur to the new time. If the timer is a Cycle Timer, this changes the time that the next firing is scheduled to occur. If later cycles exist, the following cycle will be scheduled at the new firing time + the repeat interval. To fire the timer immediately, set p_is_immediate = true. It should then run on the next timer cycle, usually within a few seconds. To change the firing time to another future time, supply a new timestamp with time zone containing the new time. A comment can be provided, which is passed to the log file for explanation of any rescheduling.

EXAMPLE

This example causes a waiting step in process ID 1 and subflow ID 3 to occur immediately.

begin
   flow_api_pkg.flow_reschedule_timer(
        p_process_id   => 1
      , p_subflow_id   => 3 
      , p_step_key     => 'NqOiEHUbAF'
      , p_is_immediate => true
   );
end;

This example causes a waiting step in process ID 1 and subflow ID 3 to be rescheduled for a future time (+2 days).

begin
   flow_api_pkg.flow_reschedule_timer(
        p_process_id    => 1
      , p_subflow_id    => 3 
      , p_step_key      => 'NqOiEHUbAF'
      , p_new_timestamp => systimestamp + 2
   );
end;

SIGNATURE

procedure flow_reschedule_timer (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
,
      p_is_immediate in boolean default false -- Causes the step to occur immediately
,
      p_new_timestamp in flow_timers.timr_start_on%type default null -- Causes the step to be rescheduled at the supplied timestamp
,
      p_comment in flow_instance_event_log.lgpr_comment%type default null -- Optional comment to be added to the event logs
   );

Function get_current_tasks

Function get_current_tasks This function is a pipelined table function which is used to create the Flows for APEX task list. Depending upon the value of p_context, the data returned by the function varies.

For p_context = ‘MY_TASKS’, the task list generated shows the current userTasks for the user. For p_context = ‘SINGLE_PROCESS’, the task list generated shows all of current userTasks and Approval tasks for process instance p_prcs_id. This is used by the Task Monitor of the Flows for APEX application.

SIGNATURE

function get_current_tasks
  ( p_context    in varchar2 default flow_constants_pkg.gc_task_list_context_my_tasks
  , p_prcs_id    in flow_processes.prcs_id%type default null
  , p_user       in varchar2 default null
  , p_groups     in varchar2 default null
  )
  return t_task_list_items pipelined;

Function get_current_usertask_url

get_current_usertask_url This function returns the URL for the current task on the specified subflow.

EXAMPLE

This example show how to get the current task url for process ID 1 and subflow ID 3.

declare
   l_url varchar2(4000);
begin
   l_url := flow_api_pkg.get_current_usertask_url(
        p_process_id => 1
      , p_subflow_id => 3
      , p_step_key   => 'NqOiEHUbAF'
   );
end;

SIGNATURE

function get_current_usertask_url (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_subflow_id in flow_subflows.sbfl_id%type -- Subflow ID
,
      p_step_key in flow_subflows.sbfl_step_key%type default null -- Step Key
,
      p_scope in flow_subflows.sbfl_scope%type default 0 -- Scope
   ) return varchar2;

Function message

message function This function returns a Flows for APEX error message with p0…p9 substitutions in p_lang.

EXAMPLE

This example show how to get the “gateway-no-route” message in french.

declare
   l_message varchar2(4000);
begin
   l_message := flow_api_pkg.message(
        p_message_key => 'gateway-no-route'
      , p_lang        => 'fr'
      , p0            => 'Variable Name'
   );
end;

SIGNATURE

function message (
      p_message_key in varchar2 -- Key of the message that shoud exists in the flow_messages table
,
      p_lang in varchar2 default 'en' -- Lang code to retrieve the message, default is “en”
,
      p0 in varchar2 default null -- Value for substitution: %0 in the message will be replaced by p0, %1 by p1, etc
,
      p1 in varchar2 default null,
      p2 in varchar2 default null,
      p3 in varchar2 default null,
      p4 in varchar2 default null,
      p5 in varchar2 default null,
      p6 in varchar2 default null,
      p7 in varchar2 default null,
      p8 in varchar2 default null,
      p9 in varchar2 default null
   ) return varchar2;

Procedure return_approval_result

return_approval_result Procedure A convenience procedure for returning an APEX Approval result into a Flows for APEX process when the task has ben completed. This procedure checks the Task ID is valid, stores p_result into the return variable (as defined in the process diagram), then performs a flow_complete_step to move to the next step.

This can be called from an APEX Approval Task Action step. Note that you can also use the APEX Approval Return Result process plug-in to do this declaratively in your application.

EXAMPLE

This code could be defined in an APEX Approval Task Action definition when a task is completed (on approval and on rejection).
In this example, we have an APEX Approval parameter PROCESS_ID which contains the Flows for APEX process ID. The values for p_task_id and p_result are

flow_api_pkg.return_approval_result ( p_process_id      => :PROCESS_ID,
                                      p_apex_task_id    => :APEX$TASK_ID,
                                      p_result          => :APEX$TASK_OUTCOME);

SIGNATURE

procedure return_approval_result (
      p_process_id in flow_processes.prcs_id%type -- Process ID
,
      p_apex_task_id in number -- APEX Task ID
,
      p_result in flow_process_variables.prov_var_vc2%type default null -- Approval Result
   );

Procedure receive_message

receive_message This procedure is called to send a Simple Message Protocol formatted message into Flows for APEX. This is used to communicate from outside the process instance to a waiting ReceiveTask or Message Catch Event that has already created a Message Subscription for the message. The inbound message must completely match the p_message_name, p_key_name, and p_key_value of the Message Subscription for the message to be received. An optional message payload can be included in p_payload, containing information for the process.

See documentation on Message Flow for more details.

EXAMPLE

This code could be used to send a message to a waiting process instance that has already subscribed for a message named ‘SendPaymentReceipt’, the a key named ‘PONumber’, and a value of ‘10345’. The Payload for this message has been defined by the parties as a JSON snippet containing the bank account, amount transferred, transfer time, and a reference number from the bank. The waiting application is expecting a payload in this format, has specified a process variable that it should be stored in, and created a variable expression that can extract the 4 values from the JSON.

flow_api_pkg.receive_message ( p_message_name => 'SendPaymentReceipt',
                               p_key_value    => 'PONumber',
                               p_key_value    => '10345',
                               p_payload      => '{ "bankAccount" = "12345634",
                                                    "amtPaid" = 10456.56,
                                                    "currency" = "USD",
                                                    "bankRef" = "BARCUK206280456756720230805"
                                                    }');

SIGNATURE

procedure receive_message
  ( p_message_name  flow_message_subscriptions.msub_message_name%type
  , p_key_name      flow_message_subscriptions.msub_key_name%type
  , p_key_value     flow_message_subscriptions.msub_key_value%type
  , p_payload       clob default null
  );