| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | 
					
						
							|  |  |  | <html> | 
					
						
							|  |  |  | <head> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  |   <meta content="text/html; charset=ISO-8859-15" | 
					
						
							|  |  |  |  http-equiv="content-type"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <title>Module specification</title> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |   <style> | 
					
						
							| 
									
										
										
										
											2005-03-06 12:37:31 +00:00
										 |  |  | <!--
 | 
					
						
							|  |  |  | 	h2 { | 
					
						
							|  |  |  | 		color:darkblue; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	h3 { | 
					
						
							|  |  |  | 		color:darkblue; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	h4 { | 
					
						
							|  |  |  | 		color:darkblue; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	table { | 
					
						
							|  |  |  | 		background-color:#bdcaff; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | --> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |   </style> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | </head> | 
					
						
							|  |  |  | <body> | 
					
						
							|  |  |  | <h1 style="text-align: center;">This document describes the module | 
					
						
							|  |  |  | interface for LDAP Account Manager</h1> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h2>1. Location and naming of modules</h2> | 
					
						
							|  |  |  | All LAM modules are placed in lib/modules/ and are named "<class | 
					
						
							|  |  |  | name>.inc".<br> | 
					
						
							|  |  |  | E.g. if you create a new module and its class name is "qmail" then the | 
					
						
							|  |  |  | filename would be "qmail.inc".<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | The class name of a module must contain only a-z, A-Z, 0-9, -, and _.<br> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | All module classes should extend the baseModule class.<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							|  |  |  | <h2>2. Class functions</h2> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <h3>2.1. Functions that have to work without superior accountContainer<br> | 
					
						
							|  |  |  | </h3> | 
					
						
							| 
									
										
										
										
											2004-03-02 19:25:09 +00:00
										 |  |  | <h3><br> | 
					
						
							|  |  |  | </h3> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <h3>2.1.1. can_manage*</h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-03-02 19:25:09 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-06-13 19:58:58 +00:00
										 |  |  |  style="font-weight: bold;">function can_manage()</span><br> | 
					
						
							| 
									
										
										
										
											2004-03-02 19:25:09 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returns <span style="font-style: italic;">true</span> if this module | 
					
						
							| 
									
										
										
										
											2004-06-13 19:58:58 +00:00
										 |  |  | can manage accounts of the current type<span style="font-style: italic;"></span>, | 
					
						
							| 
									
										
										
										
											2004-03-02 19:25:09 +00:00
										 |  |  | otherwise <span style="font-style: italic;">false</span>.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <h3>2.1.2. get_alias*</h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-06-14 16:05:36 +00:00
										 |  |  |  style="font-weight: bold;">function get_alias()</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | This function returns a more descriptive string than the class name. | 
					
						
							|  |  |  | Alias names are used for the buttons of the account pages and the | 
					
						
							|  |  |  | module selection of the configuration wizard.<br> | 
					
						
							|  |  |  | Please take care that your alias name is not too long. It may contain | 
					
						
							| 
									
										
										
										
											2004-06-14 16:05:36 +00:00
										 |  |  | any character but should not include parts that may be interpreted by | 
					
						
							|  |  |  | the browser (e.g. '<' or '>').<br> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | If you use different aliases dependent on the account type please make | 
					
						
							|  |  |  | sure that there is a general alias for unknown types.<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <h3>2.1.3. is_base_module*</h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |  style="font-weight: bold;">function is_base_module()</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | Returns <span style="font-weight: bold;">true</span> if your module is | 
					
						
							|  |  |  | a base module and otherwise <span style="font-weight: bold;">false</span>.<br> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <span style="font-weight: bold;"></span><br> | 
					
						
							| 
									
										
										
										
											2005-01-10 10:58:05 +00:00
										 |  |  | Every account type needs exactly one base module. A base module manages | 
					
						
							|  |  |  | a structural object class.<br> | 
					
						
							|  |  |  | E.g. the inetOrgPerson module is a base module since its object class | 
					
						
							|  |  |  | is structural.<br> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <h3>2.1.4. get_ldap_filter*</h3> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  |  style="font-weight: bold;">function get_ldap_filter()</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-04 11:28:22 +00:00
										 |  |  | Returns an array('or' => '...', 'and' => '...') that is used to | 
					
						
							|  |  |  | build the LDAP filter. Usually | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | used to filter object classes.<br> | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  | <span style="font-weight: bold;"></span><br> | 
					
						
							| 
									
										
										
										
											2004-06-04 11:28:22 +00:00
										 |  |  | All "or" filter parts of the base modules are combined with OR and then | 
					
						
							|  |  |  | combined with the "and" parts.<br> | 
					
						
							|  |  |  | The resulting LDAP filter will look like this: | 
					
						
							|  |  |  | (&(|(OR1)(OR2)(OR3))(AND1)(AND2)(AND3))<br> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Example: <span | 
					
						
							| 
									
										
										
										
											2004-06-04 11:28:22 +00:00
										 |  |  |  style="font-style: italic;">return "('or' => | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  | '(objectClass=posixAccount)', 'and' => '(!(uid=*$))')"</span></span><br> | 
					
						
							| 
									
										
										
										
											2005-01-10 10:58:05 +00:00
										 |  |  | <span style="font-weight: bold; color: rgb(255, 0, 0);"></span><br> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>2.1.5. get_RDNAttributes*</h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  |  style="font-weight: bold;">function get_RDNAttributes()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returns a hash array containing a list of possible LDAP attributes that | 
					
						
							|  |  |  | can be used to form the RDN (Relative Distinguished Name).<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span><br> | 
					
						
							|  |  |  | The keys of the array are the LDAP attributes, the values are the | 
					
						
							|  |  |  | priority <span style="font-style: italic;">("low"/"normal"/"high")</span>.<br> | 
					
						
							|  |  |  | Attributes with higher priority are placed higher in the drop down box | 
					
						
							|  |  |  | for the RDN selection.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Example: <span | 
					
						
							|  |  |  |  style="font-style: italic;">return "('uid' => | 
					
						
							|  |  |  | 'normal', 'cn' => 'low')"</span></span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold; color: rgb(255, 0, 0);"></span><br> | 
					
						
							|  |  |  | <h3>2.1.6. get_dependencies*</h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-06 12:37:31 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							|  |  |  |       <td | 
					
						
							| 
									
										
										
										
											2005-03-06 12:37:31 +00:00
										 |  |  |  style="vertical-align: top; text-align: center; font-weight: bold;">function | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  | get_dependencies()<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function returns a list of modules it depends on.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | The return value is an array with two sub arrays, <span | 
					
						
							|  |  |  |  style="font-weight: bold;">"depends"</span> and <span | 
					
						
							|  |  |  |  style="font-weight: bold;">"conficts"</span>.<br> | 
					
						
							|  |  |  | All values of the conflict array are string values with module names.<br> | 
					
						
							|  |  |  | All values of the depends array are either string values with module | 
					
						
							|  |  |  | names or arrays which include only string values with module names. If | 
					
						
							|  |  |  | an element of the depends array is itself an array, this means that | 
					
						
							|  |  |  | your module depends on one of these modules.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Example: </span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">return array("depends" | 
					
						
							|  |  |  | => array("posixAccount", array("qmail", "sendmail")), "conflicts" | 
					
						
							|  |  |  | => array("exim"));</span><br | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>2.1.7. get_metaData()</h3> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |  style="font-weight: bold;">function get_metaData()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returns an hash array including meta data for the baseModule.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Example: return array("is_base" => | 
					
						
							|  |  |  | true);</span><br style="font-weight: bold;"> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>2.1.8. get_configOptions()*</h3> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  |  style="font-weight: bold;">function get_configOptions($scopes)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returns a list of configuration options.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$scopes</span> is a list of <span | 
					
						
							|  |  |  |  style="font-style: italic;">account types</span> (user, group, host) | 
					
						
							|  |  |  | which are used.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span><br> | 
					
						
							|  |  |  | The return value is an array | 
					
						
							|  |  |  | that contains <span style="font-weight: bold;">meta HTML code</span>.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | The type "fieldset" is not allowed here.<br> | 
					
						
							|  |  |  | The <span style="font-style: italic;">name</span> attributes are used | 
					
						
							|  |  |  | as keywords to load and save settings. We recommend to use the module | 
					
						
							|  |  |  | name as prefix for them (e.g. posixAccount_homeDirectory) to avoid | 
					
						
							|  |  |  | naming confilcts.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>2.1.9. get_configDescriptions()*</h3> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  |  style="font-weight: bold;">function get_configDescriptions()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returns the description of every configuration option and the legend of | 
					
						
							|  |  |  | the module fieldset on the configuration page.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span><br> | 
					
						
							|  |  |  | The <span style="font-style: italic;">return</span> value is a hash | 
					
						
							|  |  |  | array with this format:<br> | 
					
						
							|  |  |  |     <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">    array( 'legend' | 
					
						
							|  |  |  | => 'Some general description for fieldset',</span><br | 
					
						
							|  |  |  |  style="font-weight: bold;"> | 
					
						
							|  |  |  | <span style="font-weight: bold;">       | 
					
						
							|  |  |  |        'descriptions' => array('option1' | 
					
						
							|  |  |  | => 'description1', ...))</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>2.1.10. check_configOptions*</h3> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  |  style="font-weight: bold;">function check_configOptions($scopes, | 
					
						
							|  |  |  | $options)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function checks the input for module configuration settings.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$scopes</span> is a list of used | 
					
						
							|  |  |  | account types (user, group, host).<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span><span style="font-weight: bold;">$options</span> | 
					
						
							|  |  |  | is an hash array | 
					
						
							|  |  |  | (option name => value) that contains the input. The option values | 
					
						
							|  |  |  | are all arrays containing one or more elements.<br> | 
					
						
							|  |  |  | If the input data is invalid the return value is an array that contains | 
					
						
							|  |  |  | arrays to build StatusMessages (0 => message type, 1 => message | 
					
						
							|  |  |  | head, 2 => message text, 3 => additional variables).<br> | 
					
						
							|  |  |  | If no errors occured the function returns an empty array.<span | 
					
						
							|  |  |  |  style="font-weight: bold;"></span><br> | 
					
						
							|  |  |  | <br style="font-weight: bold;"> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>2.1.11. get_scope()</h3> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |  style="font-weight: bold;">function get_scope()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returns the account type (user/group/host) of this module object.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span><br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">This function is provided by the | 
					
						
							|  |  |  | baseModule and should not be overwritten.</span><br> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.1.12. get_uploadColumns*</h3> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function get_uploadColumns()</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | Returns a list of column entries for the upload .csv-file.<br> | 
					
						
							|  |  |  | Each column entry is an array containing these values:<br> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">string</span> | 
					
						
							|  |  |  | name:</span> fixed non-translated name which is used as column name | 
					
						
							|  |  |  | (should be of format: <module name>_<column name>)</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">string</span> | 
					
						
							|  |  |  | description:</span> short descriptive name</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">string</span> | 
					
						
							|  |  |  | help:</span> help ID</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">string</span> | 
					
						
							|  |  |  | example:</span> example value</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">string</span> | 
					
						
							|  |  |  | values:</span> possible input values<span style="font-style: italic;"> </span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">(optional)</span></li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold; font-style: italic;">string</span><span | 
					
						
							|  |  |  |  style="font-weight: bold;"> default:</span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"> </span>default value <span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">(optional)</span><br> | 
					
						
							|  |  |  |   </li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">boolean</span> | 
					
						
							|  |  |  | required:</span> true, if user must set a value for this column <span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">(optional, default: | 
					
						
							|  |  |  | "false")</span><br> | 
					
						
							|  |  |  |   </li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><span style="font-style: italic;">boolean</span> | 
					
						
							|  |  |  | unique:</span> true if | 
					
						
							|  |  |  | all values of this column must be different values <span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;">(optional, default: | 
					
						
							|  |  |  | "false")</span><br> | 
					
						
							|  |  |  |   </li> | 
					
						
							|  |  |  | </ul> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.1.13. get_uploadPreDepends*</h3> | 
					
						
							| 
									
										
										
										
											2004-03-14 16:40:59 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-03-14 16:40:59 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function get_uploadPreDepends()</span><br> | 
					
						
							| 
									
										
										
										
											2004-03-14 16:40:59 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | Returns a list of module names which must be processed before this | 
					
						
							|  |  |  | module at builing accounts.<br> | 
					
						
							|  |  |  | The named modules may not be active, LAM will check this automatically.<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.1.14. build_uploadAccounts</h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function get_uploadAccounts($rawAccounts, | 
					
						
							|  |  |  | $ids, $partialAccounts)</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | This function takes the user input and generates the LDAP accounts.<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | $rawAccounts:</span> The user input data, contains one sub array for | 
					
						
							|  |  |  | each account.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | $ids:</span> Maps the column names to keys for the sub arrays.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | $partialAccounts:</span> Containing one sub array for each account, | 
					
						
							|  |  |  | format is the same as used for ldap_add().<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | Returns an array which contains sub arrays to generate StatusMessages | 
					
						
							|  |  |  | if any errors occured.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>2.1.15. do_uploadPostActions</h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function do_uploadPostActions($data, $ids, | 
					
						
							|  |  |  | $failed, &$temp)</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | This function is responsible to do additional tasks after the account | 
					
						
							|  |  |  | has been created in LDAP.<br> | 
					
						
							|  |  |  | E.g. modifying group memberships, adding Quota etc..<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function is called as long as the returned status is <span | 
					
						
							|  |  |  |  style="font-style: italic;">'finished'</span>. Please make sure that | 
					
						
							|  |  |  | one function call lasts no longer than 3-4 seconds. Otherwise the | 
					
						
							|  |  |  | upload may fail because the time limit is exceeded. You should not make | 
					
						
							|  |  |  | more than one LDAP operation in each call.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | $data:</span> The user input data, contains one sub array for each | 
					
						
							|  |  |  | account.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | $ids:</span> Maps the column names to keys for the sub arrays.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | $failed:</span> List of account numbers which could not be successfully | 
					
						
							|  |  |  | uploaded to LDAP.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;">array</span> | 
					
						
							|  |  |  | &$temp:</span> Pointer to temporary variable which can be used to | 
					
						
							|  |  |  | save information between two function calls.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">return array (</span><br> | 
					
						
							|  |  |  |     <span style="font-weight: bold;">'status' => | 
					
						
							|  |  |  | 'finished' | 'inProgress'</span>   // Defines if all | 
					
						
							|  |  |  | operations are complete<br> | 
					
						
							|  |  |  |     <span style="font-weight: bold;">'progress' => | 
					
						
							|  |  |  | 0..100</span>   // The progress of the operations in percent<br> | 
					
						
							|  |  |  |     <span style="font-weight: bold;">'errors' => | 
					
						
							|  |  |  | array()</span>   // List of arrays which are used to generate | 
					
						
							|  |  |  | StatusMessages<br> | 
					
						
							|  |  |  |     <span style="font-weight: bold;">)</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>2.1.16. get_profileOptions*</h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  |  style="font-weight: bold;">function get_profileOptions()</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | This function defines what attributes will be used in the account | 
					
						
							|  |  |  | profiles and their appearance in the profile editor.<br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  | <span style="font-weight: bold;"></span>The return value is an array | 
					
						
							|  |  |  | that contains <span style="font-weight: bold;">meta HTML code</span>.<br> | 
					
						
							| 
									
										
										
										
											2004-03-15 16:30:52 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | The type "fieldset" is not allowed here.<br> | 
					
						
							|  |  |  | The <span style="font-style: italic;">name</span> attributes are used | 
					
						
							|  |  |  | as keywords to load and save profiles. We recommend to use the module | 
					
						
							|  |  |  | name as prefix for them (e.g. posixAccount_homeDirectory) to avoid | 
					
						
							|  |  |  | naming confilcts.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.1.17. check_profileOptions*</h3> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-03-15 16:30:52 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  |  style="font-weight: bold;">function check_profileOptions($options)</span><br> | 
					
						
							| 
									
										
										
										
											2004-03-15 16:30:52 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | This function checks the input for a new or modified account profile.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-07-13 14:51:28 +00:00
										 |  |  | <span style="font-weight: bold;"></span><span style="font-weight: bold;">$options</span> | 
					
						
							|  |  |  | is an hash array | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | (option name => value) that contains the input. The option values | 
					
						
							|  |  |  | are all arrays containing one or more elements.<br> | 
					
						
							|  |  |  | If the input data is invalid the return value is an array that contains | 
					
						
							|  |  |  | arrays to build StatusMessages (0 => message type, 1 => message | 
					
						
							|  |  |  | head, 2 => message text, 3 => additional variables).<br> | 
					
						
							|  |  |  | If no errors occured the function returns an empty array.<span | 
					
						
							|  |  |  |  style="font-weight: bold;"></span><br> | 
					
						
							| 
									
										
										
										
											2004-03-15 16:30:52 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  | <h3>2.1.18. load_profile*</h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  |  style="font-weight: bold;">function load_profile($profile)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function loads the values from an account profile to the module's | 
					
						
							|  |  |  | internal data structures.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span><span style="font-weight: bold;">$profile</span> | 
					
						
							|  |  |  | is an hash array (identifier => array(values))  with all values | 
					
						
							|  |  |  | of an account profile.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3><br> | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>2.2. Functions which are called inside of an account container<br> | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  | <h3>2.2.1. init</h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function init($base)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Every module needs a initializing function that has an<span | 
					
						
							|  |  |  |  style="font-style: italic;"> <span style="font-weight: bold;">account | 
					
						
							|  |  |  | container</span></span> as argument $base.<br> | 
					
						
							|  |  |  | With this account container you can interact with other modules and use | 
					
						
							|  |  |  | several helper functions.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>2.2.2. module_ready</h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function module_ready()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Your module might depend on input of other modules. This function | 
					
						
							| 
									
										
										
										
											2005-08-13 09:14:05 +00:00
										 |  |  | determines if the user can change to your module page or not.<br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | The return value is <span style="font-weight: bold;">true</span> if | 
					
						
							|  |  |  | your module accepts input, otherwise <span style="font-weight: bold;">false</span>.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>2.2.3. module_complete</h3> | 
					
						
							| 
									
										
										
										
											2004-05-19 21:46:14 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-05-19 21:46:14 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function module_complete()</span><br> | 
					
						
							| 
									
										
										
										
											2004-05-19 21:46:14 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-08-13 09:14:05 +00:00
										 |  |  | This function tells LAM if it can create/modify the LDAP account. If | 
					
						
							|  |  |  | your module needs any additional input then set this to <span | 
					
						
							|  |  |  |  style="font-weight: bold;">false</span>. The user will be notified | 
					
						
							|  |  |  | that your module needs more input.<br> | 
					
						
							| 
									
										
										
										
											2004-05-19 21:46:14 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-08-26 08:53:16 +00:00
										 |  |  | <h3>2.2.4. getButtonStatus<br> | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							|  |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							|  |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							|  |  |  |  style="font-weight: bold;">function getButtonStatus()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function tells LAM if the module button on the account page is | 
					
						
							|  |  |  | visible and active.<br> | 
					
						
							|  |  |  | The function may return these values:<br> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">enabled:</span> button is | 
					
						
							|  |  |  | visible and active</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">disabled:</span> button is | 
					
						
							|  |  |  | visible and deactivated (greyed)</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">hidden:</span> no button will be | 
					
						
							|  |  |  | shown<br> | 
					
						
							|  |  |  |   </li> | 
					
						
							|  |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.4. get_help</h3> | 
					
						
							| 
									
										
										
										
											2004-08-28 11:53:40 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-08-28 11:53:40 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |  style="font-weight: bold;">function get_help($helpID)</span><br> | 
					
						
							| 
									
										
										
										
											2004-08-28 11:53:40 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | This function is called when a page requests a help topic from this | 
					
						
							|  |  |  | module.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$helpID</span> is the help identifier; | 
					
						
							|  |  |  | it must only contain a-z, A-Z, 0-9 | 
					
						
							|  |  |  | -, . and _.<br> | 
					
						
							|  |  |  | It must return the help entry as array for the submitted help | 
					
						
							|  |  |  | identifier. The format of the array to be returned is described in | 
					
						
							|  |  |  | section 4. "Help entry syntax".<br> | 
					
						
							| 
									
										
										
										
											2004-08-28 11:53:40 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.7. get_pdfEntries</h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2005-06-19 09:40:30 +00:00
										 |  |  |  style="font-weight: bold;">function get_PDF_Entries()</span><br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function is called when a PDF is to be created.<br> | 
					
						
							|  |  |  | It returns the fields which are printed in the PDF file for the | 
					
						
							|  |  |  | specified account type. At the monent there is no (easy) possibility | 
					
						
							|  |  |  | for the user to decide which fields are to be displayed. Perhaps there | 
					
						
							|  |  |  | will be a PDF config tool in future releases where you can offer the | 
					
						
							|  |  |  | user to decide which fields are to be displayed on the PDF file. The | 
					
						
							|  |  |  | format of the array to be returned is described in section 5. "PDF | 
					
						
							|  |  |  | syntax".<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>2.2.8. dynamic_Message<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function dynamic_Message($attribute, $id)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function is only needed when a status message contains strings | 
					
						
							|  |  |  | with variables.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$attribute</span> is the attribute the | 
					
						
							|  |  |  | message is corresponding to.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$id</span> selects the exact message.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Returnis an array as expected from StatusMessage().<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.9. load_Messages<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function load_Messages()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function is fills the array $this->messages. First Index (x) is | 
					
						
							|  |  |  | the attribute the message is corresponding to.<br> | 
					
						
							|  |  |  | Second Index (y) selects the exact message. Third Index (z) contains an | 
					
						
							|  |  |  | array as expected from StatusMessage().<br> | 
					
						
							|  |  |  | $this->messages[x][y][z]<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.10. load_attributes<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function load_attributes($attr)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function loads attributes when an account should be loaded.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$attr</span> is an array like the | 
					
						
							|  |  |  | array returned by get_ldap_attributes(dn of account) but without count | 
					
						
							|  |  |  | indicees.<br> | 
					
						
							|  |  |  | If all attributes are very simple are part of the dn of account it's | 
					
						
							|  |  |  | possible to just call $this->load_ldap_attributes($attr)<br> | 
					
						
							|  |  |  | which is part of baseModule.<br> | 
					
						
							|  |  |  | The function load_ldap_attributes loads all attributes which fit to the | 
					
						
							|  |  |  | objectClass of the module.<br> | 
					
						
							|  |  |  | This function has t be expanded when attributes have to be loaded from | 
					
						
							|  |  |  | a different DN or handled completly<br> | 
					
						
							|  |  |  | separat.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.11. save_attributes<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function save_attributes()</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function returns an array with changes which should be saved. If | 
					
						
							|  |  |  | all attributes are very simple are part of<br> | 
					
						
							|  |  |  | the dn of account it's possible to just call | 
					
						
							|  |  |  | $this->save_ldap_attributes($this->attributes, $this->orig).<br> | 
					
						
							|  |  |  | The return array has the following syntax: First index is the ldap dn | 
					
						
							|  |  |  | which should be changed. Second<br> | 
					
						
							|  |  |  | index is the kind of modification. Possible values are: 'add', | 
					
						
							|  |  |  | 'modify', 'notchanged', 'remove'.<br> | 
					
						
							|  |  |  | Third index is the attribute which should be changes. Fourth index is | 
					
						
							|  |  |  | an array with all values of<br> | 
					
						
							|  |  |  | an attribute.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"></span>If you want to call lamdaemon | 
					
						
							|  |  |  | first index is 'lamdaemon'. Second index is 'command'. Third index is | 
					
						
							|  |  |  | the command<br> | 
					
						
							|  |  |  | itself which should be executed by lamdaemon.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.12. delete_attributes<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function delete_attributes($post)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function returns an array with the same syntax as | 
					
						
							| 
									
										
										
										
											2005-11-06 11:18:33 +00:00
										 |  |  | save_attributes(). It additional LDAP changes when an account is | 
					
						
							|  |  |  | deleted.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$post</span> is the $_POST array.<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-10 18:35:04 +00:00
										 |  |  | <h3>2.2.13. process_attributes<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2005-03-10 18:35:04 +00:00
										 |  |  |  style="font-weight: bold;">function process_attributes($post)</span><br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  | This function processes user input. It checks user input. It also | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | saves changes in attributes.<br> | 
					
						
							| 
									
										
										
										
											2005-09-07 12:58:34 +00:00
										 |  |  | It may | 
					
						
							|  |  |  | return an array which contains status messages. Each entry is an array | 
					
						
							|  |  |  | containing the status message parameters.<br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  | <span style="font-weight: bold;">$post</span> is the $_POST | 
					
						
							|  |  |  | array.<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-09-07 12:58:34 +00:00
										 |  |  | <span style="font-weight: bold; text-decoration: underline;">Example:</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | return array(0 => array('ERROR', 'Invalid input!', 'This is not | 
					
						
							|  |  |  | allowed here.'));<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-10 18:35:04 +00:00
										 |  |  | <h3>2.2.14. process_*<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2005-03-10 18:35:04 +00:00
										 |  |  |  style="font-weight: bold;">function process_*($post)</span><br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-10 18:35:04 +00:00
										 |  |  | This function has the exact behavoir like process_attributes function. | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | * is the name of the subpage which<br> | 
					
						
							| 
									
										
										
										
											2005-03-10 18:35:04 +00:00
										 |  |  | should be processed.<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | <span style="font-weight: bold;">$post</span> is the $_POST array. It | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  | is needed to interact with the user.<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.15. display_html_attributes($post)<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function display_html_attributes($post)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function creates meta HTML code. The code is the page the module | 
					
						
							|  |  |  | wants to display.<br> | 
					
						
							|  |  |  | Return is an array of meta HTML code.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$post</span> is the $_POST array. It | 
					
						
							|  |  |  | is needed t interact with the user.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.16. display_html_*($post)<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function display_html_*($post)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function has the exact behavoir like display_html_attributes(). * | 
					
						
							|  |  |  | is the name of the subpage which<br> | 
					
						
							|  |  |  | should be displayed.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$post</span> is the $_POST array. It | 
					
						
							|  |  |  | is needed t interact with the user.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><br> | 
					
						
							|  |  |  | </span> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | <h3>2.2.17. display_html_delete($post)<br> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | <table border="0" cellpadding="2" cellspacing="2"> | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |       <td style="vertical-align: top; text-align: center;"><span | 
					
						
							| 
									
										
										
										
											2004-10-16 18:41:39 +00:00
										 |  |  |  style="font-weight: bold;">function display_html_delete($post)</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This function creates meta HTML code. The code will be displayed when | 
					
						
							|  |  |  | an account should be deleted.<br> | 
					
						
							|  |  |  | This is needed to interact, e.g. should the home directory be deleted?<br> | 
					
						
							|  |  |  | The output of all modules is displayed on a single page.<br> | 
					
						
							|  |  |  | Return is an array of meta HTML code.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">$post</span> is the $_POST array. It | 
					
						
							|  |  |  | is needed t interact with the user.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">*: These functions do not need to be | 
					
						
							|  |  |  | implemented if meta data is supplied. See 6 for a list of meta data | 
					
						
							|  |  |  | formats.</span><br> | 
					
						
							| 
									
										
										
										
											2004-02-21 19:27:12 +00:00
										 |  |  | <h3><br> | 
					
						
							|  |  |  | </h3> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <h2>3. Meta HTML code</h2> | 
					
						
							|  |  |  | The modules are not allowed to display HTML code directly but return | 
					
						
							|  |  |  | meta HTML code. This allows to have a common design for all module | 
					
						
							|  |  |  | pages.<br> | 
					
						
							|  |  |  | Meta HTML code is always returned as a three dimensional <span | 
					
						
							|  |  |  |  style="font-weight: bold;">array[a][b][c]</span> where <span | 
					
						
							|  |  |  |  style="font-weight: bold;">a</span> is the row number, <span | 
					
						
							|  |  |  |  style="font-weight: bold;">b</span> is the coumn number and <span | 
					
						
							|  |  |  |  style="font-weight: bold;">c</span> is is a <span | 
					
						
							|  |  |  |  style="font-style: italic;">data elememt</span>.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Format for <span | 
					
						
							|  |  |  |  style="font-style: italic;">data elements</span>:</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | A <span style="font-style: italic;">data element</span> is an array | 
					
						
							|  |  |  | which contains the data to display.<br> | 
					
						
							|  |  |  | All <span style="font-style: italic;">data elements</span> must | 
					
						
							|  |  |  | contail a value <span style="font-weight: bold;">"kind"</span> which | 
					
						
							|  |  |  | defines what kind of element should be displayed.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | These are the possibilies for <span style="font-weight: bold;">kind</span> | 
					
						
							|  |  |  | and what other options are implicated:<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">fieldset:</span> Inserts a | 
					
						
							|  |  |  | fieldset.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">legend:</span> The legend of | 
					
						
							|  |  |  | the fieldset.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">value:</span> A <span | 
					
						
							|  |  |  |  style="font-style: italic;">data element</span>. Can be used | 
					
						
							|  |  |  | recursively.</li> | 
					
						
							|  |  |  |   </ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">help:</span> Adds a help link.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">value:</span> The help number | 
					
						
							|  |  |  | for the help entry.</li> | 
					
						
							| 
									
										
										
										
											2004-10-02 18:46:01 +00:00
										 |  |  |     <li><span style="font-weight: bold;">scope:</span> The account type | 
					
						
							|  |  |  | for the help entry.<br> | 
					
						
							|  |  |  |     </li> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   </ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">input:</span> Adds a HTML input | 
					
						
							|  |  |  | element.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">name:</span> The name of the | 
					
						
							|  |  |  | element, will be used later as variable name when user input is | 
					
						
							|  |  |  | returned.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">type:</span> allowed values: | 
					
						
							|  |  |  | submit, reset, checkbox, text, password, file, hidden</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">checked:</span> Boolean value, | 
					
						
							|  |  |  | if true a checkbox will be checked. This value is only needed or | 
					
						
							|  |  |  | checkboxes.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">disabled:</span> Boolean | 
					
						
							|  |  |  | value, if true the element will be disabled.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">size:</span> The length of the | 
					
						
							|  |  |  | input element, only used for text, password and file.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">maxlength:</span> The maximum | 
					
						
							|  |  |  | size of the input element, only used for text, password and file.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">value:</span> The element will | 
					
						
							|  |  |  | have this value as default. Button elements will have this as caption.</li> | 
					
						
							|  |  |  |   </ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">select:</span> This will add a | 
					
						
							|  |  |  | select field.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">name:</span> The name of the | 
					
						
							|  |  |  | element, will be used later as variable name when user input is | 
					
						
							|  |  |  | returned.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">multiple:</span> Boolean | 
					
						
							|  |  |  | value, if set to true the user can select more than one entry.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">options:</span> Array of | 
					
						
							|  |  |  | string. This is the list of option values the user can select.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">options_selected:</span> Array | 
					
						
							|  |  |  | of string. This is the list of pre selected elements, must contain | 
					
						
							|  |  |  | values that are also in <span style="font-style: italic;">options</span>.</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">size:</span> The size of the | 
					
						
							|  |  |  | select field, if set to 1 a dropdown box will be displayed.</li> | 
					
						
							| 
									
										
										
										
											2005-08-13 11:31:26 +00:00
										 |  |  |     <li><span style="font-weight: bold;">noSorting:</span> If set to | 
					
						
							|  |  |  | true then the entries will not be sorted. Default is false.<br> | 
					
						
							|  |  |  |     </li> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   </ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">table:</span> Adds a table. Can | 
					
						
							|  |  |  | be used recursively.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">value:</span> A <span | 
					
						
							|  |  |  |  style="font-style: italic;">data element</span>. Can be used | 
					
						
							|  |  |  | recursively.</li> | 
					
						
							|  |  |  |   </ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">text:</span> Inserts a text | 
					
						
							|  |  |  | element.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">text:</span> The text to | 
					
						
							|  |  |  | display.</li> | 
					
						
							|  |  |  |   </ul> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  |   <li><span style="font-weight: bold;">image:</span> Displays an image.</li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">path:</span> Path to the image</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">width:</span> Width of the | 
					
						
							|  |  |  | image</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">height:</span> Height of the | 
					
						
							|  |  |  | image</li> | 
					
						
							|  |  |  |     <li><span style="font-weight: bold;">alt:</span> Alt text of the | 
					
						
							|  |  |  | image<br> | 
					
						
							|  |  |  |     </li> | 
					
						
							|  |  |  |   </ul> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Beneath those values a <span style="font-weight: bold;">"td"</span> | 
					
						
							|  |  |  | value may be added. This has to be an array with one or more of these | 
					
						
							|  |  |  | options:<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">colspan:</span> Like the HTML | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | colspan attribute for td elements</li> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <li><span style="font-weight: bold;">rowspan:</span> Like the HTML | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | rowspan attribute for td elements</li> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  |   <li><span style="font-weight: bold;">align:</span> | 
					
						
							| 
									
										
										
										
											2005-03-29 10:04:19 +00:00
										 |  |  | left/center/right/justify Like the HTML align attribute</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">valign:</span> top/middle/bottom | 
					
						
							|  |  |  | Like the HTML valign attribute</li> | 
					
						
							| 
									
										
										
										
											2005-07-05 12:46:53 +00:00
										 |  |  |   <li><span style="font-weight: bold;">width:</span> Like the HTML | 
					
						
							|  |  |  | height attribute for td elements<br> | 
					
						
							|  |  |  |   </li> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  | Input buttons which should load a different subpage of a module must | 
					
						
							|  |  |  | have a special <span style="font-style: italic;">name </span>attribute:<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">name</span> => 'form_subpage_' . <span | 
					
						
							|  |  |  |  style="font-style: italic;"><module name></span> . '_' . <span | 
					
						
							|  |  |  |  style="font-style: italic;"><subpage name></span> . '_' . <span | 
					
						
							|  |  |  |  style="font-style: italic;"><button name></span><br> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><module name>:</span> name | 
					
						
							|  |  |  | of this account module (e.g. 'posixAccount')</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"><subpage name>:</span> | 
					
						
							|  |  |  | name of next subpage (e.g. 'attributes')</li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;"> <button name>:</span> a | 
					
						
							|  |  |  | name to distinguish buttons (e.g. 'ok'/'cancel'/'back')<br> | 
					
						
							|  |  |  |   </li> | 
					
						
							|  |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-02-18 19:36:10 +00:00
										 |  |  | <span style="font-weight: bold;">Example:</span><span | 
					
						
							|  |  |  |  style="font-family: monospace;"><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span><code>array(<br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  |   0 => array(<br> | 
					
						
							|  |  |  |     0 => array("kind" => "text", "text" => | 
					
						
							|  |  |  | "This is an | 
					
						
							| 
									
										
										
										
											2004-02-18 19:36:10 +00:00
										 |  |  | example", "td" => array("colspan" => 3))<br> | 
					
						
							|  |  |  |   ), <br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  |   1 => array(<br> | 
					
						
							|  |  |  |     0 => array("kind" => "text", "text" => | 
					
						
							|  |  |  | "Input:"),<br> | 
					
						
							|  |  |  |     1 => array("kind" => "input", "name" => | 
					
						
							|  |  |  | "myinput", | 
					
						
							| 
									
										
										
										
											2004-02-18 19:36:10 +00:00
										 |  |  | "type" => "text"),<br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  |     2 => array("kind" => "help", "value" => "42")<br> | 
					
						
							|  |  |  |   ),<br> | 
					
						
							|  |  |  | </code><code>  2 => array(<br> | 
					
						
							|  |  |  |     0 => array("kind" => "input", "name" => | 
					
						
							|  |  |  | 'form_subpage_myModule_attributes_back', "value" => _("Back"))<br> | 
					
						
							| 
									
										
										
										
											2004-02-18 19:36:10 +00:00
										 |  |  |   )<br> | 
					
						
							| 
									
										
										
										
											2005-09-01 15:20:15 +00:00
										 |  |  | </code><code>)<br> | 
					
						
							| 
									
										
										
										
											2004-02-18 19:36:10 +00:00
										 |  |  | </code><br> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-03-15 16:30:52 +00:00
										 |  |  | <h3><br> | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  | <h2>4. Help entry syntax</h2> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | The array that is returned by the get_help function must follow the | 
					
						
							|  |  |  | below described syntax. Fields marked <b>REQUIRED</b> are neccessary | 
					
						
							|  |  |  | under any circumstances. Fields marked <b>OPTIONAL</b> may be left out | 
					
						
							|  |  |  | when not needed.<br> | 
					
						
							|  |  |  | There are basically two different types of help entries that can be | 
					
						
							|  |  |  | used. Internal help entries, that means the headline, text, etc is | 
					
						
							|  |  |  | included in the help entry or external help entries, that means the | 
					
						
							|  |  |  | help entry has only a reference pointing to a HTML/PHP page that offers | 
					
						
							|  |  |  | the help entry. | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3><br> | 
					
						
							|  |  |  | 4.1. Internal help entries</h3> | 
					
						
							|  |  |  | <span style="font-weight: bold;">ext</span> <span | 
					
						
							|  |  |  |  style="font-style: italic;">(REQUIRED)</span> <br> | 
					
						
							|  |  |  | Must be <b>FALSE</b> in this case. | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Headline</span> <span | 
					
						
							|  |  |  |  style="font-style: italic;">(REQUIRED)</span> <br> | 
					
						
							|  |  |  | The headline of this help entry. Can consist of any alpha-numeric | 
					
						
							|  |  |  | characters. No HTML/CSS elements are not allowed here. | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Text</span> <span | 
					
						
							|  |  |  |  style="font-style: italic;">(REQUIRED)</span> <br> | 
					
						
							|  |  |  | The text of this help entry. Can constist if any alpha-numeric | 
					
						
							|  |  |  | characters and can contain placeholder for variables passed to this | 
					
						
							|  |  |  | help entry. The placeholder must follow the syntax for placeholder | 
					
						
							|  |  |  | defined by the PHP <b>printf</b> function. HTML/CSS elements are | 
					
						
							|  |  |  | allowed here as long as they follow the XHTML1.0 Strict specification.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | When placeholders are included you can submit the values that should be | 
					
						
							|  |  |  | displayed there as arguments when calling the <b>templates/help.php</b> | 
					
						
							|  |  |  | file. There they are attached as <b>var1</b>, <b>var2</b> and so on. | 
					
						
							|  |  |  | The names must follow the following rules:<br> | 
					
						
							| 
									
										
										
										
											2004-03-17 17:27:56 +00:00
										 |  |  | <ul> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  |   <li>1. They must be named <b>var$i</b> where $i is any positive | 
					
						
							|  |  |  | number except the '0'.</li> | 
					
						
							|  |  |  |   <li>2. This number ($i) must either be '1' or $i -1 must be present.</li> | 
					
						
							| 
									
										
										
										
											2004-03-17 17:27:56 +00:00
										 |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-04-03 14:43:40 +00:00
										 |  |  | <span style="font-weight: bold;">SeeAlso</span> <span | 
					
						
							|  |  |  |  style="font-style: italic;">(OPTIONAL)</span> <br> | 
					
						
							|  |  |  | An array of references to anonther related subjects. Each row of the | 
					
						
							|  |  |  | array must contain a field called "text" with the text that should be | 
					
						
							|  |  |  | displayed and may contain a field called "link" which is used as value | 
					
						
							|  |  |  | for the href attribute of a HTML <a> tag when set. | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </a> | 
					
						
							|  |  |  | <h3><a><br> | 
					
						
							|  |  |  | 4.2. External help entries</a></h3> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><a>ext</a></span><a> <span | 
					
						
							|  |  |  |  style="font-style: italic;">(REQUIRED)</span> <br> | 
					
						
							|  |  |  | Must be <b>TRUE</b> in this case. | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">Link</span> <span | 
					
						
							|  |  |  |  style="font-style: italic;">(REQUIRED)</span> <br> | 
					
						
							|  |  |  | The complete filename of the file stored under the help/ directory | 
					
						
							|  |  |  | which should be displayed when this help entry is called. | 
					
						
							| 
									
										
										
										
											2004-05-19 21:46:14 +00:00
										 |  |  | </a><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3><br> | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  | <h2>5. PDF syntax</h2> | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  | The get_pdfEntries() function uses XML formatted commands to define the | 
					
						
							|  |  |  | PDF output. Each part in the PDF document is surrounded by <span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">"<block>"</span> | 
					
						
							|  |  |  | and <span style="font-weight: bold; font-style: italic;">"</block>"</span>.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Inside the <block> tags there are different ways to format the | 
					
						
							|  |  |  | output:<br> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">simple line with attribute name | 
					
						
							|  |  |  | and value:</span> <span style="font-weight: bold; font-style: italic;"><block><key></span>attribute | 
					
						
							|  |  |  | name<span style="font-weight: bold; font-style: italic;"></key><value></span>attribute | 
					
						
							|  |  |  | value<span style="font-weight: bold; font-style: italic;"></value></block></span></li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">table:</span> <span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><block><key></span>attribute | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  | name<span style="font-weight: bold; font-style: italic;"></key><tr><td></span>value<span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><td></span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><td></span>value<span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><td></span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"></tr></block><block><tr><td></span>value<span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"></td></span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><td></span>value<span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><td></span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"></tr></block></span><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"></span></li> | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Special commands:<br style="font-weight: bold;"> | 
					
						
							|  |  |  | <ul> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">Alignment in <td>:</span> | 
					
						
							|  |  |  | You can specify the alignment in <td> tags with <span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">align=(L|R|C)</span> | 
					
						
							|  |  |  | (e.g. <td align=\"L\">)</li> | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  |   <li><span style="font-weight: bold;">Cell width: <td></span> | 
					
						
							|  |  |  | allows an attribute "width" to set the cell width (e.g. <td | 
					
						
							|  |  |  | width=20%> or <td width=30>).<br> | 
					
						
							|  |  |  |   </li> | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  |   <li><span style="font-weight: bold;">Line breaks:</span> Line breaks | 
					
						
							|  |  |  | can be specified by adding a <span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"><br /></span> | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  | tag. The new line will start at the left border of the PDF document.</li> | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  | </ul> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold; text-decoration: underline;">Examples:</span><br | 
					
						
							|  |  |  |  style="font-weight: bold; text-decoration: underline;"> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">1. Simple name+value lines:</span><br | 
					
						
							|  |  |  |  style="font-weight: bold;"> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | In most cases you will just want to display a single line per attribute | 
					
						
							|  |  |  | with its name and value.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  |     <span style="font-weight: bold;">'myAttribute'</span> | 
					
						
							|  |  |  | => <span style="font-weight: bold;">'<span | 
					
						
							|  |  |  |  style="font-style: italic;"><block><key></span></span>AttrName<span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"></key><value></span>12345<span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;"></value></block></span><span | 
					
						
							|  |  |  |  style="font-weight: bold;">'</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This will give the following PDF output: <span | 
					
						
							|  |  |  |  style="font-weight: bold;">AttrName:</span> 12345<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><br> | 
					
						
							|  |  |  | 2. Multiline values:</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | Sometimes you have multivalued attributes where it is not applicable to | 
					
						
							|  |  |  | write all values in one line but where you want to list your values one | 
					
						
							|  |  |  | below the other or show a table.<br> | 
					
						
							|  |  |  | This can be done by using the <td> tag. This example only uses | 
					
						
							|  |  |  | one column but can just use more <td> tags per <block> tag | 
					
						
							|  |  |  | to display more columns.<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  |     <span style="font-weight: bold;">'myAttribute'</span> | 
					
						
							|  |  |  | => <span style="font-weight: bold;">'<span | 
					
						
							|  |  |  |  style="font-style: italic;"><block><key></span></span>AttrName<span | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  |  style="font-weight: bold; font-style: italic;"></key><tr><td | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  | align=\"L\"></span>123<span | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  |  style="font-weight: bold; font-style: italic;"></td></tr></block><block><tr><td | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  | align=\"L\"></span>456<span | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  |  style="font-weight: bold; font-style: italic;"></td></tr></block><block><tr><td | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  | align=\"L\"></span>789<span | 
					
						
							| 
									
										
										
										
											2005-07-28 09:01:41 +00:00
										 |  |  |  style="font-weight: bold; font-style: italic;"></td></tr></block></span><span | 
					
						
							| 
									
										
										
										
											2005-07-10 11:16:07 +00:00
										 |  |  |  style="font-weight: bold;">'</span><br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | This will give the following PDF output: <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <table | 
					
						
							|  |  |  |  style="text-align: left; background-color: rgb(255, 255, 255); width: 121px; height: 79px;" | 
					
						
							|  |  |  |  border="0" cellpadding="2" cellspacing="2"> | 
					
						
							|  |  |  |   <tbody> | 
					
						
							|  |  |  |     <tr> | 
					
						
							|  |  |  |       <td style="vertical-align: top;"><span style="font-weight: bold;">AttrName:</span><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |       <td style="vertical-align: top;">123<br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |     <tr> | 
					
						
							|  |  |  |       <td style="vertical-align: top;"><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |       <td | 
					
						
							|  |  |  |  style="vertical-align: top; background-color: rgb(255, 255, 255);">456<br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |     <tr> | 
					
						
							|  |  |  |       <td style="vertical-align: top;"><br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |       <td style="vertical-align: top;">789<br> | 
					
						
							|  |  |  |       </td> | 
					
						
							|  |  |  |     </tr> | 
					
						
							|  |  |  |   </tbody> | 
					
						
							|  |  |  | </table> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  | <br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h2>6. Module meta data</h2> | 
					
						
							| 
									
										
										
										
											2004-06-13 19:58:58 +00:00
										 |  |  | <h3>6.1 can_manage() | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  |     "account_types" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">    Example: | 
					
						
							|  |  |  | array("user", "host")</span><br style="font-weight: bold;"> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <h3>6.2 is_base_module()</h3> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |     "is_base" => boolean<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-13 19:58:58 +00:00
										 |  |  | <h3>6.3 get_ldap_filter()</h3> | 
					
						
							| 
									
										
										
										
											2004-06-11 15:44:49 +00:00
										 |  |  |     "ldap_filter" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   Example:</span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"> array('or' => | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  | 'objectClass=posixAccount', 'and' => '(!(uid=*$))')<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>6.4 get_RDNAttributes()</h3> | 
					
						
							|  |  |  |     "RDN" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   Example:</span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"> array('uid' => | 
					
						
							|  |  |  | 'normal', 'cn' => 'low')<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span> | 
					
						
							|  |  |  | <span style="font-style: italic; font-weight: bold;"></span> | 
					
						
							|  |  |  | <h3>6.5 get_dependencies()<br> | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  |     "dependencies" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   Example:</span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"> array(</span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"><span | 
					
						
							|  |  |  |  style="font-weight: bold; font-style: italic;">"depends" | 
					
						
							|  |  |  | => array("posixAccount", array("qmail", "sendmail")), "conflicts" | 
					
						
							|  |  |  | => array("exim")</span></span><span | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  |  style="font-style: italic; font-weight: bold;">)<br> | 
					
						
							|  |  |  | </span><br> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>6.6 get_profileOptions()<br> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  |     "profile_options" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   <span | 
					
						
							|  |  |  |  style="font-style: italic;">Syntax for array is the same as for the | 
					
						
							|  |  |  | return value of get_profileOptions().<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span></span> | 
					
						
							| 
									
										
										
										
											2004-10-06 18:17:22 +00:00
										 |  |  | <h3>6.7 check_profileOptions()<br> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  |     "profile_checks" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   The keys of the array are | 
					
						
							|  |  |  | the names of the option identifiers.<br> | 
					
						
							|  |  |  |    Each array element is an array containing these values:<br> | 
					
						
							|  |  |  | <br> | 
					
						
							| 
									
										
										
										
											2004-06-20 17:32:02 +00:00
										 |  |  | </span> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  | <ul> | 
					
						
							|  |  |  |   <li style="font-weight: bold;">type:<span style="font-weight: normal;"> | 
					
						
							|  |  |  | determines how to check input</span></li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li style="font-weight: bold;">regex:<span | 
					
						
							|  |  |  |  style="font-weight: normal;"> check with regular expression from <span | 
					
						
							|  |  |  |  style="font-style: italic;">regex</span> variable, case sensitive</span></li> | 
					
						
							|  |  |  |     <li style="font-weight: bold;">regex_i:<span | 
					
						
							|  |  |  |  style="font-weight: normal;"> check with regular expression from <span | 
					
						
							|  |  |  |  style="font-style: italic;">regex</span> variable, case insensitive</span></li> | 
					
						
							| 
									
										
										
										
											2004-07-13 14:51:28 +00:00
										 |  |  |     <li style="font-weight: bold;"><span style="font-weight: normal;"><span | 
					
						
							|  |  |  |  style="font-weight: bold;">int_greater:</span> integer value of <span | 
					
						
							|  |  |  |  style="font-style: italic;">cmp_name1</span> must be | 
					
						
							|  |  |  | greater than the integer value from the option <span | 
					
						
							|  |  |  |  style="font-style: italic;">cmp_name2</span></span></li> | 
					
						
							|  |  |  |     <li style="font-weight: bold;"><span style="font-weight: normal;"><span | 
					
						
							|  |  |  |  style="font-weight: bold;">int_greaterOrEqual:</span> integer value</span><span | 
					
						
							|  |  |  |  style="font-weight: normal;"><span style="font-weight: normal;"> of <span | 
					
						
							|  |  |  |  style="font-style: italic;">cmp_name1</span></span></span><span | 
					
						
							|  |  |  |  style="font-weight: normal;"> | 
					
						
							|  |  |  | must be greater or equal than the integer value from the option <span | 
					
						
							|  |  |  |  style="font-style: italic;">cmp_name2</span></span></li> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  |   </ul> | 
					
						
							|  |  |  |   <li style="font-weight: bold;">error_message:<span | 
					
						
							|  |  |  |  style="font-weight: normal;"> message that is displayed if input value | 
					
						
							|  |  |  | was syntactically incorrect</span></li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li style="font-weight: bold;"><span style="font-weight: normal;">array | 
					
						
							|  |  |  | to build StatusMessages (0 => message type, 1 => message | 
					
						
							|  |  |  | head, 2 => message text, 3 => additional variables)</span><span | 
					
						
							|  |  |  |  style="font-weight: normal;"></span></li> | 
					
						
							|  |  |  |   </ul> | 
					
						
							|  |  |  |   <li style="font-weight: bold;">regex:<span | 
					
						
							|  |  |  |  style="font-weight: normal;"> regular expression string (only if <span | 
					
						
							|  |  |  |  style="font-style: italic;">type</span> is <span | 
					
						
							|  |  |  |  style="font-style: italic;">regex</span>/<span | 
					
						
							| 
									
										
										
										
											2004-07-13 14:51:28 +00:00
										 |  |  |  style="font-style: italic;">regex_i</span>)</span></li> | 
					
						
							|  |  |  |   <li style="font-weight: bold;"><span style="font-weight: normal;"><span | 
					
						
							|  |  |  |  style="font-weight: normal;"><span style="font-weight: bold;">cmp_name1:</span> | 
					
						
							|  |  |  | name of first input | 
					
						
							|  |  |  | variable that is used for comparison (only if <span | 
					
						
							|  |  |  |  style="font-style: italic;">type</span> is <span | 
					
						
							|  |  |  |  style="font-style: italic;">int_greater/int_greaterOrEqual</span>)</span></span></li> | 
					
						
							|  |  |  |   <li style="font-weight: bold;"><span style="font-weight: normal;"><span | 
					
						
							|  |  |  |  style="font-weight: bold;">cmp_name2:</span> name of second input | 
					
						
							|  |  |  | variable that is used for comparison (only if <span | 
					
						
							|  |  |  |  style="font-style: italic;">type</span> is <span | 
					
						
							|  |  |  |  style="font-style: italic;">int_greater/int_greaterOrEqual</span>)<br> | 
					
						
							|  |  |  |     </span></li> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  |   <li><span style="font-weight: bold;">required:</span> <span | 
					
						
							|  |  |  |  style="font-style: italic;">true</span> or <span | 
					
						
							|  |  |  |  style="font-style: italic;">false</span>, if this input field must be | 
					
						
							|  |  |  | filled set to true (optional)<span style="font-weight: bold;"><br> | 
					
						
							|  |  |  |     </span></li> | 
					
						
							|  |  |  |   <li><span style="font-weight: bold;">required_message:</span> message<span | 
					
						
							|  |  |  |  style="font-weight: normal;"> that is displayed if no input value was | 
					
						
							|  |  |  | given</span><span style="font-weight: normal;"> (only if <span | 
					
						
							|  |  |  |  style="font-style: italic;">required</span> == true)</span><span | 
					
						
							|  |  |  |  style="font-weight: bold;"></span></li> | 
					
						
							|  |  |  |   <ul> | 
					
						
							|  |  |  |     <li> array to build StatusMessages (0 => message type, 1 | 
					
						
							|  |  |  | => message | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | head, 2 => message text, 3 => additional variables)</li> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  |   </ul> | 
					
						
							|  |  |  | </ul> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | <br> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  | <h3>6.8 load_profile()<br> | 
					
						
							|  |  |  | </h3> | 
					
						
							|  |  |  |     "profile_mappings" => array('profile_identifier1' | 
					
						
							|  |  |  | => 'LDAP_attribute1', 'profile_identifier2' => 'LDAP_attribute2')<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  |     The mapped values are stored directly in | 
					
						
							|  |  |  | $this->attributes.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><span style="font-style: italic;"><br> | 
					
						
							|  |  |  | </span></span> | 
					
						
							|  |  |  | <h3>6.9 get_configOptions()<br> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  |     "config_options" => array('user' => array, | 
					
						
							|  |  |  | 'host' => array, 'all' => array)<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  |     The values from <span style="font-weight: bold;">'all'</span> | 
					
						
							|  |  |  | are always returned, the other values only if they are inside the <span | 
					
						
							|  |  |  |  style="font-style: italic;">$scopes</span> array.<br | 
					
						
							|  |  |  |  style="font-weight: bold;"> | 
					
						
							|  |  |  | <br style="font-weight: bold;"> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   <span | 
					
						
							|  |  |  |  style="font-style: italic;">Syntax for sub arrays is the same as for | 
					
						
							|  |  |  | the | 
					
						
							|  |  |  | return value of get_configOptions().<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span></span> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  | <h3>6.10 get_configDescriptions()<br> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  |     "config_descriptions" => array<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | <span style="font-weight: bold;">   <span | 
					
						
							|  |  |  |  style="font-style: italic;">Syntax for array is the same as for the | 
					
						
							|  |  |  | return value of get_configDescriptions().<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span></span> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  | <h3>6.11 check_configOptions()<br> | 
					
						
							| 
									
										
										
										
											2004-07-24 17:14:39 +00:00
										 |  |  | </h3> | 
					
						
							|  |  |  |     "config_checks" => array('user' => array, | 
					
						
							|  |  |  | 'host' => 'array', 'all' => array)<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  |     The values from 'all' are always used for checking, | 
					
						
							|  |  |  | the other values only if they are inside the <span | 
					
						
							|  |  |  |  style="font-style: italic;">$scopes</span> array.<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><br style="font-weight: bold;"> | 
					
						
							|  |  |  | </span><span style="font-weight: bold;">   <span | 
					
						
							|  |  |  |  style="font-style: italic;">Syntax for sub arrays is the same as for | 
					
						
							|  |  |  | check_profileOptions().<br> | 
					
						
							|  |  |  | <br> | 
					
						
							|  |  |  | </span></span> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  | <h3>6.12 get_uploadColumns()</h3> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | "upload_columns" => array()<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><br> | 
					
						
							|  |  |  | <span style="font-style: italic;">Syntax for array is the same as for | 
					
						
							|  |  |  | the | 
					
						
							|  |  |  | return value of get_uploadColumns().<br> | 
					
						
							|  |  |  | </span></span><br> | 
					
						
							| 
									
										
										
										
											2005-01-07 10:51:56 +00:00
										 |  |  | <h3>6.13 get_uploadPreDepends()</h3> | 
					
						
							| 
									
										
										
										
											2004-10-19 16:37:52 +00:00
										 |  |  | "upload_preDepends" => array()<br> | 
					
						
							|  |  |  | <span style="font-weight: bold;"><br> | 
					
						
							|  |  |  | <span style="font-style: italic;">Syntax for array is the same as for | 
					
						
							|  |  |  | the | 
					
						
							|  |  |  | return value of get_uploadPreDepends().<br> | 
					
						
							|  |  |  | </span></span><br> | 
					
						
							| 
									
										
										
										
											2004-07-01 15:54:33 +00:00
										 |  |  | <span style="font-weight: bold;"></span><span style="font-weight: bold;"><span | 
					
						
							|  |  |  |  style="font-style: italic;"></span></span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"></span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"></span><span | 
					
						
							|  |  |  |  style="font-style: italic; font-weight: bold;"></span> | 
					
						
							| 
									
										
										
										
											2004-02-17 21:08:08 +00:00
										 |  |  | </body> | 
					
						
							|  |  |  | </html> |