Subversion Repositories portal2

Rev

Rev 722 | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
/*  emg - Energy Monitoring & Graphing
*  Copyright (C) 2006-2012 Romain Lievin
*
*  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 3 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
*/

?>

<div id="page_form_data_mod_submit">
        <h1>
                <?php echo _('Modify Data'); ?>
        </h1>
</div>

<?php

$error = new Error();
$ok = false;

if(!isset($_POST['form_token_2'], $_POST['form_data'],
                $_POST['form_datum_key'],
                $_POST['form_datum_name'], $_POST['form_datum_unit'],
                $_POST['form_datum_a'], $_POST['form_datum_b']
        ))
{
        $error->push(_('One or more fields are missing.'));
}
else
if( $_POST['form_token_2'] != $_SESSION['form_token_2'])
{
        $error->push(_('Internal error: invalid token.'));
}
else
if(isset($_POST['form_cancel']))
{
        $error->push(_('Operation aborted.'));
        unset($_SESSION['groups']);
}
elseif(strlen( $_POST['form_datum_name']) > 64 || strlen($_POST['form_datum_name']) < 4)
{
        $error->push(_('Name must have [4-64] characters.'));
}
else
if(filter_var($_POST['form_datum_b'], FILTER_VALIDATE_INT) === false)
{
        $error->push(_('Incorrect numeric value.'));
}
else
if(filter_var($_POST['form_datum_a'], FILTER_VALIDATE_FLOAT) === false)
{
        $error->push(_('Incorrect numeric value.'));
}

else
{
        $form_datum_key = filter_var($_POST['form_datum_key'], FILTER_SANITIZE_STRING);
        $form_datum_name= filter_var($_POST['form_datum_name'], FILTER_SANITIZE_STRING);
        $form_datum_unit= filter_var($_POST['form_datum_unit'], FILTER_SANITIZE_STRING);
        $form_datum_a   = filter_var($_POST['form_datum_a'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_SCIENTIFIC | FILTER_FLAG_ALLOW_FRACTION);
        $form_datum_b   = filter_var($_POST['form_datum_b'], FILTER_SANITIZE_NUMBER_INT);

        if(isset($_SESSION['data']))
        {
                $data = $_SESSION['data'];
                $datum= $data->getItem($form_datum_key);

                $datum->setName($form_datum_name);
                $datum->setUnit($form_datum_unit);
                $datum->setSlope((float)$form_datum_a);
                $datum->setIntercept((int)$form_datum_b);
        }

        $error->push(_('Data updated.'));
        $ok      = true;

        /*** save configuration contents ***/
        config_save();
}

echo $error->display();

/* Redirection */
if(isset($_POST['form_cancel']) || ($ok === true))
{
        $id = link_get_id_from_filename("form_data_list.php");
        $refresh = $_SESSION['refresh_redirection'];
        echo "<meta http-equiv=\"refresh\" content=\"$refresh; URL=index.php?id_page=$id\">";
}
else if($ok == false)
{
        $id = link_get_id_from_filename("form_data_modify.php");
        $refresh = $_SESSION['refresh_redirection'];
        echo "<meta http-equiv=\"refresh\" content=\"$refresh; URL=index.php?id_page=$id\">";
}

?>