aboutsummaryrefslogtreecommitdiff
path: root/lib/models/StudipScmEntry.php
blob: 30c13d30213606e55938ae3641fbd0614e85343d (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.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);
    }
}