blob: 7001a4a29ad7c30c90fb69db8d8f9200f215f025 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
<?php
/**
* StudipScmEntry.class.php
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License, or (at your option) any later version.
*
* @author André Noack <noack@data-quest>, Suchi & Berg GmbH <info@data-quest.de>
* @author Jan-Hendrik Willms <tleilax+studip@gmail.com>
*
* @property string $id alias column for scm_id
* @property string $scm_id database column
* @property string $range_id database column
* @property string $user_id database column
* @property I18NString $tab_name database column
* @property I18NString $content database column
* @property int $mkdate database column
* @property int $chdate database column
* @property int $position database column
* @property User $user belongs_to User
* @property Course $course belongs_to Course
*/
class StudipScmEntry extends SimpleORMap
{
protected static function configure($config = [])
{
$config['db_table'] = 'scm';
$config['belongs_to']['user'] = [
'class_name' => User::class,
'foreign_key' => 'user_id',
];
$config['belongs_to']['course'] = [
'class_name' => Course::class,
'foreign_key' => 'range_id',
];
$config['i18n_fields']['tab_name'] = true;
$config['i18n_fields']['content'] = true;
$config['registered_callbacks']['before_create'][] = function ($scm) {
$query = "SELECT MAX(`position`)
FROM `scm`
WHERE `range_id` = ?";
$max_pos = DBManager::get()->fetchColumn($query, [$scm->range_id]);
$scm->position = $max_pos + 1;
};
parent::configure($config);
}
}
|