some todos done or partially done

-added alias delete function
-remove silly password function in domain and alias

-changed some $this->err to $this->error
-error ends with stop(1) which returns 1 in *unix shells



git-svn-id: https://svn.code.sf.net/p/postfixadmin/code/trunk@920 a1433add-5e2c-0410-b055-b7f2511e0802
pull/2/head
Valkum 14 years ago
parent 320a9331f1
commit c6771f7f04

@ -8,10 +8,6 @@ class AliasHandler {
private $username = null; private $username = null;
# TODO: implement a "delete" method. Pseudocode:
# - check if alias exists
# - check if mailbox exists - if yes, error out (never delete the alias of a mailbox!)
# - (if still here) delete alias
/** /**
* @param string $username * @param string $username
@ -210,7 +206,30 @@ class AliasHandler {
} }
return false; return false;
} }
# TODO: implement a "delete" method. Pseudocode:
# - check if alias exists
# - check if mailbox exists - if yes, error out (never delete the alias of a mailbox!)
# - (if still here) delete alias
#HERE IT IS!
/**
* @param alias address
* @return true on success false on failure
*/
public function delete($address){
$E_address = escape_string($address);
$table_alias = table_by_key('alias');
if( $this->get($address) && !is_mailbox_alias($address) ) {
sql = "DELETE FROM $table_alias" WHERE address = '$E_address';
$result = db_query($sql);
if( $result['rows'] == 1 ) {
return true;
}
return false;
}
}
/** /**
* @return return value of previously called method * @return return value of previously called method
*/ */

@ -107,7 +107,7 @@ class AddTask extends Shell {
$return = $handler->add($goto); $return = $handler->add($goto);
if($return == 1) { if($return == 1) {
$this->err(join("\n", $handler->errormsg)); $this->error("Error:", join("\n", $handler->errormsg));
} else { } else {
$this->out(""); $this->out("");
$this->out("Alias ( $address -> $goto ) generated."); $this->out("Alias ( $address -> $goto ) generated.");
@ -132,6 +132,7 @@ class AddTask extends Shell {
} }
} }
#TODO: implement
class UpdateTask extends Shell { class UpdateTask extends Shell {
/** /**
* Execution method always used for tasks * Execution method always used for tasks
@ -209,7 +210,7 @@ class DeleteTask extends Shell {
$create = $this->in($question, array('y','n')); $create = $this->in($question, array('y','n'));
$create == 'y' ? $random = true : $random = false; $create == 'y' ? $create = true : $create = false;
if ($create) if ($create)
$this->__handle($address); $this->__handle($address);
@ -227,13 +228,15 @@ class DeleteTask extends Shell {
### TODO: don't use UserHandler, instead add delete function to AliasHandler (if not already there) ### TODO: don't use UserHandler, instead add delete function to AliasHandler (if not already there)
### using UserHandler for deleting aliases is like taking a sledgehammer to crack a nut ### using UserHandler for deleting aliases is like taking a sledgehammer to crack a nut
### (and will probably cause some error messages that I added today ;-) ### (and will probably cause some error messages that I added today ;-)
$handler = new UserHandler($address);
### Implemented check it please!
$handler = new AliasHandler($address);
$status = $handler->delete(); $status = $handler->delete();
if ($status == true) { if ($status == true) {
$this->out("Mailbox of '$address' was deleted."); $this->out("Mailbox of '$address' was deleted.");
} else { } else {
$this->err(join("\n", $handler->errormsg)); $this->error("Error:", join("\n", $handler->errormsg));
} }
return; return;
@ -256,128 +259,7 @@ class DeleteTask extends Shell {
} }
} }
class PasswordTask extends Shell { ### PasswordTask was a rest of Copy Paste :D Deleted. Check it!
/**
* Execution method always used for tasks
*
* @access public
*/
function execute() {
if (empty($this->args)) {
$this->__interactive();
}
if (!empty($this->args[0])) {
$address = $this->args[0];
if (isset($this->params['g']) && $this->params['g'] == true ) {
$random = true;
$password = NULL;
} elseif (isset($this->args[1]) && length($this->args[1]) > 8) {
$password = $this->args[1];
} else {
$this->Dispatch->stderr('Missing <newpw> or -g. Falling back to interactive mode.');
$this->__interactive();
}
$this->__handle($address, $password, $random);
}
}
/**
* Interactive
*
* @access private
*/
function __interactive() {
while(0==0) {
$question = "Which address' password do you want to change?";
$address = $this->in($question);
if(preg_match("/^((?:(?:(?:[a-zA-Z0-9][\.\-\+_]?)*)[a-zA-Z0-9])+)\@((?:(?:(?:[a-zA-Z0-9][\.\-_]?){0,62})[a-zA-Z0-9])+)\.([a-zA-Z0-9]{2,6})$/", $address) == 1)
break;
$this->err("Invalid emailaddress");
}
$question2[] = "Do you want to change the password?";
$question2[] = "Are you really sure?";
$sure = $this->in(join("\n", $question2), array('y','n'));
if ($sure == 'n' ) {
$this->out('You\'re not sure.');
$this->_stop();
}
$question = "Do you want to generate a random password?";
$random = $this->in($question, array('y','n'));
$random == 'y' ? $random = true : $random = false;
$password = NULL;
if ($random == false) {
$question = "Pleas enter the new password?";
$password = $this->in($question);
}
var_dump($random);
$this->__handle($address, $password, $random);
}
/**
* Interactive
*
* @access private
*/
function __handle($address, $password = NULL, $random = false) {
# TODO: Does PasswordTask really make sense for Aliases? Probably not...
if ($random == true) {
$password = generate_password();
}
if ($password != NULL) {
$handler = new UserHandler($address);
if ($handler->change_pw($password, NULL, false) == 1){
$this->error("Change Password",join("\n", $handler->errormsg));
}
}
$this->out("");
$this->out("Password updated.");
$this->hr();
$this->out(sprintf('The Mail address is %20s', $address));
$this->out(sprintf('The new password is %20s',$password));
$this->hr();
return ;
}
/**
* Displays help contents
*
* @access public
*/
function help() {
$this->out("");
$this->hr();
$this->out("Usage: postfixadmin-cli user password <address> [<newpw>] [-g]");
$this->hr();
$this->out('Commands:');
$this->out("\n\tpassword\n\t\tchanges the password in interactive mode.");
$this->out("\n\tpassword <address> [<newpw>] [-g]\n\t\tchanges the password to <newpw> or if -g genereate a new pw for <address>");
$this->out("");
$this->_stop();
}
}
class ViewTask extends Shell { class ViewTask extends Shell {
/** /**
* Execution method always used for tasks * Execution method always used for tasks
@ -421,7 +303,7 @@ class ViewTask extends Shell {
$handler = new AliasHandler($address); $handler = new AliasHandler($address);
$status = $handler->get(); # TODO: set the "all" flag? $status = $handler->get(); # TODO: set the "all" flag?
if ( ! $status) { if ( ! $status) {
# TODO: error message $this->error("Error: Not Found", "The requested alias was not found!");
} else { } else {
$result = $handler->return; $result = $handler->return;
@ -431,7 +313,18 @@ class ViewTask extends Shell {
$this->out("\t -> ".$goto); $this->out("\t -> ".$goto);
} }
# TODO: display "deliver to mailbox" # TODO: display "deliver to mailbox"
##NEED fix in is_mailbox_alias because user is not set correctly in this scenario!
/**
if( $handler->is_mailbox_alias($address) )
$this->out("A mailbox was set for this alias!\n");
}
*/
# TODO: display if vacation is on? # TODO: display if vacation is on?
/**
if( $handler->is_vacation_address($address) ) {
$this->out("This alias is a vacation address!");
}
*/
} }
return; return;

@ -139,8 +139,8 @@ class AddTask extends Shell {
$handler = new DomainHandler('CONSOLE'); $handler = new DomainHandler('CONSOLE');
$return = $handler->add($domain, $desc, $a, $m, $t, $q, $default, $backup); $return = $handler->add($domain, $desc, $a, $m, $t, $q, $default, $backup);
if($return == 1) { if(!$return) {
$this->err(join("\n", $handler->errormsg)); $this->error("Error:", join("\n", $handler->errormsg));
} else { } else {
$this->out(""); $this->out("");
$this->out("Domain ( $domain ) generated."); $this->out("Domain ( $domain ) generated.");
@ -264,7 +264,7 @@ class DeleteTask extends Shell {
$this->out("Mailbox of '$address' was deleted."); $this->out("Mailbox of '$address' was deleted.");
} else { } else {
$this->err(join("\n", $handler->errormsg)); $this->error("Error:", join("\n", $handler->errormsg));
} }
return; return;
@ -287,129 +287,7 @@ class DeleteTask extends Shell {
} }
} }
class PasswordTask extends Shell { ##Deleted PasswordTask because its silly in domain shell
/**
* Execution method always used for tasks
*
* @access public
*/
function execute() {
if (empty($this->args)) {
$this->help();
// $this->__interactive();
}
if (!empty($this->args[0])) {
$this->help();
//$address = $this->args[0];
//if (isset($this->params['g']) && $this->params['g'] == true ) {
// $random = true;
// $password = NULL;
//} elseif (isset($this->args[1]) && length($this->args[1]) > 8) {
// $password = $this->args[1];
//} else {
// $this->Dispatch->stderr('Missing <newpw> or -g. Falling back to interactive mode.');
// $this->__interactive();
//}
//$this->__handle($address, $password, $random);
}
}
/**
* Interactive
*
* @access private
*/
function __interactive() {
while(0==0) {
$question = "Which address' password do you want to change?";
$address = $this->in($question);
if(preg_match("/^((?:(?:(?:[a-zA-Z0-9][\.\-\+_]?)*)[a-zA-Z0-9])+)\@((?:(?:(?:[a-zA-Z0-9][\.\-_]?){0,62})[a-zA-Z0-9])+)\.([a-zA-Z0-9]{2,6})$/", $address) == 1)
break;
$this->err("Invalid emailaddress");
}
$question2[] = "Do you want to change the password?";
$question2[] = "Are you really sure?";
$sure = $this->in(join("\n", $question2), array('y','n'));
if ($sure == 'n' ) {
$this->out('You\'re not sure.');
$this->_stop();
}
$question = "Do you want to generate a random password?";
$random = $this->in($question, array('y','n'));
$random == 'y' ? $random = true : $random = false;
$password = NULL;
if ($random == false) {
$question = "Pleas enter the new password?";
$password = $this->in($question);
}
var_dump($random);
$this->__handle($address, $password, $random);
}
/**
* Interactive
*
* @access private
*/
function __handle($address, $password = NULL, $random = false) {
if ($random == true) {
$password = generate_password();
}
if ($password != NULL) {
$handler = new UserHandler($address);
if ($handler->change_pw($password, NULL, false) == 1){
$this->error("Change Password",join("\n", $handler->errormsg));
}
}
$this->out("");
$this->out("Password updated.");
$this->hr();
$this->out(sprintf('The Mail address is %20s', $address));
$this->out(sprintf('The new password is %20s',$password));
$this->hr();
return ;
}
/**
* Displays help contents
*
* @access public
*/
function help() {
$this->out("NOT implemented yet.");
$this->hr();
$this->out("Usage: postfixadmin-cli user password <address> [<newpw>] [-g]");
$this->hr();
$this->out('Commands:');
$this->out("\n\tpassword\n\t\tchanges the password in interactive mode.");
$this->out("\n\tpassword <address> [<newpw>] [-g]\n\t\tchanges the password to <newpw> or if -g genereate a new pw for <address>");
$this->out("");
$this->_stop();
}
}
class ViewTask extends Shell { class ViewTask extends Shell {
/** /**
* Execution method always used for tasks * Execution method always used for tasks
@ -453,7 +331,9 @@ class ViewTask extends Shell {
$handler = new DomainHandler('CONSOLE'); $handler = new DomainHandler('CONSOLE');
$status = $handler->view($domain); $status = $handler->view($domain);
if ($status == 0) { if (!$status) {
$this->error("Error:",join("\n", $handler->errormsg));
} else {
$result = $handler->return; $result = $handler->return;
$this->out("Domain: \t".$result['domain']); $this->out("Domain: \t".$result['domain']);
$this->out("Description: \t".$result['description']); $this->out("Description: \t".$result['description']);
@ -466,9 +346,8 @@ class ViewTask extends Shell {
$this->out("Modified: \t".$result['modified']); $this->out("Modified: \t".$result['modified']);
$this->out("Created: \t".$result['created']); $this->out("Created: \t".$result['created']);
return ;
} }
return;
} }
/** /**

@ -327,7 +327,7 @@ if ( empty($this->params['q'] ) ) {
$out .= "$msg\n"; $out .= "$msg\n";
$out .= "\n"; $out .= "\n";
$this->err($out); $this->err($out);
$this->_stop(); $this->_stop(1);
} }
/** /**
* Outputs usage text on the standard output. Implement it in subclasses. * Outputs usage text on the standard output. Implement it in subclasses.
@ -341,7 +341,7 @@ if ( empty($this->params['q'] ) ) {
$this->Dispatch->help(); $this->Dispatch->help();
} }
} }
/** /**
* Stop execution of the current script * Stop execution of the current script
* *
* @param $status see http://php.net/exit for values * @param $status see http://php.net/exit for values

@ -57,6 +57,11 @@ class AddTask extends Shell {
* *
* @access public * @access public
*/ */
# Find one function that matches all executes in shell childclasses.
# Eventually getopts like call in __handle??
function execute() { function execute() {
if (empty($this->args)) { if (empty($this->args)) {
$this->__interactive(); $this->__interactive();
@ -143,8 +148,10 @@ if ( !empty($this->params['q']) ) {
} }
} else { } else {
if( $return == false ) { if( $return == false ) {
$this->err($handler->errormsg); ### When $this->error is used, $this->_stop is useless.
$this->_stop(1); ### Changed $this->error to stop with level 1.
### Eventually param q check in $this->error is better!! !Important!
$this->error("Error:", $handler->errormsg);
} else { } else {
$this->out(""); $this->out("");
if ($name != '') if ($name != '')
@ -270,7 +277,8 @@ class DeleteTask extends Shell {
$handler = new UserHandler($address); $handler = new UserHandler($address);
$status = $handler->delete(); $status = $handler->delete();
if ( ! $status ) { if ( ! $status ) {
$this->err(join("\n", $handler->errormsg)); $this->error("Error:", join("\n", $handler->errormsg));
} else { } else {
$this->out("Mailbox of '$address' was deleted."); $this->out("Mailbox of '$address' was deleted.");
} }
@ -460,9 +468,8 @@ class ViewTask extends Shell {
$handler = new UserHandler($address); $handler = new UserHandler($address);
if ( ! $handler->view() ) { if ( ! $handler->view() ) {
return ; $this->error("Not Found!", "The user you have searched could not be found.");
# TODO: display error message "not found" }
}
# TODO: offer alternative output formats (based on parameter) # TODO: offer alternative output formats (based on parameter)
# TODO: whitespace fix - 8 lines below # TODO: whitespace fix - 8 lines below
$result = $handler->return; $result = $handler->return;

Loading…
Cancel
Save