381 lines
14 KiB
PHP
381 lines
14 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* Domain Api of AlternC, used by alternc-api package
|
||
|
*/
|
||
|
class Alternc_Api_Object_Mail extends Alternc_Api_Legacyobject {
|
||
|
|
||
|
protected $mail; // m_mail instance
|
||
|
|
||
|
function __construct($service) {
|
||
|
global $mail;
|
||
|
parent::__construct($service);
|
||
|
$this->mail = $mail;
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method mail->enum_domains()
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* @return Alternc_Api_Response whose content is the list of hosted domains
|
||
|
* for mails on this server
|
||
|
* (no more details as of now)
|
||
|
*/
|
||
|
function listDomains($options) {
|
||
|
global $cuid;
|
||
|
$sql = "";
|
||
|
$uid = $cuid;
|
||
|
if ($this->isAdmin && isset($options["uid"])) {
|
||
|
$uid = intval($options["uid"]);
|
||
|
}
|
||
|
|
||
|
$did = $this->mail->enum_domains($uid);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method mail->available()
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail(str)
|
||
|
* @return Alternc_Api_Response telling TRUE or FALSE
|
||
|
*/
|
||
|
function isAvailable($options) {
|
||
|
if (!isset($options["mail"])) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . "mail"));
|
||
|
}
|
||
|
$did = $this->mail->available($options["mail"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->enum_domain_mails
|
||
|
* ($dom_id = null, $search="", $offset=0, $count=30, $show_systemmails=false)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters:
|
||
|
* non-mandatory:
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function getAll($options) {
|
||
|
$defaults = array("dom_id" => null, "search" => "", "offset" => 0, "count" => 30, "show_systemmails" => false);
|
||
|
foreach ($defaults as $key => $value) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$options[$key] = $value;
|
||
|
}
|
||
|
}
|
||
|
$did = $this->mail->enum_domain_mails($options["dom_id"], $options["search"], $options["offset"], $options["count"], $options["show_systemmails"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->create
|
||
|
* ($dom_id, $mail,$type="",$dontcheck=false){
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters:
|
||
|
* non-mandatory:
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function create($options) {
|
||
|
$defaults = array("type" => "");
|
||
|
$mandatory = array("dom_id", "mail");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
foreach ($defaults as $key => $value) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$options[$key] = $value;
|
||
|
}
|
||
|
}
|
||
|
$did = $this->mail->create($options["dom_id"], $options["mail"], $options["type"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->get_details($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function get($options) {
|
||
|
$mandatory = array("mail_id");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->get_details($options["mail_id"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->get_account_by_mail_id($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function account($options) {
|
||
|
$mandatory = array("mail_id");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->get_account_by_mail_id($options["mail_id"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->delete($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function delete($options) {
|
||
|
$mandatory = array("mail_id");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->delete($options["mail_id"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->undelete($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function undelete($options) {
|
||
|
$mandatory = array("mail_id");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->undelete($options["mail_id"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->delete($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id, password
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function passwd($options) {
|
||
|
$mandatory = array("mail_id", "password");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->set_passwd($options["mail_id"], $options["password"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->enable($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function enable($options) {
|
||
|
$mandatory = array("mail_id");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->enable($options["mail_id"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail->disable($mail_id)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters: mail_id
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function disable($options) {
|
||
|
$mandatory = array("mail_id");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
$did = $this->mail->disable($options["mail_id"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** API Method from legacy class method $mail-> set_details
|
||
|
* ($mail_id, $islocal, $quotamb, $recipients,$delivery="dovecot",$dontcheck=false)
|
||
|
* @param $options a hash with parameters transmitted to legacy call
|
||
|
* mandatory parameters:
|
||
|
* non-mandatory:
|
||
|
* @return Alternc_Api_Response whose content is
|
||
|
*/
|
||
|
function update($options) {
|
||
|
$defaults = array("delivery" => "dovecot");
|
||
|
$mandatory = array("mail_id", "islocal", "quotamb", "recipients");
|
||
|
$missing = "";
|
||
|
foreach ($mandatory as $key) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$missing.=$key . " ";
|
||
|
}
|
||
|
}
|
||
|
if ($missing) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing or invalid argument: " . $missing));
|
||
|
}
|
||
|
foreach ($defaults as $key => $value) {
|
||
|
if (!isset($options[$key])) {
|
||
|
$options[$key] = $value;
|
||
|
}
|
||
|
}
|
||
|
$did = $this->mail->set_details($options["mail_id"], $options["islocal"], $options["quotamb"], $options["recipients"], $options["delivery"]);
|
||
|
if (!$did) {
|
||
|
return $this->alterncLegacyErrorManager();
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => $did));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/** API Method for email authentication
|
||
|
* @param $options a hash with email and password parameters.
|
||
|
* @return Alternc_Api_Response whose content is true / false if the auth
|
||
|
* to this email was successfull.
|
||
|
*/
|
||
|
function login($options) {
|
||
|
global $cuid;
|
||
|
$uid = $cuid;
|
||
|
if ($this->isAdmin && isset($options["uid"])) {
|
||
|
$uid = intval($options["uid"]);
|
||
|
}
|
||
|
if (!isset($options["email"]) || !isset($options["password"])) {
|
||
|
return new Alternc_Api_Response(array("code" => self::ERR_INVALID_ARGUMENT, "message" => "Missing email or password argument"));
|
||
|
}
|
||
|
list($address,$domain)=explode("@",$options["email"],2);
|
||
|
$stmt = $this->db->prepare("SELECT enabled,password FROM domaines d,address a WHERE a.domain_id=d.id AND address=? AND domaine=?;");
|
||
|
$stmt->execute(array($address,$domain));
|
||
|
$me = $stmt->fetch(PDO::FETCH_OBJ);
|
||
|
if ($me && $me->enabled) {
|
||
|
// Check password :
|
||
|
return new Alternc_Api_Response(array("content" => $this->check_password($options["password"],$me->password) ));
|
||
|
} else {
|
||
|
return new Alternc_Api_Response(array("content" => false));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
function check_password($password, $hash) {
|
||
|
if ($hash == '') { // no password
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
if ($hash{0} != '{') { // plaintext or crypt() password ?
|
||
|
if ($hash{0} == '$' ) {
|
||
|
if (crypt($password,$hash)==$hash)
|
||
|
return TRUE;
|
||
|
} else { // plaintext ? (NOT RECOMMENDED !!!)
|
||
|
if ($password == $hash)
|
||
|
return TRUE;
|
||
|
}
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
if (substr($hash,0,7) == '{crypt}') {
|
||
|
if (crypt($password, substr($hash,7)) == substr($hash,7))
|
||
|
return TRUE;
|
||
|
return FALSE;
|
||
|
}
|
||
|
elseif (substr($hash,0,5) == '{MD5}') {
|
||
|
$encrypted_password = '{MD5}' . base64_encode(md5( $password,TRUE));
|
||
|
}
|
||
|
elseif (substr($hash,0,6) == '{SHA1}') {
|
||
|
$encrypted_password = '{SHA}' . base64_encode(sha1( $password, TRUE ));
|
||
|
}
|
||
|
elseif (substr($hash,0,6) == '{SSHA}') {
|
||
|
$salt = substr(base64_decode(substr($hash,6)),20);
|
||
|
$encrypted_password = '{SSHA}' . base64_encode(sha1( $password.$salt, TRUE ). $salt);
|
||
|
} else {
|
||
|
echo "Unsupported password hash format";
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
if ($hash == $encrypted_password)
|
||
|
return TRUE;
|
||
|
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// class Alternc_Api_Object_Mail
|