1 <?php
defined('SYSPATH') OR die('No direct access allowed.');
4 * Model for scheduled reports
6 class Scheduled_reports_Model
extends Model
8 const USERFIELD
= 'username'; /**< Name of username column in database */
11 * Given a scheduled report id, delet it from db
13 static function delete_scheduled_report($id=false)
16 if (empty($id)) return false;
17 $sql = "DELETE FROM scheduled_reports WHERE id=".$id;
18 $db = Database
::instance();
24 * Delete ALL schedules for a certain report_id and type
26 static function delete_all_scheduled_reports($type='avail',$id=false)
28 $type = strtolower($type);
29 $db = Database
::instance();
31 # what report_type_id do we have?
32 $sql = "SELECT id FROM scheduled_report_types WHERE identifier=".$db->escape($type);
33 $res = $db->query($sql);
36 # bail out if we can't find report_type
38 $row = $res->current();
39 $report_type_id = $row->id
;
40 $sql = "DELETE FROM scheduled_reports WHERE report_type_id=".$report_type_id." AND report_id=".$id;
43 } catch (Kohana_Database_Exception
$e) {
50 * Fetches all scheduled reports of current report type (avail/sla)
52 * @param $type string: {avail, sla, summary}
55 public static function get_scheduled_reports($type)
57 $type = strtolower($type);
59 $db = Database
::instance();
62 $auth = op5auth
::instance();
63 if (!$auth->authorized_for('host_view_all')) {
64 $sql_xtra = ' AND sr.'.self
::USERFIELD
.'='.$db->escape(Auth
::instance()->get_user()->username
).' ';
70 r.report_name AS reportname
73 scheduled_report_types rt,
74 scheduled_report_periods rp,
77 rt.identifier='".$type."' AND
78 sr.report_type_id=rt.id AND
79 rp.id=sr.period_id AND
80 sr.report_id=r.id".$sql_xtra."
84 $res = $db->query($sql);
89 * Checks if a report is scheduled in autoreports
91 * @param $type string: {avail, sla}
92 * @param $id int The report id
93 * @return Array on success. False on error.
95 static function report_is_scheduled($type='avail', $id=false)
97 $type = strtolower($type);
100 if (!$id) return false;
101 $res = self
::get_scheduled_reports($type);
102 if (!$res ||
count($res)==0) {
107 foreach ($res as $row) {
108 if ($row['report_id'] == $id) {
116 * Get available report periods
117 * @return array [id] => string. False on errors.
119 static function get_available_report_periods()
121 $sql = "SELECT * from scheduled_report_periods";
122 $db = Database
::instance();
123 $res = $db->query($sql);
124 if(!$res ||
count($res)==0) {
129 foreach ($res as $period_row) {
130 $periods[$period_row->id
] = $period_row->periodname
;
136 * Retrieves the value of a db field for a report id
137 * @param $type the database column
138 * @param $id the id of the scheduled report
140 static function fetch_scheduled_field_value($type=false, $id=false)
144 if (empty($type) ||
empty($id)) return false;
145 $sql = "SELECT $type FROM scheduled_reports WHERE id=".$id;
146 $db = Database
::instance();
147 $res = $db->query($sql);
148 if (!$res ||
count($res) == 0) {
151 $row = $res->current();
152 return $row->{$type};
157 * @param $rep_type = false
158 * @param $saved_report_id = false
159 * @param $period = false
160 * @param $recipients = false comma separated
161 * @param $filename = ''
162 * @param $description = ''
163 * @param $local_persistent_filepath = ''
164 * @param $attach_description = ''
165 * @return string|int either error string or the report's id
167 static public function edit_report($id=false, $rep_type=false, $saved_report_id=false, $period=false, $recipients=false, $filename='', $description='', $local_persistent_filepath = '', $attach_description = 0)
169 $local_persistent_filepath = trim($local_persistent_filepath);
170 if($local_persistent_filepath && !is_writable(rtrim($local_persistent_filepath, '/').'/')) {
171 return _("File path '$local_persistent_filepath' is not writable");
173 $db = Database
::instance();
175 $rep_type = (int)$rep_type;
176 $saved_report_id = (int)$saved_report_id;
177 $period = (int)$period;
178 $recipients = trim($recipients);
179 $filename = trim($filename);
180 $description = trim($description);
181 $attach_description = (int) $attach_description;
182 $user = Auth
::instance()->get_user()->username
;
184 if (!$rep_type ||
!$saved_report_id ||
!$period ||
empty($recipients)) return _('Missing data');
186 // some users might use ';' to separate email adresses
187 // just replace it with ',' and continue
188 $recipients = str_replace(';', ',', $recipients);
189 $rec_arr = explode(',', $recipients);
190 if (!empty($rec_arr)) {
191 foreach ($rec_arr as $recipient) {
192 if (trim($recipient)!='') {
193 $checked_recipients[] = trim($recipient);
196 $recipients = implode(', ', $checked_recipients);
201 $sql = "UPDATE scheduled_reports SET ".self
::USERFIELD
."=".$db->escape($user).", report_type_id=".$rep_type.", report_id=".$saved_report_id.", recipients=".$db->escape($recipients).", period_id=".$period.", filename=".$db->escape($filename).", description=".$db->escape($description).", local_persistent_filepath = ".$db->escape($local_persistent_filepath).", attach_description = ".$db->escape($attach_description)." WHERE id=".$id;
203 $sql = "INSERT INTO scheduled_reports (".self
::USERFIELD
.", report_type_id, report_id, recipients, period_id, filename, description, local_persistent_filepath, attach_description)
204 VALUES(".$db->escape($user).", ".$rep_type.", ".$saved_report_id.", ".$db->escape($recipients).", ".$period.", ".$db->escape($filename).", ".$db->escape($description).", ".$db->escape($local_persistent_filepath).", ".$db->escape($attach_description).")";
208 $res = $db->query($sql);
209 } catch (Kohana_Database_Exception
$e) {
210 return _('DATABASE ERROR').": {$e->getMessage()}; $sql";
214 $id = $res->insert_id();
220 * Update specific field for certain scheduled report
221 * Called from reports_Controller::save_schedule_item() through ajax
223 * @param $id int: The id of the report.
224 * @param $field string: The report field to update.
225 * @param $value string: The new value.
226 * @return true on succes. false on errors.
228 static function update_report_field($id=false, $field=false, $value=false)
231 $field = trim($field);
232 $value = trim($value);
233 $db = Database
::instance();
234 $sql = "UPDATE scheduled_reports SET ".$field."= ".$db->escape($value)." WHERE id=".$id;
236 $res = $db->query($sql);
237 } catch (Kohana_Database_Exception
$e) {
238 print $e->getMessage();
245 * Get the type of a report.
247 * @param $id The id of the report.
248 * @return Report type on success. False on errors.
250 static function get_typeof_report($id=false)
252 $sql = "SELECT t.identifier FROM scheduled_reports sr, scheduled_report_types t WHERE ".
253 "sr.id=".(int)$id." AND t.id=sr.report_type_id";
254 $db = Database
::instance();
256 $res = $db->query($sql);
257 } catch (Kohana_Database_Exception
$e) {
261 return count($res)!=0 ?
$res->current()->identifier
: false;
265 * Get the id of a named report
267 * @param $identifier string: The name of the report
268 * @return False on errors. Id of the report on success.
270 static function get_report_type_id($identifier=false)
272 $db = Database
::instance();
273 $sql = "SELECT id FROM scheduled_report_types WHERE identifier=".$db->escape($identifier);
275 $res = $db->query($sql);
276 } catch (Kohana_Database_Exception
$e) {
281 if (count($res)!=0) {
282 $res = $res->current();
289 * Fetch info on all defined report types, i.e all
290 * types we can schedule
292 static function get_all_report_types()
294 $db = Database
::instance();
295 $sql = "SELECT * FROM scheduled_report_types ORDER BY id";
296 $res = $db->query($sql);
297 return count($res) != 0 ?
$res : false;
301 * Fetch all info for a specific schedule.
302 * This includes all relevant data about both schedule
305 * @param $schedule_id The id of the schedule we're interested in.
306 * @return False on errors. Array with scheduling information on success.
308 static function get_scheduled_data($schedule_id=false)
310 $schedule_id = (int)$schedule_id;
315 $sql = "SELECT sr.recipients, sr.filename, sr.local_persistent_filepath, sr.report_id FROM ".
316 "scheduled_reports sr ".
317 "WHERE sr.id=".$schedule_id;
318 $db = Database
::instance();
319 $res = $db->query($sql)->result_array(false);
326 * Fetch info on reports to be sent for specific
327 * period (daily/weekly/monthly)
329 * @param $period_str string: { daily, weekly, monthly }
332 static function get_period_schedules($period_str)
334 $period_str = trim(ucfirst($period_str));
335 $db = Database
::instance();
337 $sql = "SELECT r.id FROM scheduled_report_types rt
338 INNER JOIN scheduled_reports r ON rt.id=r.report_type_id
339 INNER JOIN scheduled_report_periods p ON r.period_id=p.id
340 WHERE p.periodname=".$db->escape($period_str);
341 $res = $db->query($sql);