mirror of
https://github.com/wheelybird/ldap-user-manager.git
synced 2025-01-18 15:32:54 +01:00
ce92321285
* New user - Remove accents/diacritics from Username and Email while typing * .gitignore added * custom logo firts commit * relative path to image * relative path adjusted * bootstrap update to v.4.3.1 * Revert "bootstrap update to v.4.3.1" This reverts commit 62792e4136dabe357fab8f09defb13388f023bf6. * modified header inline blocks * span fix * hardcoded logo * hardcoded logo - style fix * hardcoded logo - style fix #2 * IMG element * modified IMG * modified IMG #2 * modified IMG #3 * adding custom styles * custom styles used * Update README.md Website logo and styles customisation * Update README.md typo... --------- Co-authored-by: Martin Švec <martin.svec@slovenskoit.sk>
739 lines
23 KiB
PHP
739 lines
23 KiB
PHP
<?php
|
|
#Security level vars
|
|
|
|
$VALIDATED = FALSE;
|
|
$IS_ADMIN = FALSE;
|
|
$IS_SETUP_ADMIN = FALSE;
|
|
$ACCESS_LEVEL_NAME = array('account','admin');
|
|
unset($USER_ID);
|
|
$CURRENT_PAGE=htmlentities($_SERVER['PHP_SELF']);
|
|
$SENT_HEADERS = FALSE;
|
|
$SESSION_TIMED_OUT = FALSE;
|
|
|
|
$paths=explode('/',getcwd());
|
|
$THIS_MODULE=end($paths);
|
|
|
|
$GOOD_ICON = "☑";
|
|
$WARN_ICON = "⚠";
|
|
$FAIL_ICON = "⛔";
|
|
|
|
$JS_EMAIL_REGEX='/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;';
|
|
|
|
if (isset($_SERVER['HTTPS']) and
|
|
($_SERVER['HTTPS'] == 'on' || $_SERVER['HTTPS'] == 1) or
|
|
isset($_SERVER['HTTP_X_FORWARDED_PROTO']) and
|
|
$_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') {
|
|
$SITE_PROTOCOL = 'https://';
|
|
}
|
|
else {
|
|
$SITE_PROTOCOL = 'http://';
|
|
}
|
|
|
|
include ("config.inc.php"); # get local settings
|
|
include ("modules.inc.php"); # module definitions
|
|
|
|
if (substr($SERVER_PATH, -1) != "/") { $SERVER_PATH .= "/"; }
|
|
$THIS_MODULE_PATH="{$SERVER_PATH}{$THIS_MODULE}";
|
|
|
|
$DEFAULT_COOKIE_OPTIONS = array( 'expires' => time()+(60 * $SESSION_TIMEOUT),
|
|
'path' => $SERVER_PATH,
|
|
'domain' => '',
|
|
'secure' => $NO_HTTPS ? FALSE : TRUE,
|
|
'samesite' => 'strict'
|
|
);
|
|
|
|
if ($REMOTE_HTTP_HEADERS_LOGIN) {
|
|
login_via_headers();
|
|
} else {
|
|
validate_passkey_cookie();
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function generate_passkey() {
|
|
|
|
$rnd1 = mt_rand(10000000, mt_getrandmax());
|
|
$rnd2 = mt_rand(10000000, mt_getrandmax());
|
|
$rnd3 = mt_rand(10000000, mt_getrandmax());
|
|
return sprintf("%0x",$rnd1) . sprintf("%0x",$rnd2) . sprintf("%0x",$rnd3);
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function set_passkey_cookie($user_id,$is_admin) {
|
|
|
|
# Create a random value, store it locally and set it in a cookie.
|
|
|
|
global $SESSION_TIMEOUT, $VALIDATED, $USER_ID, $IS_ADMIN, $log_prefix, $SESSION_DEBUG, $DEFAULT_COOKIE_OPTIONS;
|
|
|
|
|
|
$passkey = generate_passkey();
|
|
$this_time=time();
|
|
$admin_val = 0;
|
|
|
|
if ($is_admin == TRUE ) {
|
|
$admin_val = 1;
|
|
$IS_ADMIN = TRUE;
|
|
}
|
|
$filename = preg_replace('/[^a-zA-Z0-9]/','_', $user_id);
|
|
@ file_put_contents("/tmp/$filename","$passkey:$admin_val:$this_time");
|
|
setcookie('orf_cookie', "$user_id:$passkey", $DEFAULT_COOKIE_OPTIONS);
|
|
$sessto_cookie_opts = $DEFAULT_COOKIE_OPTIONS;
|
|
$sessto_cookie_opts['expires'] = $this_time+7200;
|
|
setcookie('sessto_cookie', $this_time+(60 * $SESSION_TIMEOUT), $sessto_cookie_opts);
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: user $user_id validated (IS_ADMIN={$IS_ADMIN}), sent orf_cookie to the browser.",0); }
|
|
$VALIDATED = TRUE;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function login_via_headers() {
|
|
|
|
global $IS_ADMIN, $USER_ID, $VALIDATED, $LDAP;
|
|
//['admins_group'];
|
|
$USER_ID = $_SERVER['HTTP_REMOTE_USER'];
|
|
$remote_groups = explode(',',$_SERVER['HTTP_REMOTE_GROUPS']);
|
|
$IS_ADMIN = in_array($LDAP['admins_group'],$remote_groups);
|
|
// users are always validated as we assume, that the auth server does this
|
|
$VALIDATED = true;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function validate_passkey_cookie() {
|
|
|
|
global $SESSION_TIMEOUT, $IS_ADMIN, $USER_ID, $VALIDATED, $log_prefix, $SESSION_TIMED_OUT, $SESSION_DEBUG;
|
|
|
|
$this_time=time();
|
|
$VALIDATED = FALSE;
|
|
$IS_ADMIN = FALSE;
|
|
|
|
if (isset($_COOKIE['orf_cookie'])) {
|
|
|
|
list($user_id,$c_passkey) = explode(":",$_COOKIE['orf_cookie']);
|
|
$filename = preg_replace('/[^a-zA-Z0-9]/','_', $user_id);
|
|
$session_file = @ file_get_contents("/tmp/$filename");
|
|
if (!$session_file) {
|
|
if ($SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: orf_cookie was sent by the client but the session file wasn't found at /tmp/$filename",0); }
|
|
}
|
|
else {
|
|
list($f_passkey,$f_is_admin,$f_time) = explode(":",$session_file);
|
|
if (!empty($c_passkey) and $f_passkey == $c_passkey and $this_time < $f_time+(60 * $SESSION_TIMEOUT)) {
|
|
if ($f_is_admin == 1) { $IS_ADMIN = TRUE; }
|
|
$VALIDATED = TRUE;
|
|
$USER_ID=$user_id;
|
|
if ($SESSION_DEBUG == TRUE) { error_log("$log_prefix Setup session: Cookie and session file values match for user {$user_id} - VALIDATED (ADMIN = {$IS_ADMIN})",0); }
|
|
set_passkey_cookie($USER_ID,$IS_ADMIN);
|
|
}
|
|
else {
|
|
if ($SESSION_DEBUG == TRUE) {
|
|
$this_error="$log_prefix Session: orf_cookie was sent by the client and the session file was found at /tmp/$filename, but";
|
|
if (empty($c_passkey)) { $this_error .= " the cookie passkey wasn't set;"; }
|
|
if ($c_passkey != $f_passkey) { $this_error .= " the session file passkey didn't match the cookie passkey;"; }
|
|
$this_error.=" Cookie: {$_COOKIE['orf_cookie']} - Session file contents: $session_file";
|
|
error_log($this_error,0);
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
else {
|
|
if ($SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: orf_cookie wasn't sent by the client.",0); }
|
|
if (isset($_COOKIE['sessto_cookie'])) {
|
|
$this_session_timeout = $_COOKIE['sessto_cookie'];
|
|
if ($this_time >= $this_session_timeout) {
|
|
$SESSION_TIMED_OUT = TRUE;
|
|
if ($SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: The session had timed-out (over $SESSION_TIMEOUT mins idle).",0); }
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function set_setup_cookie() {
|
|
|
|
# Create a random value, store it locally and set it in a cookie.
|
|
|
|
global $SESSION_TIMEOUT, $IS_SETUP_ADMIN, $log_prefix, $SESSION_DEBUG, $DEFAULT_COOKIE_OPTIONS;
|
|
|
|
$passkey = generate_passkey();
|
|
$this_time=time();
|
|
|
|
$IS_SETUP_ADMIN = TRUE;
|
|
|
|
@ file_put_contents("/tmp/ldap_setup","$passkey:$this_time");
|
|
|
|
setcookie('setup_cookie', $passkey, $DEFAULT_COOKIE_OPTIONS);
|
|
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Setup session: sent setup_cookie to the client.",0); }
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function validate_setup_cookie() {
|
|
|
|
global $SESSION_TIMEOUT, $IS_SETUP_ADMIN, $log_prefix, $SESSION_DEBUG;
|
|
|
|
if (isset($_COOKIE['setup_cookie'])) {
|
|
|
|
$c_passkey = $_COOKIE['setup_cookie'];
|
|
$session_file = file_get_contents("/tmp/ldap_setup");
|
|
if (!$session_file) {
|
|
$IS_SETUP_ADMIN = FALSE;
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Setup session: setup_cookie was sent by the client but the session file wasn't found at /tmp/ldap_setup",0); }
|
|
}
|
|
list($f_passkey,$f_time) = explode(":",$session_file);
|
|
$this_time=time();
|
|
if (!empty($c_passkey) and $f_passkey == $c_passkey and $this_time < $f_time+(60 * $SESSION_TIMEOUT)) {
|
|
$IS_SETUP_ADMIN = TRUE;
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Setup session: Cookie and session file values match - VALIDATED ",0); }
|
|
set_setup_cookie();
|
|
}
|
|
elseif ( $SESSION_DEBUG == TRUE) {
|
|
$this_error="$log_prefix Setup session: setup_cookie was sent by the client and the session file was found at /tmp/ldap_setup, but";
|
|
if (empty($c_passkey)) { $this_error .= " the cookie passkey wasn't set;"; }
|
|
if ($c_passkey != $f_passkey) { $this_error .= " the session file passkey didn't match the cookie passkey;"; }
|
|
$this_error += " Cookie: {$_COOKIE['setup_cookie']} - Session file contents: $session_file";
|
|
error_log($this_error,0);
|
|
}
|
|
}
|
|
elseif ( $SESSION_DEBUG == TRUE) {
|
|
error_log("$log_prefix Session: setup_cookie wasn't sent by the client.",0);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function log_out($method='normal') {
|
|
|
|
# Delete the passkey from the database and the passkey cookie
|
|
|
|
global $USER_ID, $SERVER_PATH, $DEFAULT_COOKIE_OPTIONS;
|
|
|
|
$this_time=time();
|
|
|
|
$orf_cookie_opts = $DEFAULT_COOKIE_OPTIONS;
|
|
$orf_cookie_opts['expires'] = $this_time-20000;
|
|
$sessto_cookie_opts = $DEFAULT_COOKIE_OPTIONS;
|
|
$sessto_cookie_opts['expires'] = $this_time-20000;
|
|
|
|
setcookie('orf_cookie', "", $DEFAULT_COOKIE_OPTIONS);
|
|
setcookie('sessto_cookie', "", $DEFAULT_COOKIE_OPTIONS);
|
|
|
|
$filename = preg_replace('/[^a-zA-Z0-9]/','_', $USER_ID);
|
|
@ unlink("/tmp/$filename");
|
|
|
|
if ($method == 'auto') { $options = "?logged_out"; } else { $options = ""; }
|
|
header("Location: //{$_SERVER["HTTP_HOST"]}{$SERVER_PATH}index.php$options\n\n");
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_header($title="",$menu=TRUE) {
|
|
|
|
global $SITE_NAME, $IS_ADMIN, $SENT_HEADERS, $SERVER_PATH, $CUSTOM_STYLES;
|
|
|
|
if (empty($title)) { $title = $SITE_NAME; }
|
|
|
|
#Initialise the HTML output for the page.
|
|
|
|
?>
|
|
<HTML>
|
|
<HEAD>
|
|
<TITLE><?php print "$title"; ?></TITLE>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<link rel="stylesheet" href="<?php print $SERVER_PATH; ?>bootstrap/css/bootstrap.min.css">
|
|
<?php if ($CUSTOM_STYLES) echo '<link rel="stylesheet" href="'.$CUSTOM_STYLES.'">' ?>
|
|
<script src="<?php print $SERVER_PATH; ?>js/jquery-3.6.0.min.js"></script>
|
|
<script src="<?php print $SERVER_PATH; ?>bootstrap/js/bootstrap.min.js"></script>
|
|
</HEAD>
|
|
<BODY>
|
|
<?php
|
|
|
|
if ($menu == TRUE) {
|
|
render_menu();
|
|
}
|
|
|
|
if (isset($_GET['logged_in'])) {
|
|
|
|
?>
|
|
<script>
|
|
window.setTimeout(function() { $(".alert").fadeTo(500, 0).slideUp(500, function(){ $(this).remove(); }); }, 10000);
|
|
</script>
|
|
<div class="alert alert-success">
|
|
<button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="TRUE">×</span></button>
|
|
<p class="text-center">You've logged in successfully.</p>
|
|
</div>
|
|
<?php
|
|
|
|
}
|
|
$SENT_HEADERS = TRUE;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_menu() {
|
|
|
|
#Render the navigation menu.
|
|
#The menu is dynamically rendered the $MODULES hash
|
|
|
|
global $SITE_NAME, $MODULES, $THIS_MODULE, $VALIDATED, $IS_ADMIN, $USER_ID, $SERVER_PATH, $CUSTOM_LOGO;
|
|
|
|
?>
|
|
<nav class="navbar navbar-default">
|
|
<div class="container-fluid">
|
|
<div class="navbar-header"><?php
|
|
if ($CUSTOM_LOGO) echo '<span class="navbar-brand"><img src="'.$CUSTOM_LOGO.'" class="logo" alt="logo"></span>'
|
|
?><a class="navbar-brand" href="./"><?php print $SITE_NAME ?></a>
|
|
</div>
|
|
<ul class="nav navbar-nav">
|
|
<?php
|
|
foreach ($MODULES as $module => $access) {
|
|
|
|
$this_module_name=stripslashes(ucwords(preg_replace('/_/',' ',$module)));
|
|
|
|
$show_this_module = TRUE;
|
|
if ($VALIDATED == TRUE) {
|
|
if ($access == 'hidden_on_login') { $show_this_module = FALSE; }
|
|
if ($IS_ADMIN == FALSE and $access == 'admin' ){ $show_this_module = FALSE; }
|
|
}
|
|
else {
|
|
if ($access != 'hidden_on_login') { $show_this_module = FALSE; }
|
|
}
|
|
#print "<p>$module - access is $access & show is $show_this_module</p>";
|
|
if ($show_this_module == TRUE ) {
|
|
if ($module == $THIS_MODULE) {
|
|
print "<li class='active'>";
|
|
}
|
|
else {
|
|
print '<li>';
|
|
}
|
|
print "<a href='{$SERVER_PATH}{$module}/'>$this_module_name</a></li>\n";
|
|
}
|
|
}
|
|
?>
|
|
</ul>
|
|
<ul class="nav navbar-nav navbar-right">
|
|
<li><a style="color:#333"><?php if(isset($USER_ID)) { print $USER_ID; } ?></a></li>
|
|
</ul>
|
|
</div>
|
|
</nav>
|
|
<?php
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_footer() {
|
|
|
|
#Finish rendering an HTML page.
|
|
|
|
?>
|
|
</BODY>
|
|
</HTML>
|
|
<?php
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function set_page_access($level) {
|
|
|
|
global $IS_ADMIN, $IS_SETUP_ADMIN, $VALIDATED, $log_prefix, $SESSION_DEBUG, $SESSION_TIMED_OUT, $SERVER_PATH;
|
|
|
|
#Set the security level needed to view a page.
|
|
#This should be one of the first pieces of code
|
|
#you call on a page.
|
|
#Either 'setup', 'admin' or 'user'.
|
|
|
|
if ($level == "setup") {
|
|
if ($IS_SETUP_ADMIN == TRUE) {
|
|
return;
|
|
}
|
|
else {
|
|
header("Location: //" . $_SERVER["HTTP_HOST"] . "{$SERVER_PATH}setup/index.php?unauthorised\n\n");
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: UNAUTHORISED: page security level is 'setup' but IS_SETUP_ADMIN isn't TRUE",0); }
|
|
exit(0);
|
|
}
|
|
}
|
|
|
|
if ($SESSION_TIMED_OUT == TRUE) { $reason = "session_timeout"; } else { $reason = "unauthorised"; }
|
|
|
|
if ($level == "admin") {
|
|
if ($IS_ADMIN == TRUE and $VALIDATED == TRUE) {
|
|
return;
|
|
}
|
|
else {
|
|
header("Location: //" . $_SERVER["HTTP_HOST"] . "{$SERVER_PATH}log_in/index.php?$reason&redirect_to=" . base64_encode($_SERVER['REQUEST_URI']) . "\n\n");
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: no access to page ($reason): page security level is 'admin' but IS_ADMIN = '{$IS_ADMIN}' and VALIDATED = '{$VALIDATED}' (user) ",0); }
|
|
exit(0);
|
|
}
|
|
}
|
|
|
|
if ($level == "user") {
|
|
if ($VALIDATED == TRUE){
|
|
return;
|
|
}
|
|
else {
|
|
header("Location: //" . $_SERVER["HTTP_HOST"] . "{$SERVER_PATH}log_in/index.php?$reason&redirect_to=" . base64_encode($_SERVER['REQUEST_URI']) . "\n\n");
|
|
if ( $SESSION_DEBUG == TRUE) { error_log("$log_prefix Session: no access to page ($reason): page security level is 'user' but VALIDATED = '{$VALIDATED}'",0); }
|
|
exit(0);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function is_valid_email($email) {
|
|
|
|
return (!filter_var($email, FILTER_VALIDATE_EMAIL)) ? FALSE : TRUE;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_js_username_check(){
|
|
|
|
global $USERNAME_REGEX, $ENFORCE_SAFE_SYSTEM_NAMES;
|
|
|
|
if ($ENFORCE_SAFE_SYSTEM_NAMES == TRUE) {
|
|
|
|
print <<<EoCheckJS
|
|
<script>
|
|
|
|
function check_entity_name_validity(name,div_id) {
|
|
|
|
var check_regex = /$USERNAME_REGEX/;
|
|
|
|
if (! check_regex.test(name) ) {
|
|
document.getElementById(div_id).classList.add("has-error");
|
|
}
|
|
else {
|
|
document.getElementById(div_id).classList.remove("has-error");
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
EoCheckJS;
|
|
}
|
|
else {
|
|
print "<script> function check_entity_name_validity(name,div_id) {} </script>";
|
|
}
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function generate_username($fn,$ln) {
|
|
|
|
global $USERNAME_FORMAT;
|
|
|
|
$username = $USERNAME_FORMAT;
|
|
$username = str_replace('{first_name}',strtolower($fn), $username);
|
|
$username = str_replace('{first_name_initial}',strtolower($fn[0]), $username);
|
|
$username = str_replace('{last_name}',strtolower($ln), $username);
|
|
$username = str_replace('{last_name_initial}',strtolower($ln[0]), $username);
|
|
|
|
return $username;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_js_username_generator($firstname_field_id,$lastname_field_id,$username_field_id,$username_div_id) {
|
|
|
|
#Parameters are the IDs of the input fields and username name div in the account creation form.
|
|
#The div will be set to warning if the username is invalid.
|
|
|
|
global $USERNAME_FORMAT, $ENFORCE_SAFE_SYSTEM_NAMES;
|
|
|
|
$remove_accents="";
|
|
if ($ENFORCE_SAFE_SYSTEM_NAMES == TRUE) { $remove_accents = ".normalize('NFD').replace(/[\u0300-\u036f]/g, '')"; }
|
|
|
|
print <<<EoRenderJS
|
|
|
|
<script>
|
|
function update_username() {
|
|
|
|
var first_name = document.getElementById('$firstname_field_id').value;
|
|
var last_name = document.getElementById('$lastname_field_id').value;
|
|
var template = '$USERNAME_FORMAT';
|
|
|
|
var actual_username = template;
|
|
|
|
actual_username = actual_username.replace('{first_name}', first_name.toLowerCase()$remove_accents );
|
|
actual_username = actual_username.replace('{first_name_initial}', first_name.charAt(0).toLowerCase()$remove_accents );
|
|
actual_username = actual_username.replace('{last_name}', last_name.toLowerCase()$remove_accents );
|
|
actual_username = actual_username.replace('{last_name_initial}', last_name.charAt(0).toLowerCase()$remove_accents );
|
|
|
|
check_entity_name_validity(actual_username,'$username_div_id');
|
|
|
|
document.getElementById('$username_field_id').value = actual_username;
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
EoRenderJS;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_js_cn_generator($firstname_field_id,$lastname_field_id,$cn_field_id,$cn_div_id) {
|
|
|
|
global $ENFORCE_SAFE_SYSTEM_NAMES;
|
|
|
|
if ($ENFORCE_SAFE_SYSTEM_NAMES == TRUE) {
|
|
$gen_js = "first_name.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '') + last_name.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '')";
|
|
}
|
|
else {
|
|
$gen_js = "first_name + ' ' + last_name";
|
|
}
|
|
|
|
print <<<EoRenderCNJS
|
|
<script>
|
|
|
|
var auto_cn_update = true;
|
|
|
|
function update_cn() {
|
|
|
|
if ( auto_cn_update == true ) {
|
|
var first_name = document.getElementById('$firstname_field_id').value;
|
|
var last_name = document.getElementById('$lastname_field_id').value;
|
|
this_cn = $gen_js;
|
|
|
|
check_entity_name_validity(this_cn,'$cn_div_id');
|
|
|
|
document.getElementById('$cn_field_id').value = this_cn;
|
|
}
|
|
|
|
}
|
|
</script>
|
|
|
|
EoRenderCNJS;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_js_email_generator($username_field_id,$email_field_id) {
|
|
|
|
global $EMAIL_DOMAIN;
|
|
|
|
print <<<EoRenderEmailJS
|
|
<script>
|
|
|
|
var auto_email_update = true;
|
|
|
|
function update_email() {
|
|
|
|
if ( auto_email_update == true && "$EMAIL_DOMAIN" != "" ) {
|
|
var username = document.getElementById('$username_field_id').value;
|
|
document.getElementById('$email_field_id').value = username + '@' + "$EMAIL_DOMAIN";
|
|
}
|
|
|
|
}
|
|
</script>
|
|
|
|
EoRenderEmailJS;
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_js_homedir_generator($username_field_id,$homedir_field_id) {
|
|
|
|
print <<<EoRenderHomedirJS
|
|
<script>
|
|
|
|
var auto_homedir_update = true;
|
|
|
|
function update_homedir() {
|
|
|
|
if ( auto_homedir_update == true ) {
|
|
var username = document.getElementById('$username_field_id').value;
|
|
document.getElementById('$homedir_field_id').value = "/home/" + username;
|
|
}
|
|
|
|
}
|
|
</script>
|
|
|
|
EoRenderHomedirJS;
|
|
|
|
}
|
|
|
|
######################################################
|
|
|
|
function render_dynamic_field_js() {
|
|
|
|
?>
|
|
<script>
|
|
|
|
function add_field_to(attribute_name,value=null) {
|
|
|
|
var parent = document.getElementById(attribute_name + '_input_div');
|
|
var input_div = document.createElement('div');
|
|
|
|
window[attribute_name + '_count'] = (window[attribute_name + '_count'] === undefined) ? 1 : window[attribute_name + '_count'] + 1;
|
|
var input_field_id = attribute_name + window[attribute_name + '_count'];
|
|
var input_div_id = 'div' + '_' + input_field_id;
|
|
|
|
input_div.className = 'input-group';
|
|
input_div.id = input_div_id;
|
|
|
|
parent.appendChild(input_div);
|
|
|
|
var input_field = document.createElement('input');
|
|
input_field.type = 'text';
|
|
input_field.className = 'form-control';
|
|
input_field.id = input_field_id;
|
|
input_field.name = attribute_name + '[]';
|
|
input_field.value = value;
|
|
|
|
var button_span = document.createElement('span');
|
|
button_span.className = 'input-group-btn';
|
|
|
|
var remove_button = document.createElement('button');
|
|
remove_button.type = 'button';
|
|
remove_button.className = 'btn btn-default';
|
|
remove_button.onclick = function() { var div_to_remove = document.getElementById(input_div_id); div_to_remove.innerHTML = ""; }
|
|
remove_button.innerHTML = '-';
|
|
|
|
input_div.appendChild(input_field);
|
|
input_div.appendChild(button_span);
|
|
button_span.appendChild(remove_button);
|
|
|
|
}
|
|
|
|
</script>
|
|
<?php
|
|
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_attribute_fields($attribute,$label,$values_r,$resource_identifier,$onkeyup="",$inputtype="",$tabindex=null) {
|
|
|
|
global $THIS_MODULE_PATH;
|
|
|
|
?>
|
|
|
|
<div class="form-group" id="<?php print $attribute; ?>_div">
|
|
|
|
<label for="<?php print $attribute; ?>" class="col-sm-3 control-label"><?php print $label; ?></label>
|
|
<div class="col-sm-6" id="<?php print $attribute; ?>_input_div">
|
|
<?php if($inputtype == "multipleinput") {
|
|
?><div class="input-group">
|
|
<input type="text" class="form-control" id="<?php print $attribute; ?>" name="<?php print $attribute; ?>[]" value="<?php if (isset($values_r[0])) { print $values_r[0]; } ?>">
|
|
<div class="input-group-btn"><button type="button" class="btn btn-default" onclick="add_field_to('<?php print $attribute; ?>')">+</i></button></div>
|
|
</div>
|
|
<?php
|
|
if (isset($values_r['count']) and $values_r['count'] > 0) {
|
|
unset($values_r['count']);
|
|
$remaining_values = array_slice($values_r, 1);
|
|
print "<script>";
|
|
foreach($remaining_values as $this_value) { print "add_field_to('$attribute','$this_value');"; }
|
|
print "</script>";
|
|
}
|
|
}
|
|
elseif ($inputtype == "binary") {
|
|
$button_text="Browse";
|
|
$file_button_action="disabled";
|
|
$description="Select a file to upload";
|
|
$mimetype="";
|
|
|
|
if (isset($values_r[0])) {
|
|
$this_file_info = new finfo(FILEINFO_MIME_TYPE);
|
|
$mimetype = $this_file_info->buffer($values_r[0]);
|
|
if (strlen($mimetype) > 23) { $mimetype = substr($mimetype,0,19) . "..."; }
|
|
$description="Download $mimetype file (" . human_readable_filesize(strlen($values_r[0])) . ")";
|
|
$button_text="Replace file";
|
|
if ($resource_identifier != "") {
|
|
$this_url="//{$_SERVER['HTTP_HOST']}{$THIS_MODULE_PATH}/download.php?resource_identifier={$resource_identifier}&attribute={$attribute}";
|
|
$file_button_action="onclick=\"window.open('$this_url','_blank');\"";
|
|
}
|
|
}
|
|
if ($mimetype == "image/jpeg") {
|
|
$this_image = base64_encode($values_r[0]);
|
|
print "<img class='img-thumbnail' src='data:image/jpeg;base64,$this_image'>";
|
|
$description="";
|
|
}
|
|
else {
|
|
?>
|
|
<button type="button" <?php print $file_button_action; ?> class="btn btn-default" id="<?php print $attribute; ?>-file-info"><?php print $description; ?></button>
|
|
<?php } ?>
|
|
<label class="btn btn-default">
|
|
<?php print $button_text; ?><input <?php if (isset($tabindex)) { ?>tabindex="<?php print $tabindex; ?>" <?php } ?>type="file" style="display:none" onchange="$('#<?php print $attribute; ?>-file-info').text(this.files[0].name)" id="<?php print $attribute; ?>" name="<?php print $attribute; ?>">
|
|
</label>
|
|
<?php
|
|
}
|
|
else { ?>
|
|
<input <?php if (isset($tabindex)) { ?>tabindex="<?php print $tabindex; ?>" <?php } ?>type="text" class="form-control" id="<?php print $attribute; ?>" name="<?php print $attribute; ?>" value="<?php if (isset($values_r[0])) { print $values_r[0]; } ?>" <?php if ($onkeyup != "") { print "onkeyup=\"$onkeyup\""; } ?>>
|
|
<?php
|
|
}
|
|
?>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<?php
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function human_readable_filesize($bytes) {
|
|
for($i = 0; ($bytes / 1024) > 0.9; $i++, $bytes /= 1024) {}
|
|
return round($bytes, [0,0,1,2,2,3,3,4,4][$i]).['B','kB','MB','GB','TB','PB','EB','ZB','YB'][$i];
|
|
}
|
|
|
|
|
|
######################################################
|
|
|
|
function render_alert_banner($message,$alert_class="success",$timeout=4000) {
|
|
|
|
?>
|
|
<script>window.setTimeout(function() {$(".alert").fadeTo(500, 0).slideUp(500, function(){ $(this).remove(); }); }, $<?php print $timeout; ?>);</script>
|
|
<div class="alert alert-<?php print $alert_class; ?>" role="alert">
|
|
<button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="TRUE">×</span></button>
|
|
<p class="text-center"><?php print $message; ?></p>
|
|
</div>
|
|
<?php
|
|
}
|
|
|
|
|
|
##EoFile
|
|
?>
|