Lock.php
[Pman.Core] / Lock.php
1 <?php
2
3
4
5 /**
6  * 
7  * Locking theory
8  * 
9  * 
10  * This page is locked by XXXXXXX.. 
11  * Do you to prevent them saving and lock it yourself..
12  * 
13  * 
14  * 
15  * 
16  * 
17  * -- interacts with Roo and _lock = id..
18  * 
19  * 
20  * call : 
21  * try and lock it..
22  * baseURL + /Core/Lock/lock?on_id=...&on_table=...
23  * - returns id or an array of who has the locks.
24  * 
25  * Force an unlock after a warning..
26  * baseURL + /Core/Lock/lock?on_id=...&on_table=...&force=1
27  * - returns id..
28  * 
29  * Unlock - call when window is closed..
30  * baseURL + /Core/Lock/unlock?on_id=...&on_table=...&force=1
31  * - returns jerr or jok
32  */
33
34 require_once 'Pman.php';
35
36 class Pman_Core_Lock extends Pman
37 {
38     
39     function getAuth()
40     {
41          $au = $this->getAuthUser();
42         if (!$au) {
43              $this->jerr("Not authenticated", array('authFailure' => true));
44         }
45         $this->authUser = $au;
46         // check that it's a supplier!!!! 
47         
48         return true; 
49     }
50     
51     function get()
52     {
53         // should we allow url links to lock things???
54     }
55     
56     function post($action)
57     {
58         
59         // default action is to attempt to lock..
60         $action = empty($action) || $action == 'lock' ? 'lock' : 'unlock';
61         $this->$action();
62         
63     }
64     
65     function unlock()
66     {
67     
68         if (empty($_REQUEST['id'])) {
69             $this->jerr("No lock id");
70         }
71         $curlock = DB_DataObject::factory('Core_locking');
72         if (!$curlock->get($_REQUEST['id'])) {
73             $this->jerr("No lock exists");
74         }
75         
76         if ($curlock->person_id != $this->authUser->id) {
77             $this->jerr("Lock id is invalid");
78         }
79         
80         $curlock->delete();
81         
82         $this->jok('unlocked');
83     }
84     function lock()
85     {
86         
87         if (empty($_REQUEST['on_id']) || empty($_REQUEST['on_table'])) {
88             $this->jerr("Missing table or id");
89         }
90        
91         $tab = str_replace('/', '',$_REQUEST['on_table']); // basic protection??
92         $x = DB_DataObject::factory($tab);
93         if (!$x->get($_REQUEST['on_id'])) {
94             $this->jerr("Item does not exist");
95         }
96         // is there a current lock on the item..
97         
98         $curlock = DB_DataObject::factory('Core_locking');
99         $curlock->setFrom(array(
100             'on_id' => $_REQUEST['on_id'],
101             'on_table' => $_REQUEST['on_table']
102         ));
103         
104         
105         $nlocks = $curlock->count() ;
106         if ($nlocks && empty($_REQUEST['force'])) {
107             
108             $ar = $curlock->fetchAll('person_id', 'created');
109             $p = DB_DataObject::factory('Person');
110             $p->whereAddIn('id', $ar, 'int');
111             $p->find();
112             $ret = array();
113             while ($p->fetch()) {
114                 $ret[$p->id] = $p->toRooArray();
115                 $ret[$p->id]->lock_created = $ar[$p->id];
116             }
117             $this->jok(array_values($ret));
118             
119         }
120         if ($nlocks) {
121             // trash all the locks..
122             $curlock->find();
123             while($curlock->fetch()) {
124                 $cc =clone($curlock);
125                 $cc->delete();
126             }
127         }
128         
129         // make a lock..
130         
131         $curlock = DB_DataObject::factory('Core_locking');
132         $curlock->setFrom(array(
133             'on_id' => $_REQUEST['on_id'],
134             'on_table' => $_REQUEST['on_table'],
135             'created' => date('Y-m-d H:i:s'),
136             'person_id' => $this->authUser->id,
137         ));
138         $id = $curlock->insert();
139         $this->jok($id);
140         
141     }
142      
143     
144         
145     
146 }