1: <?php
2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14:
15:
16: defined('CON_FRAMEWORK') || die('Illegal call: Missing framework initialization - request aborted.');
17:
18: 19: 20: 21: 22: 23:
24: class WorkflowUserSequences extends ItemCollection {
25:
26: 27: 28: 29: 30:
31: public function __construct() {
32: global $cfg;
33: parent::__construct($cfg["tab"]["workflow_user_sequences"], "idusersequence");
34: $this->_setItemClass("WorkflowUserSequence");
35: }
36:
37: public function delete($id) {
38: global $cfg, $idworkflow;
39:
40: $item = new WorkflowUserSequence();
41: $item->loadByPrimaryKey($id);
42:
43: $pos = $item->get("position");
44: $idworkflowitem = $item->get("idworkflowitem");
45: $this->select("position > $pos AND idworkflowitem = " . (int) $idworkflowitem);
46: while (($obj = $this->next()) !== false) {
47: $pos = $obj->get("position") - 1;
48: $obj->setPosition($pos);
49: $obj->store();
50: }
51:
52: parent::delete($id);
53:
54: $this->updateArtAllocation($id);
55: }
56:
57: public function updateArtAllocation($idusersequence) {
58: global $idworkflow, $cfg;
59: $oDb = cRegistry::getDb();
60:
61: $aIdArtLang = array();
62: $sSql = 'SELECT idartlang FROM ' . $cfg["tab"]["workflow_art_allocation"] . ' WHERE idusersequence = ' . $oDb->escape($idusersequence) . ';';
63: $oDb->query($sSql);
64: while ($oDb->nextRecord()) {
65: array_push($aIdArtLang, $oDb->f('idartlang'));
66: }
67:
68: $sSql = 'DELETE FROM ' . $cfg["tab"]["workflow_art_allocation"] . ' WHERE idusersequence = ' . $oDb->escape($idusersequence) . ';';
69: $oDb->query($sSql);
70:
71: foreach ($aIdArtLang as $iIdArtLang) {
72: setUserSequence($iIdArtLang, $idworkflow);
73: }
74: }
75:
76: public function create($idworkflowitem) {
77: global $auth, $client, $idworkflow;
78:
79: $workflowitems = new WorkflowItems();
80: if (!$workflowitems->exists($idworkflowitem)) {
81: $this->lasterror = i18n("Workflow item doesn't exist. Can't create entry.", "workflow");
82: return false;
83: }
84:
85: $this->select("idworkflowitem = " . (int) $idworkflowitem, "", "position DESC", "1");
86:
87: $item = $this->next();
88:
89: if ($item === false) {
90: $lastPos = 1;
91: } else {
92: $lastPos = $item->getField("position") + 1;
93: }
94:
95: $newitem = $this->createNewItem();
96: $newitem->setWorkflowItem($idworkflowitem);
97: $newitem->setPosition($lastPos);
98: $newitem->store();
99:
100: return $newitem;
101: }
102:
103: public function swap($idworkflowitem, $pos1, $pos2) {
104: $this->select("idworkflowitem = '$idworkflowitem' AND position = " . (int) $pos1);
105: if (($item = $this->next()) === false) {
106: $this->lasterror = i18n("Swapping items failed: Item doesn't exist", "workflow");
107: return false;
108: }
109:
110: $pos1ID = $item->getField("idusersequence");
111:
112: $this->select("idworkflowitem = '$idworkflowitem' AND position = " . (int) $pos2);
113: if (($item = $this->next()) === false) {
114: $this->lasterror(i18n("Swapping items failed: Item doesn't exist", "workflow"));
115: return false;
116: }
117:
118: $pos2ID = $item->getField("idusersequence");
119:
120: $item = new WorkflowUserSequence();
121: $item->loadByPrimaryKey($pos1ID);
122: $item->setPosition($pos2);
123: $item->store();
124: $item->loadByPrimaryKey($pos2ID);
125: $item->setPosition($pos1);
126: $item->store();
127:
128: $this->updateArtAllocation($pos2ID);
129: $this->updateArtAllocation($pos1ID);
130:
131: return true;
132: }
133:
134: }
135:
136: 137: 138: 139: 140: 141: 142: 143: 144: 145:
146: class WorkflowUserSequence extends Item {
147:
148: 149: 150: 151: 152:
153: public function __construct() {
154: global $cfg;
155: parent::__construct($cfg["tab"]["workflow_user_sequences"], "idusersequence");
156: }
157:
158: 159: 160: 161: 162: 163: 164: 165: 166: 167:
168: public function setField($field, $value, $safe = true) {
169: global $cfg;
170:
171: switch ($field) {
172: case "idworkflowitem":
173: throw new cInvalidArgumentException("Please use create to modify idsequence. Direct modifications are not allowed");
174: case "idusersequence":
175: throw new cInvalidArgumentException("Please use create to modify idsequence. Direct modifications are not allowed");
176: case "position":
177: throw new cInvalidArgumentException("Please use create and swap to set the position. Direct modifications are not allowed");
178: case "iduser":
179: if ($value != 0) {
180: $db = cRegistry::getDb();
181: $sql = "SELECT user_id FROM " . $cfg['tab']['user'] . " WHERE user_id = '" . $db->escape($value) . "'";
182: $db->query($sql);
183:
184: if (!$db->nextRecord()) {
185: $sql = "SELECT group_id FROM " . $cfg["tab"]["groups"] . " WHERE group_id = '" . $db->escape($value) . "'";
186:
187: $db->query($sql);
188: if (!$db->nextRecord()) {
189: $this->lasterror = i18n("Can't set user_id: User or group doesn't exist", "workflow");
190: return false;
191: }
192: }
193: $idusersquence = parent::getField('idusersequence');
194: }
195: }
196:
197: parent::setField($field, $value, $safe);
198: if ($idusersquence) {
199: $workflowUserSequences = new WorkflowUserSequences();
200: $workflowUserSequences->updateArtAllocation(0);
201: }
202: }
203:
204: 205: 206: 207: 208:
209: public function getWorkflowItem() {
210: if ($this->isLoaded()) {
211: $workflowItem = new WorkflowItem();
212: $workflowItem->loadByPrimaryKey($this->values["idworkflowitem"]);
213: return ($workflowItem);
214: } else {
215: return false;
216: }
217: }
218:
219: 220: 221: 222: 223: 224:
225: public function setWorkflowItem($value) {
226: parent::setField("idworkflowitem", $value);
227: }
228:
229: 230: 231: 232: 233: 234:
235: public function setPosition($value) {
236: parent::setField("position", $value);
237: }
238:
239: }
240:
241: ?>