}
# Check for SQL injection attacks
if (isset($_GET)) {
    foreach ($_GET as $k => $v) {
        if (preg_match('[\']', $v)) {
            print "Bad request ! Please contact site administrator.";
            exit;
        } else {
            $_GET[$k] = $core->con->escape($v);
        }
    }
}
# Check if setting table exist
$schema = dbSchema::init($core->con);
if (in_array($core->prefix . 'setting', $schema->getTables())) {
    $blog_settings = new bpSettings($core, 'root');
    $user_settings = null;
    /* Set backward compatibility */
    if (!defined('BP_PLANET_URL')) {
        define('BP_PLANET_URL', $blog_settings->get('planet_url'));
    }
    # Set timezone
    $timezone_default = $blog_settings->get('planet_timezone');
    if (!empty($timezone_default)) {
        dt::setTZ($timezone_default);
    }
    #date_default_timezone_set($timezone_default);
    # Set Locale
    $locale = $blog_settings->get('planet_lang');
    # Set log level
    $log = $blog_settings->get('planet_log');
Exemple #2
0
function render_page($page)
{
    global $core, $blog_settings, $user_settings;
    $user_id = $core->auth->userID();
    if ($user_settings == null) {
        $user_settings = new bpSettings($core, $user_id);
    }
    $planet_theme = $blog_settings->get('planet_theme');
    $tpl = new Hyla_Tpl(dirname(__FILE__) . '/../../themes/' . $planet_theme . '/user');
    $tpl->setL10nCallback('T_');
    $tpl->importFile($page, $page . '.tpl');
    $tpl->setVar('planet', array("url" => BP_PLANET_URL, "theme" => $blog_settings->get('planet_theme'), "title" => $blog_settings->get('planet_title'), "desc" => $blog_settings->get('planet_desc'), "keywords" => $blog_settings->get('planet_keywords'), "desc_meta" => $blog_settings->get('planet_desc_meta'), "msg_info" => $blog_settings->get('planet_msg_info')));
    switch ($page) {
        case 'dashboard':
            $sql = generate_SQL(0, 10, array($user_id), array(), '', '', false, null, 2);
            $rs = $core->con->select($sql);
            while ($rs->fetch()) {
                $status = "";
                if (!$rs->status) {
                    $status = "disabled";
                }
                $post = array('id' => $rs->post_id, 'title' => html_entity_decode($rs->title, ENT_QUOTES, 'UTF-8'), 'title2' => htmlspecialchars($rs->title), 'permalink' => $rs->permalink, 'pubdate' => $rs->pubdate, "date" => mysqldatetime_to_date("d/m/Y", $rs->pubdate), "status" => $status);
                $rs2 = $core->con->select("SELECT tag_id FROM " . $core->prefix . "post_tag\n\t\t\t\tWHERE post_id = " . $rs->post_id);
                $tpl->setVar('post', $post);
                while ($rs2->fetch()) {
                    $tpl->setVar('tag', $rs2->tag_id);
                    $tpl->setVar('post_id', $rs->post_id);
                    $tpl->render('userpost.tags');
                }
                if (!$rs->status) {
                    $tpl->render('userpost.action');
                }
                if ($rs->comment) {
                    $tpl->render('userpost.action.nocomment');
                } else {
                    $tpl->render('userpost.action.comment');
                }
                if ($blog_settings->get('allow_post_modification')) {
                    $tpl->render('userpost.action.activate');
                }
                $tpl->render('userpost.item');
            }
            break;
        case 'profile':
            $rs = $core->con->select("SELECT * FROM " . $core->prefix . "user\n\t\t\tWHERE user_id = '" . $user_id . "'");
            $user = array("user_id" => $user_id, 'user_fullname' => $rs->f('user_fullname'), 'user_email' => $rs->f('user_email'));
            $tpl->setVar('user', $user);
            foreach (getAllSupportedLanguages() as $lang) {
                $tpl->setVar('lang', array("code" => $lang['code'], "name" => $lang['name'], "selected" => $lang['code'] == $rs->f('user_lang') ? 'selected="selected"' : ""));
                $tpl->render("lang.select");
            }
            $rs_feed = $core->con->select("SELECT * FROM " . $core->prefix . "feed\n\t\t\tWHERE user_id ='" . $user_id . "'");
            while ($rs_feed->fetch()) {
                $status = "";
                if (!$rs_feed->feed_status || $rs_feed->feed_status == 2) {
                    $status = "disabled";
                }
                $feed = array("status" => $status, "id" => $rs_feed->feed_id, "url" => $rs_feed->feed_url);
                $tpl->setVar('feed', $feed);
                if (!$rs_feed->feed_comment) {
                    $tpl->render('userfeed.action');
                }
                $rs_tags = $core->con->select("SELECT tag_id FROM " . $core->prefix . "feed_tag\n\t\t\t\tWHERE feed_id=" . $rs_feed->feed_id);
                while ($rs_tags->fetch()) {
                    $tpl->setVar('tag', $rs_tags->tag_id);
                    $tpl->setVar('feed_id', $rs_feed->feed_id);
                    $tpl->render('userfeed.tags');
                }
                if ($blog_settings->get('allow_feed_modification')) {
                    $tpl->render('userfeed.action.activate');
                }
                $tpl->render('userfeed.item');
            }
            $rs_pfeed = $core->con->select("SELECT * FROM " . $core->prefix . "pending_feed\n\t\t\tWHERE user_id ='" . $user_id . "'");
            if ($rs_pfeed->count() > 0) {
                while ($rs_pfeed->fetch()) {
                    $feed = array("site" => $rs_pfeed->site_url, "url" => $rs_pfeed->feed_url);
                    $tpl->setVar('pfeed', $feed);
                    $tpl->render('userpfeed.item');
                }
                $tpl->render('pendingfeed');
            }
            $rs_esite = $core->con->select("SELECT * FROM " . $core->prefix . "site WHERE user_id='" . $user_id . "'");
            while ($rs_esite->fetch()) {
                $tpl->setVar("esite", array("id" => $rs_esite->site_id, "url" => $rs_esite->site_url));
                $tpl->render("existing.site");
            }
            break;
        case 'social':
            $newsletter_options = array("nomail" => array("selected" => "", "value" => "nomail", "text" => T_('Disable newsletter')), "dayly" => array("selected" => "", "value" => "dayly", "text" => T_('Every day')), "weekly" => array("selected" => "", "value" => "weekly", "text" => T_('Every week')), "monthly" => array("selected" => "", "value" => "monthly", "text" => T_('Every month')));
            $option = $user_settings->get('social.newsletter');
            if (!isset($option)) {
                $option = 'nomail';
            }
            $newsletter_options[$option]['selected'] = "selected";
            foreach ($newsletter_options as $news) {
                $tpl->setVar('news', $news);
                $tpl->render('newsletter.option');
            }
            $checked = array("twitter" => $user_settings->get('social.twitter') ? 'checked' : '', "statusnet" => $user_settings->get('social.statusnet') ? 'checked' : '', "shaarli" => $user_settings->get('social.shaarli') ? 'checked' : '', "shaarli-type.remote" => $user_settings->get('social.shaarli.type') == 'remote' ? 'selected="selected"' : '', "shaarli-type.local" => $user_settings->get('social.shaarli.type') == 'local' ? 'selected="selected"' : '', "google" => $user_settings->get('social.google') ? 'checked' : '', "reddit" => $user_settings->get('social.reddit') ? 'checked' : '');
            $tpl->setVar('checked', $checked);
            $tpl->setVar('statusnet_account', $user_settings->get('social.statusnet.account'));
            $tpl->setVar('shaarli_instance', $user_settings->get('social.shaarli.instance'));
            break;
        case 'tribes':
            $rs_users = $core->con->select('SELECT user_id, user_fullname
			FROM ' . $core->prefix . 'user
			WHERE user_status=1');
            while ($rs_users->fetch()) {
                $tpl->setVar('option', array("user_id" => $rs_users->user_id, "user_name" => $rs_users->user_fullname));
                $tpl->render('tribe.option.userlist');
            }
            # On recupere les informtions sur les membres
            $sql = 'SELECT
			user_id,
			tribe_id,
			tribe_name,
			tribe_tags,
			tribe_notags,
			tribe_users,
			tribe_nousers,
			tribe_search,
			tribe_icon,
			visibility,
			ordering
			FROM ' . $core->prefix . 'tribe
			WHERE user_id=\'' . $user_id . '\'
			ORDER by ordering
			ASC LIMIT 100 OFFSET 0';
            $rs = $core->con->select($sql);
            if ($rs->count() > 0) {
                while ($rs->fetch()) {
                    $sql_post = generate_tribe_SQL($rs->tribe_id, 0, 0);
                    $rs_post = $core->con->select($sql_post);
                    $tribe_state = "private";
                    if ($rs->visibility == 1) {
                        $tribe_state = "public";
                    }
                    $tribe_tags = preg_split('/,/', $rs->tribe_tags, -1, PREG_SPLIT_NO_EMPTY);
                    foreach ($tribe_tags as $tag_item) {
                        $tpl->setVar('tribe_tag', $tag_item);
                        $tpl->setVar('tribe_id', $rs->tribe_id);
                        $tpl->render('tribes.tag');
                    }
                    $tribe_notags = preg_split('/,/', $rs->tribe_notags, -1, PREG_SPLIT_NO_EMPTY);
                    foreach ($tribe_notags as $tag_item) {
                        $tpl->setVar('tribe_notag', $tag_item);
                        $tpl->setVar('tribe_id', $rs->tribe_id);
                        $tpl->render('tribes.notag');
                    }
                    $tribe_users = preg_split('/,/', $rs->tribe_users, -1, PREG_SPLIT_NO_EMPTY);
                    foreach ($tribe_users as $user_item) {
                        $tpl->setVar('tribe_user', $user_item);
                        $tpl->setVar('tribe_id', $rs->tribe_id);
                        $tpl->render('tribes.user');
                    }
                    if ($rs->tribe_search) {
                        $tpl->setVar('tribe_id', $rs->tribe_id);
                        $tpl->render('tribes.search');
                    }
                    $tribe_icon = getTribeIcon($rs->tribe_id, $rs->tribe_name, $rs->tribe_icon);
                    $tpl->setVar('tribe_id', $rs->tribe_id);
                    $tpl->render('tribes.icon.action');
                    $tribe_name = html_entity_decode($rs->tribe_name, ENT_QUOTES, 'UTF-8');
                    $tpl->setVar('tribe', array('id' => $rs->tribe_id, 'name' => $rs->tribe_name, 'stripped_name' => addslashes($rs->tribe_name), 'state' => $tribe_state, 'icon' => $tribe_icon, 'last_post' => mysqldatetime_to_date("d/m/Y", $rs_post->last), 'count' => $rs_post->count, 'ordering' => $rs->ordering, 'search' => $rs->tribe_search));
                    $tpl->render('tribes.box');
                }
            }
            break;
        default:
            break;
    }
    return $tpl->render();
}
     $cur->modified = array(' NOW() ');
     $cur->insert();
 }
 # Create main tribe
 $cur = $core->con->openCursor($core->prefix . 'tribe');
 $cur->tribe_id = 'root';
 $cur->user_id = 'root';
 $cur->tribe_name = (string) $p_title;
 $cur->visibility = 1;
 $cur->created = array('NOW()');
 $cur->modified = array('NOW()');
 $cur->insert();
 $core->setUserRole($u_login, 'god');
 $root_url = preg_replace('%/admin/install/index.php$%', '', $_SERVER['REQUEST_URI']);
 $planet_url = http::getHost() . $root_url;
 $blog_settings = new bpSettings($core, 'root');
 $blog_settings->put('author', "{$u_fullname}", "string");
 $blog_settings->put('author_mail', $u_email, "string");
 $blog_settings->put('author_id', $u_login, "string");
 $blog_settings->put('author_site', $u_site, "string");
 $blog_settings->put('author_jabber', "Your Jabber", "string");
 $blog_settings->put('author_im', "MSN Messenger, Yahoo Messenger and Other", "string");
 $blog_settings->put('author_about', "About me", "string");
 $blog_settings->put('planet_title', $p_title, "string");
 $blog_settings->put('planet_url', $planet_url, "string");
 $blog_settings->put('planet_desc', $p_desc, "string");
 $blog_settings->put('planet_lang', $p_lang, "string");
 if ($p_lang == "ar") {
     $blog_settings->put('planet_rtl', '1', "boolean");
 }
 $blog_settings->put('planet_version', $p_version, "string");
$scripts = array();
$scripts[] = "javascript/main.js";
$scripts[] = "javascript/jquery.boxy.js";
$current_page = "users";
include dirname(__FILE__) . '/tpl.php';
#
header('Content-type: text/html; charset=utf-8');
# Valeurs par defaut
$params = array('title' => $blog_settings->get('planet_title') . " - " . T_('Users'));
$core->tpl->setVar('params', $params);
$sql_users = "SELECT\n\t\t" . $core->prefix . "user.user_id,\n\t\t" . $core->prefix . "user.user_fullname,\n\t\t" . $core->prefix . "user.user_email,\n\t\t" . $core->prefix . "site.site_url,\n\t\tMAX(" . $core->prefix . "post.post_pubdate) as pubdate,\n\t\tCOUNT(" . $core->prefix . "post.post_id) as nb_post\n\tFROM " . $core->prefix . "user, " . $core->prefix . "post, " . $core->prefix . "site\n\tWHERE " . $core->prefix . "user.user_status = 1\n\tAND " . $core->prefix . "user.user_id = " . $core->prefix . "post.user_id\n\tAND " . $core->prefix . "user.user_id = " . $core->prefix . "site.user_id\n\tGROUP BY " . $core->prefix . "user.user_id\n\tORDER BY pubdate DESC";
//print $sql_users;
//exit;
$rs = $core->con->select($sql_users);
while ($rs->fetch()) {
    $puser_settings = new bpSettings($core, $rs->user_id);
    if ($puser_settings != null && $puser_settings->get('social.shaarli')) {
        $shaarli = $puser_settings->get('social.shaarli.instance');
        $core->tpl->setVar('user_shaarli', $shaarli);
        $core->tpl->render('user.shaarli');
    }
    $user = array("id" => $rs->user_id, "fullname" => $rs->user_fullname, "email" => $rs->user_email, "website" => $rs->site_url, "last" => mysqldatetime_to_date("d/m/Y", $rs->pubdate), "nb_post" => $rs->nb_post);
    $core->tpl->setVar('user', $user);
    //$avatar_email = strtolower($rs->user_email);
    //$libravatar = "http://cdn.libravatar.org/avatar/".md5($avatar_email)."?default=identicon";
    $libravatar = getUserIcon($rs->user_email);
    $core->tpl->setVar('avatar_url', $libravatar);
    $core->tpl->render("user.block");
}
$core->tpl->render("content.users");
# Show result
Exemple #5
0
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program.  If not, see <http://www.gnu.org/licenses/>.
*
***** END LICENSE BLOCK *****/
require dirname(__FILE__) . '/inc/admin/prepend.php';
$blog_settings = new bpSettings($core, 'root');
if (isset($_GET['came_from']) && !empty($_GET['came_from'])) {
    $came_from = $_GET['came_from'];
} elseif (isset($_POST['came_from']) && !empty($_POST['came_from'])) {
    $came_from = $_POST['came_from'];
} else {
    $came_from = 'index.php';
}
# If we have a session cookie, go to index.php
if (isset($_SESSION['sess_user_id'])) {
    http::redirect($came_from);
}
$page_url = http::getHost() . $_SERVER['REQUEST_URI'];
$change_pwd = $core->auth->allowPassChange() && isset($_POST['new_pwd']) && isset($_POST['new_pwd_c']) && isset($_POST['login_data']);
$login_data = !empty($_POST['login_data']) ? $_POST['login_data'] : null;
$recover = $core->auth->allowPassChange() && !empty($_REQUEST['recover']);