dropbox_class.inc.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * Dropbox module for Chamilo
  5. * Classes for the dropbox module.
  6. *
  7. * 3 classes have been defined:
  8. * - Dropbox_Work:
  9. * . id
  10. * . uploader_id => who sent it
  11. * . uploaderName
  12. * . filename => name of file stored on the server
  13. * . filesize
  14. * . title => name of file returned to user. This is the original name of the file
  15. * except when the original name contained spaces. In that case the spaces
  16. * will be replaced by _
  17. * . description
  18. * . author
  19. * . upload_date => date when file was first sent
  20. * . last_upload_date => date when file was last sent
  21. * . isOldWork => has the work already been uploaded before
  22. *
  23. * . feedback_date => date of most recent feedback
  24. * . feedback => feedback text (or HTML?)
  25. *
  26. * - Dropbox_SentWork extends Dropbox_Work
  27. * . recipients => array of ["id"]["name"] lists the recipients of the work
  28. *
  29. * - Dropbox_Person:
  30. * . userId
  31. * . receivedWork => array of Dropbox_Work objects
  32. * . sentWork => array of Dropbox_SentWork objects
  33. * . isCourseTutor
  34. * . isCourseAdmin
  35. * . _orderBy => private property used for determining the field by which the works have to be ordered
  36. *
  37. * @version 1.30
  38. * @copyright 2004
  39. * @author Jan Bols <jan@ivpv.UGent.be>
  40. * with contributions by René Haentjens <rene.haentjens@UGent.be>
  41. * @package chamilo.dropbox
  42. */
  43. class Dropbox_Work {
  44. public $id;
  45. public $uploader_id;
  46. public $uploaderName;
  47. public $filename;
  48. public $filesize;
  49. public $title;
  50. public $description;
  51. public $author;
  52. public $upload_date;
  53. public $last_upload_date;
  54. public $isOldWork;
  55. public $feedback_date, $feedback;
  56. /**
  57. * Constructor calls private functions to create a new work or retreive an existing work from DB
  58. * depending on the number of parameters
  59. *
  60. * @param unknown_type $arg1
  61. * @param unknown_type $arg2
  62. * @param unknown_type $arg3
  63. * @param unknown_type $arg4
  64. * @param unknown_type $arg5
  65. * @param unknown_type $arg6
  66. * @return Dropbox_Work
  67. */
  68. function Dropbox_Work($arg1, $arg2 = null, $arg3 = null, $arg4 = null, $arg5 = null, $arg6 = null) {
  69. if (func_num_args() > 1) {
  70. $this->_createNewWork($arg1, $arg2, $arg3, $arg4, $arg5, $arg6);
  71. } else {
  72. $this->_createExistingWork($arg1);
  73. }
  74. }
  75. /**
  76. * private function creating a new work object
  77. *
  78. * @param unknown_type $uploader_id
  79. * @param unknown_type $title
  80. * @param unknown_type $description
  81. * @param unknown_type $author
  82. * @param unknown_type $filename
  83. * @param unknown_type $filesize
  84. *
  85. * @todo $author was originally a field but this has now been replaced by the first and lastname of the uploader (to prevent anonymous uploads)
  86. * As a consequence this parameter can be removed
  87. */
  88. function _createNewWork($uploader_id, $title, $description, $author, $filename, $filesize) {
  89. global $_user, $dropbox_cnf;
  90. // Do some sanity checks
  91. settype($uploader_id, 'integer') or die(get_lang('GeneralError').' (code 201)'); //set $uploader_id to correct type
  92. //if (! isCourseMember($uploader_id)) die(); //uploader must be coursemember to be able to upload
  93. //-->this check is done when submitting data so it isn't checked here
  94. // Fill in the properties
  95. $this->uploader_id = $uploader_id;
  96. $this->uploaderName = getUserNameFromId($this->uploader_id);
  97. $this->filename = $filename;
  98. $this->filesize = $filesize;
  99. $this->title = $title;
  100. $this->description = $description;
  101. $this->author = api_get_person_name($_user['firstName'], $_user['lastName']);
  102. $this->last_upload_date = api_get_utc_datetime();
  103. $course_id = api_get_course_int_id();
  104. // Check if object exists already. If it does, the old object is used
  105. // with updated information (authors, descriptio, upload_date)
  106. $this->isOldWork = false;
  107. $sql = "SELECT id, upload_date FROM ".$dropbox_cnf['tbl_file']."
  108. WHERE c_id = $course_id AND filename = '".Database::escape_string($this->filename)."'";
  109. $result = Database::query($sql);
  110. $res = Database::fetch_array($result);
  111. if ($res) {
  112. $this->isOldWork = true;
  113. }
  114. // Insert or update the dropbox_file table and set the id property
  115. if ($this->isOldWork) {
  116. $this->id = $res['id'];
  117. $this->upload_date = $res['upload_date'];
  118. $sql = "UPDATE ".$dropbox_cnf["tbl_file"]." SET
  119. filesize = '".Database::escape_string($this->filesize)."' ,
  120. title = '".Database::escape_string($this->title)."',
  121. description = '".Database::escape_string($this->description)."',
  122. author = '".Database::escape_string($this->author)."',
  123. last_upload_date = '".Database::escape_string($this->last_upload_date)."'
  124. WHERE c_id = $course_id AND id='".Database::escape_string($this->id)."'";
  125. $result = Database::query($sql);
  126. } else {
  127. $this->upload_date = $this->last_upload_date;
  128. $sql = "INSERT INTO ".$dropbox_cnf['tbl_file']." (c_id, uploader_id, filename, filesize, title, description, author, upload_date, last_upload_date, session_id)
  129. VALUES ( $course_id,
  130. '".Database::escape_string($this->uploader_id)."'
  131. , '".Database::escape_string($this->filename)."'
  132. , '".Database::escape_string($this->filesize)."'
  133. , '".Database::escape_string($this->title)."'
  134. , '".Database::escape_string($this->description)."'
  135. , '".Database::escape_string($this->author)."'
  136. , '".Database::escape_string($this->upload_date)."'
  137. , '".Database::escape_string($this->last_upload_date)."'
  138. , ".intval($_SESSION['id_session'])."
  139. )";
  140. $result = Database::query($sql);
  141. $this->id = Database::insert_id(); // Get automatically inserted id
  142. }
  143. // Insert entries into person table
  144. $sql = "INSERT INTO ".$dropbox_cnf['tbl_person']." (c_id, file_id, user_id)
  145. VALUES ($course_id,
  146. '".Database::escape_string($this->id)."'
  147. , '".Database::escape_string($this->uploader_id)."'
  148. )";
  149. $result = Database::query($sql); //if work already exists no error is generated
  150. }
  151. /**
  152. * private function creating existing object by retreiving info from db
  153. *
  154. * @param unknown_type $id
  155. */
  156. function _createExistingWork($id) {
  157. $course_id = api_get_course_int_id();
  158. global $_user, $dropbox_cnf;
  159. // Do some sanity checks
  160. settype($id, 'integer') or die(get_lang('GeneralError').' (code 205)'); // Set $id to correct type
  161. $id = intval($id);
  162. // Get the data from DB
  163. $sql = "SELECT uploader_id, filename, filesize, title, description, author, upload_date, last_upload_date, cat_id
  164. FROM ".$dropbox_cnf['tbl_file']."
  165. WHERE c_id = $course_id AND id = '".Database::escape_string($id)."'";
  166. $result = Database::query($sql);
  167. $res = Database::fetch_array($result, 'ASSOC');
  168. // Check if uploader is still in Chamilo system
  169. $uploader_id = stripslashes($res['uploader_id']);
  170. $uploaderName = getUserNameFromId($uploader_id);
  171. if (!$uploaderName) {
  172. //deleted user
  173. $this->uploader_id = -1;
  174. $this->uploaderName = get_lang('Unknown', '');
  175. } else {
  176. $this->uploader_id = $uploader_id;
  177. $this->uploaderName = $uploaderName;
  178. }
  179. // Fill in properties
  180. $this->id = $id;
  181. $this->filename = stripslashes($res['filename']);
  182. $this->filesize = stripslashes($res['filesize']);
  183. $this->title = stripslashes($res['title']);
  184. $this->description = stripslashes($res['description']);
  185. $this->author = stripslashes($res['author']);
  186. $this->upload_date = stripslashes($res['upload_date']);
  187. $this->last_upload_date = stripslashes($res['last_upload_date']);
  188. $this->category = $res['cat_id'];
  189. // Getting the feedback on the work.
  190. if ($_GET['action'] == 'viewfeedback' AND $this->id == $_GET['id']) {
  191. $feedback2 = array();
  192. $sql_feedback = "SELECT * FROM ".$dropbox_cnf['tbl_feedback']." WHERE c_id = $course_id AND file_id='".$id."' ORDER BY feedback_id ASC";
  193. $result = Database::query($sql_feedback);
  194. while ($row_feedback = Database::fetch_array($result)) {
  195. $row_feedback['feedback'] = Security::remove_XSS($row_feedback['feedback']);
  196. $feedback2[] = $row_feedback;
  197. }
  198. $this->feedback2= $feedback2;
  199. }
  200. }
  201. }
  202. class Dropbox_SentWork extends Dropbox_Work
  203. {
  204. public $recipients; //array of ['id']['name'] arrays
  205. /**
  206. * Constructor calls private functions to create a new work or retreive an existing work from DB
  207. * depending on the number of parameters
  208. *
  209. * @param unknown_type $arg1
  210. * @param unknown_type $arg2
  211. * @param unknown_type $arg3
  212. * @param unknown_type $arg4
  213. * @param unknown_type $arg5
  214. * @param unknown_type $arg6
  215. * @param unknown_type $arg7
  216. * @return Dropbox_SentWork
  217. */
  218. function Dropbox_SentWork($arg1, $arg2 = null, $arg3 = null, $arg4 = null, $arg5 = null, $arg6 = null, $arg7 = null) {
  219. if (func_num_args() > 1) {
  220. $this->_createNewSentWork($arg1, $arg2, $arg3, $arg4, $arg5, $arg6, $arg7);
  221. } else {
  222. $this->_createExistingSentWork($arg1);
  223. }
  224. }
  225. /**
  226. * private function creating a new SentWork object
  227. *
  228. * @param unknown_type $uploader_id
  229. * @param unknown_type $title
  230. * @param unknown_type $description
  231. * @param unknown_type $author
  232. * @param unknown_type $filename
  233. * @param unknown_type $filesize
  234. * @param unknown_type $recipient_ids
  235. */
  236. function _createNewSentWork($uploader_id, $title, $description, $author, $filename, $filesize, $recipient_ids) {
  237. global $dropbox_cnf;
  238. // Call constructor of Dropbox_Work object
  239. $this->Dropbox_Work($uploader_id, $title, $description, $author, $filename, $filesize);
  240. $course_id = api_get_course_int_id();
  241. // Do sanity checks on recipient_ids array & property fillin
  242. // The sanity check for ex-coursemembers is already done in base constructor
  243. settype($uploader_id, 'integer') or die(get_lang('GeneralError').' (code 208)'); // Set $uploader_id to correct type
  244. $justSubmit = false;
  245. if ( is_int($recipient_ids)) {
  246. $justSubmit = true;
  247. $recipient_ids = array($recipient_ids + $this->id);
  248. } elseif ( count($recipient_ids) == 0) {
  249. $justSubmit = true;
  250. $recipient_ids = array($uploader_id);
  251. }
  252. if (! is_array($recipient_ids) || count($recipient_ids) == 0) {
  253. die(get_lang('GeneralError').' (code 209)');
  254. }
  255. foreach ($recipient_ids as $rec) {
  256. if (empty($rec)) die(get_lang('GeneralError').' (code 210)');
  257. //if (!isCourseMember($rec)) die(); //cannot sent document to someone outside of course
  258. //this check is done when validating submitted data
  259. $this->recipients[] = array('id' => $rec, 'name' => getUserNameFromId($rec));
  260. }
  261. $table_post = $dropbox_cnf['tbl_post'];
  262. $table_person = $dropbox_cnf['tbl_person'];
  263. $session_id = api_get_session_id();
  264. $uploader_id = $this->uploader_id;
  265. $user = api_get_user_id();
  266. // Insert data in dropbox_post and dropbox_person table for each recipient
  267. foreach ($this->recipients as $rec) {
  268. $file_id = (int)$this->id;
  269. $user_id = (int)$rec['id'];
  270. $sql = "INSERT INTO $table_post (c_id, file_id, dest_user_id, session_id)
  271. VALUES ($course_id, $file_id, $user_id, $session_id)";
  272. $result = Database::query($sql);
  273. // If work already exists no error is generated
  274. /**
  275. * Poster is already added when work is created - not so good to split logic
  276. */
  277. if ($user_id != $user) {
  278. // Insert entries into person table
  279. $sql = "INSERT INTO $table_person (c_id, file_id, user_id)
  280. VALUES ($course_id, $file_id, $user_id)";
  281. // Do not add recipient in person table if mailing zip or just upload.
  282. if (!$justSubmit) {
  283. $result = Database::query($sql); // If work already exists no error is generated
  284. }
  285. }
  286. // Update item_property table for each recipient
  287. global $dropbox_cnf;
  288. $_course = api_get_course_info();
  289. if (($ownerid = $this->uploader_id) > $dropbox_cnf['mailingIdBase']) {
  290. $ownerid = getUserOwningThisMailing($ownerid);
  291. }
  292. if (($recipid = $rec["id"]) > $dropbox_cnf['mailingIdBase']) {
  293. $recipid = $ownerid; // mailing file recipient = mailing id, not a person
  294. }
  295. api_item_property_update($_course, TOOL_DROPBOX, $this->id, 'DropboxFileAdded', $ownerid, null, $recipid) ;
  296. }
  297. }
  298. /**
  299. * private function creating existing object by retreiving info from db
  300. *
  301. * @param unknown_type $id
  302. */
  303. function _createExistingSentWork ($id) {
  304. global $dropbox_cnf;
  305. $id = intval($id);
  306. $course_id = api_get_course_int_id();
  307. // Call constructor of Dropbox_Work object
  308. $this->Dropbox_Work($id);
  309. // Fill in recipients array
  310. $this->recipients = array();
  311. $sql = "SELECT dest_user_id, feedback_date, feedback
  312. FROM ".$dropbox_cnf['tbl_post']."
  313. WHERE c_id = $course_id AND file_id='".Database::escape_string($id)."'";
  314. $result = Database::query($sql);
  315. while ($res = Database::fetch_array($result, 'ASSOC')) {
  316. // Check for deleted users
  317. $dest_user_id = $res['dest_user_id'];
  318. $user_info = api_get_user_info($dest_user_id);
  319. //$this->category = $res['cat_id'];
  320. if (!$user_info) {
  321. $this->recipients[] = array('id' => -1, 'name' => get_lang('Unknown', ''));
  322. } else {
  323. $this->recipients[] = array(
  324. 'id' => $dest_user_id,
  325. 'name' => $user_info['complete_name'],
  326. 'user_id' => $dest_user_id,
  327. 'feedback_date' => $res['feedback_date'],
  328. 'feedback' => $res['feedback']);
  329. }
  330. }
  331. }
  332. }
  333. class Dropbox_Person
  334. {
  335. // The receivedWork and the sentWork arrays are sorted.
  336. public $receivedWork; // an array of Dropbox_Work objects
  337. public $sentWork; // an array of Dropbox_SentWork objects
  338. public $userId = 0;
  339. public $isCourseAdmin = false;
  340. public $isCourseTutor = false;
  341. public $_orderBy = ''; // private property that determines by which field
  342. /**
  343. * Constructor for recreating the Dropbox_Person object
  344. *
  345. * @param int $userId
  346. * @param bool $isCourseAdmin
  347. * @param bool $isCourseTutor
  348. * @return Dropbox_Person
  349. */
  350. function Dropbox_Person($userId, $isCourseAdmin, $isCourseTutor) {
  351. $course_id = api_get_course_int_id();
  352. // Fill in properties
  353. $this->userId = $userId;
  354. $this->isCourseAdmin = $isCourseAdmin;
  355. $this->isCourseTutor = $isCourseTutor;
  356. $this->receivedWork = array();
  357. $this->sentWork = array();
  358. // Note: perhaps include an ex coursemember check to delete old files
  359. $session_id = api_get_session_id();
  360. $condition_session = api_get_session_condition($session_id);
  361. $post_tbl = Database::get_course_table(TABLE_DROPBOX_POST);
  362. $person_tbl = Database::get_course_table(TABLE_DROPBOX_PERSON);
  363. $file_tbl = Database::get_course_table(TABLE_DROPBOX_FILE);
  364. // Find all entries where this person is the recipient
  365. $sql = "SELECT DISTINCT r.file_id, r.cat_id
  366. FROM $post_tbl r INNER JOIN $person_tbl p
  367. ON (r.file_id = p.file_id AND r.c_id = $course_id AND p.c_id = $course_id )
  368. WHERE
  369. p.user_id = ".intval($this->userId)." AND
  370. r.dest_user_id = ".intval($this->userId)." $condition_session ";
  371. $result = Database::query($sql);
  372. while ($res = Database::fetch_array($result)) {
  373. $temp = new Dropbox_Work($res['file_id']);
  374. $temp->category = $res['cat_id'];
  375. $this->receivedWork[] = $temp;
  376. }
  377. // Find all entries where this person is the sender/uploader
  378. $sql = "SELECT DISTINCT f.id
  379. FROM $file_tbl f INNER JOIN $person_tbl p
  380. ON (f.id = p.file_id AND f.c_id = $course_id AND p.c_id = $course_id)
  381. WHERE
  382. f.uploader_id = '".Database::escape_string($this->userId)."' AND
  383. p.user_id = '".Database::escape_string($this->userId)."'
  384. $condition_session
  385. ";
  386. $result = Database::query($sql);
  387. while ($res = Database::fetch_array($result)) {
  388. $this->sentWork[] = new Dropbox_SentWork($res['id']);
  389. }
  390. }
  391. /**
  392. * This private method is used by the usort function in the
  393. * orderSentWork and orderReceivedWork methods.
  394. * It compares 2 work-objects by 1 of the properties of that object, dictated by the
  395. * private property _orderBy
  396. *
  397. * @param unknown_type $a
  398. * @param unknown_type $b
  399. * @return -1, 0 or 1 dependent of the result of the comparison.
  400. */
  401. function _cmpWork($a, $b) {
  402. $sort = $this->_orderBy;
  403. $aval = $a->$sort;
  404. $bval = $b->$sort;
  405. if ($sort == 'recipients') { // The recipients property is an array so we do the comparison based on the first item of the recipients array
  406. $aval = $aval[0]['name'];
  407. $bval = $bval[0]['name'];
  408. }
  409. if ($sort == 'filesize') { // Filesize is not a string, so we use other comparison technique
  410. return $aval < $bval ? -1 : 1;
  411. } elseif ($sort == 'title') { // Natural order for sorting titles is more "human-friendly"
  412. return api_strnatcmp($aval, $bval);
  413. } else {
  414. return api_strcasecmp($aval, $bval);
  415. }
  416. }
  417. /**
  418. * A method that sorts the objects in the sentWork array, dependent on the $sort parameter.
  419. * $sort can be lastDate, firstDate, title, size, ...
  420. *
  421. * @param unknown_type $sort
  422. */
  423. function orderSentWork($sort) {
  424. switch($sort) {
  425. case 'lastDate':
  426. $this->_orderBy = 'last_upload_date';
  427. break;
  428. case 'firstDate':
  429. $this->_orderBy = 'upload_date';
  430. break;
  431. case 'title':
  432. $this->_orderBy = 'title';
  433. break;
  434. case 'size':
  435. $this->_orderBy = 'filesize';
  436. break;
  437. case 'author':
  438. $this->_orderBy = 'author';
  439. break;
  440. case 'recipient':
  441. $this->_orderBy = 'recipients';
  442. break;
  443. default:
  444. $this->_orderBy = 'last_upload_date';
  445. }
  446. usort($this->sentWork, array($this, '_cmpWork'));
  447. }
  448. /**
  449. * method that sorts the objects in the receivedWork array, dependent on the $sort parameter.
  450. * $sort can be lastDate, firstDate, title, size, ...
  451. * @param unknown_type $sort
  452. */
  453. function orderReceivedWork($sort) {
  454. switch($sort) {
  455. case 'lastDate':
  456. $this->_orderBy = 'last_upload_date';
  457. break;
  458. case 'firstDate':
  459. $this->_orderBy = 'upload_date';
  460. break;
  461. case 'title':
  462. $this->_orderBy = 'title';
  463. break;
  464. case 'size':
  465. $this->_orderBy = 'filesize';
  466. break;
  467. case 'author':
  468. $this->_orderBy = 'author';
  469. break;
  470. case 'sender':
  471. $this->_orderBy = 'uploaderName';
  472. break;
  473. default:
  474. $this->_orderBy = 'last_upload_date';
  475. }
  476. usort($this->receivedWork, array($this, '_cmpWork'));
  477. }
  478. /**
  479. * Deletes all the received work of this person
  480. */
  481. function deleteAllReceivedWork () {
  482. $course_id = api_get_course_int_id();
  483. global $dropbox_cnf;
  484. // Delete entries in person table concerning received works
  485. foreach ($this->receivedWork as $w) {
  486. Database::query("DELETE FROM ".$dropbox_cnf['tbl_person']." WHERE c_id = $course_id AND user_id='".$this->userId."' AND file_id='".$w->id."'");
  487. }
  488. removeUnusedFiles(); // Check for unused files
  489. }
  490. /**
  491. * Deletes all the received categories and work of this person
  492. */
  493. function deleteReceivedWorkFolder($id) {
  494. global $dropbox_cnf;
  495. $course_id = api_get_course_int_id();
  496. $id = intval($id);
  497. $sql = "DELETE FROM ".$dropbox_cnf['tbl_file']." WHERE c_id = $course_id AND cat_id = '".$id."' ";
  498. if (!Database::query($sql)) return false;
  499. $sql = "DELETE FROM ".$dropbox_cnf['tbl_category']." WHERE c_id = $course_id AND cat_id = '".$id."' ";
  500. if (!Database::query($sql)) return false;
  501. $sql = "DELETE FROM ".$dropbox_cnf['tbl_post']." WHERE c_id = $course_id AND cat_id = '".$id."' ";
  502. if (!Database::query($sql)) return false;
  503. return true;
  504. }
  505. /**
  506. * Deletes a received dropbox file of this person with id=$id
  507. *
  508. * @param integer $id
  509. */
  510. function deleteReceivedWork($id) {
  511. $course_id = api_get_course_int_id();
  512. global $dropbox_cnf;
  513. $id = intval($id);
  514. // index check
  515. $found = false;
  516. foreach ($this->receivedWork as $w) {
  517. if ($w->id == $id) {
  518. $found = true;
  519. break;
  520. }
  521. }
  522. if (!$found) {
  523. if(!$this->deleteReceivedWorkFolder($id)) {
  524. die(get_lang('GeneralError').' (code 216)');
  525. }
  526. }
  527. // Delete entries in person table concerning received works
  528. $sql = "DELETE FROM ".$dropbox_cnf['tbl_person']." WHERE c_id = $course_id AND user_id = '".$this->userId."' AND file_id ='".$id."'";
  529. Database::query($sql);
  530. removeUnusedFiles(); // Check for unused files
  531. }
  532. /**
  533. * Deletes all the sent dropbox files of this person
  534. */
  535. function deleteAllSentWork() {
  536. $course_id = api_get_course_int_id();
  537. global $dropbox_cnf;
  538. //delete entries in person table concerning sent works
  539. foreach ($this->sentWork as $w) {
  540. Database::query("DELETE FROM ".$dropbox_cnf['tbl_person']." WHERE c_id = $course_id AND user_id='".$this->userId."' AND file_id='".$w->id."'");
  541. removeMoreIfMailing($w->id);
  542. }
  543. removeUnusedFiles(); // Check for unused files
  544. }
  545. /**
  546. * Deletes a sent dropbox file of this person with id=$id
  547. *
  548. * @param unknown_type $id
  549. */
  550. function deleteSentWork($id) {
  551. $course_id = api_get_course_int_id();
  552. global $dropbox_cnf;
  553. $id = intval($id);
  554. // index check
  555. $found = false;
  556. foreach ($this->sentWork as $w) {
  557. if ($w->id == $id) {
  558. $found = true;
  559. break;
  560. }
  561. }
  562. if (!$found) {
  563. if (!$this->deleteReceivedWorkFolder($id)) {
  564. die(get_lang('GeneralError').' (code 219)');
  565. }
  566. }
  567. //$file_id = $this->sentWork[$index]->id;
  568. // Delete entries in person table concerning sent works
  569. Database::query("DELETE FROM ".$dropbox_cnf['tbl_person']." WHERE c_id = $course_id AND user_id='".$this->userId."' AND file_id='".$id."'");
  570. removeMoreIfMailing($id);
  571. removeUnusedFiles(); // Check for unused files
  572. }
  573. /**
  574. * Updates feedback for received work of this person with id=$id
  575. *
  576. * @param unknown_type $id
  577. * @param unknown_type $text
  578. */
  579. function updateFeedback($id, $text) {
  580. $course_id = api_get_course_int_id();
  581. global $dropbox_cnf;
  582. $_course = api_get_course_info();
  583. $id = intval($id);
  584. // index check
  585. $found = false;
  586. $wi = -1;
  587. foreach ($this->receivedWork as $w) {
  588. $wi++;
  589. if ($w->id == $id){
  590. $found = true;
  591. break;
  592. } // foreach (... as $wi -> $w) gives error 221! (no idea why...)
  593. }
  594. if (!$found) {
  595. die(get_lang('GeneralError').' (code 221)');
  596. }
  597. $feedback_date = date('Y-m-d H:i:s', time());
  598. $this->receivedWork[$wi]->feedback_date = $feedback_date;
  599. $this->receivedWork[$wi]->feedback = $text;
  600. Database::query("UPDATE ".$dropbox_cnf['tbl_post']." SET feedback_date='".
  601. Database::escape_string($feedback_date)."', feedback='".Database::escape_string($text).
  602. "' WHERE c_id = $course_id AND dest_user_id='".$this->userId."' AND file_id='".$id."'");
  603. // Update item_property table
  604. if (($ownerid = $this->receivedWork[$wi]->uploader_id) > $dropbox_cnf['mailingIdBase']) {
  605. $ownerid = getUserOwningThisMailing($ownerid);
  606. }
  607. api_item_property_update($_course, TOOL_DROPBOX, $this->receivedWork[$wi]->id, 'DropboxFileUpdated', $this->userId, null, $ownerid) ;
  608. }
  609. /**
  610. * Filter the received work
  611. * @param string $type
  612. * @param string $value
  613. */
  614. function filter_received_work($type, $value) {
  615. global $dropbox_cnf;
  616. $new_received_work = array();
  617. foreach ($this->receivedWork as $index => $work) {
  618. switch ($type) {
  619. case 'uploader_id':
  620. if ($work->uploader_id == $value ||
  621. ($work->uploader_id > $dropbox_cnf['mailingIdBase'] && getUserOwningThisMailing($work->uploader_id) == $value)) {
  622. $new_received_work[] = $work;
  623. }
  624. break;
  625. default:
  626. $new_received_work[] = $work;
  627. }
  628. }
  629. $this->receivedWork = $new_received_work;
  630. }
  631. }