123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 |
- <?php
- /*
- FusionPBX
- Version: MPL 1.1
- The contents of this file are subject to the Mozilla Public License Version
- 1.1 (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
- http://www.mozilla.org/MPL/
- Software distributed under the License is distributed on an "AS IS" basis,
- WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- for the specific language governing rights and limitations under the
- License.
- The Original Code is FusionPBX
- The Initial Developer of the Original Code is
- Mark J Crane <[email protected]>
- Portions created by the Initial Developer are Copyright (C) 2008-2012
- the Initial Developer. All Rights Reserved.
- Contributor(s):
- Mark J Crane <[email protected]>
- */
- include "root.php";
- require_once "includes/require.php";
- require_once "includes/checkauth.php";
- if (if_group("admin") || if_group("superadmin")) {
- //access allowed
- }
- else {
- echo "access denied";
- return;
- }
- $username = check_str($_POST["username"]);
- $password = check_str($_POST["password"]);
- $confirmpassword = check_str($_POST["confirmpassword"]);
- $contact_organization = check_str($_POST["contact_organization"]);
- $contact_name_given = check_str($_POST["contact_name_given"]);
- $contact_name_family = check_str($_POST["contact_name_family"]);
- $user_email = check_str($_POST["user_email"]);
- if (count($_POST)>0 && check_str($_POST["persistform"]) != "1") {
- $msgerror = '';
- //--- begin captcha verification ---------------------
- //session_start(); //make sure sessions are started
- if (strtolower($_SESSION["captcha"]) != strtolower($_REQUEST["captcha"]) || strlen($_SESSION["captcha"]) == 0) {
- //$msgerror .= "Captcha Verification Failed<br>\n";
- }
- else {
- //echo "verified";
- }
- //--- end captcha verification -----------------------
- //username is already used.
- if (strlen($username) == 0) {
- $msgerror .= "Please provide a Username.<br>\n";
- }
- else {
- $sql = "SELECT * FROM v_users ";
- $sql .= "where domain_uuid = '$domain_uuid' ";
- $sql .= "and username = '$username' ";
- $prep_statement = $db->prepare(check_sql($sql));
- $prep_statement->execute();
- if (count($prep_statement->fetchAll(PDO::FETCH_NAMED)) > 0) {
- $msgerror .= "Please choose a different Username.<br>\n";
- }
- }
- if (strlen($password) == 0) { $msgerror .= "Password cannot be blank.<br>\n"; }
- if ($password != $confirmpassword) { $msgerror .= "Passwords did not match.<br>\n"; }
- //if (strlen($contact_organization) == 0) { $msgerror .= "Please provide a organization name.<br>\n"; }
- //if (strlen($contact_name_given) == 0) { $msgerror .= "Please provide a first name.<br>\n"; }
- //if (strlen($contact_name_family) == 0) { $msgerror .= "Please provide a last name $user_last_name.<br>\n"; }
- if (strlen($user_email) == 0) { $msgerror .= "Please provide an email.<br>\n"; }
- if (strlen($msgerror) > 0) {
- require_once "includes/header.php";
- echo "<div align='center'>";
- echo "<table><tr><td>";
- echo $msgerror;
- echo "</td></tr></table>";
- require_once "includes/persistform.php";
- echo persistform($_POST);
- echo "</div>";
- require_once "includes/footer.php";
- return;
- }
- //salt used with the password to create a one way hash
- $salt = generate_password('20', '4');
- //prepare the uuids
- $user_uuid = uuid();
- $contact_uuid = uuid();
- //add the user
- $sql = "insert into v_users ";
- $sql .= "(";
- $sql .= "domain_uuid, ";
- $sql .= "user_uuid, ";
- $sql .= "contact_uuid, ";
- $sql .= "username, ";
- $sql .= "password, ";
- $sql .= "salt, ";
- $sql .= "user_add_date, ";
- $sql .= "user_add_user ";
- $sql .= ") ";
- $sql .= "values ";
- $sql .= "(";
- $sql .= "'$domain_uuid', ";
- $sql .= "'$user_uuid', ";
- $sql .= "'$contact_uuid', ";
- $sql .= "'$username', ";
- $sql .= "'".md5($salt.$password)."', ";
- $sql .= "'".$salt."', ";
- $sql .= "now(), ";
- $sql .= "'".$_SESSION["username"]."' ";
- $sql .= ")";
- $db->exec(check_sql($sql));
- unset($sql);
- //add to contacts
- $sql = "insert into v_contacts ";
- $sql .= "(";
- $sql .= "domain_uuid, ";
- $sql .= "contact_uuid, ";
- $sql .= "contact_type, ";
- $sql .= "contact_organization, ";
- $sql .= "contact_name_given, ";
- $sql .= "contact_name_family, ";
- $sql .= "contact_nickname, ";
- $sql .= "contact_email ";
- $sql .= ") ";
- $sql .= "values ";
- $sql .= "(";
- $sql .= "'$domain_uuid', ";
- $sql .= "'$contact_uuid', ";
- $sql .= "'user', ";
- $sql .= "'$contact_organization', ";
- $sql .= "'$contact_name_given', ";
- $sql .= "'$contact_name_family', ";
- $sql .= "'$username', ";
- $sql .= "'$user_email' ";
- $sql .= ")";
- $db->exec(check_sql($sql));
- unset($sql);
- //log the success
- //$log_type = 'user'; $log_status='add'; $log_add_user=$_SESSION["username"]; $log_desc= "username: ".$username." user added.";
- //log_add($db, $log_type, $log_status, $log_desc, $log_add_user, $_SERVER["REMOTE_ADDR"]);
- $group_name = 'user';
- $sql = "insert into v_group_users ";
- $sql .= "(";
- $sql .= "group_user_uuid, ";
- $sql .= "domain_uuid, ";
- $sql .= "group_name, ";
- $sql .= "user_uuid ";
- $sql .= ")";
- $sql .= "values ";
- $sql .= "(";
- $sql .= "'".uuid()."', ";
- $sql .= "'$domain_uuid', ";
- $sql .= "'$group_name', ";
- $sql .= "'$user_uuid' ";
- $sql .= ")";
- $db->exec(check_sql($sql));
- unset($sql);
- require_once "includes/header.php";
- echo "<meta http-equiv=\"refresh\" content=\"3;url=index.php\">\n";
- echo "<div align='center'>Add Complete</div>";
- require_once "includes/footer.php";
- return;
- }
- //show the header
- require_once "includes/header.php";
- //show the content
- echo "<div align='center'>";
- echo "<table width='100%' border='0' cellpadding='0' cellspacing='2'>\n";
- echo "<tr>\n";
- echo " <td align=\"left\">\n";
- echo " <br>";
- $tablewidth ='width="100%"';
- echo "<form method='post' action=''>";
- echo "<div class='borderlight' style='padding:10px;'>\n";
- echo "<table border='0' $tablewidth cellpadding='6' cellspacing='0'>";
- echo " <tr>\n";
- echo " <td width='80%'>\n";
- echo " <b>To add a user, please fill out this form completely. All fields are required. </b><br>";
- echo " </td>\n";
- echo " <td width='20%' align='right'>\n";
- echo " <input type='button' class='btn' name='back' alt='back' onclick=\"window.history.back()\" value='Back'>\n";
- echo " </td>\n";
- echo " </tr>\n";
- echo "</table>\n";
- echo "<table border='0' $tablewidth cellpadding='6' cellspacing='0'>";
- echo " <tr>";
- echo " <td class='vncellreq' width='40%'>Username:</td>";
- echo " <td class='vtable' width='60%'><input type='text' class='formfld' autocomplete='off' name='username' value='$username'></td>";
- echo " </tr>";
- echo " <tr>";
- echo " <td class='vncellreq'>Password:</td>";
- echo " <td class='vtable'><input type='password' class='formfld' autocomplete='off' name='password' value='$password'></td>";
- echo " </tr>";
- echo " <tr>";
- echo " <td class='vncellreq'>Confirm Password:</td>";
- echo " <td class='vtable'><input type='password' class='formfld' autocomplete='off' name='confirmpassword' value='$confirmpassword'></td>";
- echo " </tr>";
- echo " <tr>";
- echo " <td class='vncellreq'>Email:</td>";
- echo " <td class='vtable'><input type='text' class='formfld' name='user_email' value='$user_email'></td>";
- echo " </tr>";
- echo " <tr>";
- echo " <td class='vncell'>First Name:</td>";
- echo " <td class='vtable'><input type='text' class='formfld' name='contact_name_given' value='$contact_name_given'></td>";
- echo " </tr>";
- echo " <tr>";
- echo " <td class='vncell'>Last Name:</td>";
- echo " <td class='vtable'><input type='text' class='formfld' name='contact_name_family' value='$contact_name_family'></td>";
- echo " </tr>";
- echo " <tr>";
- echo " <td class='vncell'>Company Name:</td>";
- echo " <td class='vtable'><input type='text' class='formfld' name='contact_organization' value='$contact_organization'></td>";
- echo " </tr>";
- echo "</table>";
- echo "</div>";
- echo "<div class='' style='padding:10px;'>\n";
- echo "<table $tablewidth>";
- echo " <tr>";
- echo " <td colspan='2' align='right'>";
- echo " <input type='submit' name='submit' class='btn' value='Create Account'>";
- echo " </td>";
- echo " </tr>";
- echo "</table>";
- echo "</form>";
- echo " </td>";
- echo " </tr>";
- echo "</table>";
- echo "</div>";
- //show the footer
- require_once "includes/footer.php";
- ?>
|