172 lines
6.1 KiB
PHP
172 lines
6.1 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Domain Api of AlternC, used by alternc-api package
|
|
*/
|
|
class Alternc_Api_Object_Domain {
|
|
|
|
const ERR_INVALID_ARGUMENT = 1115401;
|
|
const ERR_ALTERNC_FUNCTION = 1115402;
|
|
|
|
var $admin; // m_admin instance
|
|
var $dom; // m_dom instance
|
|
var $cuid; // current user id
|
|
var $isAdmin; // is it an Admin account?
|
|
|
|
function __construct($service) {
|
|
global $admin,$cuid,$dom;
|
|
if (!($service instanceof Alternc_Api_Service)) {
|
|
throw new \Exception("Bad argument: service is not an Alternc_Api_Service", self::ERR_INVALID_ARGUMENT);
|
|
}
|
|
// We store the global $cuid to AlternC legacy classes
|
|
$this->cuid=$cuid=$service->token->uid;
|
|
$this->isAdmin=$service->token->isAdmin;
|
|
// We use the global $admin & $dom from AlternC legacy classes
|
|
$this->admin=$admin;
|
|
$this->dom=$dom;
|
|
// Set the legacy rights:
|
|
$this->admin->enabled=$this->isAdmin;
|
|
}
|
|
|
|
|
|
/** API Method from legacy class method dom->get_domain_list()
|
|
* @param $options a hash with parameters transmitted to legacy call
|
|
* may be "uid" to only return domains for a specific user-id
|
|
* (if you are not admin, this WILL only list YOUR domains anyway)
|
|
* may be "offset" and/or "count" to do paging.
|
|
* @return Alternc_Api_Response whose content is the list of hosted domains on this server
|
|
* (no more details as of now)
|
|
*/
|
|
function find($options) {
|
|
global $cuid;
|
|
$sql="";
|
|
if ($this->isAdmin) {
|
|
if (isset($options["uid"])) {
|
|
$uid=intval($options["uid"]);
|
|
} else {
|
|
$uid=-1;
|
|
}
|
|
} else {
|
|
$uid=$cuid;
|
|
}
|
|
$result=$this->dom->get_domain_list($uid);
|
|
if (!$result) {
|
|
return $this->alterncLegacyErrorManager();
|
|
} else {
|
|
$offset=-1; $count=-1;
|
|
if (isset($options["count"])) $count=intval($options["count"]);
|
|
if (isset($options["offset"])) $offset=intval($options["offset"]);
|
|
if ($offset!=-1 || $count!=-1) {
|
|
if ($offset<0 || $offset>count($result)) $offset=0;
|
|
if ($count<0 || $count>1000) $count=1000;
|
|
$result= array_slice($result, $offset, $count);
|
|
}
|
|
return new Alternc_Api_Response( array("content" =>$result) );
|
|
}
|
|
}
|
|
|
|
|
|
/** API Method from legacy class method dom->add_domain()
|
|
* @param $options a hash with parameters transmitted to legacy call
|
|
* mandatory parameters: domain(str), dns(bool)
|
|
* non-mandatory: noerase(bool, only admins), force(bool, only admins), isslave(bool), slavedom(str)
|
|
* @return Alternc_Api_Response whose content is the newly created DOMAIN id
|
|
*/
|
|
function add($options) {
|
|
$mandatory=array("domain","dns");
|
|
$defaults=array("noerase"=>false, "force"=>false, "isslave"=>false, "slavedom"=>"");
|
|
$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;
|
|
}
|
|
}
|
|
if (!$this->isAdmin) { // only admin can change the options below:
|
|
$options["noerase"]=false;
|
|
$options["force"]=false;
|
|
}
|
|
$did=$this->dom->add_domain($options["domain"], $options["dns"], $options["noerase"],
|
|
$options["force"], $options["isslave"], $options["slavedom"]);
|
|
if (!$did) {
|
|
return $this->alterncLegacyErrorManager();
|
|
} else {
|
|
return new Alternc_Api_Response( array("content" => $did ) );
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/** API Method from legacy class method dom->edit_domain()
|
|
* @param $options a hash with parameters transmitted to legacy call
|
|
* mandatory parameters: domain(str), dns(bool)
|
|
* non-mandatory: noerase(bool, only admins), force(bool, only admins), isslave(bool), slavedom(str)
|
|
* @return Alternc_Api_Response whose content is the newly created DOMAIN id
|
|
*/
|
|
function update($options) {
|
|
$mandatory=array("domain","dns","gesmx");
|
|
$defaults=array("force"=>false, "ttl"=>86400);
|
|
$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;
|
|
}
|
|
}
|
|
if (!$this->isAdmin) { // only admin can change the options below:
|
|
$options["force"]=false;
|
|
}
|
|
$did=$this->dom->edit_domain($options["domain"], $options["dns"], $options["gesmx"],
|
|
$options["force"], $options["ttl"]);
|
|
if (!$did) {
|
|
return $this->alterncLegacyErrorManager();
|
|
} else {
|
|
return new Alternc_Api_Response( array("content" => $did ) );
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/** API Method from legacy class method dom->del_domain()
|
|
* @param $options a hash with parameters transmitted to legacy call
|
|
* mandatory parameters: domain
|
|
* @return Alternc_Api_Response TRUE if the domain has been marked for deletion.
|
|
*/
|
|
function del($options) {
|
|
if (!isset($options["domain"])) {
|
|
return new Alternc_Api_Response( array("code" => self::ERR_ALTERNC_FUNCTION, "message" => "Missing or invalid argument: DOMAIN") );
|
|
}
|
|
$result=$this->dom->del_domain($options["domain"]);
|
|
if (!$result) {
|
|
return $this->alterncLegacyErrorManager();
|
|
} else {
|
|
return new Alternc_Api_Response( array("content" => true ) );
|
|
}
|
|
}
|
|
|
|
|
|
/** return a proper Alternc_Api_Response from an error class and error string
|
|
* from AlternC legacy class
|
|
*/
|
|
private function alterncLegacyErrorManager() {
|
|
global $err;
|
|
return new Alternc_Api_Response( array("code" => self::ERR_ALTERNC_FUNCTION, "message" => "[".$err->clsid."] ".$err->error) );
|
|
}
|
|
|
|
|
|
} // class Alternc_Api_Object_Domain
|