250 lines
7.3 KiB
PHP
250 lines
7.3 KiB
PHP
<?php
|
|
|
|
//
|
|
// logger.admin.inc : callbacks for logger account and admin pages
|
|
// Copyright (c) 2010 flukso.net
|
|
//
|
|
// 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.
|
|
//
|
|
// This program 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 this program; if not, write to the Free Software
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
//
|
|
// $Id$
|
|
//
|
|
|
|
/**
|
|
* Callback function for the user/x/devices page's drupal_get_form
|
|
*
|
|
* @ingroup forms
|
|
* @see _logger_account_devices_validate
|
|
* @see _logger_account_devices_submit
|
|
* @see theme_logger_account_devices
|
|
*/
|
|
function _logger_account_devices() {
|
|
$form['serial'] = array(
|
|
'#type' => 'textfield',
|
|
'#size' => 10,
|
|
'#maxlength' => 10,
|
|
'#required' => TRUE,
|
|
);
|
|
$form['submit'] = array(
|
|
'#type' => 'submit',
|
|
'#value' => t('Add device'),
|
|
);
|
|
$form['#validate'][] = '_logger_account_devices_validate';
|
|
$form['#submit'][] = '_logger_account_devices_submit';
|
|
$form['#theme'] = 'logger_account_devices';
|
|
|
|
return $form;
|
|
}
|
|
|
|
function _logger_account_devices_validate($form, &$form_state) {
|
|
$serial = $form_state['values']['serial'];
|
|
if (strlen($serial) == 10 && is_numeric(substr($serial, 2, 9))) {
|
|
if (db_result(db_query("SELECT COUNT(*) FROM {logger_devices} WHERE serial = %d AND uid = %d", substr($serial, 2, 9), 0)) == 0) {
|
|
form_set_error('serial', t('Please specify a valid serial number.'));
|
|
}
|
|
}
|
|
else {
|
|
form_set_error('serial', t('Please specify a proper 10-character serial number.'));
|
|
}
|
|
}
|
|
|
|
function _logger_account_devices_submit($form, &$form_state) {
|
|
global $user;
|
|
$serial = substr($form_state['values']['serial'], 2, 9);
|
|
$device = db_result(db_query("SELECT device FROM {logger_devices} WHERE serial = %d", $serial));
|
|
|
|
db_query("UPDATE {logger_devices} SET uid = %d WHERE serial = %d", $user->uid, $serial);
|
|
db_query("UPDATE {logger_meters} SET uid = %d WHERE device = '%s'", $user->uid, $device);
|
|
|
|
// check whether the user is already a true fluksonian
|
|
// if not, generate the proper entries in {users_roles} and {logger_users}
|
|
if (!user_access('logger')) {
|
|
$rid = db_result(db_query("SELECT rid FROM {role} WHERE name = '%s'", 'fluksonian'));
|
|
db_query("INSERT INTO {users_roles} (uid, rid) VALUES (%d, %d)", $user->uid, $rid);
|
|
db_query("INSERT INTO {logger_users} (uid, private) VALUES (%d, %d)", $user->uid, 0);
|
|
}
|
|
|
|
drupal_set_message(t("The device is now associated with your account."));
|
|
}
|
|
|
|
/**
|
|
* Theme function for displaying the devices form
|
|
*
|
|
* @ingroup themeable
|
|
*
|
|
* @param $form
|
|
* The device form array.
|
|
*/
|
|
function theme_logger_account_devices($form) {
|
|
global $user;
|
|
$rows = array();
|
|
|
|
$result = db_query("SELECT serial, access, resets, uptime
|
|
FROM {logger_devices}
|
|
WHERE uid = %d
|
|
ORDER BY serial", $user->uid);
|
|
|
|
function unix_to_userlocaltime($unix) {
|
|
global $user;
|
|
$unix_local = gmdate('r', $unix + $user->timezone);
|
|
return substr($unix_local, 0, strlen($unix_local) - 6);
|
|
}
|
|
|
|
function seconds_to_dayshours($seconds) {
|
|
$days = intval($seconds / 86400);
|
|
$hours = intval(($seconds % 86400) / 3600);
|
|
return sprintf('%d days %d hours', $days, $hours);
|
|
}
|
|
|
|
while ($device = db_fetch_object($result)) {
|
|
$row = array();
|
|
$row[] = $device->serial;
|
|
$row[] = $device->resets;
|
|
$row[] = unix_to_userlocaltime($device->access);
|
|
$row[] = seconds_to_dayshours($device->uptime);
|
|
|
|
$rows[] = $row;
|
|
}
|
|
|
|
$rows[] = array(drupal_render($form['serial']), array('data' => drupal_render($form['submit']), 'colspan' => 3));
|
|
|
|
$output = drupal_render($form);
|
|
$output .= theme('logger_account_devices_list', $rows);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Theme function for displaying the list of devices
|
|
*
|
|
* @ingroup themeable
|
|
*
|
|
* @param $items
|
|
* An array of table rows.
|
|
*/
|
|
function theme_logger_account_devices_list($items) {
|
|
if (count($items) > 0) {
|
|
$headers = array(t('Serial'), t('Resets'), t('Last heartbeat'), t('Uptime'));
|
|
$output = theme('table', $headers, $items);
|
|
}
|
|
else {
|
|
$output = t('No devices available.');
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Callback function for the user/x/sensors page
|
|
*
|
|
* @param $type
|
|
* String defining the sensor type
|
|
*/
|
|
function _logger_account_sensors($type = 'electricity') {
|
|
global $user;
|
|
$rows = array();
|
|
|
|
$result = db_query("SELECT lm.meter, lm.function, lt.token, lt.permissions
|
|
FROM {logger_meters} lm
|
|
INNER JOIN {logger_tokens} lt ON lm.meter = lt.meter
|
|
WHERE lm.uid = %d AND lm.type = '%s' AND lm.enabled = %d
|
|
ORDER BY lm.function", $user->uid, $type, 1);
|
|
|
|
while ($sensor = db_fetch_object($result)) {
|
|
$row = array();
|
|
$row[] = $sensor->meter;
|
|
$row[] = $sensor->token;
|
|
$row[] = $type;
|
|
$row[] = $sensor->function;
|
|
|
|
$rows[] = $row;
|
|
}
|
|
|
|
return theme('logger_account_sensors_list', $rows);
|
|
}
|
|
|
|
/**
|
|
* Theme function for displaying the user's sensors
|
|
*
|
|
* @param $items
|
|
* An array of table rows.
|
|
*/
|
|
function theme_logger_account_sensors_list($items) {
|
|
if (count($items) > 0) {
|
|
$headers = array(t('Sensor'), t('Token'), t('Type'), t('Function'));
|
|
$output = theme('table', $headers, $items);
|
|
}
|
|
else {
|
|
$output = t('No sensors available.');
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Callback function for the user/x/privacy page
|
|
*/
|
|
function _logger_account_privacy() {
|
|
$output .= drupal_get_form('_logger_account_privacy_form');
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Generates the privacy form.
|
|
*/
|
|
function _logger_account_privacy_form() {
|
|
global $user;
|
|
|
|
$form['privacy'] = array(
|
|
'#title' => t('Set your preferred privacy mode'),
|
|
'#type' => 'radios',
|
|
'#options' => array(
|
|
t('Shared within Flukso'),
|
|
t('Private'),
|
|
),
|
|
'#description' => t("When selecting Private mode, your data stream will not be drawn on other people's graph and all statistics will be marked as 'prv'. Conversely, nobody else's data stream will be drawn on your chart."),
|
|
'#default_value' => db_result(db_query("SELECT private
|
|
FROM {logger_users}
|
|
WHERE uid = %d", $user->uid)),
|
|
);
|
|
$form['submit'] = array(
|
|
'#type' => 'submit',
|
|
'#value' => t('Submit'),
|
|
);
|
|
return $form;
|
|
}
|
|
|
|
/**
|
|
* Process settings form submissions.
|
|
*/
|
|
function _logger_account_privacy_form_submit($form, &$form_state) {
|
|
global $user;
|
|
|
|
// the built-in validation function already checks elements with options
|
|
$private = $form_state['values']['privacy'];
|
|
db_query("UPDATE {logger_users}
|
|
SET private = %d
|
|
WHERE uid = %d", $private, $user->uid);
|
|
|
|
// page redirection to the dashboard after form submission
|
|
$form_state['redirect'] = 'logger';
|
|
}
|
|
|
|
/**
|
|
* Define the administration settings form for the logger module
|
|
*/
|
|
function _logger_admin_settings() {
|
|
//TODO
|
|
}
|
|
|