blash/modules/users/users.php

222 lines
4.6 KiB
PHP
Raw Normal View History

2010-12-25 13:27:38 +01:00
<?php
include 'userlist.php';
include 'user_utils.php';
2010-12-26 18:08:43 +01:00
2010-12-30 23:05:42 +01:00
global $sudo_cmd;
2010-12-25 13:27:38 +01:00
$action = $_REQUEST['action'];
if ( $action == null )
{
die ("");
}
switch ( $action )
{
case 'add':
$username = $_REQUEST['user'];
$password = $_REQUEST['pass'];
if ( !( $username != null && $password != null ))
{
die ("");
}
if ( preg_match ( '/[^a-zA-Z0-9_]/', $username ))
{
print "The username can only contain characters in the charset '[a-zA-Z0-9_]'\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 13:27:38 +01:00
}
2010-12-30 23:05:42 +01:00
if ( preg_match ( '/[^a-fA-F0-9]/', $password ) || strlen ( $password ) != 32 )
2010-12-25 13:27:38 +01:00
{
2010-12-25 21:52:37 +01:00
print "The provided password is not a valid hash\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 13:27:38 +01:00
}
if ( !( $xml = new SimpleXMLElement ( $xmlcontent )))
{
print "Unable to open the users XML file\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 13:27:38 +01:00
}
for ( $i = 0; $i < count ( $xml->user ); $i++ )
{
if ( !strcasecmp ( $xml->user[$i]['name'], $username ))
{
print "The specified user already exists\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 13:27:38 +01:00
}
}
$newuser = $xml->addChild ( 'user' );
$newuser->addAttribute ( 'name', $username );
$newuser->addAttribute ( 'pass', $password );
$newuser->addAttribute ( 'home', '/home/' . $username );
if ( !( $fp = fopen ( 'userlist.php', 'w' )))
{
print "Unable to add the specified user, unknown error\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 13:27:38 +01:00
}
fwrite ( $fp, '<?php'."\n\n".'$xmlcontent = <<<XML'."\n" . $xml->asXML() . "\nXML;\n\n?>\n" );
2010-12-25 13:27:38 +01:00
fclose ( $fp );
2010-12-30 23:05:42 +01:00
$perms = array();
$perms['owner'] = $username;
$perms['can_read'] = $username;
$perms['can_write'] = $username;
$GLOBALS['sudo_cmd'] = true;
print __mkdir ( '/home/'.$username, $perms )."<br/>\n";
$GLOBALS['sudo_cmd'] = false;
print 'User "'.$username.'" successfully added, home directory set to "/home/'.$username."\"\n";
2010-12-25 13:27:38 +01:00
break;
2010-12-25 21:52:37 +01:00
case 'login':
$username = $_REQUEST['user'];
$password = $_REQUEST['pass'];
if ( !( $username != null && $password != null ))
{
die ("");
}
if ( preg_match ( '/[^a-zA-Z0-9_]/', $username ))
{
print "The username can only contain characters in the charset '[a-zA-Z0-9_]'\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 21:52:37 +01:00
}
if ( !( $xml = new SimpleXMLElement ( $xmlcontent )))
{
print "Unable to open the users XML file\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 21:52:37 +01:00
}
for ( $i = 0; $i < count ( $xml->user ) && !$found; $i++ )
{
if ( !strcasecmp ( $xml->user[$i]['name'], $username ))
{
if ( strcasecmp ( $xml->user[$i]['pass'], $password ))
{
print "Wrong password provided for user '$username'\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 21:52:37 +01:00
} else {
$auth = md5 ( $xml->user[$i]['name'] . $xml->user[$i]['pass'] );
setcookie ( 'username', $xml->user[$i]['name'], 0, "/" );
setcookie ( 'auth', $auth, 0, "/" );
print "Successfully logged in as '$username'\n";
2010-12-25 21:52:37 +01:00
return 0;
}
}
}
print "Username not found: '$username'\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 21:52:37 +01:00
break;
case 'getuser':
2010-12-26 18:08:43 +01:00
print getUser();
return 0;
break;
case 'logout':
setcookie ( 'username', '', 0, "/" );
setcookie ( 'auth', '', 0, "/" );
break;
case 'changepwd':
$old_pass = $_REQUEST['oldpass'];
$new_pass = $_REQUEST['newpass'];
$user = $_REQUEST['user'];
$cur_user = getUser();
// If the current user is not root and he's trying to change someone else's password, STOP HIM!
if ( $cur_user != 'root' && $cur_user != $user )
2010-12-25 21:52:37 +01:00
{
2010-12-26 18:08:43 +01:00
print "You cannot change the password for the user '$user'\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-26 18:08:43 +01:00
}
2010-12-25 21:52:37 +01:00
2010-12-26 18:08:43 +01:00
if ( !( $xml = new SimpleXMLElement ( $xmlcontent )))
{
print "Unable to open the users XML file\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-26 18:08:43 +01:00
}
for ( $i = 0; $i < count ( $xml->user ); $i++ )
{
// If we've found the user whose password should be changed...
if ( !strcasecmp ( $xml->user[$i]['name'], $user ))
2010-12-25 21:52:37 +01:00
{
2010-12-26 18:08:43 +01:00
$found = true;
2010-12-25 21:52:37 +01:00
2010-12-26 18:08:43 +01:00
// If the current user is not root, check his own inserted current password
if ( $cur_user != 'root' )
{
if ( $xml->user[$i]['pass'] != $old_pass )
2010-12-25 21:52:37 +01:00
{
2010-12-26 18:08:43 +01:00
print "The provided current password is wrong\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-25 21:52:37 +01:00
}
}
2010-12-26 18:08:43 +01:00
$xml->user[$i]['pass'] = $new_pass;
if ( !( $fp = fopen ( 'userlist.php', 'w' )))
{
print "Unable to change the password for the specified user, unknown error\n";
2010-12-30 23:05:42 +01:00
return '';
2010-12-26 18:08:43 +01:00
}
fwrite ( $fp, "<?php\n\n\$xmlcontent = <<<XML\n" . $xml->asXML() . "\nXML;\n\n?>\n" );
fclose ( $fp );
print 'Password successfully changed for the user '.$user."\n";
return 0;
}
2010-12-25 21:52:37 +01:00
}
break;
case 'getperms':
$res = $_REQUEST['resource'];
if ( !$res )
{
return false;
}
print getPerms ( $res );
break;
2010-12-30 23:05:42 +01:00
case 'mkdir':
$dir = $_REQUEST['dir'];
if ( !$dir )
{
return false;
}
print __mkdir ( $dir, null );
break;
case 'rmdir':
$dir = $_REQUEST['dir'];
if ( !$dir )
{
return false;
}
print __rmdir ( $dir );
break;
2010-12-25 13:27:38 +01:00
}
?>