diff --git a/plugins/admin/systems/class_goNtpServer.inc b/plugins/admin/systems/class_goNtpServer.inc
index 8cb692ffab41356cd38194d19b6694f97501b022..b179ae95b6830c1dfb991fcece65b060a547ecf4 100644 (file)
<?php
-class goNtpServer extends plugin{
+class goNtpServer extends goService{
var $cli_summary = "This pluign is used within the ServerService Pluign \nand indicates that this server supports NTP service.";
var $cli_description = "Some longer text\nfor help";
var $goNtpServerStatus= "";
var $acl;
var $cn = "";
+ var $view_logged =FALSE;
- function goNtpServer($config,$dn)
+ function goNtpServer(&$config,$dn)
{
- plugin::plugin($config,$dn);
- $this->DisplayName = _("Time service");
+ goService::goService($config,$dn);
+ $this->DisplayName = _("Time service (NTP)");
/* Load arrays */
$tmp = array();
{
$smarty = get_smarty();
+ if($this->is_account && !$this->view_logged){
+ $this->view_logged = TRUE;
+ new log("view","server/".get_class($this),$this->dn);
+ }
+
/* Here we add a new entry */
- if(isset($_POST['NewNTPAdd']) && $_POST['NewNTPExport'] != "") {
+ if(isset($_POST['NewNTPAdd']) && $_POST['NewNTPExport'] != "" && $this->acl_is_writeable("goTimeSource")) {
$this->goTimeSource[$_POST['NewNTPExport']]= $_POST['NewNTPExport'];
asort($this->goTimeSource);
}
/* Deleting an Entry, is a bit more complicated than adding one*/
- if((isset($_POST['DelNTPEnt'])) && (isset($_POST['goTimeSource']))) {
+ if((isset($_POST['DelNTPEnt'])) && (isset($_POST['goTimeSource'])) && $this->acl_is_writeable("goTimeSource")) {
foreach ($_POST['goTimeSource'] as $entry){
if (isset($this->goTimeSource[$entry])){
unset($this->goTimeSource[$entry]);
}
}
- $smarty->assign("goNtpServerACL",chkacl($this->acl,"goNtpServer")) ;
+ $smarty->assign("goNtpServerACL", $this->getacl("goNtpServer")) ;
$smarty->assign("goTimeSource" , $this->goTimeSource);
return($smarty->fetch(get_template_path("goNtpServer.tpl",TRUE,dirname(__FILE__))));
}
function getListEntry()
{
- $flag = $this->StatusFlag;
- $fields['Status'] = $this->$flag;
- $fields['Message'] = _("NTP service");
- $fields['AllowStart'] = true;
- $fields['AllowStop'] = true;
- $fields['AllowRestart'] = true;
- $fields['AllowRemove']= true;
+ $fields = goService::getListEntry();
+ $fields['Message'] = _("Time service (NTP)");
$fields['AllowEdit'] = true;
return($fields);
}
- function remove_from_parent()
- {
- plugin::remove_from_parent();
- /* Check if this is a new entry ... add/modify */
- $ldap = $this->config->get_ldap_link();
- $ldap->cat($this->dn,array("objectClass"));
- if($ldap->count()){
- $ldap->cd($this->dn);
- $ldap->modify($this->attrs);
- }else{
- $ldap->cd($this->dn);
- $ldap->add($this->attrs);
- }
- show_ldap_error($ldap->get_error());
- $this->handle_post_events("remove");
- }
-
-
function save()
{
plugin::save();
$ldap->cd($this->dn);
$ldap->add($this->attrs);
}
- show_ldap_error($ldap->get_error());
+ show_ldap_error($ldap->get_error(), sprintf(_("Saving server services/goNtpServer with dn '%s' failed."),$this->dn));
if($this->initially_was_account){
$this->handle_post_events("modify");
+ new log("modify","server/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
}else{
$this->handle_post_events("add");
+ new log("create","server/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
}
}
- /* Directly save new status flag */
- function setStatus($value)
+ /* Return plugin informations for acl handling */
+ static function plInfo()
{
- if($value == "none") return;
- if(!$this->initially_was_account) return;
- $ldap = $this->config->get_ldap_link();
- $ldap->cd($this->dn);
- $ldap->cat($this->dn,array("objectClass"));
- if($ldap->count()){
-
- $tmp = $ldap->fetch();
- for($i = 0; $i < $tmp['objectClass']['count']; $i ++){
- $attrs['objectClass'][] = $tmp['objectClass'][$i];
- }
- $flag = $this->StatusFlag;
- $attrs[$flag] = $value;
- $this->$flag = $value;
- $ldap->modify($attrs);
- show_ldap_error($ldap->get_error());
- $this->action_hook();
- }
+ return (array(
+ "plShortName" => _("Time service"),
+ "plDescription" => _("Time service - NTP")." ("._("Services").")",
+ "plSelfModify" => FALSE,
+ "plDepends" => array(),
+ "plPriority" => 91,
+ "plSection" => array("administration"),
+ "plCategory" => array("server"),
+
+ "plProvidedAcls"=> array(
+ "goTimeSource" =>_("Ntp source"))
+ ));
}
- function action_hook($add_attrs= array())
+
+ function PrepareForCopyPaste($source)
{
- /* Find postcreate entries for this class */
- $command= search_config($this->config->data['MENU'], get_class($this), "ACTION_HOOK");
- if ($command == "" && isset($this->config->data['TABS'])){
- $command= search_config($this->config->data['TABS'], get_class($this), "ACTION_HOOK");
- }
- if ($command != ""){
- /* Walk through attribute list */
- foreach ($this->attributes as $attr){
- if (!is_array($this->$attr)){
- $command= preg_replace("/%$attr/", $this->$attr, $command);
- }
- }
- $command= preg_replace("/%dn/", $this->dn, $command);
- /* Additional attributes */
- foreach ($add_attrs as $name => $value){
- $command= preg_replace("/%$name/", $value, $command);
- }
+ plugin::PrepareForCopyPaste($source);
- /* If there are still some %.. in our command, try to fill these with some other class vars */
- if(preg_match("/%/",$command)){
- $attrs = get_object_vars($this);
- foreach($attrs as $name => $value){
- if(!is_string($value)) continue;
- $command= preg_replace("/%$name/", $value, $command);
- }
+ /* Load arrays */
+ $tmp = array();
+ if (isset($source['goTimeSource'])){
+ for ($i= 0; $i<$source['goTimeSource']['count']; $i++){
+ $tmp[$source['goTimeSource'][$i]]= $source['goTimeSource'][$i];
}
+ }
+ $this->goTimeSource= $tmp;
- if (check_command($command)){
- @DEBUG (DEBUG_SHELL, __LINE__, __FUNCTION__, __FILE__,
- $command, "Execute");
- exec($command);
- } else {
- $message= sprintf(_("Command '%s', specified as ACTION_HOOK for plugin '%s' doesn't seem to exist."), $command, get_class($this));
- print_red ($message);
- }
- }
}
function check(){ return array();}