2013-08-25 23:59:52 +00:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
LICENSE
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License (GPL)
|
|
|
|
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.
|
|
|
|
|
|
|
|
To read the license please visit http://www.gnu.org/copyleft/gpl.html
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2017-10-09 18:56:03 +00:00
|
|
|
/**
|
|
|
|
* Manages piwik user accounts
|
|
|
|
* @copyright AlternC-Team 2000-2017 https://alternc.com/
|
|
|
|
*/
|
|
|
|
|
|
|
|
require_once("../class/config.php");
|
2013-08-25 23:59:52 +00:00
|
|
|
include_once("head.php");
|
|
|
|
|
|
|
|
$fields = array (
|
2016-05-23 13:03:13 +00:00
|
|
|
"user_name" => array ("post", "string", FALSE),
|
2013-08-25 23:59:52 +00:00
|
|
|
"site_id" => array ("post", "integer", -1),
|
|
|
|
"right" => array ("post", "string", FALSE),
|
|
|
|
);
|
|
|
|
getFields($fields);
|
|
|
|
|
|
|
|
if ($user_name === FALSE)
|
|
|
|
{
|
2017-10-06 16:04:36 +00:00
|
|
|
$msg->raise("ERROR", "piwik", _('No piwik user specified'));
|
2013-08-25 23:59:52 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Add a user to a piwik website
|
|
|
|
if ($site_id != -1 && $right !== FALSE) {
|
2016-05-17 16:47:09 +00:00
|
|
|
$db->query("SELECT COUNT(*) AS ok FROM piwik_sites WHERE uid=? AND piwik_id=?;",array($cuid,$site_id));
|
2013-08-25 23:59:52 +00:00
|
|
|
$db->next_record();
|
|
|
|
if ($db->f('ok')!=1)
|
|
|
|
{
|
2017-10-06 16:04:36 +00:00
|
|
|
$msg->raise("ERROR", "piwik", _("You don't own this piwik website"));
|
2013-08-25 23:59:52 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-05-17 16:47:09 +00:00
|
|
|
$db->query("SELECT COUNT(*) AS ok FROM piwik_users WHERE uid=? AND login=?",array($cuid,$user_name));
|
2013-08-25 23:59:52 +00:00
|
|
|
$db->next_record();
|
|
|
|
if ($db->f('ok')!=1)
|
|
|
|
{
|
2017-10-06 16:04:36 +00:00
|
|
|
$msg->raise("ERROR", "piwik", _("You don't own this piwik user"));
|
2013-08-25 23:59:52 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$piwik_rights = array("noaccess", "view", "admin");
|
|
|
|
if (in_array($right, $piwik_rights))
|
|
|
|
{
|
|
|
|
$api_data = $piwik->site_set_user_right($site_id, $user_name, $right);
|
|
|
|
if ($api_data === FALSE)
|
2017-10-07 10:15:35 +00:00
|
|
|
$msg->raise("ERROR", "piwik", $api_data->message);
|
|
|
|
$msg->raise("ERROR", "piwik", $api_data->message);
|
2013-08-25 23:59:52 +00:00
|
|
|
else
|
2017-10-06 16:04:36 +00:00
|
|
|
$msg->raise("INFO", "piwik", _('success'));
|
2013-08-25 23:59:52 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-10-06 16:04:36 +00:00
|
|
|
$msg->raise("ERROR", "piwik", _("This right does not exist"));
|
2013-08-25 23:59:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$user_piwik_sites = array();
|
2016-05-17 16:47:09 +00:00
|
|
|
$db->query("SELECT piwik_id FROM piwik_sites WHERE uid=?",array($cuid));
|
2013-08-25 23:59:52 +00:00
|
|
|
while ($db->next_record())
|
|
|
|
array_push($user_piwik_sites, $db->f('piwik_id'));
|
|
|
|
// Weird behaviour of php: array_push products an array such as:
|
|
|
|
// array_push(array(1,2,3) , 4) produces
|
|
|
|
// array(0 => 1, 1 => 2, 2 => 3, 3 => 4)
|
|
|
|
// So for further comparison, we need to exchange keys and values
|
|
|
|
$user_piwik_sites = array_flip($user_piwik_sites);
|
|
|
|
|
|
|
|
$user_piwik_users = array();
|
2016-05-17 16:47:09 +00:00
|
|
|
$db->query("SELECT login FROM piwik_users WHERE uid=?",arary($cuid));
|
2013-08-25 23:59:52 +00:00
|
|
|
while ($db->next_record())
|
|
|
|
array_push ($user_piwik_users, $db->f('login'));
|
|
|
|
// Swap keys and values, see user_piwik_sites
|
|
|
|
$user_piwik_users = array_flip($user_piwik_users);
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|
|
|
|
<h3><?php printf('%s "%s"', _("Rights for user"), $user_name); ?></h3>
|
|
|
|
<?php
|
2017-08-16 16:29:25 +00:00
|
|
|
echo $msg->msg_html_all();
|
|
|
|
|
2013-08-25 23:59:52 +00:00
|
|
|
$raw_sites = $piwik->get_site_list();
|
|
|
|
$piwik_sites = array();
|
|
|
|
foreach ($raw_sites AS $site) {
|
|
|
|
$piwik_sites[ $site->idsite ] = array('name' => $site->name, 'url' => $site->main_url);
|
|
|
|
}
|
|
|
|
|
|
|
|
$raw_access = $piwik->get_site_access($user_name);
|
|
|
|
|
|
|
|
$piwik_user_sites = array_intersect_ukey($piwik_sites, $user_piwik_sites, "strcmp");
|
|
|
|
$available_user_sites = $piwik_user_sites;
|
|
|
|
|
|
|
|
echo '<ul>';
|
|
|
|
foreach ($raw_access AS $access)
|
|
|
|
{
|
|
|
|
unset($available_user_sites[ $access->site ]);
|
|
|
|
printf("<li>%s -> %s</li>\n", $piwik_sites[ $access->site ]['name'], $access->access);
|
|
|
|
}
|
|
|
|
echo '</ul>';
|
|
|
|
if (count($available_user_sites)>0)
|
|
|
|
{
|
|
|
|
?>
|
|
|
|
<h3><?php printf('%s "%s"', _("Add rights to user"), $user_name); ?></h3>
|
|
|
|
<ul>
|
|
|
|
<?php
|
|
|
|
foreach ($available_user_sites AS $current_id_site => $available_user_site)
|
|
|
|
{
|
|
|
|
printf('<li>%s <form method="post"><input type="hidden" name="site_id" value="%d">
|
2016-05-20 12:21:47 +00:00
|
|
|
<input type="hidden" name="csrf" value="'.csrf_get(true).'" />
|
2013-08-25 23:59:52 +00:00
|
|
|
<select name="right">
|
|
|
|
<option value="noaccess">%s</option>
|
|
|
|
<option value="view">%s</option>
|
|
|
|
<option value="admin">%s</option>
|
|
|
|
</select>
|
|
|
|
<input type="submit" name="add" value="ajouter" class="inb" /></form></li>', $available_user_site['name'], $current_id_site, _("noacces"), _("view"), _("admin"));
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
</li>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
include_once("foot.php"); ?>
|