Esempio n. 1
0
function createUser($user, $pass, $link, $clear = true)
{
    if ($clear) {
        deleteUsers($link);
    }
    $sql = "INSERT INTO web500_users (user, pass) VALUES ('{$user}', '{$pass}')";
    $res = mysql_query($sql, $link);
    return mysql_affected_rows() > 0;
}
Esempio n. 2
0
 public function index()
 {
     /*
     UserCake (Via CupCake) Version: 2.0.2
     http://usercake.com
     */
     $baseURL = getcwd();
     require_once "{$baseURL}/application/third_party/user_cake/models/config.php";
     if (!securePage($_SERVER['PHP_SELF'])) {
         die;
     }
     //Forms posted
     if (!empty($_POST)) {
         if (!empty($_POST['delete'])) {
             $deletions = $_POST['delete'];
             if ($deletion_count = deleteUsers($deletions)) {
                 $successes[] = lang("ACCOUNT_DELETIONS_SUCCESSFUL", array($deletion_count));
             } else {
                 $errors[] = lang("SQL_ERROR");
             }
         } else {
             $errors[] = lang("NO_SELECTION_TO_DELETE_USER");
         }
     }
     $userData = fetchAllUsers();
     //Fetch information for all users
     require_once "{$baseURL}/application/third_party/user_cake/models/header.php";
     echo "\r\n<body>\r\n<div id='wrapper'>\r\n<div id='top'><div id='logo'></div></div>\r\n<div id='content'>\r\n<h1>UserCake (Via CupCake)</h1>\r\n<h2>Admin Users</h2>\r\n<div id='left-nav'>";
     include "{$baseURL}/application/third_party/user_cake/left-nav.php";
     echo "\r\n</div>\r\n<div id='main'>";
     echo resultBlock($errors, $successes);
     echo "\r\n<form name='adminUsers' action='" . $_SERVER['PHP_SELF'] . "' method='post'>\r\n<table class='admin'>\r\n<tr>\r\n<th>Delete</th><th>Username</th><th>Display Name</th><th>Title</th><th>Last Sign In</th>\r\n</tr>";
     //Cycle through users
     foreach ($userData as $v1) {
         echo "\r\n\t<tr>\r\n\t<td><input type='checkbox' name='delete[" . $v1['id'] . "]' id='delete[" . $v1['id'] . "]' value='" . $v1['id'] . "'></td>\r\n\t<td><a href='" . str_replace('index.php/', '', site_url('admin_user')) . "?id=" . $v1['id'] . "'>" . $v1['user_name'] . "</a></td>\r\n\t<td>" . $v1['display_name'] . "</td>\r\n\t<td>" . $v1['title'] . "</td>\r\n\t<td>\r\n\t";
         //Interprety last login
         if ($v1['last_sign_in_stamp'] == '0') {
             echo "Never";
         } else {
             echo date("j M, Y", $v1['last_sign_in_stamp']);
         }
         echo "\r\n\t</td>\r\n\t</tr>";
     }
     echo "\r\n</table>\r\n<input type='submit' name='Submit' value='Delete' />\r\n</form>\r\n</div>\r\n<div id='bottom'></div>\r\n</div>\r\n</body>\r\n</html>";
 }
Esempio n. 3
0
<?php

/*
UserCake Version: 2.0.2
http://usercake.com
*/
require_once __DIR__ . "/models/config.php";
if (!securePage($_SERVER['PHP_SELF'])) {
    die;
}
//Forms posted
if (!empty($_POST)) {
    $deletions = $_POST['delete'];
    if ($deletion_count = deleteUsers($deletions)) {
        $successes[] = lang("ACCOUNT_DELETIONS_SUCCESSFUL", array($deletion_count));
    } else {
        $errors[] = lang("SQL_ERROR");
    }
}
$userData = fetchAllUsers();
//Fetch information for all users
require_once __DIR__ . "/models/header.php";
echo "\n<body>\n<div id='wrapper'>\n<div id='top'><div id='logo'></div></div>\n<div id='content'>\n<h1>" . $websiteName . "</h1>\n<h2>Admin Users</h2>\n<div id='left-nav'>";
include __DIR__ . "/left-nav.php";
echo "\n</div>\n<div id='main'>";
echo resultBlock($errors, $successes);
echo "\n<form name='adminUsers' action='" . $_SERVER['PHP_SELF'] . "' method='post'>\n<table class='admin'>\n<tr>\n<th>Delete</th><th>Username</th><th>Display Name</th><th>Title</th><th>Last Sign In</th>\n</tr>";
//Cycle through users
foreach ($userData as $v1) {
    echo "\n\t<tr>\n\t<td><input type='checkbox' name='delete[" . $v1['id'] . "]' id='delete[" . $v1['id'] . "]' value='" . $v1['id'] . "'></td>\n\t<td><a href='admin_user.php?id=" . $v1['id'] . "'>" . $v1['user_name'] . "</a></td>\n\t<td>" . $v1['display_name'] . "</td>\n\t<td>" . $v1['title'] . "</td>\n\t<td>\n\t";
    //Interprety last login
Esempio n. 4
0
        redirectMsg('./users.php?' . $ruta, __('Errors ocurred while trying to update users', 'galleries') . '<br />' . $errors, 1);
        die;
    } else {
        redirectMsg('./users.php?' . $ruta, __('Users updated successfully!', 'galleries'), 0);
        die;
    }
}
$op = rmc_server_var($_REQUEST, 'op', '');
switch ($op) {
    case 'new':
        formUsers();
        break;
    case 'edit':
        formUsers(1);
        break;
    case 'save':
        saveUsers();
        break;
    case 'saveedit':
        saveUsers(1);
        break;
    case 'delete':
        deleteUsers();
        break;
    case 'block':
        blockUsers();
        break;
    default:
        showUsers();
        break;
}
function syncUsers()
{
    global $_CB_database, $_CB_Backend_Title, $ueConfig, $_PLUGINS;
    $_CB_Backend_Title = array(0 => array('fa fa-wrench', CBTxt::T('CB Tools: Synchronize users: Results')));
    // Try extending time, as unziping/ftping took already quite some... :
    @set_time_limit(240);
    $_PLUGINS->loadPluginGroup('user');
    $messages = $_PLUGINS->trigger('onBeforeSyncUser', array(true));
    foreach ($messages as $msg) {
        if ($msg) {
            echo '<div class="form-group cb_form_line clearfix">' . $msg . '</div>';
        }
    }
    // 0a. delete user table for bad rows
    $sql = "DELETE FROM #__users WHERE id = 0";
    $_CB_database->setQuery($sql);
    try {
        $_CB_database->query();
    } catch (RuntimeException $e) {
        print '<div class="form-group cb_form_line clearfix text-danger">' . sprintf(CBTxt::T('SQL error %s'), $e->getMessage()) . '</div>';
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print '<div class="form-group cb_form_line clearfix text-warning">' . sprintf(CBTxt::T('Deleted %s not allowed user id 0 entry.'), $affected) . '</div>';
    }
    // 0b. delete comprofiler table for bad rows
    $sql = "DELETE FROM #__comprofiler WHERE id = 0";
    $_CB_database->setQuery($sql);
    try {
        $_CB_database->query();
    } catch (RuntimeException $e) {
        print '<div class="form-group cb_form_line clearfix text-danger">' . sprintf(CBTxt::T('SQL error %s'), $e->getMessage()) . '</div>';
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print '<div class="form-group cb_form_line clearfix text-warning">' . sprintf(CBTxt::T('Deleted %s not allowed user id 0 entry.'), $affected) . '</div>';
    }
    // 1. add missing comprofiler entries, guessing naming depending on CB's name style:
    switch ($ueConfig['name_style']) {
        case 2:
            // firstname + lastname:
            $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id,lastname,firstname) " . " SELECT id,id, SUBSTRING_INDEX(name,' ',-1), " . "SUBSTRING( name, 1, length( name ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ) " . " FROM #__users";
            break;
        case 3:
            // firstname + middlename + lastname:
            $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id,middlename,lastname,firstname) " . " SELECT id,id,SUBSTRING( name, INSTR( name, ' ' ) +1," . " length( name ) - INSTR( name, ' ' ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 )," . " SUBSTRING_INDEX(name,' ',-1)," . " IF(INSTR(name,' '),SUBSTRING_INDEX( name, ' ', 1 ),'') " . " FROM #__users";
            break;
        default:
            // name only:
            $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id) SELECT id,id FROM #__users";
            break;
    }
    $_CB_database->setQuery($sql);
    try {
        $_CB_database->query();
    } catch (RuntimeException $e) {
        print '<div class="form-group cb_form_line clearfix text-danger">' . sprintf(CBTxt::T('SQL error %s'), $e->getMessage()) . '</div>';
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print '<div class="form-group cb_form_line clearfix text-warning">' . sprintf(CBTxt::T('Added %s new entries to Community Builder from users Table.'), $affected) . '</div>';
    }
    $sql = "UPDATE #__comprofiler SET `user_id`=`id`";
    $_CB_database->setQuery($sql);
    try {
        $_CB_database->query();
    } catch (RuntimeException $e) {
        print '<div class="form-group cb_form_line clearfix text-danger">' . sprintf(CBTxt::T('SQL error %s'), $e->getMessage()) . '</div>';
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print '<div class="form-group cb_form_line clearfix text-warning">' . sprintf(CBTxt::T('Fixed %s existing entries in Community Builder: fixed wrong user_id.'), $affected) . '</div>';
    }
    // 2. remove excessive comprofiler entries (e.g. if admin used mambo/joomla delete user function:
    $sql = "SELECT c.id FROM #__comprofiler c LEFT JOIN #__users u ON u.id = c.id WHERE u.id IS NULL";
    $_CB_database->setQuery($sql);
    try {
        $users = $_CB_database->loadResultArray();
    } catch (RuntimeException $e) {
        print '<div class="form-group cb_form_line clearfix text-danger">' . sprintf(CBTxt::T('SQL error %s'), $e->getMessage()) . '</div>';
        return;
    }
    if (count($users)) {
        print '<div class="form-group cb_form_line clearfix text-warning">' . sprintf(CBTxt::T('Removing %s entries from Community Builder missing in users Table.'), count($users)) . '</div>';
        $msg = deleteUsers($users, true);
        print '<div class="form-group cb_form_line clearfix">' . $msg . '</div>';
    }
    print '<div class="form-group cb_form_line clearfix text-success">' . CBTxt::T('Joomla User Table and Joomla Community Builder User Table now in sync!') . '</div>';
    $messages = $_PLUGINS->trigger('onAfterSyncUser', array(true));
    foreach ($messages as $msg) {
        if ($msg) {
            echo '<div class="form-group cb_form_line clearfix">' . $msg . '</div>';
        }
    }
}
Esempio n. 6
0
 case 15:
     //获取批量用户---不分页(默认返回10个)
     var_dump(getUsers());
     break;
 case 16:
     //获取批量用户----分页
     $cursor = readCursor("userfile.txt");
     var_dump(getUsersForPage(10, $cursor));
     break;
 case 17:
     //删除单个用户
     var_dump(deleteUser("zhangsan"));
     break;
 case 18:
     //删除批量用户
     var_dump(deleteUsers(2));
     break;
 case 19:
     //修改昵称
     var_dump(editNickname("zhangsan", "小A"));
     break;
 case 20:
     //添加好友----
     var_dump(addFriend("zhangsan", "lisi"));
     break;
 case 21:
     //删除好友
     var_dump(deleteFriend("zhangsan", "lisi"));
     break;
 case 22:
     //查看好友
function syncUsers()
{
    global $_CB_database, $ueConfig, $_PLUGINS;
    // Try extending time, as unziping/ftping took already quite some... :
    @set_time_limit(240);
    $_PLUGINS->loadPluginGroup('user');
    $messages = $_PLUGINS->trigger('onBeforeSyncUser', true);
    foreach ($messages as $msg) {
        if ($msg) {
            echo "<p>" . $msg . "</p>";
        }
    }
    // 0a. delete user table for bad rows
    $sql = "DELETE FROM #__users WHERE id = 0";
    $_CB_database->setQuery($sql);
    if (!$_CB_database->query()) {
        print "<font color=red>" . sprintf(CBTxt::T('SQL error %s'), $_CB_database->stderr(true)) . "</font><br />";
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print "<p><font color='orange'>" . sprintf(CBTxt::T('Deleted %s not allowed user id 0 entry.'), $affected) . "</font></p>";
    }
    // 0b. delete comprofiler table for bad rows
    $sql = "DELETE FROM #__comprofiler WHERE id = 0";
    $_CB_database->setQuery($sql);
    if (!$_CB_database->query()) {
        print "<font color=red>" . sprintf(CBTxt::T('SQL error %s'), $_CB_database->stderr(true)) . "</font><br />";
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print "<p><font color='orange'>" . sprintf(CBTxt::T('Deleted %s not allowed user id 0 entry.'), $affected) . "</font></p>";
    }
    // 1. add missing comprofiler entries, guessing naming depending on CB's name style:
    switch ($ueConfig['name_style']) {
        case 2:
            // firstname + lastname:
            $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id,lastname,firstname) " . " SELECT id,id, SUBSTRING_INDEX(name,' ',-1), " . "SUBSTRING( name, 1, length( name ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ) " . " FROM #__users";
            break;
        case 3:
            // firstname + middlename + lastname:
            $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id,middlename,lastname,firstname) " . " SELECT id,id,SUBSTRING( name, INSTR( name, ' ' ) +1," . " length( name ) - INSTR( name, ' ' ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 )," . " SUBSTRING_INDEX(name,' ',-1)," . " IF(INSTR(name,' '),SUBSTRING_INDEX( name, ' ', 1 ),'') " . " FROM #__users";
            break;
        default:
            // name only:
            $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id) SELECT id,id FROM #__users";
            break;
    }
    $_CB_database->setQuery($sql);
    if (!$_CB_database->query()) {
        print "<font color=red>" . sprintf(CBTxt::T('SQL error %s'), $_CB_database->stderr(true)) . "</font><br />";
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print "<p><font color='orange'>" . sprintf(CBTxt::T('Added %s new entries to Community Builder from users Table.'), $affected) . "</font></p>";
    }
    $sql = "UPDATE #__comprofiler SET `user_id`=`id`";
    $_CB_database->setQuery($sql);
    if (!$_CB_database->query()) {
        print "<font color=red>" . sprintf(CBTxt::T('SQL error %s'), $_CB_database->stderr(true)) . "</font><br />";
        return;
    }
    $affected = $_CB_database->getAffectedRows();
    if ($affected) {
        print "<p><font color='orange'>" . sprintf(CBTxt::T('Fixed %s existing entries in Community Builder: fixed wrong user_id.'), $affected) . "</font></p>";
    }
    // 2. remove excessive comprofiler entries (e.g. if admin used mambo/joomla delete user function:
    $sql = "SELECT c.id FROM #__comprofiler c LEFT JOIN #__users u ON u.id = c.id WHERE u.id IS NULL";
    $_CB_database->setQuery($sql);
    $users = $_CB_database->loadResultArray();
    if ($_CB_database->getErrorNum()) {
        print "<font color=red>" . sprintf(CBTxt::T('SQL error %s'), $_CB_database->stderr(true)) . "</font><br />";
        return;
    }
    if (count($users)) {
        print "<p><font color='orange'>" . sprintf(CBTxt::T('Removing %s entries from Community Builder missing in users Table.'), count($users)) . "</font></p>";
        $msg = deleteUsers($users, true);
        print "<p>" . $msg . "</p>";
    }
    print "<font color=green>" . CBTxt::T('Joomla/Mambo User Table and Joomla/Mambo Community Builder User Table now in sync!') . "</font>";
    $messages = $_PLUGINS->trigger('onAfterSyncUser', true);
    foreach ($messages as $msg) {
        if ($msg) {
            echo "<p>" . $msg . "</p>";
        }
    }
}
Esempio n. 8
0
 public function index()
 {
     /*
     UserCake (Via CupCake) Version: 2.0.2
     http://usercake.com
     */
     global $baseURL;
     require_once "{$baseURL}/application/third_party/user_cake/models/config.php";
     if (!securePage($_SERVER['PHP_SELF'])) {
         die;
     }
     $userId = $_GET['id'];
     //Check if selected user exists
     if (!userIdExists($userId)) {
         header("Location: " . str_replace('index.php/', '', site_url('admin_users')));
         die;
     }
     $userdetails = fetchUserDetails(NULL, NULL, $userId);
     //Fetch user details
     //Forms posted
     if (!empty($_POST)) {
         //Delete selected account
         if (!empty($_POST['delete'])) {
             $deletions = $_POST['delete'];
             if ($deletion_count = deleteUsers($deletions)) {
                 $successes[] = lang("ACCOUNT_DELETIONS_SUCCESSFUL", array($deletion_count));
             } else {
                 $errors[] = lang("SQL_ERROR");
             }
         } else {
             //Update display name
             if ($userdetails['display_name'] != $_POST['display']) {
                 $displayname = trim($_POST['display']);
                 //Validate display name
                 if (displayNameExists($displayname)) {
                     $errors[] = lang("ACCOUNT_DISPLAYNAME_IN_USE", array($displayname));
                 } elseif (minMaxRange(5, 25, $displayname)) {
                     $errors[] = lang("ACCOUNT_DISPLAY_CHAR_LIMIT", array(5, 25));
                 } elseif (!ctype_alnum($displayname)) {
                     $errors[] = lang("ACCOUNT_DISPLAY_INVALID_CHARACTERS");
                 } else {
                     if (updateDisplayName($userId, $displayname)) {
                         $successes[] = lang("ACCOUNT_DISPLAYNAME_UPDATED", array($displayname));
                     } else {
                         $errors[] = lang("SQL_ERROR");
                     }
                 }
             } else {
                 $displayname = $userdetails['display_name'];
             }
             //Activate account
             if (isset($_POST['activate']) && $_POST['activate'] == "activate") {
                 if (setUserActive($userdetails['activation_token'])) {
                     $successes[] = lang("ACCOUNT_MANUALLY_ACTIVATED", array($displayname));
                 } else {
                     $errors[] = lang("SQL_ERROR");
                 }
             }
             //Update email
             if ($userdetails['email'] != $_POST['email']) {
                 $email = trim($_POST["email"]);
                 //Validate email
                 if (!isValidEmail($email)) {
                     $errors[] = lang("ACCOUNT_INVALID_EMAIL");
                 } elseif (emailExists($email)) {
                     $errors[] = lang("ACCOUNT_EMAIL_IN_USE", array($email));
                 } else {
                     if (updateEmail($userId, $email)) {
                         $successes[] = lang("ACCOUNT_EMAIL_UPDATED");
                     } else {
                         $errors[] = lang("SQL_ERROR");
                     }
                 }
             }
             //Update title
             if ($userdetails['title'] != $_POST['title']) {
                 $title = trim($_POST['title']);
                 //Validate title
                 if (minMaxRange(1, 50, $title)) {
                     $errors[] = lang("ACCOUNT_TITLE_CHAR_LIMIT", array(1, 50));
                 } else {
                     if (updateTitle($userId, $title)) {
                         $successes[] = lang("ACCOUNT_TITLE_UPDATED", array($displayname, $title));
                     } else {
                         $errors[] = lang("SQL_ERROR");
                     }
                 }
             }
             //Remove permission level
             if (!empty($_POST['removePermission'])) {
                 $remove = $_POST['removePermission'];
                 if ($deletion_count = removePermission($remove, $userId)) {
                     $successes[] = lang("ACCOUNT_PERMISSION_REMOVED", array($deletion_count));
                 } else {
                     $errors[] = lang("SQL_ERROR");
                 }
             }
             if (!empty($_POST['addPermission'])) {
                 $add = $_POST['addPermission'];
                 if ($addition_count = addPermission($add, $userId)) {
                     $successes[] = lang("ACCOUNT_PERMISSION_ADDED", array($addition_count));
                 } else {
                     $errors[] = lang("SQL_ERROR");
                 }
             }
             $userdetails = fetchUserDetails(NULL, NULL, $userId);
         }
     }
     $userPermission = fetchUserPermissions($userId);
     $permissionData = fetchAllPermissions();
     require_once "{$baseURL}/application/third_party/user_cake/models/header.php";
     echo "\r\n<body>\r\n<div id='wrapper'>\r\n<div id='top'><div id='logo'></div></div>\r\n<div id='content'>\r\n<h1>UserCake (Via CupCake)</h1>\r\n<h2>Admin User</h2>\r\n<div id='left-nav'>";
     include "{$baseURL}/application/third_party/user_cake/left-nav.php";
     echo "\r\n</div>\r\n<div id='main'>";
     echo resultBlock($errors, $successes);
     echo "\r\n<form name='adminUser' action='" . $_SERVER['PHP_SELF'] . "?id=" . $userId . "' method='post'>\r\n<table class='admin'><tr><td>\r\n<h3>User Information</h3>\r\n<div id='regbox'>\r\n<p>\r\n<label>ID:</label>\r\n" . $userdetails['id'] . "\r\n</p>\r\n<p>\r\n<label>Username:</label>\r\n" . $userdetails['user_name'] . "\r\n</p>\r\n<p>\r\n<label>Display Name:</label>\r\n<input type='text' name='display' value='" . $userdetails['display_name'] . "' />\r\n</p>\r\n<p>\r\n<label>Email:</label>\r\n<input type='text' name='email' value='" . $userdetails['email'] . "' />\r\n</p>\r\n<p>\r\n<label>Active:</label>";
     //Display activation link, if account inactive
     if ($userdetails['active'] == '1') {
         echo "Yes";
     } else {
         echo "No\r\n\t</p>\r\n\t<p>\r\n\t<label>Activate:</label>\r\n\t<input type='checkbox' name='activate' id='activate' value='activate'>\r\n\t";
     }
     echo "\r\n</p>\r\n<p>\r\n<label>Title:</label>\r\n<input type='text' name='title' value='" . $userdetails['title'] . "' />\r\n</p>\r\n<p>\r\n<label>Sign Up:</label>\r\n" . date("j M, Y", $userdetails['sign_up_stamp']) . "\r\n</p>\r\n<p>\r\n<label>Last Sign In:</label>";
     //Last sign in, interpretation
     if ($userdetails['last_sign_in_stamp'] == '0') {
         echo "Never";
     } else {
         echo date("j M, Y", $userdetails['last_sign_in_stamp']);
     }
     echo "\r\n</p>\r\n<p>\r\n<label>Delete:</label>\r\n<input type='checkbox' name='delete[" . $userdetails['id'] . "]' id='delete[" . $userdetails['id'] . "]' value='" . $userdetails['id'] . "'>\r\n</p>\r\n<p>\r\n<label>&nbsp;</label>\r\n<input type='submit' value='Update' class='submit' />\r\n</p>\r\n</div>\r\n</td>\r\n<td>\r\n<h3>Permission Membership</h3>\r\n<div id='regbox'>\r\n<p>Remove Permission:";
     //List of permission levels user is apart of
     foreach ($permissionData as $v1) {
         if (isset($userPermission[$v1['id']])) {
             echo "<br><input type='checkbox' name='removePermission[" . $v1['id'] . "]' id='removePermission[" . $v1['id'] . "]' value='" . $v1['id'] . "'> " . $v1['name'];
         }
     }
     //List of permission levels user is not apart of
     echo "</p><p>Add Permission:";
     foreach ($permissionData as $v1) {
         if (!isset($userPermission[$v1['id']])) {
             echo "<br><input type='checkbox' name='addPermission[" . $v1['id'] . "]' id='addPermission[" . $v1['id'] . "]' value='" . $v1['id'] . "'> " . $v1['name'];
         }
     }
     echo "\r\n</p>\r\n</div>\r\n</td>\r\n</tr>\r\n</table>\r\n</form>\r\n</div>\r\n<div id='bottom'></div>\r\n</div>\r\n</body>\r\n</html>";
 }