Jump to content

Moduel=>Provisioning ChangePassword question...


leewells

Recommended Posts

Greetings!

 

I'm creating a module that will automatically log someone into a Hivelocity account to create orders, grab charts, data usage, etc for those of us that resell servers for them (anyone interested in buying something like this let me know btw). We have currently this up using cURL to automatically login, grab the data, and log out every so often.

 

But now I'm having an issue with the password change function (and not what you think lol). The way it is setup is, the server will be given a password and the password can be reset via remote KVM or via the control panel. Right now I'm working on the Webmin control panel interface. The password change function works precisely as intended in the back-end (admin side) but when the user imitates it, it throws the error "Password Change Failed!" which is not in any of the docs and not anything we've hooked into this thing.

 

If anyone has had similar problems with the mod_passwordchange() function, please let me know what you did to get around that or what variable I may be missing to set or catch.

 

Thanks for any help ahead of time.

 

 

function hivelocity_ChangePassword($params)
{
require('/home/my/public_html/modules/servers/hivelocity/changepw.php'); // Library of curl functions to reset passwords for Webmin. Planned: Hivelocity KVMs
   $result 			= mysql_query("SELECT * FROM `mod_hivelocity` WHERE `serviceid`='".$params['serviceid']."'");
   $data 				= mysql_fetch_array($result);
   $passen 			= mydecrypt($data['cpass']); 
					  // mydecrypt($string) and myencrypt($string) is a custom 1024-bit, 32-layer
					  // cypher and encryption algorithm located in changepw.php
					  // We need to rethink this, maybe -- it can be CPU demanding.
if(empty($data['cpass']))
	{
	mysql_query("UPDATE `mod_hivelocity` SET `cpass`='".myecrypt($params["password"])."' WHERE `serviceid`='".$params['serviceid']."'");
	}
if($params["password"] == $passen)
	{
	$result 		= "Passwords already match!";  // No need to reset the password and pull a curl request if it is already the same.
	} else {
	$thepage = GetValue($params["serverip"],$params["username"],$passen,$params["password"]); // Lights, Camera, Action Function ref in changepw.php
	if($thepage == 'successfully')
		{
		mysql_query("UPDATE `mod_hivelocity` SET `cpass`='".myecrypt($params["password"])."' WHERE `serviceid`='".$params['serviceid']."'");
		$result 	= "success";
		} else {
		$result 	= "Could not change the password likely because the root password was already changed.";
		}
	}
return $result;
}

Edited by leewells
Added code..
Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use & Guidelines and understand your posts will initially be pre-moderated