[795] | 1 | <?php |
---|
| 2 | /** |
---|
| 3 | * Provê métodos que acessam informações relacionadas aos workitems. |
---|
| 4 | * @author Anderson Tadayuki Saikawa - asaikawa@celepar.pr.gov.br |
---|
| 5 | * @version 1.0 |
---|
| 6 | * @license http://www.gnu.org/copyleft/gpl.html GPL |
---|
| 7 | * @package Workflow |
---|
| 8 | * @subpackage local |
---|
| 9 | */ |
---|
| 10 | class wf_workitem |
---|
| 11 | { |
---|
| 12 | /** |
---|
| 13 | * @var object $db objeto do banco de dados |
---|
| 14 | * @access private |
---|
| 15 | */ |
---|
| 16 | private $db; |
---|
| 17 | |
---|
| 18 | /** |
---|
| 19 | * @var int $processID o ID do processo onde a classe está sendo utilizada |
---|
| 20 | * @access private |
---|
| 21 | */ |
---|
| 22 | private $processID; |
---|
| 23 | |
---|
| 24 | /** |
---|
| 25 | * Construtor do wf_workitem. |
---|
| 26 | * @return object |
---|
| 27 | * @access public |
---|
| 28 | */ |
---|
| 29 | public function wf_workitem() |
---|
| 30 | { |
---|
[2591] | 31 | $this->db = &Factory::getInstance('WorkflowObjects')->getDBGalaxia()->Link_ID; |
---|
[795] | 32 | $this->processID = (int) $GLOBALS['workflow']['wf_runtime']->activity->getProcessId(); |
---|
| 33 | } |
---|
| 34 | |
---|
| 35 | /** |
---|
| 36 | * Busca workitems de uma instância pelo seu nome (identificador). |
---|
| 37 | * @param int $instanceName O nome da instância. |
---|
| 38 | * @param mixed $activities Uma lista de IDs de atividades das quais se quer os workitems (também pode ser um valor inteiro). |
---|
| 39 | * @return array Array onde cada elemento corresponde aos workitens de cada instâncias que satisfaz o critério de seleção. |
---|
| 40 | * @access public |
---|
| 41 | */ |
---|
| 42 | public function getWorkitemsByInstanceName($instanceName, $activities = null) |
---|
| 43 | { |
---|
| 44 | $output = array(); |
---|
| 45 | |
---|
| 46 | if (is_numeric($activities)) |
---|
| 47 | $activities = array((int) $activities); |
---|
| 48 | |
---|
| 49 | /* build the SQL query */ |
---|
| 50 | $query = 'SELECT w.wf_instance_id, w.wf_item_id, w.wf_order_id, w.wf_activity_id, w.wf_started, w.wf_ended, w.wf_user '; |
---|
| 51 | $query .= 'FROM egw_wf_workitems w '; |
---|
| 52 | $query .= 'INNER JOIN egw_wf_instances i ON w.wf_instance_id = i.wf_instance_id '; |
---|
| 53 | $query .= 'WHERE (i.wf_p_id = ?) AND (UPPER(i.wf_name) = UPPER(?)) '; |
---|
| 54 | |
---|
| 55 | $values = array($this->processID, $instanceName); |
---|
| 56 | |
---|
| 57 | /* if there are activities, add a condition */ |
---|
| 58 | if(is_array($activities) && (count($activities) > 0)) |
---|
| 59 | { |
---|
| 60 | $query .= 'AND (w.wf_activity_id = ANY (?))'; |
---|
| 61 | $values[] = '{' . implode(', ', $activities) . '}'; |
---|
| 62 | } |
---|
| 63 | |
---|
| 64 | $result = $this->db->query($query, $values); |
---|
| 65 | if ($result !== false) |
---|
| 66 | { |
---|
| 67 | while (($row = $result->fetchRow())) |
---|
| 68 | $output[$row['wf_instance_id']][] = $row; |
---|
| 69 | $output = array_values($output); |
---|
| 70 | } |
---|
| 71 | |
---|
| 72 | return $output; |
---|
| 73 | } |
---|
| 74 | } |
---|
| 75 | ?> |
---|