aboutsummaryrefslogtreecommitdiff
path: root/lib.php
blob: af728268df0941637dbec6deed92c53283e88fd3 (plain) (blame)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle 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 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * This file contains the functions used by the plugin.
 *
 * @copyright 2018 'Valentin Popov' <info@valentineus.link>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @package   local_webhooks
 */

defined( "MOODLE_INTERNAL" ) || die();

define( "LW_TABLE_SERVICES", "local_webhooks_service" );
define( "LW_TABLE_EVENTS", "local_webhooks_events" );

/**
 * Class local_webhooks_api
 *
 * @copyright 2018 'Valentin Popov' <info@valentineus.link>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @package   local_webhooks
 */
class local_webhooks_api {
    /**
     * Create service data in the database.
     *
     * @param  array $service Data to the service
     * @return int Service ID
     */
    public static function create_service( $service = array() ) {
        global $DB;

        if ( !is_array( $service ) || empty( $service ) ) {
            print_error( "unknowparamtype", "error", null, "service" );
        }

        $serviceId = $DB->insert_record( LW_TABLE_SERVICES, $service, true, false );
        if ( $serviceId && is_array( $service[ "events" ] ) && !empty( $service[ "events" ] ) ) {
            self::insert_events( $service[ "events" ], $serviceId );
        }

        return (int) $serviceId;
    }

    /**
     * Delete the service data from the database.
     *
     * @param  int $serviceId Service ID
     * @return bool Execution result
     */
    public static function delete_service( $serviceId = 0 ) {
        global $DB;

        if ( !is_numeric( $serviceId ) || empty( $serviceId ) ) {
            print_error( "unknowparamtype", "error", null, "serviceId" );
        }

        $DB->delete_records( LW_TABLE_EVENTS, array( "serviceid" => $serviceId ) );
        return $DB->delete_records( LW_TABLE_SERVICES, array( "id" => $serviceId ) );
    }

    /**
     * Update the service data in the database.
     *
     * @param  array $service Data to the service
     * @return bool Execution result
     */
    public static function update_service( $service = array() ) {
        global $DB;

        if ( !is_array( $service ) || empty( $service ) || empty( $service[ "id" ] ) ) {
            print_error( "unknowparamtype", "error", null, "service" );
        }

        $result = $DB->update_record( LW_TABLE_SERVICES, $service, false );
        $DB->delete_records( LW_TABLE_EVENTS, array( "serviceid" => $service[ "id" ] ) );
        if ( $result && is_array( $service[ "events" ] ) && !empty( $service[ "events" ] ) ) {
            self::insert_events( $service[ "events" ], $service[ "id" ] );
        }

        return $result;
    }

    /**
     * Save the list of events to the database.
     *
     * @param array $events    List of events
     * @param int   $serviceId Service ID
     */
    private static function insert_events( $events = array(), $serviceId = 0 ) {
        global $DB;

        $conditions = array();
        foreach ( $events as $eventName ) {
            $conditions[] = array( "name" => $eventName, "serviceid" => $serviceId );
        }

        $DB->insert_records( LW_TABLE_EVENTS, $conditions );
    }
}