<?php
/*
$Id$

  This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
  Copyright (C) 2011  Roland Gruber

  This program is free software; you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation; either version 2 of the License, or
  (at your option) any later version.

  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.

  You should have received a copy of the GNU General Public License
  along with this program; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

/**
* Shows general information like the creation time of an account.
*
* @package modules
* @author Roland Gruber
*/

/**
* Shows general information like the creation time of an account.
*
* @package modules
*/
class generalInformation extends baseModule {

	/**
	* Returns meta data that is interpreted by parent class
	*
	* @return array array with meta data
	* 
	* @see baseModule::get_metaData()
	*/
	public function get_metaData() {
		$return = array();
		// icon
		$return['icon'] = 'info.png';
		// manages all accounts
		$return["account_types"] = getTypes();
		// alias name
		$return["alias"] = _("General information");
		// module dependencies
		$return['dependencies'] = array('depends' => array(), 'conflicts' => array());
		// managed attributes
		$return['attributes'] = array('creatorsName', 'createTimestamp', 'modifiersName',
			'modifyTimestamp', 'hasSubordinates', 'memberOf', 'pwdChangedTime');
		return $return;
	}

	/**
	 * Returns the HTML meta data for the main account page.
	 * 
	 * @return htmlElement HTML meta data
	 */
	public function display_html_attributes() {
		$return = new htmlTable();
		// creation info
		if (isset($this->attributes['creatorsName'][0])) {
			$return->addElement(new htmlOutputText(_('Created by')));
			$return->addElement(new htmlOutputText(getAbstractDN($this->attributes['creatorsName'][0])), true);
		}
		if (isset($this->attributes['createTimestamp'][0])) {
			$return->addElement(new htmlOutputText(_('Creation time')));
			$return->addElement(new htmlOutputText(formatLDAPTimestamp($this->attributes['createTimestamp'][0])), true);
		}
		if (isset($this->attributes['creatorsName'][0]) || isset($this->attributes['createTimestamp'][0])) {
			$return->addElement(new htmlSpacer(null, '5px'), true);
		}
		// modification info
		if (isset($this->attributes['modifiersName'][0])) {
			$return->addElement(new htmlOutputText(_('Modified by')));
			$return->addElement(new htmlOutputText(getAbstractDN($this->attributes['modifiersName'][0])), true);
		}
		if (isset($this->attributes['modifyTimestamp'][0])) {
			$return->addElement(new htmlOutputText(_('Modification time')));
			$return->addElement(new htmlOutputText(formatLDAPTimestamp($this->attributes['modifyTimestamp'][0])), true);
		}
		if (isset($this->attributes['modifiersName'][0]) || isset($this->attributes['modifyTimestamp'][0])) {
			$return->addElement(new htmlSpacer(null, '5px'), true);
		}
		// children
		if (isset($this->attributes['hasSubordinates'][0])) {
			$hasChilds = _('no');
			if ($this->attributes['hasSubordinates'][0] == 'TRUE') {
				$hasChilds = _('yes');
			}
			$return->addElement(new htmlOutputText(_('Has subentries')));
			$return->addElement(new htmlOutputText($hasChilds), true);
			$return->addElement(new htmlSpacer(null, '5px'), true);
		}
		// group memberships
		if (isset($this->attributes['memberOf'][0])) {
			$groupLabel = new htmlOutputText(_('Groups'));
			$groupLabel->alignment = htmlElement::ALIGN_TOP;
			$return->addElement($groupLabel);
			$groups = new htmlTable();
			for ($i = 0; $i < sizeof($this->attributes['memberOf']); $i++) {
				$groups->addElement(new htmlOutputText(getAbstractDN($this->attributes['memberOf'][$i])), true);
			}
			$return->addElement($groups);
		}
		return $return;
	}

	/**
	* Processes user input of the primary module page.
	* It checks if all input values are correct and updates the associated LDAP attributes.
	*
	* @return array list of info/error messages
	*/
	public function process_attributes() {
		return array();
	}

}


?>