From 59cf91925ca8da43d2427331b23e4673b0e53095 Mon Sep 17 00:00:00 2001 From: Tarik Gasmi Date: Mon, 14 May 2007 08:03:48 +0000 Subject: Other webinterface data. git-svn-id: http://svn.openslx.org/svn/openslx/trunk@1077 95ad53e4-c205-0410-b2fa-d234c58c8868 --- .../webinterface/computers/computers.dwt | 79 ++ .../webinterface/computers/computers.php | 28 + .../computers/computers_footer.inc.php | 18 + .../computers/computers_header.inc.php | 21 + .../webinterface/computers/computers_menu.php | 382 ++++++ .../webinterface/computers/computers_menu.save.php | 188 +++ .../webinterface/computers/computers_start.dwt | 42 + .../webinterface/computers/delete_confirm.php | 39 + .../webinterface/computers/dhcphost.dwt | 84 ++ .../webinterface/computers/dhcphost.php | 278 ++++ .../webinterface/computers/dhcphost_change.php | 177 +++ ldap-site-mngmt/webinterface/computers/group.dwt | 397 ++++++ ldap-site-mngmt/webinterface/computers/group.php | 120 ++ .../webinterface/computers/group_add.php | 84 ++ .../webinterface/computers/group_change.php | 252 ++++ .../webinterface/computers/group_delete.php | 47 + .../webinterface/computers/groupoverview.dwt | 38 + .../webinterface/computers/groupoverview.php | 64 + ldap-site-mngmt/webinterface/computers/host.dwt | 421 ++++++ ldap-site-mngmt/webinterface/computers/host.php | 95 ++ .../webinterface/computers/host_add.php | 101 ++ .../webinterface/computers/host_change.php | 396 ++++++ .../webinterface/computers/host_delete.php | 47 + .../webinterface/computers/hostoverview.dwt | 40 + .../webinterface/computers/hostoverview.php | 82 ++ ldap-site-mngmt/webinterface/computers/hwhost.dwt | 60 + ldap-site-mngmt/webinterface/computers/hwhost.php | 78 ++ .../webinterface/computers/hwhost_change.php | 127 ++ .../computers/machineconfig_default.dwt | 323 +++++ .../computers/machineconfig_default.php | 75 ++ .../webinterface/computers/mc_wochenplan.php | 154 +++ ldap-site-mngmt/webinterface/computers/mcdef.dwt | 293 +++++ ldap-site-mngmt/webinterface/computers/mcdef.php | 137 ++ .../webinterface/computers/mcdef_add.php | 160 +++ .../webinterface/computers/mcdef_change.php | 402 ++++++ .../webinterface/computers/mcdef_copy.php | 111 ++ .../webinterface/computers/mcdef_delete.php | 40 + ldap-site-mngmt/webinterface/computers/menu.dwt | 40 + .../webinterface/computers/menuentry.dwt | 249 ++++ .../webinterface/computers/menuentry.php | 170 +++ .../webinterface/computers/menuentry_add.php | 263 ++++ .../webinterface/computers/menuentry_change.php | 208 +++ .../webinterface/computers/menuentry_delete.php | 41 + .../webinterface/computers/menuposition_down.php | 42 + .../webinterface/computers/menuposition_up.php | 40 + .../webinterface/computers/new_group.dwt | 101 ++ .../webinterface/computers/new_group.php | 76 ++ .../webinterface/computers/new_host.dwt | 112 ++ .../webinterface/computers/new_host.php | 53 + .../webinterface/computers/new_mcdef.dwt | 184 +++ .../webinterface/computers/new_mcdef.php | 74 ++ .../webinterface/computers/new_menuentry.dwt | 191 +++ .../webinterface/computers/new_menuentry.php | 150 +++ ldap-site-mngmt/webinterface/computers/new_pxe.dwt | 175 +++ ldap-site-mngmt/webinterface/computers/new_pxe.php | 130 ++ ldap-site-mngmt/webinterface/computers/pxe.dwt | 476 +++++++ ldap-site-mngmt/webinterface/computers/pxe.php | 252 ++++ ldap-site-mngmt/webinterface/computers/pxe_add.php | 228 ++++ .../webinterface/computers/pxe_change.php | 437 ++++++ .../webinterface/computers/pxe_copy.php | 180 +++ .../webinterface/computers/pxe_delete.php | 42 + .../webinterface/dhcp/delete_confirm.php | 37 + ldap-site-mngmt/webinterface/dhcp/dhcp.dwt | 78 ++ ldap-site-mngmt/webinterface/dhcp/dhcp.php | 27 + .../webinterface/dhcp/dhcp_footer.inc.php | 18 + .../webinterface/dhcp/dhcp_header.inc.php | 21 + ldap-site-mngmt/webinterface/dhcp/dhcp_menu.php | 199 +++ ldap-site-mngmt/webinterface/dhcp/dhcp_start.dwt | 27 + ldap-site-mngmt/webinterface/dhcp/dhcpservice.dwt | 257 ++++ ldap-site-mngmt/webinterface/dhcp/dhcpservice.php | 164 +++ .../webinterface/dhcp/dhcpservice_add.php | 70 + .../webinterface/dhcp/dhcpservice_change.php | 202 +++ .../webinterface/dhcp/dhcpservice_delete.php | 37 + ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.dwt | 207 +++ ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.php | 126 ++ .../webinterface/dhcp/dhcpsubnet_add.php | 71 + .../webinterface/dhcp/dhcpsubnet_change.php | 292 +++++ .../webinterface/dhcp/dhcpsubnet_delete.php | 34 + ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.dwt | 37 + ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.php | 65 + ldap-site-mngmt/webinterface/dhcp/menu.dwt | 29 + .../webinterface/dhcp/new_dhcpservice.dwt | 151 +++ .../webinterface/dhcp/new_dhcpservice.php | 79 ++ .../webinterface/dhcp/new_dhcpsubnet.dwt | 149 +++ .../webinterface/dhcp/new_dhcpsubnet.php | 84 ++ ldap-site-mngmt/webinterface/dhcp/no_dhcp.dwt | 25 + ldap-site-mngmt/webinterface/dhcp/no_dhcp.php | 27 + ldap-site-mngmt/webinterface/dns/dns.dwt | 79 ++ ldap-site-mngmt/webinterface/dns/dns.php | 26 + .../webinterface/dns/dns_footer.inc.php | 18 + .../webinterface/dns/dns_header.inc.php | 21 + ldap-site-mngmt/webinterface/dns/dns_menu.php | 72 + ldap-site-mngmt/webinterface/dns/dns_start.dwt | 30 + ldap-site-mngmt/webinterface/dns/menu.dwt | 22 + ldap-site-mngmt/webinterface/ip/ip.dwt | 88 ++ ldap-site-mngmt/webinterface/ip/ip.php | 29 + ldap-site-mngmt/webinterface/ip/ip_blocks.inc.php | 68 + ldap-site-mngmt/webinterface/ip/ip_deleg.dwt | 40 + ldap-site-mngmt/webinterface/ip/ip_deleg.php | 102 ++ .../webinterface/ip/ip_deleg_change.php | 198 +++ ldap-site-mngmt/webinterface/ip/ip_dhcp.dwt | 39 + ldap-site-mngmt/webinterface/ip/ip_dhcp.php | 54 + ldap-site-mngmt/webinterface/ip/ip_dhcp_change.php | 146 +++ ldap-site-mngmt/webinterface/ip/ip_footer.inc.php | 19 + ldap-site-mngmt/webinterface/ip/ip_header.inc.php | 22 + ldap-site-mngmt/webinterface/ip/ip_menu.php | 69 + ldap-site-mngmt/webinterface/ip/ip_rechner.dwt | 39 + ldap-site-mngmt/webinterface/ip/ip_rechner.php | 65 + .../webinterface/ip/ip_rechner_change.php | 125 ++ ldap-site-mngmt/webinterface/ip/ip_start.dwt | 36 + ldap-site-mngmt/webinterface/ip/ipblocks.dwt | 11 + ldap-site-mngmt/webinterface/ip/menu.dwt | 22 + .../webinterface/lib/au_management_functions.php | 1186 +++++++++++++++++ ldap-site-mngmt/webinterface/lib/commonlib.inc.php | 552 ++++++++ ldap-site-mngmt/webinterface/lib/config.inc.php | 27 + .../webinterface/lib/dhcp_management_functions.php | 625 +++++++++ .../webinterface/lib/host_management_functions.php | 385 ++++++ .../webinterface/lib/ip_management_functions.php | 1385 ++++++++++++++++++++ ldap-site-mngmt/webinterface/lib/ldap.inc.php | 996 ++++++++++++++ ldap-site-mngmt/webinterface/lib/ldap2.inc.php | 350 +++++ .../webinterface/lib/rbs_management_functions.php | 591 +++++++++ ldap-site-mngmt/webinterface/lib/syntax_check.php | 268 ++++ ldap-site-mngmt/webinterface/login_form.inc.html | 18 + .../webinterface/rbs/delete_confirm.php | 90 ++ ldap-site-mngmt/webinterface/rbs/gbm.dwt | 129 ++ ldap-site-mngmt/webinterface/rbs/gbm.php | 110 ++ ldap-site-mngmt/webinterface/rbs/gbm_add.php | 68 + ldap-site-mngmt/webinterface/rbs/gbm_change.php | 210 +++ ldap-site-mngmt/webinterface/rbs/gbm_delete.php | 40 + ldap-site-mngmt/webinterface/rbs/gbm_overview.dwt | 29 + ldap-site-mngmt/webinterface/rbs/gbm_overview.php | 56 + ldap-site-mngmt/webinterface/rbs/menu.dwt | 31 + ldap-site-mngmt/webinterface/rbs/menuentry.dwt | 247 ++++ ldap-site-mngmt/webinterface/rbs/menuentry.php | 158 +++ ldap-site-mngmt/webinterface/rbs/menuentry_add.php | 258 ++++ .../webinterface/rbs/menuentry_change.php | 207 +++ .../webinterface/rbs/menuentry_delete.php | 41 + .../webinterface/rbs/menuposition_down.php | 41 + .../webinterface/rbs/menuposition_up.php | 39 + ldap-site-mngmt/webinterface/rbs/new_gbm.dwt | 91 ++ ldap-site-mngmt/webinterface/rbs/new_gbm.php | 66 + ldap-site-mngmt/webinterface/rbs/new_menuentry.dwt | 188 +++ ldap-site-mngmt/webinterface/rbs/new_menuentry.php | 166 +++ ldap-site-mngmt/webinterface/rbs/new_pxe.dwt | 157 +++ ldap-site-mngmt/webinterface/rbs/new_pxe.php | 95 ++ ldap-site-mngmt/webinterface/rbs/new_rbservice.dwt | 117 ++ ldap-site-mngmt/webinterface/rbs/new_rbservice.php | 107 ++ ldap-site-mngmt/webinterface/rbs/no_rbservice.dwt | 22 + ldap-site-mngmt/webinterface/rbs/no_rbservice.php | 32 + ldap-site-mngmt/webinterface/rbs/pxe.dwt | 453 +++++++ ldap-site-mngmt/webinterface/rbs/pxe.php | 221 ++++ ldap-site-mngmt/webinterface/rbs/pxe_add.php | 118 ++ ldap-site-mngmt/webinterface/rbs/pxe_change.php | 434 ++++++ ldap-site-mngmt/webinterface/rbs/pxe_copy.php | 189 +++ ldap-site-mngmt/webinterface/rbs/pxe_delete.php | 42 + .../webinterface/rbs/pxe_wochenplan.php | 154 +++ .../webinterface/rbs/pxeconfig_default.dwt | 323 +++++ .../webinterface/rbs/pxeconfig_default.php | 77 ++ ldap-site-mngmt/webinterface/rbs/rbs.dwt | 79 ++ ldap-site-mngmt/webinterface/rbs/rbs.php | 30 + .../webinterface/rbs/rbs_footer.inc.php | 18 + .../webinterface/rbs/rbs_header.inc.php | 21 + ldap-site-mngmt/webinterface/rbs/rbs_menu.php | 215 +++ ldap-site-mngmt/webinterface/rbs/rbs_start.dwt | 41 + ldap-site-mngmt/webinterface/rbs/rbservice.dwt | 228 ++++ ldap-site-mngmt/webinterface/rbs/rbservice.php | 148 +++ ldap-site-mngmt/webinterface/rbs/rbservice_add.php | 140 ++ .../webinterface/rbs/rbservice_change.php | 337 +++++ .../webinterface/rbs/rbservice_delete.php | 41 + ldap-site-mngmt/webinterface/roles/menu.dwt | 22 + ldap-site-mngmt/webinterface/roles/role_add.php | 53 + ldap-site-mngmt/webinterface/roles/role_delete.php | 57 + ldap-site-mngmt/webinterface/roles/role_show.dwt | 70 + ldap-site-mngmt/webinterface/roles/role_show.php | 116 ++ ldap-site-mngmt/webinterface/roles/roles.dwt | 79 ++ ldap-site-mngmt/webinterface/roles/roles.php | 26 + .../webinterface/roles/roles_footer.inc.php | 18 + .../webinterface/roles/roles_header.inc.php | 19 + ldap-site-mngmt/webinterface/roles/roles_menu.php | 87 ++ ldap-site-mngmt/webinterface/roles/roles_start.dwt | 37 + 180 files changed, 26418 insertions(+) create mode 100644 ldap-site-mngmt/webinterface/computers/computers.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/computers.php create mode 100644 ldap-site-mngmt/webinterface/computers/computers_footer.inc.php create mode 100644 ldap-site-mngmt/webinterface/computers/computers_header.inc.php create mode 100644 ldap-site-mngmt/webinterface/computers/computers_menu.php create mode 100644 ldap-site-mngmt/webinterface/computers/computers_menu.save.php create mode 100644 ldap-site-mngmt/webinterface/computers/computers_start.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/delete_confirm.php create mode 100644 ldap-site-mngmt/webinterface/computers/dhcphost.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/dhcphost.php create mode 100644 ldap-site-mngmt/webinterface/computers/dhcphost_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/group.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/group.php create mode 100644 ldap-site-mngmt/webinterface/computers/group_add.php create mode 100644 ldap-site-mngmt/webinterface/computers/group_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/group_delete.php create mode 100644 ldap-site-mngmt/webinterface/computers/groupoverview.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/groupoverview.php create mode 100644 ldap-site-mngmt/webinterface/computers/host.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/host.php create mode 100644 ldap-site-mngmt/webinterface/computers/host_add.php create mode 100644 ldap-site-mngmt/webinterface/computers/host_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/host_delete.php create mode 100644 ldap-site-mngmt/webinterface/computers/hostoverview.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/hostoverview.php create mode 100644 ldap-site-mngmt/webinterface/computers/hwhost.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/hwhost.php create mode 100644 ldap-site-mngmt/webinterface/computers/hwhost_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/machineconfig_default.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/machineconfig_default.php create mode 100644 ldap-site-mngmt/webinterface/computers/mc_wochenplan.php create mode 100644 ldap-site-mngmt/webinterface/computers/mcdef.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/mcdef.php create mode 100644 ldap-site-mngmt/webinterface/computers/mcdef_add.php create mode 100644 ldap-site-mngmt/webinterface/computers/mcdef_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/mcdef_copy.php create mode 100644 ldap-site-mngmt/webinterface/computers/mcdef_delete.php create mode 100644 ldap-site-mngmt/webinterface/computers/menu.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/menuentry.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/menuentry.php create mode 100644 ldap-site-mngmt/webinterface/computers/menuentry_add.php create mode 100644 ldap-site-mngmt/webinterface/computers/menuentry_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/menuentry_delete.php create mode 100644 ldap-site-mngmt/webinterface/computers/menuposition_down.php create mode 100644 ldap-site-mngmt/webinterface/computers/menuposition_up.php create mode 100644 ldap-site-mngmt/webinterface/computers/new_group.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/new_group.php create mode 100644 ldap-site-mngmt/webinterface/computers/new_host.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/new_host.php create mode 100644 ldap-site-mngmt/webinterface/computers/new_mcdef.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/new_mcdef.php create mode 100644 ldap-site-mngmt/webinterface/computers/new_menuentry.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/new_menuentry.php create mode 100644 ldap-site-mngmt/webinterface/computers/new_pxe.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/new_pxe.php create mode 100644 ldap-site-mngmt/webinterface/computers/pxe.dwt create mode 100644 ldap-site-mngmt/webinterface/computers/pxe.php create mode 100644 ldap-site-mngmt/webinterface/computers/pxe_add.php create mode 100644 ldap-site-mngmt/webinterface/computers/pxe_change.php create mode 100644 ldap-site-mngmt/webinterface/computers/pxe_copy.php create mode 100644 ldap-site-mngmt/webinterface/computers/pxe_delete.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/delete_confirm.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcp.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcp.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcp_footer.inc.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcp_header.inc.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcp_menu.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcp_start.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpservice.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpservice.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpservice_add.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpservice_change.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpservice_delete.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_add.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_change.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_delete.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/menu.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.php create mode 100644 ldap-site-mngmt/webinterface/dhcp/no_dhcp.dwt create mode 100644 ldap-site-mngmt/webinterface/dhcp/no_dhcp.php create mode 100644 ldap-site-mngmt/webinterface/dns/dns.dwt create mode 100644 ldap-site-mngmt/webinterface/dns/dns.php create mode 100644 ldap-site-mngmt/webinterface/dns/dns_footer.inc.php create mode 100644 ldap-site-mngmt/webinterface/dns/dns_header.inc.php create mode 100644 ldap-site-mngmt/webinterface/dns/dns_menu.php create mode 100644 ldap-site-mngmt/webinterface/dns/dns_start.dwt create mode 100644 ldap-site-mngmt/webinterface/dns/menu.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/ip.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/ip.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_blocks.inc.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_deleg.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/ip_deleg.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_deleg_change.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_dhcp.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/ip_dhcp.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_dhcp_change.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_footer.inc.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_header.inc.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_menu.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_rechner.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/ip_rechner.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_rechner_change.php create mode 100644 ldap-site-mngmt/webinterface/ip/ip_start.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/ipblocks.dwt create mode 100644 ldap-site-mngmt/webinterface/ip/menu.dwt create mode 100644 ldap-site-mngmt/webinterface/lib/au_management_functions.php create mode 100644 ldap-site-mngmt/webinterface/lib/commonlib.inc.php create mode 100644 ldap-site-mngmt/webinterface/lib/config.inc.php create mode 100644 ldap-site-mngmt/webinterface/lib/dhcp_management_functions.php create mode 100644 ldap-site-mngmt/webinterface/lib/host_management_functions.php create mode 100644 ldap-site-mngmt/webinterface/lib/ip_management_functions.php create mode 100644 ldap-site-mngmt/webinterface/lib/ldap.inc.php create mode 100644 ldap-site-mngmt/webinterface/lib/ldap2.inc.php create mode 100644 ldap-site-mngmt/webinterface/lib/rbs_management_functions.php create mode 100644 ldap-site-mngmt/webinterface/lib/syntax_check.php create mode 100644 ldap-site-mngmt/webinterface/login_form.inc.html create mode 100644 ldap-site-mngmt/webinterface/rbs/delete_confirm.php create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm.php create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm_add.php create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm_change.php create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm_delete.php create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm_overview.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/gbm_overview.php create mode 100644 ldap-site-mngmt/webinterface/rbs/menu.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/menuentry.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/menuentry.php create mode 100644 ldap-site-mngmt/webinterface/rbs/menuentry_add.php create mode 100644 ldap-site-mngmt/webinterface/rbs/menuentry_change.php create mode 100644 ldap-site-mngmt/webinterface/rbs/menuentry_delete.php create mode 100644 ldap-site-mngmt/webinterface/rbs/menuposition_down.php create mode 100644 ldap-site-mngmt/webinterface/rbs/menuposition_up.php create mode 100644 ldap-site-mngmt/webinterface/rbs/new_gbm.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/new_gbm.php create mode 100644 ldap-site-mngmt/webinterface/rbs/new_menuentry.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/new_menuentry.php create mode 100644 ldap-site-mngmt/webinterface/rbs/new_pxe.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/new_pxe.php create mode 100644 ldap-site-mngmt/webinterface/rbs/new_rbservice.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/new_rbservice.php create mode 100644 ldap-site-mngmt/webinterface/rbs/no_rbservice.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/no_rbservice.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe_add.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe_change.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe_copy.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe_delete.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxe_wochenplan.php create mode 100644 ldap-site-mngmt/webinterface/rbs/pxeconfig_default.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/pxeconfig_default.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbs.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/rbs.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbs_footer.inc.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbs_header.inc.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbs_menu.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbs_start.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/rbservice.dwt create mode 100644 ldap-site-mngmt/webinterface/rbs/rbservice.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbservice_add.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbservice_change.php create mode 100644 ldap-site-mngmt/webinterface/rbs/rbservice_delete.php create mode 100644 ldap-site-mngmt/webinterface/roles/menu.dwt create mode 100644 ldap-site-mngmt/webinterface/roles/role_add.php create mode 100644 ldap-site-mngmt/webinterface/roles/role_delete.php create mode 100644 ldap-site-mngmt/webinterface/roles/role_show.dwt create mode 100644 ldap-site-mngmt/webinterface/roles/role_show.php create mode 100644 ldap-site-mngmt/webinterface/roles/roles.dwt create mode 100644 ldap-site-mngmt/webinterface/roles/roles.php create mode 100644 ldap-site-mngmt/webinterface/roles/roles_footer.inc.php create mode 100644 ldap-site-mngmt/webinterface/roles/roles_header.inc.php create mode 100644 ldap-site-mngmt/webinterface/roles/roles_menu.php create mode 100644 ldap-site-mngmt/webinterface/roles/roles_start.dwt (limited to 'ldap-site-mngmt') diff --git a/ldap-site-mngmt/webinterface/computers/computers.dwt b/ldap-site-mngmt/webinterface/computers/computers.dwt new file mode 100644 index 00000000..ec6d0cbc --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers.dwt @@ -0,0 +1,79 @@ + + + + {SEITENTITEL} + + + + + + + + + + +
+ + + + + +

Rechner und IP Management

+
+ + + + +
+

Startseite +  >>  {AU}  [ {DOMAIN} ]

+
+
+ + + + +
+ {LOGIN} +
+
+ + + + + +
{MAINMENU}
+ +
+ + + + + + + + + + + +
+ + +
+ + {NAVIGATION} + +
+
+ + +
+ + {HAUPTFENSTER} + +
+
+ + + + diff --git a/ldap-site-mngmt/webinterface/computers/computers.php b/ldap-site-mngmt/webinterface/computers/computers.php new file mode 100644 index 00000000..46b686df --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers.php @@ -0,0 +1,28 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/computers_footer.inc.php b/ldap-site-mngmt/webinterface/computers/computers_footer.inc.php new file mode 100644 index 00000000..311721c5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers_footer.inc.php @@ -0,0 +1,18 @@ +assign(array("PFAD" => $START_PATH)); + +# Daten in die Vorlage parsen +$template->parse("LOGIN", "Login"); +$template->parse("MAINMENU", "Mmenu"); +$template->parse("NAVIGATION", "Menu"); +$template->parse("HAUPTFENSTER", "Webseite"); +$template->parse("PAGE", "Vorlage"); + +# Fertige Seite an den Browser senden +$template->FastPrint("PAGE"); + +# Abmelden vom LDAP +ldap_unbind($ds); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/computers_header.inc.php b/ldap-site-mngmt/webinterface/computers/computers_header.inc.php new file mode 100644 index 00000000..d51a42d1 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers_header.inc.php @@ -0,0 +1,21 @@ + "computers.dwt", + "Login" => "../logout_form.inc.dwt", + "Mmenu" => "../hauptmenue.dwt", + "Menu" => "menu.dwt", + "Webseite" => $webseite); +if (isset($additionalTemplates)) { + foreach ($additionalTemplates as $templateKey => $templateFile) { + $definedTemplates[$templateKey] = $templateFile; + } +} +$template->define($definedTemplates); + +$template->assign(array("SEITENTITEL" => $titel, "AU" => $au_ou, "DOMAIN" => $assocdom, "USERCN" => $usercn)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/computers_menu.php b/ldap-site-mngmt/webinterface/computers/computers_menu.php new file mode 100644 index 00000000..9b681bee --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers_menu.php @@ -0,0 +1,382 @@ + "computers.php", + "text" => "Übersicht", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")), + array("link" => "hostoverview.php", + "text" => "Rechner", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")), + array("link" => "groupoverview.php", + "text" => "Rechnergruppen", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")), + array("link" => "machineconfig_default.php", + "text" => "Default MachineConfigs", + "zugriff" => array("MainAdmin","HostAdmin")), + array("link" => "new_mcdef.php", + "text" => "Neue MachineConfig", + "zugriff" => array("MainAdmin","HostAdmin")), + array("link" => "new_pxe.php", + "text" => "Neues PXE Bootmenü", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin"))); + + # Submenu + #$comps = array(); + $computers_array = get_hosts($auDN,array("dn","hostname","ou")); + #if (count($computers_array) != 0){ + for($n=0;$n "mcdef.php?dn=".$machineconfigs[$m]['dn']."&mnr=1&sbmnr=".$n."&mcnr=".$m, + "text" => $machineconfigs[$m]['cn'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + } + }else{$mcc = array();} + + if (count($pxeconfigs) != 0){ + $pxec = array(); + for ($p=0;$p "pxe.php?dn=".$pxeconfigs[$p]['dn']."&mnr=1&sbmnr=".$n."&mcnr=".$z, + "text" => $pxeconfigs[$p]['cn'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + } + }else{$pxec = array();} + + + $comps[] = array("link" => "host.php?dn=".$computers_array[$n]['dn']."&sbmnr=".$n, + "text" => $computers_array[$n]['hostname'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + # print_r($comps); echo "
"; + $mccpxec = array_merge($mcc,$pxec); + $compmc[] = $mccpxec; + + } + #} + $comps[] = array("link" => "new_host.php?sbmnr=".$n, + "text" => "Neuer Rechner", + "zugriff" => array("MainAdmin","HostAdmin")); + + $groups_array = get_groups($auDN,array("dn","cn")); + for($n=0;$n "mcdef.php?dn=".$machineconfigs[$m]['dn']."&mnr=2&sbmnr=".$n."&mcnr=".$m, + "text" => $machineconfigs[$m]['cn'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + } + }else{$mcg = array();} + + if (count($pxeconfigs) != 0){ + $pxeg = array(); + for ($p=0;$p "pxe.php?dn=".$pxeconfigs[$p]['dn']."&mnr=2&sbmnr=".$n."&mcnr=".$z, + "text" => $pxeconfigs[$p]['cn'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + } + }else{$pxeg = array();} + $groups = array(); + $groups[] = array("link" => "group.php?dn=".$groups_array[$n]['dn']."&sbmnr=".$n, + "text" => $groups_array[$n]['cn'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + + $mcgpxeg = array_merge($mcg,$pxeg); + $groupmc[] = $mcgpxeg; + } + $groups[] = array("link" => "new_group.php?sbmnr=".$n, + "text" => "Neue Gruppe", + "zugriff" => array("MainAdmin","HostAdmin")); + # print_r($compmc); echo "

"; + # print_r($groupmc); echo "

"; + + # default machine-configs + $mcdef_array = get_machineconfigs("cn=computers,".$auDN,array("dn","cn","timerange")); + for($n=0;$n "mcdef.php?dn=".$mcdef_array[$n]['dn']."&mnr=3&sbmnr=".$n, + "text" => $mcdef_array[$n]['cn'], + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")); + } + + $submenu = array(array(), + $comps, + $groups, + $defmc, + array()); + #echo "submenu: ";print_r($submenu);echo "

"; + + $subsubmenu = array(array(array(array())), + $compmc, + $groupmc, + array(array(array())), + array(array(array()))); + #echo "subsubmenu: ";print_r($subsubmenu);echo "

"; + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $template->define_dynamic("Submenu", "Menu"); + $template->define_dynamic("Subsubmenu", "Menu"); + $i=0; + + $maxmenu = count($hauptmenu); + foreach($hauptmenu as $item){ + $template->clear_parse("SUBMENU_LIST"); + + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + + ######################################################################### + # SUBMENU + + $subempty = 0; + $j=0; + $maxsub = count($submenu[$mnr]); + #echo "_"; print_r($maxsub); echo "_"; + if($maxsub > 0){ + foreach($submenu[$mnr] as $item2) { + + $template->clear_parse("SUBSUBMENU_LIST"); + + + if($item2['zugriff'] === "alle" || vergleicheArrays($rollen, $item2['zugriff'])) { + + ######################################################################## + # SUBSUBMENU + $subsubempty = 0; + $k=0; + $maxsubsub = count($subsubmenu[$mnr][$sbmnr]); + #print_r($maxsubsub); + if ($maxsubsub > 0){ + if($sbmnr >= 0){ + + foreach($subsubmenu[$mnr][$sbmnr] as $item3) { + + if($item3['zugriff'] === "alle" || vergleicheArrays($rollen, $item3['zugriff'])) { + + if($j != $sbmnr || $i != $mnr){ + + $template->assign(array("SUBSUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBSUBMENU_LIST", ".Subsubmenu"); + $template->clear_dynamic("Subsubmenu"); + $template->clear_parse("SUBSUBMENU_LIST"); + } + else{ + if ($k==0) { + if ($mcnr==0) { + if($maxsubsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if($maxsubsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mcnr==$k) { + if($maxsubsub == $k+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if($maxsubsub == $k+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + # if ($lastaktive) {$zwisch="branch";} + # else {$zwisch="branch";} + $lastaktive=false; + } + } + $htmlcode= " + + + + +   +   + + + ".$item3['text']." +   + + "; + $template->assign(array("SUBSUB" => $htmlcode)); + $template->assign(array("FARBE_MC" => $farb)); + $template->parse("SUBSUBMENU_LIST", ".Subsubmenu"); + $template->clear_dynamic("Subsubmenu"); + + } + } + else { + $subsubempty++; + } + $k=$k+1; + } + } + + if($subsubempty == count($subsubmenu[$mnr][$sbmnr])) { + $template->assign(array("SUBSUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBSUBMENU_LIST", ".Subsubmenu"); + $template->clear_dynamic("Subsubmenu"); + $template->clear_parse("SUBSUBMENU_LIST"); + } + + } + $template->assign(array("SUBSUB" => "")); + # SUBSUBMENU + ######################################################################## + if($i != $mnr){ + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + else{ + if ($j==0) { + if ($sbmnr==0) { + if($maxsub == 1){$zwisch2="";} + else {$zwisch2="";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if(count($subsubmenu[$i][$j][0]) != 0){ + if($maxsub == 1){$zwisch2=" + ";} + else {$zwisch2=" + ";} + }else{$zwisch2="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($sbmnr==$j) { + if($maxsub == $j+1){$zwisch2="";} + else {$zwisch2="";} + $lastaktive=true; + $farb="#505050"; + } + else { + if(count($subsubmenu[$i][$j][0]) != 0){ + if($maxsub == $i+1){$zwisch2=" + ";} + else {$zwisch2=" + ";} + }else{$zwisch2="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + $htmlcode= " + + + + +   + ".$zwisch2." +   + + ".$item2['text']." +   + + "; + $template->assign(array("SUB" => $htmlcode)); + $template->assign(array("FARBE_S" => $farb)); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + } + else { + $subempty++; + } + $j=$j+1; + } + } + if($subempty == count($submenu[$mnr])) { + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + + } + $template->assign(array("SUBSUB" => "")); + # SUBMENU + ##################################################################### + + if ($i==0) { + if ($mnr==0) { + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch="";} # {$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + if(count($submenu[$mnr][0]) != 0){ + if($maxmenu == $i+1){$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else { + + if(count($submenu[$i][0]) != 0){ + if($maxmenu == $i+1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + $template->assign(array("ICON" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + $template->clear_dynamic("Hauptmenu"); + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else{ + $template->assign(array("ENDE" => "")); + } +} +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/computers_menu.save.php b/ldap-site-mngmt/webinterface/computers/computers_menu.save.php new file mode 100644 index 00000000..183d9309 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers_menu.save.php @@ -0,0 +1,188 @@ + "computers.php", + "text" => "Übersicht", + "zugriff" => "alle"), + array("link" => "hostoverview.php", + "text" => "Rechner", + "zugriff" => array("MainAdmin")), + array("link" => "computers.php", + "text" => "Neuen Rechner anlegen", + "zugriff" => array("MainAdmin")), + array("link" => "groupoverview.php", + "text" => "Rechnergruppen", + "zugriff" => array("MainAdmin")), + array("link" => "computers.php", + "text" => "Neue Gruppe anlegen", + "zugriff" => array("MainAdmin"))); + + # Submenu + $computers_array = get_hosts($auDN,array("dn","hostname","ou")); + for($n=0;$n "host.php?dn=".$computers_array[$n]['dn']."&sbmnr=".$n, + "text" => $computers_array[$n]['hostname'], + "zugriff" => array("MainAdmin")); + } + $groups_array = get_groups($auDN,array("dn","cn")); + for($n=0;$n "group.php?dn=".$groups_array[$n]['dn']."&sbmnr=".$n, + "text" => $groups_array[$n]['cn'], + "zugriff" => array("MainAdmin")); + } + $submenu = array(array(array()), + $comps, + array(array()), + $groups, + array(array())); + + $rollen = array_keys($roles); + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $template->define_dynamic("Submenu", "Menu"); + $i=0; + + $maxmenu = count($hauptmenu); + foreach($hauptmenu as $item){ + $template->clear_parse("SUBMENU_LIST"); + + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + $subempty = 0; + $j=0; + $maxsub = count($submenu[$mnr]); + foreach($submenu[$mnr] as $item2) { + + if($item2['zugriff'] === "alle" || vergleicheArrays($rollen, $item2['zugriff'])) { + if($i != $mnr){ + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + else{ + if ($j==0) { + if ($sbmnr==0) { + if($maxsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if($maxsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($sbmnr==$j) { + if($maxsub == $j+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if($maxsub == $j+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + # if ($lastaktive) {$zwisch="branch";} + # else {$zwisch="branch";} + $lastaktive=false; + } + } + $htmlcode= " + + + + +   + + + ".$item2['text']." +   + + "; + $template->assign(array("SUB" => $htmlcode)); + $template->assign(array("FARBE_S" => $farb)); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + } + else { + $subempty++; + } + $j=$j+1; + + } + if($subempty == count($submenu[$mnr])) { + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + + if ($i==0) { + if ($mnr==0) { + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch="";} # {$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + if(count($submenu[$mnr][0]) != 0){ + if($maxmenu == $i+1){$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if(count($submenu[$i][0]) != 0){ + if($maxmenu == $i+1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + #if ($lastaktive) {$zwisch="";} + #else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("ICON" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + $template->clear_dynamic("Hauptmenu"); + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else{ + $template->assign(array("ENDE" => "")); + } +} +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/computers_start.dwt b/ldap-site-mngmt/webinterface/computers/computers_start.dwt new file mode 100644 index 00000000..09cade01 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/computers_start.dwt @@ -0,0 +1,42 @@ + + + + + + + + + + + +

Modul - Rechner und Rechnergruppen Management:

+

Dieses Modul dient der Verwaltung der Rechner und Rechnergruppen in ihrer Abteilung + (AU), inklusive ihrer spezifischen Rechner- und PXE Boot Konfigurationen
+ Benutzen Sie die Navigation links, um die einzelnen Verwaltungsbereiche anzusteuern:

+
    +
  • Rechner

    + Hier verwalten Sie ihre Rechner (anlegen, bearbeiten, löschen), und können zu dem + einige Hardware-Parameter festlegen. Daneben verwalten Sie hier rechner-spezifische + Computer-Profile (MachineConfig) und PXE Boot Konfigurationen. +
  • +
  • Rechnergruppen

    + Hier verwalten Sie die Rechnergruppen (anlegen, bearbeiten, löschen), sowie + ihre gemeinsamen Hardware-Parameter. Daneben verwalten Sie hier gruppen-spezifische + Computer-Profile (MachineConfig) und PXE Boot Konfigurationen. +
  • +
  • Default MachineConfig

    + Hier verwalten Sie ihre Default Computer-Profile (bearbeiten, löschen, kopieren), + d.h. Computer-Profile, die beim booten von Rechnern verwendet werden, für die + keine rechner- oder gruppen-spezifischen MachineConfigs angelegt sind. +
  • +
  • Neue MachineConfig

    + Hier köennen Sie neue Computer-Profile (MachineConfigs) als rechner-, gruppen- + spezifische, oder Default MachineConfigs anlegen. +
  • +
  • Neues PXE Bootmenü

    + Hier können Sie neue PXE Bootmenüs (PXEConfigs) für ihre Rechner oder + Rechnergruppen anlegen. +
  • +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/delete_confirm.php b/ldap-site-mngmt/webinterface/computers/delete_confirm.php new file mode 100644 index 00000000..c3f2bc8b --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/delete_confirm.php @@ -0,0 +1,39 @@ + + + AU Management + + + + + + + +
+ Wollen Sie das Objekt ".$name." wirklich löschen?

+
+ Falls ja:

+ + + + +

+
+
+ Falls, nein:

+ +
+
+ +"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/dhcphost.dwt b/ldap-site-mngmt/webinterface/computers/dhcphost.dwt new file mode 100644 index 00000000..8ab5c7af --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/dhcphost.dwt @@ -0,0 +1,84 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Rechner   {HOSTNAME}

{HOSTLINK} Allgemein

DHCP/RBS

{HWLINK} Hardware

 
+ + + + + + + + + + + + + + + + + {HOST_DHCPOPT} + +

DHCP Setup

  
Eingebunden in DHCP Dienst:   + {DHCPCONT}
+ +
+ + + + + + + + + + {RBS} + + + {RBS_DHCPOPT} + +

PXE/TFTP Setup

 
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/dhcphost.php b/ldap-site-mngmt/webinterface/computers/dhcphost.php new file mode 100644 index 00000000..5267157c --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/dhcphost.php @@ -0,0 +1,278 @@ +
"; +$dhcphlpcont = $host['dhcphlpcont']; +$objectDN = $dhcphlpcont; +$rbsDN = $host['hlprbservice']; + +$rbs_dhcpopt = ""; +$host_dhcpopt = ""; + +# DHCP Daten +if ($dhcphlpcont == ""){ + $dhcp = "Rechner ist in keinem DHCP Dienst angemeldet
+ + DHCP Dienst auswählen: "; + $objecttype = "nodhcp"; + $rbs = " + Sie müssen den Rechner zuerst in einem DHCP Dienst anmelden, bevor Sie ihn + einem Remote Boot Dienst zuordnen können
(DHCP Optionen!!).
+ + "; +}else{ + # Subnet? + $objecttype = "service"; + $dhcp = ""; + $ocarray = get_node_data($dhcphlpcont,array("objectclass","dhcphlpcont")); + #print_r($ocarray); echo "
"; + $sub = array_search('dhcpSubnet', $ocarray['objectclass']); + #print_r($sub); + if ($sub !== false ){ + $objecttype = "subnet"; + $exp0 = explode(',',$dhcphlpcont); + $expsub = explode('=',$exp0[0]); $dhcpsub = $expsub[1]; + $dhcp .= "Subnet ".$dhcpsub." / "; + $dhcphlpcont = $ocarray['dhcphlpcont']; + } + $exp1 = explode(',',$dhcphlpcont); + $expdhcp = explode('=',$exp1[0]); $dhcpserv = $expdhcp[1]; + $expdhcpau = explode('=',$exp1[2]); $dhcpau = $expdhcpau[1]; + $dhcp .= "Service ".$dhcpserv." / AU ".$dhcpau."
+ + DHCP Dienst ändern: "; + + + $fixedaddselopt = ""; + switch ( $host['dhcpoptfixed-address'] ){ + case "": + $fixedaddress = " -
(dynamische Vergabe)"; + if ( $hostip[0] != "" ){ + $fixedaddselopt .= ""; + } + $fixedaddselopt .= ""; + break; + case "ip": + $fixedaddress = "".$hostip[0]."
(Fixe IP Adresse)"; + $fixedaddselopt .= " + "; + break; + case "hostname": + $fixedaddress = "".$host['hostname']."
(Fixe IP Adresse über Hostnamen aufgelöst)"; + if ( $hostip[0] != "" ){ + $fixedaddselopt .= ""; + } + $fixedaddselopt .= ""; + break; + } + + + $host_dhcpopt = "DHCP Optionen: + + hardware ethernet:   + ".$host['hwaddress']."  +   + + + fixed-address:   + ".$fixedaddress."  + + + + "; + + ########################################################### + # RBS Setup + $rbs_selectbox = ""; + $rbs_dhcpopt = ""; + $altrbs = alternative_rbservices($rbsDN); + + if (count($altrbs) != 0){ + $rbs_selectbox .= " + "; + } + + # RBS Daten + if ($rbsDN == ""){ + + $rbs = "Remote Boot Dienst:   + + Rechner ist in keinem Remote Boot Dienst angemeldet
+ + RBS auswählen:
".$rbs_selectbox; + }else{ + + $rbs = ""; + $rbsdata = get_node_data($rbsDN,array("tftpserverip")); + #print_r($rbsdata); echo "
"; + $exp2 = explode(',',$host['hlprbservice']); + $exprbs = explode('=',$exp2[0]); $rbserv = $exprbs[1]; + $exprbsau = explode('=',$exp2[2]); $rbsau = $exprbsau[1]; + $rbs .= "Remote Boot Dienst:   + + Remote Boot Service ".$rbserv." / AU ".$rbsau."
+ TFTP (Boot) Server: ".$rbsdata['tftpserverip']."
+ + RBS ändern:
".$rbs_selectbox; + + $rbs_dhcpopt = "DHCP Optionen: + + next-server  (TFTP Server): + ".$host['dhcpoptnext-server']."  + + + filename  (initiale remote Bootdatei): + ".$host['dhcpoptfilename']."  + "; + } + +} + +$template->assign(array("HOSTDN" => $hostDN, + "HOSTNAME" => $host['hostname'], + "DOMAINNAME" => $host['domainname'], + "HWADDRESS" => $host['hwaddress'], + "IPADDRESS" => $hostip[0], + "DESCRIPTION" => $host['description'], + "OLDDHCP" => $objectDN, + "OLDFIXADD" => $host['dhcpoptfixed-address'], + "OLDRBS" => $rbsDN, + "DHCPCONT" => $dhcp, + "HOST_DHCPOPT" => $host_dhcpopt, + "RBS" => $rbs, + "RBS_DHCPOPT" => $rbs_dhcpopt, + "NEXTSERVER" => $host['dhcpoptnext-server'], + "FILENAME" => $host['dhcpoptfilename'], + "HOSTLINK" => "", + "HWLINK" => "", + "AUDN" => $auDN, + "SBMNR" => $sbmnr)); + + +########################################################## +# DHCP Setup + +$altdhcp = alternative_dhcpobjects($objecttype,$objectDN,$hostip[0]); +#echo "

";print_r($altdhcp); + +$template->assign(array("ALTDN" => "", + "ALTCN" => "", + "ALTAU" => "")); +if (count($altdhcp) != 0){ +$template->define_dynamic("Altdhcp", "Webseite"); + foreach ($altdhcp as $item){ + + $template->assign(array("ALTDN" => $item['dn'], + "ALTCN" => $item['cn'], + "ALTAU" => $item['au'],)); + $template->parse("ALTDHCP_LIST", ".Altdhcp"); + } +} + + +########################################################### +# RBS Setup + +/*$altrbs = alternative_rbservices($rbsDN); +#print_r($altrbs); echo "

"; +$template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); +if (count($altrbs) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($altrbs as $item){ + $template->assign(array("ALTRBSDN" => $item['dn'], + "ALTRBSCN" => $item['cn'], + "ALTRBSAU" => $item['au'],)); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +}*/ + + +################################################################################### + +include("computers_footer.inc.php"); + + + +/* + + DHCP Option hardware ethernet:   + {HWADDRESS}   + + + + DHCP Option fixed-address:   + {IPADDRESS}   + + + + + + + + TFTP Server
DHCP Option next-server:
  + {NEXTSERVER}   + + + + PXE initiale Bootdatei
DHCP Option filename:
  + {FILENAME}   + + + + + */ +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/dhcphost_change.php b/ldap-site-mngmt/webinterface/computers/dhcphost_change.php new file mode 100644 index 00000000..907fae8f --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/dhcphost_change.php @@ -0,0 +1,177 @@ +"; +echo "old dhcp:"; print_r($olddhcp); echo "
"; +echo "new rbs:"; print_r($rbs); echo "
"; +echo "old rbs:"; print_r($oldrbs); echo "
"; +echo "Host DN:"; print_r($hostDN); echo "
"; +echo "submenuNR:"; print_r($sbmnr); echo "

";*/ + + +$seconds = 40; +$url = 'dhcphost.php?dn='.$hostDN.'&sbmnr='.$sbmnr; + +echo " + + + AU Management + + + + +
"; + +########################################## +# DHCP + +if ($dhcp != "none" && $dhcp != $olddhcp){ + if ($dhcp != ""){ + $exp = ldap_explode_dn($dhcp, 1); + $dhcpcn = $exp[0]; + $dhcpau = $exp[2]; + + $entrydhcp ['dhcphlpcont'] = $dhcp; + if ($olddhcp != ""){ + echo "DHCP replace "; print_r($olddhcp); echo " with "; print_r($entrydhcp); echo "
"; + if ($result = ldap_mod_replace($ds,$hostDN,$entrydhcp)){ + $mesg = "Rechner erfolgreich in DHCP ".$dhcpcn." [Abt.: ".$dhcpau."] angemeldet

"; + }else{ + $mesg = "Fehler beim ändern des DHCP Dienstes zu ".$dhcpcn."!

"; + } + }else{ + if ( $hostip != "" ){ + $entrydhcp ['dhcpoptfixed-address'] = "ip"; + } + echo "DHCP add "; print_r($entrydhcp); echo "
"; + if ($result = ldap_mod_add($ds,$hostDN,$entrydhcp)){ + $mesg = "Rechner erfolgreich in DHCP ".$dhcpcn." [Abt.: ".$dhcpau."] angemeldet

"; + }else{ + $mesg = "Fehler beim ändern des DHCP Dienstes zu ".$dhcpcn."!

"; + } + } + }else{ + $entrydhcp ['dhcphlpcont'] = array(); + if ( $fixedaddress != "" ){ + $entrydhcp ['dhcpoptfixed-address'] = array(); + } + echo "DHCP delete "; echo "
"; + if ($result = ldap_mod_del($ds,$hostDN,$entrydhcp)){ + $mesg = "Rechner erfolgreich aus DHCP gelöscht

"; + }else{ + $mesg = "Fehler beim löschen aus DHCP Dienst!

"; + } + } + +} +if ($dhcp == "none"){ + echo " DHCP none
"; +} + +# DHCP Option fixed-address +if ($fixedaddress != "none" && $fixedaddress != $oldfixedaddress){ + if ($fixedaddress != ""){ + $entryfixadd ['dhcpoptfixed-address'] = $fixedaddress; + if ($oldfixedaddress != ""){ + echo "Fixed Address ändern"; echo "
"; + if ($result = ldap_mod_replace($ds,$hostDN,$entryfixadd)){ + $mesg = "Option Fixed-Address erfolgreich auf ".$fixedaddress." geändert

"; + }else{ + $mesg = "Fehler beim ändern der Option Fixed-Address auf ".$fixedaddress."!

"; + } + }else{ + echo "Fixed Address auf IP Adresse setzen"; echo "
"; + if ($result = ldap_mod_add($ds,$hostDN,$entryfixadd)){ + $mesg = "Option Fixed-Address erfolgreich auf ".$fixedaddress." gesetzt

"; + }else{ + $mesg = "Fehler beim setzen der Option Fixed-Address auf ".$fixedaddress."!

"; + } + } + }else{ + $entryfixadd ['dhcpoptfixed-address'] = array(); + echo "No Fixed Address"; echo "
"; + if ($result = ldap_mod_del($ds,$hostDN,$entryfixadd)){ + $mesg = "Option Fixed-Address erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen der Option Fixed-Address!

"; + } + } +} + + +########################################## +# RBS + +if ($rbs != "none" && $rbs != $oldrbs){ + if ($rbs != ""){ + $exp = ldap_explode_dn($rbs, 1); + $rbscn = $exp[0]; + $rbsau = $exp[2]; + + $dhcpdata = get_node_data($rbs,array("tftpserverip","initbootfile")); + $entryrbs ['hlprbservice'] = $rbs; + $entryrbs ['dhcpoptnext-server'] = $dhcpdata['tftpserverip']; + $entryrbs ['dhcpoptfilename'] = $dhcpdata['initbootfile']; + if ($oldrbs != ""){ + echo "RBS replace "; print_r($oldrbs); echo " with "; print_r($entryrbs); echo "
"; + if ($result = ldap_mod_replace($ds,$hostDN,$entryrbs)){ + rbs_adjust_host($hostDN, $rbs); + $mesg = "Remote Boot Service erfolgreich zu ".$rbscn." [Abt.: ".$rbsau."] geändert

"; + }else{ + $mesg = "Fehler beim ändern des Remote Boot Services zu ".$rbscn."!

"; + } + }else{ + echo "RBS add "; print_r($entryrbs); echo "
"; + if ($result = ldap_mod_add($ds,$hostDN,$entryrbs)){ + rbs_adjust_host($hostDN, $rbs); + $mesg = "Remote Boot Service erfolgreich zu ".$rbscn." [Abt.: ".$rbsau."] geändert

"; + }else{ + $mesg = "Fehler beim ändern des Remote Boot Services zu ".$rbscn."!

"; + } + } + }else{ + $entryrbs ['hlprbservice'] = array(); + $entryrbs ['dhcpoptnext-server'] = array(); + $entryrbs ['dhcpoptfilename'] = array(); + echo "RBS delete "; echo "
"; + if ($result = ldap_mod_del($ds,$hostDN,$entryrbs)){ + $mesg = "Rechner erfolgreich aus RBS gelöscht

"; + }else{ + $mesg = "Fehler beim löschen aus RBS!

"; + } + } +} +if ($rbs == "none"){ + echo "RBS none
"; +} + + +##################### + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/group.dwt b/ldap-site-mngmt/webinterface/computers/group.dwt new file mode 100644 index 00000000..cda53f18 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/group.dwt @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Daten bearbeiten Gruppe  {GROUPCN} 

+ + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger Gruppenname (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +   +
Beschreibung:   + +   +
Gruppen-Rechner:   + + Aktuelle Mitglieder (zum Löschen bitte Häkchen setzen):
+ +   {MEMBER}
+ +
+ + Als neues Mitglied aufnehmen (Mehrfachauswahl möglich)
+ +
+

Gruppe - {GROUPCN} - löschen:

+ + + + + + + + + + + + + +
+ Die Rechnergruppe wird komplett gelöscht,
d.h. inklusive aller spezifisch für sie angelegten + Hardware-Profile (MachineConfig) und PXE Bootmenüs. +
+ +

Wochen Übersicht Machine Configs Gruppe  {GROUPCN}  :

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
UhrzeitMontagDienstagMittwochDonnerstagFreitagSamstagSonntag
0       
        
2       
        
4       
        
6       
        
8       
        
10       
        
12       
        
14       
        
16        
        
18       
        
20       
        
22       
        

Legende:

+ + + + + + + + + + + + + + + + + + + + + +
Machine Config Farbe
Keine Konfiguration    
{DESCRIPTION}     
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/group.php b/ldap-site-mngmt/webinterface/computers/group.php new file mode 100644 index 00000000..13819e62 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/group.php @@ -0,0 +1,120 @@ +assign(array("GROUPDN" => $groupDN, + "GROUPCN" => $group['cn'], + "GROUPDESC" => $group['description'], + # "MEMBERS" => $anzahlmember, + "MEMBER" => $group['member'], + "DHCPCONT" => $group['dhcphlpcont'], + "AUDN" => $auDN, + "SBMNR" => $sbmnr)); + +$template->define_dynamic("Members", "Webseite"); + +if ( count($group['member']) == 1 ){ + $member = $group['member']; + $group = array(); + $group['member'][] = $member; +} + +if ( count($group['member']) != 0 ){ + sort($group['member']); + foreach ($group['member'] as $member){ + $exp = explode(',',$member); + $memberexp = explode('=',$exp[0]); + $membername = $memberexp[1]; + $template->assign(array("MEMBERDN" => $member, + "MEMBER" => $membername)); + $template->parse("MEMBERS_LIST", ".Members"); + } +} + +############################################## +# neues Member anlegen ... +$hosts_array = get_hosts($auDN,array("dn","hostname")); +# print_r($hosts_array); echo "

"; +$groups = get_groups($auDN, array("member")); +$template->assign(array("HN" => "")); + +foreach ($groups as $group){ + for ($i=0; $i < count($hosts_array); $i++){ + if (count($group['member']) > 1){ + foreach ($group['member'] as $item){ + if ($hosts_array[$i]['dn'] == $item){ + array_splice($hosts_array, $i, 1); + $i--; # da ja ein Member gelöscht wurde + } + } + } + if (count($group['member']) == 1){ + if ($hosts_array[$i]['dn'] == $group['member']){ + array_splice($hosts_array, $i, 1); + } + } + } +} +#print_r($hosts_array);echo"
"; + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "HOSTNUMBER" => 5)); + $template->parse("HOSTS_LIST", ".Hosts"); +} + + +########################################################## +# MC Wochenübersicht +$mc_array = get_machineconfigs($groupDN,array("dn","cn","timerange","description")); +# print_r($mc_array); +for ($i=0; $i 1 ){ + foreach ($mc_array[$i]['timerange'] as $tr){ + $exptime = array_merge(explode('_',$tr),$mc_array[$i]['description']); + $timeranges[$i][] = $exptime; # Für grafische Wo-Ansicht + } + }else{ + $exptime = array_merge(explode('_',$mc_array[$i]['timerange']), $mc_array[$i]['description']); + $timeranges[$i] = $exptime; # Für grafische Wo-Ansicht + } +} +include("mc_wochenplan.php"); + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/group_add.php b/ldap-site-mngmt/webinterface/computers/group_add.php new file mode 100644 index 00000000..dfc7fbe7 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/group_add.php @@ -0,0 +1,84 @@ +"; +echo "groupcn:"; print_r($groupcn); echo "
"; +echo "groupdesc:"; print_r($groupdesc); echo "
"; +echo "members to add:"; print_r($addmember); echo "
"; +*/ + +$seconds = 2; + +echo " + + + AU Management + + + + +
"; + +if ( $groupcn != ""){ + + # Formulareingaben anpassen + $expgr = explode(" ",$groupcn); + foreach ($expgr as $word){$expuc[] = ucfirst($word);} + $groupcn = implode(" ",$expuc); + $groupcn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $groupcn); + + # Host Objekt anlegen + $brothers = get_hosts($auDN,array("groupcn")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['groupcn'] == $groupcn ){ + $mesg = "Es existiert bereits eine Gruppe mit dem eingegebenen Namen (CN)!
+ Bitte geben Sie einen anderen Namen (CN) ein.

"; + $get_groupdesc = str_replace ( " ", "_", $groupdesc ); + $url = "new_group.php?groupcn=Hier_anderen_CN_eingeben&groupdesc=".$get_groupdesc; + $brother = 1; + break; + } + } + if ($brother == 0){ + $groupDN = "cn=".$groupcn.",cn=groups,".$auDN; + # print_r($groupDN); echo "
"; + + if (add_group($groupDN,$groupcn,$groupdesc,$addmember)){ + $mesg .= "
Neue Rechnergruppe erfolgreich angelegt
"; + } + else{ + $mesg .= "
Fehler beim anlegen der Rechnergruppe!
"; + } + + $url = 'groupoverview.php'; + } +} + + +elseif ( $groupcn == ""){ + + $get_groupdesc = str_replace ( " ", "_", $groupdesc ); + $mesg = "Sie haben den CN der neuen Gruppe nicht angegeben. Dieser ist aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "new_group.php?ou=Hier_CN_eingeben&groupdesc=".$get_groupdesc; +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/group_change.php b/ldap-site-mngmt/webinterface/computers/group_change.php new file mode 100644 index 00000000..cb26a429 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/group_change.php @@ -0,0 +1,252 @@ +"; +echo "old groupcn:"; print_r($oldgroupcn); echo "
"; +echo "new groupdesc:"; print_r($groupdesc); echo "
"; +echo "old groupdesc:"; print_r($oldgroupdesc); echo "

"; + +echo "members to delete:"; print_r($delmember); echo "

"; +echo "members to add:"; print_r($addmember); echo "

"; + +echo "Group DN:"; print_r($groupDN); echo "
"; +echo "submenuNR:"; print_r($submenu); echo "

"; +*/ + +$seconds = 2; +$url = 'group.php?dn='.$groupDN.'&sbmnr='.$sbmnr; + +echo " + + + AU Management + + + + +
"; + +############################################## +# CN (DN) + +if ( $oldgroupcn == $groupcn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldgroupcn != "" && $groupcn != "" && $oldgroupcn != $groupcn ){ + echo "Gruppenname aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $expgr = explode(" ",$groupcn); + foreach ($expgr as $word){$expuc[] = ucfirst($word);} + $groupcn = implode(" ",$expuc); + $groupcn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $groupcn); + + + $newgroupDN = "cn=".$groupcn.",cn=groups,".$auDN; + print_r($newgroupDN); echo "

"; + + modify_group_dn($groupDN, $newgroupDN); + + # newsubmenu holen... + $url = 'group.php?dn='.$newgroupDN.'&sbmnr='.$sbmnr; +} + +if ( $oldgroupcn != "" && $groupcn == "" ){ + echo "Gruppenname loeschen!
+ Dieses ist Teil des DN, Sie werden die Gruppe komplett löschen

"; + echo "Wollen Sie die Gruppe ".$oldgroupcn."mit seinen Hardware-Profilen (MachineConfigs) + und PXE Bootmenüs wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + +######################################## +# Member löschen/aufnehmen + +if ( count($delmember) == 0 || count($addmember) == 0 ){ + # $mesg = "keine Aenderung
"; +} + +if ( count($delmember) != 0 ){ + echo "Gruppen-Mitglieder löschen
"; + # hier noch Syntaxcheck + # print_r($delmember); echo "

"; + + $i = 0; + foreach ($delmember as $member){ + $entry['member'][$i] = $member; + $i++; + } + #print_r($entry); echo "

"; + + if ($result = ldap_mod_del($ds,$groupDN,$entry)){ + # Fehler hier muessen die verbliebenen Members hin!!! + # Filenames in PXEs die an der Gruppe hängen anpassen + $pxes = get_pxeconfigs($groupDN,array("dn")); + foreach ($pxes as $pxe){ + if ( $entry['member'] > 1 ){ + $j = 0; + foreach ($entry['member'] as $host){ + $macdata = get_node_data($host, array("hwaddress")); + $entryfilename ['filename'][$j] = "01-".$macdata['hwaddress']; + $j++; + } + } + if ( $entry['member'] == 1 ){ + $macdata = get_node_data($entry['member'], array("hwaddress")); + $entryfilename ['filename'] = "01-".$macdata['hwaddress']; + } + ldap_mod_del($ds,$pxe['dn'],$entryfilename); + } + $mesg = "Gruppen-Mitglieder erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen der Gruppen-Mitglieder

"; + } +} + +if ( count($addmember) != 0 ){ + + echo "Gruppen-Mitglieder anlegen
"; + # hier noch Syntaxcheck + $members = get_node_data($groupDN,array("member")); + if ( count($members['member']) == 1 ){ + $member = $members['member']; + $members = array(); + $members['member'][] = $member; + } + if (count($members['member']) != 0){ + foreach ($members['member'] as $member){ + $entry2['member'][] = $member; + } + } + $i = 0; + foreach ($addmember as $member){ + $exp = explode('_',$member); + # Falls ein neues Mitglied keine MAC hat und an der Gruppe PXEs hängen + # dann wird diese nicht aufgenommen ... + $macdata = get_node_data($exp[0], array("hwaddress")); + $pxes = get_pxeconfigs($groupDN,array("dn","filename")); + if ( count($pxes) != 0 && $macdata['hwaddress'] == "" ){ + echo "Rechner ".$exp[1]." hat keine MAC Adresse eingetragen.
+ Fü die Gruppe sind PXE Bootmenüs definiert.
+ Da MACs für die PXE Datei notwendig ist wird der Rechner nicht aufgenommen!"; + } + else{ + $entry2['member'][] = $exp[0]; + } + $i++; + + } + + #print_r($entry2); echo "

"; + + if ($result = ldap_mod_replace($ds, $groupDN, $entry2)){ + + # PXEs die an der Gruppe hängen anpassen + $pxes = get_pxeconfigs($groupDN,array("dn")); + foreach ($pxes as $pxe){ + if ( $entry2['member'] > 1 ){ + $j = 0; + foreach ($entry2['member'] as $host){ + $macdata = get_node_data($host, array("hwaddress")); + $entryfilename ['filename'][$j] = "01-".$macdata['hwaddress']; + $j++; + } + } + if ( $entry2['member'] == 1 ){ + $macdata = get_node_data($entry2['member'], array("hwaddress")); + $entryfilename ['filename'] = "01-".$macdata['hwaddress']; + } + ldap_mod_replace($ds,$pxe['dn'],$entryfilename); + } + $mesg = "Gruppen-Mitglieder erfolgreich angelegt

"; + }else{ + $mesg = "Fehler beim anlegen der Gruppen-Mitglieder

"; + } +} + + +##################################### +# Description + +if ( $oldgroupdesc == $groupdesc ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldgroupdesc == "" && $groupdesc != "" ){ + echo "Gruppen-Beschreibung neu anlegen
"; + # hier noch Syntaxcheck + $entry['description'] = $groupdesc; + if($result = ldap_mod_add($ds,$groupDN,$entry)){ + $mesg = "Gruppen-Beschreibung erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Gruppen-Beschreibung

"; + } +} + +if ( $oldgroupdesc != "" && $groupdesc != "" && $oldgroupdesc != $groupdesc ){ + echo "Gruppen-Beschreibung aendern
"; + # hier noch Syntaxcheck + $entry['description'] = $groupdesc; + if($result = ldap_mod_replace($ds,$groupDN,$entry)){ + $mesg = "Gruppen-Beschreibung erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Gruppen-Beschreibung

"; + } +} + +if ( $oldgroupdesc != "" && $groupdesc == "" ){ + echo "Gruppen-Beschreibung loeschen
"; + # hier noch Syntaxcheck + $entry['description'] = $oldgroupdesc; + if($result = ldap_mod_del($ds,$groupDN,$entry)){ + $mesg = "Gruppen-Beschreibung erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Gruppen-Beschreibung

"; + } +} + + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/group_delete.php b/ldap-site-mngmt/webinterface/computers/group_delete.php new file mode 100644 index 00000000..2a7e3d29 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/group_delete.php @@ -0,0 +1,47 @@ +"; +echo "groupdn:"; print_r($groupDN); echo "
"; +echo "groupcn:"; print_r($groupcn); echo "
"; +*/ + +$seconds = 1; +$url = 'groupoverview.php'; + +echo " + + + AU Management + + + + +
"; + +if ( $groupDN != ""){ + + if ( delete_group($groupDN) ){ + $mesg = "Rechnergruppe ".$groupcn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen der Rechnergruppe ".$groupcn." !

"; + } + +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/groupoverview.dwt b/ldap-site-mngmt/webinterface/computers/groupoverview.dwt new file mode 100644 index 00000000..d875c3be --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/groupoverview.dwt @@ -0,0 +1,38 @@ + + + + + + + + + + + + + + + + +

Rechnergruppen  {AU} 

+ + + + + + + + + + + + + + + + + +
RechnergruppeAnzahl RechnerDHCP
{GROUPCN}  {MEMBERS}  {DHCPCONT}  
+ Zum Verwalten einer bestimmten Gruppe, wählen Sie links entsprechenden Submenü-Eintrag.
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/groupoverview.php b/ldap-site-mngmt/webinterface/computers/groupoverview.php new file mode 100644 index 00000000..b9f9ce05 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/groupoverview.php @@ -0,0 +1,64 @@ +assign(array("DN" => "", + "GROUPCN" => "Noch keine Rechnergruppen angelegt", + "GROUPDESC" => "", + "MEMBERS" => "", + "DHCPCONT" => "")); + +$attributes = array("dn","cn","member","description","dhcphlpcont"); +$group_array = get_groups($auDN,$attributes); + +$template->define_dynamic("Gruppen", "Webseite"); + +foreach ($group_array as $group){ + + $anzahlmember = count($group['member']); + + if ( count($group['dhcphlpcont']) != 0 ){ + $subnetCN = explode('cn=',$group['dhcphlpcont']); + $subnet = explode(',', $subnetCN[1]); + $dhcpcont = "Subnet $subnet[0]"; + }else{$dhcpcont = "";} + + $template->assign(array("DN" => $group['dn'], + "GROUPCN" => $group['cn'], + "GROUPDESC" => $group['description'], + "MEMBERS" => $anzahlmember, + # "MEMBER" => $group['member'], + "DHCPCONT" => $dhcpcont, + "AUDN" => $auDN )); + $template->parse("GRUPPEN_LIST", ".Gruppen"); +} + + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/host.dwt b/ldap-site-mngmt/webinterface/computers/host.dwt new file mode 100644 index 00000000..13d1da11 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/host.dwt @@ -0,0 +1,421 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Rechner   {HOSTNAME}

Allgemein

{DHCPLINK} DHCP/RBS

{HWLINK} Hardware

 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger Rechnername (hostname):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +   +
Rechner Beschreibung:   + + +   +
MAC Adresse: + + + (Format hex:hex:hex:hex:hex:hex)  +
IP Adresse:   + + + (Format xx.xx.xx.xx)  +
+

Rechner  {HOSTNAME}  löschen:

+ + + + + + + + + + + + +
+ Der Rechner wird komplett gelöscht,
d.h. inklusive aller spezifisch für ihn angelegten + Hardware-Profile (MachineConfig) und PXE Bootmenüs. +
+ +

Wochen Übersicht Machine Configs Rechner  {HOSTNAME}  :

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
UhrzeitMontagDienstagMittwochDonnerstagFreitagSamstagSonntag
0       
        
2       
        
4       
        
6       
        
8       
        
10       
        
12       
        
14       
        
16        
        
18       
        
20       
        
22       
        

Legende:

+ + + + + + + + + + + + + + + + + + + + + +
Machine Config Farbe
Keine Konfiguration    
{MCDESC}     
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/host.php b/ldap-site-mngmt/webinterface/computers/host.php new file mode 100644 index 00000000..928df62c --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/host.php @@ -0,0 +1,95 @@ +assign(array("HOSTDN" => $hostDN, + "HOSTNAME" => $host['hostname'], + "DOMAINNAME" => $host['domainname'], + "HWADDRESS" => $host['hwaddress'], + "IPADDRESS" => $hostip[0], + "DESCRIPTION" => $host['description'], + "DHCPCONT" => $host['dhcphlpcont'], + "DHCPTYPE" => $dhcptype, + "MOUSE" => $host['hw-mouse'], + "GRAPHIC" => $host['hw-graphic'], + "MONITOR" => $host['hw-monitor'], + "DHCPLINK" => "
", + "HWLINK" => "", + "AUDN" => $auDN, + "SBMNR" => $sbmnr)); + + +########################################################## +# MC Wochenübersicht +$mc_array = get_machineconfigs($hostDN,array("dn","cn","timerange","description")); +# print_r($mc_array); +for ($i=0; $i 1 ){ + foreach ($mc_array[$i]['timerange'] as $tr){ + $exptime = array_merge(explode('_',$tr),$mc_array[$i]['description']); + $timeranges[$i][] = $exptime; # Für grafische Wo-Ansicht + } + }else{ + $exptime = array_merge(explode('_',$mc_array[$i]['timerange']), $mc_array[$i]['description']); + $timeranges[$i] = $exptime; # Für grafische Wo-Ansicht + } +} +include("mc_wochenplan.php"); + +########################################################### +# PXE Wochenübersicht + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/host_add.php b/ldap-site-mngmt/webinterface/computers/host_add.php new file mode 100644 index 00000000..bde6f26a --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/host_add.php @@ -0,0 +1,101 @@ +"; +echo "hostname:"; print_r($hostname); echo "
"; +echo "hostdesc:"; print_r($hostdesc); echo "
"; +echo "mac:"; print_r($mac); echo "
"; +echo "ip:"; print_r($ip); echo "

"; +*/ + +$attribs = $_POST['attribs']; +if (count($attribs) != 0){ + foreach (array_keys($attribs) as $key){ + $atts[$key] = htmlentities($attribs[$key]); + } +} + +$seconds = 2; + +echo " + + + AU Management + + + + +
"; + +if ( $hostname != ""){ + + # Formulareingaben anpassen + $exphn = explode(" ",$hostname); + foreach ($exphn as $word){$expuc[] = ucfirst($word);} + $hostname = implode(" ",$expuc); + $hostname = preg_replace ( '/\s+([0-9A-Z])/', '$1', $hostname); + + # Host Objekt anlegen + $brothers = get_hosts($auDN,array("hostname")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['hostname'] == $hostname ){ + $mesg = "Es existiert bereits ein Rechner mit dem eingegebenen HOSTNAME!
+ Bitte geben Sie einen anderen HOSTNAME ein.

"; + $get_hostdesc = str_replace ( " ", "_", $hostdesc ); + $get_mac = str_replace ( " ", "_", $mac ); + $get_ip = str_replace ( " ", "_", $ip ); + $url = "new_host.php?hostname=Hier_anderen_HOSTNAME_eingeben&hostdesc=".$get_hostdesc."&mac=".$get_mac."&ip=".$ip; + $brother = 1; + break; + } + } + if ($brother == 0){ + $hostDN = "HostName=".$hostname.",cn=computers,".$auDN; + # print_r($hostDN); echo "
"; + + if (add_host($hostDN,$hostname,$hostdesc,$mac,$ip,$atts)){ + $mesg .= "
Neuer Rechner erfolgreich angelegt
"; + } + else{ + $mesg .= "
Fehler beim anlegen des Rechners!
"; + } + + $url = 'hostoverview.php'; + } +} + + +elseif ( $hostname == ""){ + + $get_hostdesc = str_replace ( " ", "_", $hostdesc ); + $get_mac = str_replace ( " ", "_", $mac ); + $get_ip = str_replace ( " ", "_", $ip ); + $mesg = "Sie haben den HOSTNAME des neuen Rechners nicht angegeben. Dieser ist aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "new_host.php?ou=Hier_HOSTNAME_eingeben&hostdesc=".$get_hostdesc."&mac=".$get_mac."&ip=".$ip; +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/host_change.php b/ldap-site-mngmt/webinterface/computers/host_change.php new file mode 100644 index 00000000..71c005fa --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/host_change.php @@ -0,0 +1,396 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +}*/ +#print_r($oldatts); echo "

"; + +/* +echo "new hostname:"; print_r($hostname); echo "
"; +echo "old hostname:"; print_r($oldhostname); echo "
"; +echo "new mac:"; print_r($mac); echo "
"; +echo "old mac:"; print_r($oldmac); echo "
"; +echo "new ip:"; print_r($ip); echo "
"; +echo "old ip:"; print_r($oldip); echo "
"; +echo "new desc:"; print_r($desc); echo "
"; +echo "old desc:"; print_r($olddesc); echo "

"; +echo "Host DN:"; print_r($hostDN); echo "
"; +echo "submenuNR:"; print_r($submenu); echo "

"; +*/ + +$seconds = 2; +$url = 'host.php?dn='.$hostDN.'&sbmnr='.$sbmnr; + +echo " + + + AU Management + + + + +
"; + +############################################## +# Hostname + +if ( $oldhostname == $hostname ){ + $mesg = "keine Aenderung
"; +} + +if ( $oldhostname != "" && $hostname != "" && $oldhostname != $hostname ){ + echo "Hostname aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $exphn = explode(" ",$hostname); + foreach ($exphn as $word){$expuc[] = ucfirst($word);} + $hostname = implode(" ",$expuc); + $hostname = preg_replace ( '/\s+([0-9A-Z])/', '$1', $hostname); + + $newhostDN = "hostname=".$hostname.",cn=computers,".$auDN; + # print_r($newhostDN); echo "

"; + modify_host_dn($hostDN, $newhostDN); + + # newsubmenu holen...hosts neu holen, sortieren, ->position + #$newhosts = get_hosts($auDN,array("dn")); + #print_r($newhosts); echo "

"; + #foreach ($newhosts as $item){ + # $newdnarray [] = $item['dn']; + #} + #$key = array_search($newhostDN, $newdnarray); + #print_r($key); echo "
"; + + $url = 'host.php?dn='.$newhostDN.'&sbmnr='.$sbmnr; + +} + +if ( $oldhostname != "" && $hostname == "" ){ + echo "Hostname loeschen!
+ Dies ist Teil des DN, Sie werden den Rechner komplett löschen

"; + echo "Wollen Sie den Rechner ".$oldhostname." mit seinen Hardware-Profilen (MachineConfigs) + und PXE Bootmenüs wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + + +##################################### +# MAC + +if ( $oldmac == $mac ){ + #$mesg = "keine Aenderung
"; +} + +if ( $oldmac == "" && $mac != "" ){ + echo "MAC neu anlegen
"; + # hier noch Syntaxcheck + $entry['hwaddress'] = $mac; + $result = ldap_mod_add($ds,$hostDN,$entry); + if($result){ + $mesg = "MAC erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der MAC

"; + } +} + +if ( $oldmac != "" && $mac != "" && $oldmac != $mac ){ + echo "MAC aendern
"; + # hier noch Syntaxcheck + $entry['hwaddress'] = $mac; + $result = ldap_mod_replace($ds,$hostDN,$entry); + if($result){ + # in den PXEs auch ändern + $pxes = get_pxeconfigs($hostDN,array("dn","filename")); + if ( count($pxes) != 0 ){ + foreach ($pxes as $pxe){ + $entrynewmac ['filename'] = "01-".$mac; + ldap_mod_replace($ds,$pxe['dn'],$entrynewmac); + } + } + # und in Gruppen PXEs + $groups = get_groups_member($auDN,array("dn"),$hostDN); + if ( count($groups) != 0 ){ + $pxes = get_pxeconfigs($groups[0]['dn'],array("dn","filename")); + if ( count($pxes) != 0 ){ + foreach ($pxes as $pxe){ + if (count($pxe['filename']) > 1){ + for ($i=0; $i"; + # check ob PXEs am Rechnerobjekt hängen + $pxes = get_pxeconfigs($hostDN,array("dn","filename")); + $groups = get_groups_member($auDN,array("dn"),$hostDN); + if ( count($groups) != 0 ){ + $pxes2 = get_pxeconfigs($groups[0]['dn'],array("dn","filename")); + } + if ( count($pxes) != 0 || count($pxes2) != 0){ + echo "Für den Rechner sind PXE Bootmenüs angelegt welche die MAC Adresse als
+ Dateinamen verwenden. Sie köennen die MAC erst löschen, wenn Sie diese PXEs
+ entfernt haben.

+ MAC nicht gelöscht!"; + } + else{ + # hier noch Syntaxcheck + $entry['hwaddress'] = $oldmac; + $result = ldap_mod_del($ds,$hostDN,$entry); + if($result){ + $mesg = "MAC erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der MAC

"; + } + } +} + + +######################################## +# IP + +if ( $oldip == $ip ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldip == "" && $ip != "" ){ + echo "IP neu anlegen
"; + # hier noch Syntaxcheck + if( $syntax->check_ip_syntax($ip) ){ + $newip_array = array($ip,$ip); + $newip = implode('_',$newip_array); + # print_r($newip); echo "

"; + if (new_ip_host($newip,$hostDN,$auDN)){ + $mesg = "IP erfolgreich eingetragen

"; + if ($dhcptype == "subnet"){ + adjust_hostip_dhcpsubnet($ip,$hostDN,$dhcphlpcont); + } + }else{ + $mesg = "Fehler beim eintragen der IP

"; + } + } + else{echo "Falsche IP Syntax

";} +} + +if ( $oldip != "" && $ip != "" && $oldip != $ip ){ + echo "IP aendern
"; + # hier noch Syntaxcheck + if( $syntax->check_ip_syntax($ip) ){ + $newip_array = array($ip,$ip); + $newip = implode('_',$newip_array); + # print_r($newip); echo "

"; + $oldip_array = array($oldip,$oldip); + $oldipp = implode('_',$oldip_array); + if (modify_ip_host($newip,$hostDN,$auDN)){ + $mesg = "IP erfolgreich geaendert

"; + if ($dhcptype == "subnet"){ + adjust_hostip_dhcpsubnet($ip,$hostDN,$dhcphlpcont); + } + }else{ + $mesg = "Fehler beim aendern der IP

"; + # oldip die schon gelöscht wurde wieder einfügen + new_ip_host($oldipp,$hostDN,$auDN); + } + } + else{echo "Falsche IP Syntax

";} +} + +if ( $oldip != "" && $ip == "" ){ + echo "IP loeschen
"; + + if(delete_ip_host($hostDN,$auDN)){ + $mesg = "IP erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der IP

"; + } +} + + +##################################### +# Description + +if ( $olddesc == $desc ){ + # $mesg = "keine Aenderung
"; +} + +if ( $olddesc == "" && $desc != "" ){ + echo "Rechner-Beschreibung neu anlegen
"; + # hier noch Syntaxcheck + $entry['description'] = $desc; + $result = ldap_mod_add($ds,$hostDN,$entry); + if($result){ + $mesg = "Rechner-Beschreibung erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Rechner-Beschreibung

"; + } +} + +if ( $olddesc != "" && $desc != "" && $olddesc != $desc ){ + echo "Rechner-Beschreibung aendern
"; + # hier noch Syntaxcheck + $entry['description'] = $desc; + $result = ldap_mod_replace($ds,$hostDN,$entry); + if($result){ + $mesg = "Rechner-Beschreibung erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Rechner-Beschreibung

"; + } +} + +if ( $olddesc != "" && $desc == "" ){ + echo "Rechner-Beschreibung loeschen
"; + # hier noch Syntaxcheck + $entry['description'] = $olddesc; + $result = ldap_mod_del($ds,$hostDN,$entry); + if($result){ + $mesg = "Rechner-Beschreibung erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Rechner-Beschreibung

"; + } +} + +#################################### +# restliche Attribute +/* +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + #$mesg = "keine Aenderung
"; + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$hostDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$hostDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$hostDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + +*/ + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/host_delete.php b/ldap-site-mngmt/webinterface/computers/host_delete.php new file mode 100644 index 00000000..bcfa0add --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/host_delete.php @@ -0,0 +1,47 @@ +"; +echo "hostdn:"; print_r($hostDN); echo "
"; +echo "hostname:"; print_r($hostname); echo "
"; +*/ + +$seconds = 1; +$url = 'hostoverview.php'; + +echo " + + + AU Management + + + + +
"; + +if ( $hostDN != ""){ + + if ( delete_host($hostDN) ){ + $mesg = "Rechner ".$hostname." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen von Rechner ".$hostname." !

"; + } + +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/hostoverview.dwt b/ldap-site-mngmt/webinterface/computers/hostoverview.dwt new file mode 100644 index 00000000..87ed24a6 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/hostoverview.dwt @@ -0,0 +1,40 @@ + + + + + + + + + + + + + + + + +

Rechner  {AU} 

+ + + + + + + + + + + + + + + + + + + +
RechnernameMAC AdresseIP AdresseDHCPRBS
{HOSTNAME}  {HWADDRESS}  {IPADDRESS}  {DHCPCONT}  {RBSCONT}  
+ Zum Verwalten eines bestimmten Rechners, wählen Sie links entsprechenden Submenü-Eintrag.
+ Um einen neuen Rechner anzulegen wählen Sie links "Neuer Rechner" +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/hostoverview.php b/ldap-site-mngmt/webinterface/computers/hostoverview.php new file mode 100644 index 00000000..c2bec0a2 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/hostoverview.php @@ -0,0 +1,82 @@ +assign(array("DN" => "", + "HOSTNAME" => "Noch keine Rechner angelegt", + "DOMAINNAME" => "", + "HWADDRESS" => "", + "IPADDRESS" => "", + "DHCPCONT" => "", + "RBSCONT" => "")); + +$attributes = array("dn","hostname","domainname","hwaddress","ipaddress","dhcphlpcont","hlprbservice"); +$host_array = get_hosts($auDN,$attributes); + +$template->define_dynamic("Rechner", "Webseite"); + +$i = 0; +foreach ($host_array as $host){ + + $hostname = "
".$host['hostname'].""; + $hostip = explode('_',$host['ipaddress']); + + $dhcpcont = ""; + if ( count($host['dhcphlpcont']) != 0 ){ + $dhcpexpdn = ldap_explode_dn($host['dhcphlpcont'],1); + $dhcpcn = $dhcpexpdn[0]; + $ocarray = get_node_data($host['dhcphlpcont'],array("objectclass","dhcphlpcont")); + $sub = array_search('dhcpSubnet', $ocarray['objectclass']); + if ($sub !== false ){ + $dhcpcont = "Subnet ".$dhcpexpdn[0]."
[".$dhcpexpdn[2]."]"; + }else{ + $dhcpcont = "Service ".$dhcpexpdn[0]."
[".$dhcpexpdn[2]."]"; + } + } + + $rbscont = ""; + if ( count($host['hlprbservice']) != 0 ){ + $rbsexpdn = ldap_explode_dn($host['hlprbservice'],1); + $rbscont = $rbsexpdn[0]."
[".$rbsexpdn[2]."]"; + } + + $template->assign(array("DN" => $host['dn'], + "HOSTNAME" => $hostname, + "DOMAINNAME" => $host['domainname'], + "HWADDRESS" => $host['hwaddress'], + "IPADDRESS" => $hostip[0], + "DHCPCONT" => $dhcpcont, + "RBSCONT" => $rbscont, + "AUDN" => $auDN )); + $template->parse("RECHNER_LIST", ".Rechner"); + + $i++; +} + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/hwhost.dwt b/ldap-site-mngmt/webinterface/computers/hwhost.dwt new file mode 100644 index 00000000..472b2f3e --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/hwhost.dwt @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + + + + + + +

Rechner   {HOSTNAME}

{HOSTLINK} Allgemein

{DHCPLINK} DHCP/RBS

Hardware

 
+ + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
HW Mouse:   + +   +
HW Graphic:   + +   +
HW Monitor:   + +   +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/hwhost.php b/ldap-site-mngmt/webinterface/computers/hwhost.php new file mode 100644 index 00000000..e401d5ce --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/hwhost.php @@ -0,0 +1,78 @@ +assign(array("HOSTDN" => $hostDN, + "HOSTNAME" => $host['hostname'], + "DOMAINNAME" => $host['domainname'], + "HWADDRESS" => $host['hwaddress'], + "IPADDRESS" => $hostip[0], + "DESCRIPTION" => $host['description'], + "DHCPCONT" => $host['dhcphlpcont'], + "MOUSE" => $host['hw-mouse'], + "GRAPHIC" => $host['hw-graphic'], + "MONITOR" => $host['hw-monitor'], + "DHCPLINK" => "", + "HOSTLINK" => "", + "AUDN" => $auDN, + "SBMNR" => $sbmnr)); + + +########################################################## +# MC Wochenübersicht +$mc_array = get_machineconfigs($hostDN,array("dn","cn","timerange","description")); +# print_r($mc_array); +for ($i=0; $i 1 ){ + foreach ($mc_array[$i]['timerange'] as $tr){ + $exptime = array_merge(explode('_',$tr),$mc_array[$i]['description']); + $timeranges[$i][] = $exptime; # Für grafische Wo-Ansicht + } + }else{ + $exptime = array_merge(explode('_',$mc_array[$i]['timerange']), $mc_array[$i]['description']); + $timeranges[$i] = $exptime; # Für grafische Wo-Ansicht + } +} +include("mc_wochenplan.php"); + +########################################################### +# PXE Wochenübersicht + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/hwhost_change.php b/ldap-site-mngmt/webinterface/computers/hwhost_change.php new file mode 100644 index 00000000..7b93f7c9 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/hwhost_change.php @@ -0,0 +1,127 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + +/* +echo "new hostname:"; print_r($hostname); echo "
"; +echo "old hostname:"; print_r($oldhostname); echo "
"; +echo "new mac:"; print_r($mac); echo "
"; +echo "old mac:"; print_r($oldmac); echo "
"; +echo "new ip:"; print_r($ip); echo "
"; +echo "old ip:"; print_r($oldip); echo "
"; +echo "new desc:"; print_r($desc); echo "
"; +echo "old desc:"; print_r($olddesc); echo "

"; +echo "Host DN:"; print_r($hostDN); echo "
"; +echo "submenuNR:"; print_r($submenu); echo "

"; +*/ + +$seconds = 2; +$url = 'host.php?dn='.$hostDN.'&sbmnr='.$sbmnr; + +echo " + + + AU Management + + + + +
"; + +#################################### +# restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + #$mesg = "keine Aenderung
"; + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$hostDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$hostDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$hostDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/machineconfig_default.dwt b/ldap-site-mngmt/webinterface/computers/machineconfig_default.dwt new file mode 100644 index 00000000..3596a0ce --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/machineconfig_default.dwt @@ -0,0 +1,323 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Default MachineConfigs (Konfigurationen)   {AU}

+ + + + + + + + + + + + + + + +
Machine ConfigGültigkeitsdauer (Time Range)
{MCDESC}  {TRANGES}  

Wochen Übersicht:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
UhrzeitMontagDienstagMittwochDonnerstagFreitagSamstagSonntag
0       
        
2       
        
4       
        
6       
        
8       
        
10       
        
12       
        
14       
        
16        
        
18       
        
20       
        
22       
        

Legende:

+ + + + + + + + + + + + + + + + + + + + + +
Machine Config Farbe
Keine Konfiguration    
{MCDESC}     
diff --git a/ldap-site-mngmt/webinterface/computers/machineconfig_default.php b/ldap-site-mngmt/webinterface/computers/machineconfig_default.php new file mode 100644 index 00000000..ac386a57 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/machineconfig_default.php @@ -0,0 +1,75 @@ +assign(array("MCDN" => "", + "MCCN" => "Noch keine Default MachineConfig angelegt", + "TRANGES" => "", + "MCDESC" => "Noch keine Default MachineConfig angelegt")); + + +$mc_array = get_machineconfigs("cn=computers,".$auDN,array("dn","cn","timerange","description")); +# print_r($mc_array); + + +$template->define_dynamic("Machineconf", "Webseite"); + +for ($i=0; $i 1 ){ + foreach ($mc_array[$i]['timerange'] as $tr){ + $exptime = array_merge(explode('_',$tr),$mc_array[$i]['description']); + $timeranges[$i][] = $exptime; # Für grafische Wo-Ansicht + if ($exptime[0] == "X"){$exptime[0]="täglich";} + # if ($exptime[1] == "X" && $exptime[2] == "X"){$exptime[1] = ""; $exptime[2]= "";} + $trange .= $exptime[0].", von ".$exptime[1].":00 bis ".$exptime[2].":59 / "; + } + }else{ + $exptime = array_merge(explode('_',$mc_array[$i]['timerange']), $mc_array[$i]['description']); + $timeranges[$i] = $exptime; # Für grafische Wo-Ansicht + if ($exptime[0] == "X"){$exptime[0]="täglich";} + # if ($exptime[1] == "X" && $exptime[2] == "X"){$exptime[1] = ""; $exptime[2]= "";} + $trange .= $exptime[0].", von ".$exptime[1].":00 bis ".$exptime[2].":59"; + } + + $template->assign(array("MCDN" => $mc_array[$i]['dn'], + "MCCN" => $mc_array[$i]['cn'], + "TRANGES" => $trange, + "MCDESC" => $mc_array[$i]['description'], + "AUDN" => $auDN)); + $template->parse("MACHINECONF_LIST", ".Machineconf"); +} + +#get_entry_number($mc_array[3]['dn'],"machineconfig"); + +include("mc_wochenplan.php"); + + +################################################################################### + +include("computers_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/computers/mc_wochenplan.php b/ldap-site-mngmt/webinterface/computers/mc_wochenplan.php new file mode 100644 index 00000000..3df7ab82 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mc_wochenplan.php @@ -0,0 +1,154 @@ +assign(array("A0" => "","B0" => "","C0" => "","D0" => "","E0" => "","F0" => "","G0" => "", + "A1" => "","B1" => "","C1" => "","D1" => "","E1" => "","F1" => "","G1" => "", + "A2" => "","B2" => "","C2" => "","D2" => "","E2" => "","F2" => "","G2" => "", + "A3" => "","B3" => "","C3" => "","D3" => "","E3" => "","F3" => "","G3" => "", + "A4" => "","B4" => "","C4" => "","D4" => "","E4" => "","F4" => "","G4" => "", + "A5" => "","B5" => "","C5" => "","D5" => "","E5" => "","F5" => "","G5" => "", + "A6" => "","B6" => "","C6" => "","D6" => "","E6" => "","F6" => "","G6" => "", + "A7" => "","B7" => "","C7" => "","D7" => "","E7" => "","F7" => "","G7" => "", + "A8" => "","B8" => "","C8" => "","D8" => "","E8" => "","F8" => "","G8" => "", + "A9" => "","B9" => "","C9" => "","D9" => "","E9" => "","F9" => "","G9" => "", + "A10" => "","B10" => "","C10" => "","D10" => "","E10" => "","F10" => "","G10" => "", + "A11" => "","B11" => "","C11" => "","D11" => "","E11" => "","F11" => "","G11" => "", + "A12" => "","B12" => "","C12" => "","D12" => "","E12" => "","F12" => "","G12" => "", + "A13" => "","B13" => "","C13" => "","D13" => "","E13" => "","F13" => "","G13" => "", + "A14" => "","B14" => "","C14" => "","D14" => "","E14" => "","F14" => "","G14" => "", + "A15" => "","B15" => "","C15" => "","D15" => "","E15" => "","F15" => "","G15" => "", + "A16" => "","B16" => "","C16" => "","D16" => "","E16" => "","F16" => "","G16" => "", + "A17" => "","B17" => "","C17" => "","D17" => "","E17" => "","F17" => "","G17" => "", + "A18" => "","B18" => "","C18" => "","D18" => "","E18" => "","F18" => "","G18" => "", + "A19" => "","B19" => "","C19" => "","D19" => "","E19" => "","F19" => "","G19" => "", + "A20" => "","B20" => "","C20" => "","D20" => "","E20" => "","F20" => "","G20" => "", + "A21" => "","B21" => "","C21" => "","D21" => "","E21" => "","F21" => "","G21" => "", + "A22" => "","B22" => "","C22" => "","D22" => "","E22" => "","F22" => "","G22" => "", + "A23" => "","B23" => "","C23" => "","D23" => "","E23" => "","F23" => "","G23" => "")); + +#print_r($timeranges); echo "
"; + +# vom spezifischsten zum unspezifischsten : +# FR_0_7 -> FR_X_X -> X_0_7 -> X_X_X +$daytime = array(); +$timex = array(); +$dayx = array(); +$allx = array(); +$legend = array(); +if(count($timeranges) != 0){ +foreach ($timeranges as $tr){ + if (count($tr[0]) > 1){ + foreach ($tr as $item){ + if ($item[0] != "X" && $item[1] != "X" && $item[2] != "X" && ($item[0] == "MO" || $item[0] == "DI" || $item[0] == "MI" || $item[0] == "DO" || $item[0] == "FR" || $item[0] == "SA" || $item[0] == "SO")){ + $daytime[] = $item; + } + if ($item[0] != "X" && $item[1] == "X" && $item[2] == "X"){ + $timex[] = $item; + } + if ($item[0] == "X" && $item[1] != "X" && $item[2] != "X"){ + $dayx[] = $item; + } + if ($item[0] == "X" && $item[1] == "X" && $item[2] == "X"){ + $allx[] = $item; + } + } + }else{ + if ($tr[0] != "X" && $tr[1] != "X" && $tr[2] != "X" && ($tr[0] == "MO" || $tr[0] == "DI" || $tr[0] == "MI" || $tr[0] == "DO" || $tr[0] == "FR" || $tr[0] == "SA" || $tr[0] == "SO")){ + $daytime[] = $tr; + } + if ($tr[0] != "X" && $tr[1] == "X" && $tr[2] == "X"){ + $timex[] = $tr; + } + if ($tr[0] == "X" && $tr[1] != "X" && $tr[2] != "X"){ + $dayx[] = $tr; + } + if ($tr[0] == "X" && $tr[1] == "X" && $tr[2] == "X"){ + $allx[] = $tr; + } + } +} + +#print_r($daytime); echo "
"; +#print_r($timex); echo "
"; +#print_r($dayx); echo "
"; +#print_r($allx); echo "
"; + +$daycode = array("MO" => "A", "DI" => "B", "MI" => "C", "DO" => "D", "FR" => "E", "SA" => "F", "SO" => "G"); +$allxcolors = array("#BEBEBE","A0A0A0","#696969","#EEDFCC","#D8BFD8","#505050"); +$dayxcolors = array("#483D8B","#7B68EE","#191970","#8470FF","#708090","#6A5ACD"); +$timexcolors = array("#CDC673","#A2CD5A","#BDB76B","#8B864E","#6B8E23","#CDBE70"); +$daytimecolors = array("880000","#CD6839","#CC3300","#CC6600","#993300","#8B4C39"); + + +if (count($allx) != 0){ + $c = 0; + foreach ($allx as $range){ + foreach ($daycode as $dc){ + for ($i = 0; $i <= 23; $i++){ + $template->assign(array($dc.$i => "background-color:".$allxcolors[$c].";")); + } + } + $legend[] = array($range ,$allxcolors[$c]); + $c++; + } +} + +if (count($dayx) != 0){ + $c = 0; + foreach ($dayx as $range){ + foreach ($daycode as $dc){ + for ($i = $range[1]; $i<= $range[2]; $i++){ + $template->assign(array($dc.$i => "background-color:".$dayxcolors[$c].";")); + } + } + $legend[] = array($range ,$dayxcolors[$c]); + $c++; + } +} + +if (count($timex) != 0){ + $c = 0; + foreach ($timex as $range){ + $dc = $daycode[$range[0]]; + for ($i = 0; $i<= 23; $i++){ + $template->assign(array($dc.$i => "background-color:".$timexcolors[$c].";")); + } + $legend[] = array($range ,$timexcolors[$c]); + $c++; + } +} + +if (count($daytime) != 0){ + $c = 0; + foreach ($daytime as $range){ + $dc = $daycode[$range[0]]; + for ($i = $range[1]; $i<= $range[2]; $i++){ + $template->assign(array($dc.$i => "background-color:".$daytimecolors[$c].";")); + } + $legend[] = array($range ,$daytimecolors[$c]); + $c++; + } +} + +} + +$template->assign(array("MCDESC" => "")); +#print_r($legend); +if (count($legend) != 0){ + $template->define_dynamic("Legende", "Webseite"); + foreach ($legend as $item){ + # Timerange Komponente + $color = $item[1]; + $template->assign(array("TR1" => $item[0][0], + "TR2" => $item[0][1], + "TR3" => $item[0][2], + "MCDESC" => $item[0][3], + "COLOR" => $color)); + $template->parse("LEGENDE_LIST", ".Legende"); + } +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/mcdef.dwt b/ldap-site-mngmt/webinterface/computers/mcdef.dwt new file mode 100644 index 00000000..15f48548 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mcdef.dwt @@ -0,0 +1,293 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

MachineConfig   {MCCN}

Allgemein:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
  + MC_ +   +
Machine Config
Beschreibung:  
  + + +   +
Gültigkeitsdauer
(Time Range(s)):
 
  + Eines der folgenden:
+ + - Datum  (dd.mm, z.B. 21.03/01.11)
+ - Monatstag  (dd, z.B. 01 oder 25)
+ - Wochentag  (MO, DI, ... , SO)
+ - X für täglich + +
+ - Uhrzeit  (Format: hh, z.B. 07-19)
+ - X für rund um die Uhr + +
Zum Löschen einer Time Range
Häkchen setzen 
+ +   + +  
+ + +
+ + :00  -   + + :59 Uhr
+
Neue Time Range hinzufügen   + + + + + :00  -   + + :59 Uhr
+ +

Dienste:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Start X:   + +   ( yes | no ) +
Start SNMP:   + +   ( yes | no ) +
Start SSHD:   + +   ( yes | no ) +
Start XDMCP:   + +   ( yes | no ) +
Start RWHOD:   + +   ( yes | no ) +
Start PRINT DAEMON:   + +   ( yes | no ) +
TEX Enable:   + +   ( yes | no ) +
Start CRON:   + +   ( yes | no ) +
Crontab Entries:  + + +  
+ +
Language:   + + +   +
NETBIOS Workgroup:   + +   +
VMWARE:   + +   +
+

MachineConfig  {MCCN}  kopieren:

+ Beachten Sie, dass die Time Ranges der Machine Config nicht mit kopiert werden.
+ Sie müssen diese anschließend neu setzen.
+ Geben Sie bitte den eindeutigen Namen des neuen MachineConfig-Objektes an. +
+ + + + + + + + + + + + + + + + + + + +
Ziel Objekt:
+ (Mehrfachauswahl möglich) 
+ + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
+ MC_ +   +
+ +

Default MachineConfig  {MCCN}  löschen:

+ + + + + + + + + + + + + +
+ Die MachineConfig wird komplett gelöscht. +
+ +
diff --git a/ldap-site-mngmt/webinterface/computers/mcdef.php b/ldap-site-mngmt/webinterface/computers/mcdef.php new file mode 100644 index 00000000..18e7a0aa --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mcdef.php @@ -0,0 +1,137 @@ +define_dynamic("TRanges", "Webseite"); +if (count($mc['timerange']) > 1){ + foreach($mc['timerange'] as $tr){ + $exptime = explode('_',$tr); + $template->assign(array("MCDAY" => $exptime[0], + "MCBEG" => $exptime[1], + "MCEND" => $exptime[2])); + $template->parse("TRANGES_LIST", ".TRanges"); + } +}else{ + $exptime = explode('_',$mc['timerange']); + $template->assign(array("MCDAY" => $exptime[0], + "MCBEG" => $exptime[1], + "MCEND" => $exptime[2])); + $template->parse("TRANGES_LIST", ".TRanges"); +} + +$expcn = explode('_',$mc['cn']); +$name = array_slice($expcn,1); +$mccn = implode('_',$name); + +$template->assign(array("MCDN" => $mcDN, + "MCCN" => $mccn, + "MCDESC" => $mc['description'], + "LANG" => $mc['language'], + "X" => $mc['start-x'], + "SNMP" => $mc['start-snmp'], + "SSHD" => $mc['start-sshd'], + "XDMCP" => $mc['start-xdmcp'], + "RWHOD" => $mc['start-rwhod'], + "CRON" => $mc['start-cron'], + "CRONTAB" => "", + "PRINTD" => $mc['start-printdaemon'], + "TEX" => $mc['tex-enable'], + "NETBIOS" => $mc['netbios-workgroup'], + "VMWARE" => $mc['vmware'], + "NODEDN" => $nodeDN, + "DEFDN" => "cn=computers,".$auDN, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +$template->define_dynamic("Crontab", "Webseite"); +if ( count($mc['crontab-entries']) != 0 ){ + if ( count($mc['crontab-entries']) > 1 ){ + foreach ($mc['crontab-entries'] as $crontab){ + $template->assign(array("CRONTAB" => $crontab)); + $template->parse("CRONTAB_LIST", ".Crontab"); + } + } + if ( count($mc['crontab-entries']) == 1 ){ + $template->assign(array("CRONTAB" => $mc['crontab-entries'])); + $template->parse("CRONTAB_LIST", ".Crontab"); + } +} +$template->assign(array("CRONTAB" => "")); +$template->parse("CRONTAB_LIST", ".Crontab"); + +################################################ +# MC kopieren + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + + +# falls TR vorhanden dann soll sie gelöscht werden (flag deltr setzen) +if (count($mc['timerange']) != 0){ + $template->assign(array("DELTR" => "1")); +} +else{ + $template->assign(array("DELTR" => "0")); +} + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/mcdef_add.php b/ldap-site-mngmt/webinterface/computers/mcdef_add.php new file mode 100644 index 00000000..efb86e87 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mcdef_add.php @@ -0,0 +1,160 @@ +"; +$n = array_keys($targets,'none'); +#print_r($n); echo "
"; +for ($i=0; $i"; + +$mcattribs = $_POST['mcattribs']; +if (count($mcattribs) != 0){ + foreach (array_keys($mcattribs) as $key){ + $mcatts[$key] = htmlentities($mcattribs[$key]); + } +} +# print_r($mcatts); echo "

"; + +$seconds = 2; +$get_mccn = str_replace ( " ", "_", $mccn ); +$get_mcdesc = str_replace ( " ", "_", $mcdesc ); +$get_mcday = str_replace ( " ", "_", $mcday ); +$get_mcbeg = str_replace ( " ", "_", $mcbeg ); +$get_mcend = str_replace ( " ", "_", $mcend ); +$url = "new_mcdef.php?mccn=".$get_mccn."&mcdesc=".$get_mcdesc."&mcday=".$get_mcday."&mcbeg=".$get_mcbeg."&mcend=".$get_mcend."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + +if ( $mccn != "" && $mccn != "Hier_MC_NAME_eintragen"){ + + $mccn = "MC_".$mccn; + # Formulareingaben anpassen + $expmc = explode(" ",$mccn); + foreach ($expmc as $word){$expuc[] = ucfirst($word);} + $mccn = implode(" ",$expuc); + $mccn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mccn); + + $mctimerange = ""; + + if (count($targets) != 0){ + foreach ($targets as $targetDN){ + + $exptargetdn = ldap_explode_dn($targetDN, 1); + $targetcn = $exptargetdn[0]; + $targettype = $exptargetdn[1]; + + # Check auf eindeutigen MC-Namen am Zielobjekt + $brothers = get_machineconfigs($targetDN,array("cn")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['cn'] == $mccn ){ + $mesg = "Es existiert bereits ein PXE Boot Menü mit dem eingegebenen Namen!
+ Bitte geben Sie einen anderen Namen ein.

"; + $url = "new_mcdef.php?mccn=".$get_mccn."&mcday=".$get_mcday."&mcbeg=".$get_mcbeg."&mcend=".$get_mcend."&mnr=".$mnr."&sbmnr=".$sbmnr; + $brother = 1; + break; + } + } + if ($brother == 0){ + + if ( $mcday != "" && $mcbeg != "" && $mcend != "" && $mcbeg <= $mcend ){ + + # TimeRange Syntax checken + $syntax = new Syntaxcheck; + if ($syntax->check_timerange_syntax($mcday,$mcbeg,$mcend)){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$mcday)){$mcday = strtoupper($mcday);} + if (preg_match("/([a-z]+)/",$mcbeg)){$mcbeg = strtoupper($mcbeg);} + if (preg_match("/([a-z]+)/",$mcend)){$mcend = strtoupper($mcend);} + + # führende Nullen weg + $mcbeg = preg_replace ( '/0([0-9])/', '$1', $mcbeg); + $mcend = preg_replace ( '/0([0-9])/', '$1', $mcend); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken + if(check_timerange($mcday,$mcbeg,$mcend,$targetDN,"")){ + $mctimerange = $mcday."_".$mcbeg."_".$mcend; + } + else{ + $mesg = "Es existiert bereits eine MachineConfig, die sich mit der eingegebenen Time Range + überschneidet!
+ Die neue MachineConfig wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + } + else{ + $mesg = "Falsche Syntax in der Time-Range-Eingabe! Die neue MachineConfig wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + } + else{ + $mesg = "Keine vollständige Time-Range-Eingabe! Die neue MachineConfig wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + + $mcDN = "cn=".$mccn.",".$targetDN; + print_r($mcDN); echo "
"; + + if (add_mc($mcDN,$mccn,$mctimerange,$mcdesc,$mcattribs)){ + $mesg .= "
Neue MachineConfig erfolgreich angelegt
"; + if ($targettype == "computers"){ + $url = "mcdef.php?dn=".$mcDN."&mnr=1"; + } + if ($targettype == "groups"){ + $url = "mcdef.php?dn=".$mcDN."&mnr=2"; + } + if ($targettype == $au_ou){ + $url = "machineconfig_default.php"; + } + } + else{ + $mesg .= "
Fehler beim anlegen der MachineConfig!
"; + } + } + } + } + else{ + $mesg .= "
Sie haben kein Ziel angegeben!
"; + } +} + +elseif ( $mccn == "" || $mccn == "Hier_MC_NAME_eintragen"){ + + $mesg = "Sie haben den Namen der neuen Machine Config nicht angegeben. Dieser ist aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "new_mcdef.php?mccn=Hier_MC_NAME_eintragen&mcdesc=".$get_mcdesc."&mcday=".$get_mcday."&mcbeg=".$get_mcbeg."&mcend=".$get_mcend."&mnr=".$mnr."&sbmnr=".$sbmnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/mcdef_change.php b/ldap-site-mngmt/webinterface/computers/mcdef_change.php new file mode 100644 index 00000000..4aaa29fe --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mcdef_change.php @@ -0,0 +1,402 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + +$seconds = 2; +$url = "mcdef.php?dn=".$mcDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# MC CN (DN) + +if ( $oldmccn == $mccn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldmccn != "" && $mccn != "" && $oldmccn != $mccn ){ + echo "Machine Config Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $expmc = explode(" ",$mccn); + foreach ($expmc as $word){$expuc[] = ucfirst($word);} + $mccn = implode(" ",$expuc); + $mccn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mccn); + + + $newmcDN = "cn=".$mccn.",".$nodeDN; + print_r($newmcDN); echo "

"; + + if(modify_mc_dn($mcDN, $newmcDN)){ + $mesg = "MC Name erfolgreich geändert

"; + $mcDN = $newmcDN; + }else{ + $mesg = "Fehler beim ändern des MC Name!

"; + } + + + # newsubmenu holen... + $url = "mcdef.php?dn=".$newmcDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + +if ( $oldmccn != "" && $mccn == "" ){ + echo "Gruppenname loeschen!
+ Dieses ist Teil des DN, Sie werden die MachineConfig komplett löschen

"; + echo "Wollen Sie die MachineConfig ".$oldmccn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + +########################################## +# bereits vorhandene TimeRange(s) bearbeiten + +$entrymodtr = array(); +$modtr = 0; +# TimeRanges zusammensetzen +# $t = 0; # Laufvariable für $entrymodtr, da nicht jede Timerange ok sein muss +for ($i=0; $icheck_timerange_syntax($mcday[$i],$mcbeg[$i],$mcend[$i])){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$mcday[$i])){$mcday[$i] = strtoupper($mcday[$i]);} + if (preg_match("/([a-z]+)/",$mcbeg[$i])){$mcbeg[$i] = strtoupper($mcbeg[$i]);} + if (preg_match("/([a-z]+)/",$mcend[$i])){$mcend[$i] = strtoupper($mcend[$i]);} + + # führende Nullen weg + $mcbeg[$i] = preg_replace ( '/0([0-9])/', '$1', $mcbeg[$i]); + $mcend[$i] = preg_replace ( '/0([0-9])/', '$1', $mcend[$i]); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken außer mit eigener alter TR da diese + # ja geändert werden soll + if(check_timerange($mcday[$i],$mcbeg[$i],$mcend[$i],$nodeDN,$oldmctimerange)){ + + $mctimerange = $mcday[$i]."_".$mcbeg[$i]."_".$mcend[$i]; + $entrymodtr ['timerange'][$i] = $mctimerange; + $modtr = 1; + + } + else{ + $mesg = "Es existiert bereits eine MachineConfig, die sich mit der eingegebenen Time Range + überschneidet!
+ Bitte geben Sie eine andere Time Range ein.

"; + $entrymodtr ['timerange'][$i] = $oldmctimerange; + } + } + else{ + $mesg = "Falsche Syntax in der Timerange-Eingabe!
+ Bitte geben Sie die erneut Time Range ein.

"; + $entrymodtr ['timerange'][$i] = $oldmctimerange; + } + +} + + +elseif ( $mcday[$i] == "" || $mcbeg[$i] == "" || $mcend[$i] == "" || $mcbeg[$i] > $mcend[$i]){ + + $mesg = "Sie haben die Time Range Nr.".$i." nicht vollständig angegeben. Diese ist aber ein notwendiges Attribut.
+ Diese Time Range wird nicht bearbeitet.

"; + $entrymodtr ['timerange'][$i] = $oldmctimerange; +} + +else{$entrymodtr ['timerange'][$i] = $oldmctimerange;} +} # Ende for-Schleife für jede Timerange +# jetzt noch alle gesammelten Änderungen Durchführen ... +if ($modtr == 1){ + # erst ändern + echo "Ändern: "; print_r($entrymodtr); echo "
"; + if($result = ldap_mod_replace($ds,$mcDN,$entrymodtr)){ + $mesg = "TimeRanges erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern der TimeRanges!

"; + } +} + + +if ( count($deltr) != 0 && $modtr == 0 ){ + # Time Range löschen + $j = 0; + foreach ($deltr as $delrange){ + $entrydeltr ['timerange'][$j] = $delrange; + $j++; + } + # dann löschen + echo "Löschen: "; print_r($entrydeltr); echo "
"; + if($result = ldap_mod_del($ds,$mcDN,$entrydeltr)){ + $mesg = "TimeRanges erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen der TimeRanges!

"; + } +}elseif(count($deltr) != 0 && $modtr == 1){ + echo "Nur Ändern (gleichzeitig Löschen und Ändern geht nicht)"; +} + +##################################### +# TimeRange hinzufügen + +if ( $newmcday != "" && $newmcbeg != "" && $newmcend != "" && $newmcbeg <= $newmcend ){ + + # TimeRange Syntax checken + $syntax = new Syntaxcheck; + if ($syntax->check_timerange_syntax($newmcday,$newmcbeg,$newmcend)){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$newmcday)){$newmcday = strtoupper($newmcday);} + if (preg_match("/([a-z]+)/",$newmcbeg)){$newmcbeg = strtoupper($newmcbeg);} + if (preg_match("/([a-z]+)/",$newmcend)){$newmcend = strtoupper($newmcend);} + + # führende Nullen weg + $newmcbeg = preg_replace ( '/0([0-9])/', '$1', $newmcbeg); + $newmcend = preg_replace ( '/0([0-9])/', '$1', $newmcend); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken + if(check_timerange($newmcday,$newmcbeg,$newmcend,$nodeDN,"")){ + + $newmctimerange = $newmcday."_".$newmcbeg."_".$newmcend; + $entrytr ['timerange'] = $newmctimerange; + if($result = ldap_mod_add($ds,$mcDN,$entrytr)){ + $mesg = "Zusätzliche TimeRange erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der zusätzlichen TimeRange!

"; + } + }else{ + $mesg = "Es existiert bereits eine MachineConfig, die sich mit der eingegebenen Time Range + überschneidet!
+ Bitte geben Sie eine andere Time Range ein.

"; + } + }else{ + $mesg = "Falsche Syntax in der Timerange-Eingabe!
+ Bitte geben Sie die erneut Time Range ein.

"; + } +} + +##################################### +# MC Description + +if ( $oldmcdesc == $mcdesc ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldmcdesc == "" && $mcdesc != "" ){ + echo "MC-Beschreibung neu anlegen
"; + # hier noch Syntaxcheck + $entrymc['description'] = $mcdesc; + if(ldap_mod_add($ds,$mcDN,$entrymc)){ + $mesg = "MC-Beschreibung erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der MC-Beschreibung

"; + } +} + +if ( $oldmcdesc != "" && $mcdesc != "" && $oldmcdesc != $mcdesc ){ + echo "MC-Beschreibung aendern
"; + # hier noch Syntaxcheck + $entrymc['description'] = $mcdesc; + if(ldap_mod_replace($ds,$mcDN,$entrymc)){ + $mesg = "MC-Beschreibung erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der MC-Beschreibung

"; + } +} + +if ( $oldmcdesc != "" && $mcdesc == "" ){ + echo "Rechner-Beschreibung loeschen
"; + # hier noch Syntaxcheck + $entrymc['description'] = $oldmcdesc; + if(ldap_mod_del($ds,$mcDN,$entrymc)){ + $mesg = "MC-Beschreibung erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der MC-Beschreibung

"; + } +} + +##################################### +# Crontab Entries + +if (count($crontab) != 0 && (count(array_diff_assoc($crontab,$oldcrontab)) != 0 || count(array_diff_assoc($oldcrontab,$crontab)) != 0) ){ + + $crontabentry = array(); + foreach ($crontab as $ct){ + if ($ct != ""){ + $crontabentry ['crontab-entries'][] = $ct; + } + } + $oldcrontabentry = array(); + foreach ($oldcrontab as $oldct){ + if ($oldct != ""){ + $oldcrontabentry ['crontab-entries'][] = $oldct; + } + } + + if (count($crontabentry) == 0){ + echo "Crontab Eintrag löschen
"; + ldap_mod_del($ds,$mcDN,$oldcrontabentry); + }else{ + echo "Crontab Eintrag ändern
"; + print_r($crontabentry); + ldap_mod_replace($ds,$mcDN,$crontabentry); + } +} + +##################################### +# Restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} + +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$mcDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$mcDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$mcDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/mcdef_copy.php b/ldap-site-mngmt/webinterface/computers/mcdef_copy.php new file mode 100644 index 00000000..313b22fc --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mcdef_copy.php @@ -0,0 +1,111 @@ +"; +$n = array_keys($copytargets,'none'); +#print_r($n); echo "
"; +for ($i=0; $i"; + + +$seconds = 2; +$url = "mcdef.php?dn=".$mcDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +if ( $mccn != ""){ + + # Formulareingaben anpassen + $expmc = explode(" ",$mccn); + foreach ($expmc as $word){$expuc[] = ucfirst($word);} + $mccn = implode(" ",$expuc); + $mccn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mccn); + + + if (count($copytargets) != 0){ + foreach ($copytargets as $targetDN){ + + $brothers = get_machineconfigs($targetDN,array("cn")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['cn'] == $mccn ){ + $mesg = "Es existiert bereits eine Machine Config mit dem eingegebenen Namen!
+ Bitte geben Sie einen anderen Namen ein.

"; + $url = "mcdef.php?dn=".$mcDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + $brother = 1; + break; + } + } + if ($brother == 0){ + + print_r($targetDN); echo "
"; + $exptarget = explode(',',$targetDN); + $target = explode('=',$exptarget[0]); + + $newmcDN = "cn=".$mccn.",".$targetDN; + print_r($newmcDN); echo "
"; + + + if (dive_into_tree_cp($mcDN,$newmcDN)){ + if($deltr == 1){ + $entrydel ['timerange'] = array(); + # Timeranges im neuen Objekt löschen + if (ldap_mod_del($ds,$newmcDN,$entrydel)){ + $mesg .= "
MachineConfig erfolgreich nach ".$target[1]." kopiert
"; + } + else{ + ldap_delete($ds,$newmcDN); + $mesg .= "
Fehler beim kopieren der MachineConfig nach ".$target[1]."
"; + } + } + } + else{ + $mesg .= "
Fehler beim kopieren der MachineConfig nach ".$target[1]."
"; + } + } + } + } + else{ + $mesg .= "
Sie haben kein Ziel angegeben!
"; + } +} + +elseif ( $mccn == ""){ + + $mesg = "Sie haben den Namen der neuen Machine Config nicht angegeben. Dieser ist aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "mcdef.php?dn=".$mcDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/mcdef_delete.php b/ldap-site-mngmt/webinterface/computers/mcdef_delete.php new file mode 100644 index 00000000..e191f703 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/mcdef_delete.php @@ -0,0 +1,40 @@ + + + Computers Management + + + + +
"; + +if ( $mcDN != ""){ + + if ( dive_into_tree_del($mcDN,"") ){ + $mesg = "Machine Config ".$mccn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen der Machine Config ".$mccn." !

"; + } + +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/menu.dwt b/ldap-site-mngmt/webinterface/computers/menu.dwt new file mode 100644 index 00000000..34e02572 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menu.dwt @@ -0,0 +1,40 @@ + + + + + + + + + + + + + + + + + + + + + + {SUB} + + + + {SUBSUB} + + + + + + + + + + + + +
{ICON}   + {TEXT_M} 
diff --git a/ldap-site-mngmt/webinterface/computers/menuentry.dwt b/ldap-site-mngmt/webinterface/computers/menuentry.dwt new file mode 100644 index 00000000..2ad75b93 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuentry.dwt @@ -0,0 +1,249 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Zurück zu  {PXECN}

 

Boot Menü Eintrag   {MECN}

 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +   +
Label:   + +   +
Generisches Boot Image:

(Angeboten von)  
+

{GMECN}

Abteilung: {GMEOU} [Remote Boot Dienst: {GMERBS}] +
Menu Label:   + +   +
Menu Default:   + +   +
Menu Passwd:   + +   +
Menu Hide:   + +   +
Localboot:   + +   +

APPEND Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Client Konfiguration via:   + + ( dhcp | file | ldap ) +
vga:   + +   +
splash:   + +   +
vci:   + +   +
no ldsc:   + +   +
elevator:   + +   +
apic:   + +   +
Union FS:   + +   +
cowloop:   + +   +
Debug Level:   + +   +
Menü Position:   + +   +
Submenü Verweis:   + +
+ Dieses Feld sollte nur bei Verweisen auf Submenüs den vollständigen Link zu diesen enthalten +
(d.h. <TFTP-Server-IP>::/<TFTP-PXE-Pfad>/<Timerange>/<PXE-Dateiname>).
+ Bei Textzeilen und Leerzeilen muss hier "self" stehen.
+ Bei normalen Menüeinträgen (inklusive Localboot) muss diese Feld leer sein. +   +
Kernel:   + +
+ Angabe hier nur sinnvoll bei Leer-, Textzeilen oder Submenüverweisen,
+ denn Eingabe wird, wenn der Menüeintrag auf ein generisches Boot Image verweist (siehe oben)
+ bei der PXE Datei Generierung überschrieben. +   +
+

Boot Menü Eintrag  {MECN}  löschen:

+ + + + + + + + + + + + + + + +
+ Das generische Boot Image wird komplett gelöscht. +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/menuentry.php b/ldap-site-mngmt/webinterface/computers/menuentry.php new file mode 100644 index 00000000..81e1dc63 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuentry.php @@ -0,0 +1,170 @@ +assign(array("MEDN" => $meDN, + "MECN" => $me['cn'], + "GMECN" => $gmecn, + "GMEOU" => $gmeou, + "GMERBS" => $gmerbs, + "LABEL" => $me['label'], + "MELABEL" => $me['menulabel'], + "MEDEF" => $me['menudefault'], + "MEPASSWD" => $me['menupasswd'], + "MEHIDE" => $me['menuhide'], + "VGA" => $me['vga'], + "SPLASH" => $me['splash'], + "NOLDSC" => $me['noldsc'], + "ELEVATOR" => $me['elevator'], + "VCI" => $me['vci'], + "CCV" => $me['clientconfvia'], + "APIC" => $me['apic'], + "COWLOOP" => $me['cowloop'], + "UNIONFS" => $me['unionfs'], + "DEBUG" => $me['debug'], + "MENPOS" => $me['menuposition'], + "LOCALBOOT" => $me['localboot'], + "KERNEL" => $me['kernel'], + "SUBMENULINK" => $me['submenulink'], + "PXEDN" => $pxeDN, + "PXECN" => $pxecn, + "TIMERANGE" => $timerange, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +#$template->define_dynamic("Submenulink", "Webseite"); +#if (count($me['submenulink']) != 0){ +# foreach ($me['submenulink'] as $sbml){ +# $template->assign(array("SUBMENULINK" => $sbml)); +# $template->parse("SUBMENULINK_LIST", ".Submenulink"); +# } +#} + +# Alternative RB Dienste holen +$altrbs = get_rbservices($auDN,array("dn","cn")); +if (count($altrbs) != 0){ + for ($i=0; $i < count($altrbs); $i++){ + if ($rbsDN == $altrbs[$i]['dn']){ + array_splice($altrbs, $i, 1); + } + } +} + + +if (count($altrbs) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($altrbs as $item){ + $altrbsexp = explode(',',$item['dn']); + $altrbsau = explode('=',$altrebsexp[2]); + $template->assign(array("ALTRBSDN" => $item['dn'], + "ALTRBSCN" => $item['cn'], + "ALTRBSAU" => "[ ".$altrbsau[1]." ]")); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +}else{ + $template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); +} + +################################################ +# Bootmenü Einträge + +$menuentries = get_menuentries($pxeDN,array("dn","menuposition","label","menulabel")); +#print_r($menuentries); echo "
"; + +$template->define_dynamic("Bootmenu", "Webseite"); + +foreach ($menuentries as $me){ + $template->assign(array("MENDN" => $me['dn'], + "MENULABEL" => $me['menulabel'], + "POSITION" => $me['menuposition'], + "AUDN" => $auDN)); + $template->parse("BOOTMENU_LIST", ".Bootmenu"); +} + + +################################################ +# PXE kopieren + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + +################################################################################### + +include("computers_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/computers/menuentry_add.php b/ldap-site-mngmt/webinterface/computers/menuentry_add.php new file mode 100644 index 00000000..dd10e7c2 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuentry_add.php @@ -0,0 +1,263 @@ +
"; + +# PXE Typ (computers/groups) für Submenulinks +$pxearray = ldap_explode_dn($pxeDN, 1); +$pxetype = $pxearray[2]; + +$seconds = 2; +$get_mecn = str_replace ( " ", "_", $mecn ); +$url = "pxe.php?dn=".$pxeDN."&mecn=".$get_mecn."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; +# switch wäre besser ... +if ($typ == "newme" && $typ != "local" && $typ != "text" && $typ != "leer" && $typ != "submenu" ){ + + if ( $mecn != "" && $mecn != "Hier_NAME_eintragen" && $gbmDN != "none" ){ + + # Formulareingaben anpassen + $expme = explode(" ",$mecn); + foreach ($expme as $word){$expuc[] = ucfirst($word);} + $mecn = implode(" ",$expuc); + $mecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mecn); + + if ($menpos != ""){ + # Syntaxcheck Menüposition + #$syntax = new Syntaxcheck; + #if (!($syntax->check_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + $meDN = "cn=".$mecn.",".$pxeDN; + + if (add_me($meDN,$mecn,$gbmDN,$menpos,$meatts,$pxeDN)){ + $mesg .= "
Neuen Menü Eintrag erfolgreich angelegt
"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr;; + } + else{ + $mesg .= "
Fehler beim anlegen des Menü Eintrags!
"; + } + } + + elseif ( $mecn == "" || $mecn == "Hier_NAME_eintragen" || $gbmDN == "none" ){ + + $mesg = "Sie haben den Namen des neuen Menü Eintrags nicht angegeben oder kein + Generisches Boot Image ausgewählt. Beide sind aber ein notwendige Attribute.
+ Bitte geben Sie sie an.

"; + $url = "new_menuentry.php?mecn=Hier_NAME_eintragen&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + } +} + +# Localboot Zeile hinzufügen +elseif ($typ == "local" && $typ != "newme" && $typ != "text" && $typ != "leer" && $typ != "submenu" ){ + + # Menu Position + $menpos = $_POST['localpos']; + if ($menpos != ""){ + # Syntaxcheck Menüposition + #$syntax = new Syntaxcheck; + #if (!($syntax->check_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + # CN bilden + $brothers = get_menuentries($pxeDN,array("dn","cn")); + $i=1; + $localcn = "localboot".$i; + if(count($brothers) != 0){ + for ($c=0; $ccheck_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + $text = $_POST['text']; + if($text != "" && $text != "TEXT"){ + $brothers = get_menuentries($pxeDN,array("dn","cn")); + $i=1; + $textcn = "textzeile".$i; + if(count($brothers) != 0){ + for ($c=0; $ccheck_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + # CN bilden + $brothers = get_menuentries($pxeDN,array("dn","cn")); + $i=1; + $leercn = "leerzeile".$i; + if(count($brothers) != 0){ + for ($c=0; $cback"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/menuentry_change.php b/ldap-site-mngmt/webinterface/computers/menuentry_change.php new file mode 100644 index 00000000..bf461f1f --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuentry_change.php @@ -0,0 +1,208 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + + +$seconds = 2; +$get_mecn = str_replace ( " ", "_", $mecn ); +$url = "menuentry.php?dn=".$meDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# ME CN (DN) + +if ( $oldmecn == $mecn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldmecn != "" && $mecn != "" && $oldmecn != $mecn ){ + echo "Menü Eintrag Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $expme = explode(" ",$mecn); + foreach ($expme as $word){$expuc[] = ucfirst($word);} + $mecn = implode(" ",$expuc); + $mecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mecn); + + + $newmeDN = "cn=".$mecn.",".$pxeDN; + print_r($newmeDN); echo "

"; + + if(modify_me_dn($meDN, $newmeDN)){ + $mesg = "Menü Eintrag Name erfolgreich geändert

"; + $meDN = $newmeDN; + }else{ + $mesg = "Fehler beim ändern des PMenü Eintrag Namen!

"; + } + + + # newsubmenu holen... + $url = "menuentry.php?dn=".$newmeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + +if ( $oldmecn != "" && $mecn == "" ){ + echo "Menü Eintrag Name loeschen!
+ Dieses ist Teil des DN, Sie werden den Menü Eintrag komplett löschen

"; + echo "Wollen Sie den Menü Eintrag ".$oldmecn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + +################################### +# Menu Position + +if ( $menpos == $oldmenpos || $menpos == "" ){ + # keine Änderung +} + +if ( $menpos != "" && $oldmenpos != $menpos ){ + echo "Menü Position ändern

"; + # Syntax Check fehlt noch + + # switch partner finden + $secmeDN = get_dn_menuposition($pxeDN,$menpos); + $entrysec ['menuposition'] = $oldmenpos; + if (ldap_mod_replace($ds,$secmeDN,$entrysec)){ + $entry ['menuposition'] = $menpos; + if (ldap_mod_replace($ds,$meDN,$entry)){ + #cleanup_menupositions($pxeDN); + $mesg .= "Menü Position erfolgeich nach ".$menpos." geändert"; + }else{ + $mesg .= "Fehler beim ändern der Menü Position!"; + } + }else{ + $mesg .= "Fehler beim ändern der Menü Position!"; + } +} + +################################### +# restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + # nix + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$meDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$meDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$meDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + +################################### +# Ende, noch Redirect + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/menuentry_delete.php b/ldap-site-mngmt/webinterface/computers/menuentry_delete.php new file mode 100644 index 00000000..ba06eb55 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuentry_delete.php @@ -0,0 +1,41 @@ + + + Computers Management + + + + +
"; + +if ( $meDN != ""){ + + if ( dive_into_tree_del($meDN,"") ){ + cleanup_menupositions($pxeDN); + $mesg = "Bootmenü Eintrag ".$mecn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des Bootmenü Eintrags ".$mecn." !

"; + } + +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/menuposition_down.php b/ldap-site-mngmt/webinterface/computers/menuposition_down.php new file mode 100644 index 00000000..53e82a21 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuposition_down.php @@ -0,0 +1,42 @@ +"; + $entrysec ['menuposition'] = $oldpos; + if ($result = ldap_mod_replace($ds,$secmeDN,$entrysec)){ + $entrymenu ['menuposition'] = $newpos; + $result = ldap_mod_replace($ds,$meDN,$entrymenu); + } + } +} +$seconds = 0; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr."&#menu"; +$mesg = ""; +#$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+# Falls nicht, klicken Sie hier
back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/menuposition_up.php b/ldap-site-mngmt/webinterface/computers/menuposition_up.php new file mode 100644 index 00000000..4a314aca --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/menuposition_up.php @@ -0,0 +1,40 @@ +"; + $entrysec ['menuposition'] = $oldpos; + if ($result = ldap_mod_replace($ds,$secmeDN,$entrysec)){ + $entrymenu ['menuposition'] = $newpos; + $result = ldap_mod_replace($ds,$meDN,$entrymenu); + } + + } +} +$seconds = 0; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr."&#menu"; +$mesg = ""; +#$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+# Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_group.dwt b/ldap-site-mngmt/webinterface/computers/new_group.dwt new file mode 100644 index 00000000..ea9accf0 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_group.dwt @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Neue Rechnergruppe anlegen:

Notwendige Attribute (müssen angegeben werden):

+ + + + + + + + + + + + + + +
AttributWert
Gruppen Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+   +

Optionale Attribute:

+ + + + + + + + + + + + + + + + + + + +
AttributWert
Gruppen-Rechner:
(Mehrfachauswahl möglich)  
+ + + + + +
Gruppen Beschreibung:   + +

Gruppe als Group-Objekt in den DHCP Dienst aufnehmen (optional):

+ + + + + + + +
DHCP ObjektAuswahl
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_group.php b/ldap-site-mngmt/webinterface/computers/new_group.php new file mode 100644 index 00000000..0fcd8bcc --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_group.php @@ -0,0 +1,76 @@ +assign(array("GROUPCN" => $groupcn, + "GROUPDESC" => $groupdesc, + "AUDN" => $auDN)); + +# DHCP Stuff ... + + +############################################## +# neues Member anlegen ... +$hosts_array = get_hosts($auDN,array("dn","hostname")); +# print_r($users_array); echo "

"; +$groups = get_groups($auDN, array("member")); +# print_r($groups); +$template->assign(array("HOSTNAME" => "")); + +if (count($groups) != 0){ + foreach ($groups as $group){ + for ($i=0; $i < count($hosts_array); $i++){ + foreach ($group['member'] as $item){ # ist hier sicher dass member ein array ist auch bei 1 member? + if ($hosts_array[$i]['dn'] == $item){ + array_splice($hosts_array, $i, 1); + $i--; + } + } + } + } +} +# if (count($users_array) != 0){ + $template->define_dynamic("Hosts", "Webseite"); + foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HOSTNAME" => $item['hostname'], + "HOSTNUMBER" => 5)); + $template->parse("HOSTS_LIST", ".Hosts"); + } + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_host.dwt b/ldap-site-mngmt/webinterface/computers/new_host.dwt new file mode 100644 index 00000000..32366a42 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_host.dwt @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Neuen Rechner anlegen:

Notwendige Attribute (müssen angegeben werden):

+ + + + + + + + + + + + + + +
AttributWert
Rechner Name (hostname):
(Teil des dn, ohne Leerzeichen eingeben)  
+   +

Optionale Attribute:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Rechner Beschreibung:   + +
MAC Adresse (HWAddress) :   + + Bsp.: 00-12-03-aa-54-e6   +
IP Adresse:   + +
HW Mouse:   + +
HW Graphic:   + +
HW Monitor:   + +

Rechner als Host-Objekt in den DHCP Dienst aufnehmen (optional):

+ + + + + + + +
DHCP ObjektAuswahl
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_host.php b/ldap-site-mngmt/webinterface/computers/new_host.php new file mode 100644 index 00000000..9be7b46e --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_host.php @@ -0,0 +1,53 @@ +assign(array("HOSTNAME" => $hostname, + "HOSTDESC" => $hostdesc, + "MAC" => $mac, + "IP" => $ip, + "MOUSE" => "", + "GRAPHIC" => "", + "MONITOR" => "", + "AUDN" => $auDN)); + + +# DHCP Stuff + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_mcdef.dwt b/ldap-site-mngmt/webinterface/computers/new_mcdef.dwt new file mode 100644 index 00000000..72ebf72d --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_mcdef.dwt @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + +

Neue Default MachineConfig anlegen:

 

Allgemein:

+ + + + + + + + + + + + + + + + + + + + + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
+ MC_ +
Machine Config
Beschreibung:  
+ +   +
Ziel Objekt:
+ (Mehrfachauswahl möglich) 
+ +
Gültigkeitsdauer
(Time Range):
 
+ +  
+ Eines der folgenden:
+ + - Datum  (Format: dd.mm, z.B. 21.03/01.11)
+ - Monatstag  (Format: dd, z.B. 01 oder 25)
+ - Wochentag  (Format: MO, DI, ... , SO)
+ - X für täglich + +
+ + :00  -   + + :59 Uhr
+ - Uhrzeit  (Format: hh, z.B. 07-19)
+ - X für rund um die Uhr +

Dienste:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Start X:   + +   ( yes | no ) +
Start SNMP:   + +   ( yes | no ) +
Start SSHD:   + +   ( yes | no ) +
Start XDMCP:   + +   ( yes | no ) +
Start RWHOD:   + +   ( yes | no ) +
Start PRINT DAEMON:   + +   ( yes | no ) +
TEX Enable:   + +   ( yes | no ) +
Start CRON:   + +   ( yes | no ) +
CRONTAB Entries:   + +
Language:   + +   +
NETBIOS Workgroup:   + +
VMWARE:   + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_mcdef.php b/ldap-site-mngmt/webinterface/computers/new_mcdef.php new file mode 100644 index 00000000..eec7a3dd --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_mcdef.php @@ -0,0 +1,74 @@ +assign(array("MCCN" => $mccn, + "MCDAY" => $mcday, + "MCBEG" => $mcbeg, + "MCEND" => $mcend, + "MCDESC" => $mcdesc, + "NODEDN" => "cn=computers,".$auDN, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +################################################# +# Ziel Objekt (nur Rechner und Gruppen, Default) + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_menuentry.dwt b/ldap-site-mngmt/webinterface/computers/new_menuentry.dwt new file mode 100644 index 00000000..9ccaa5ff --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_menuentry.dwt @@ -0,0 +1,191 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Zurück zu  {PXECN}

 

Neuen Boot Menü Eintrag anlegen:

 

Notwendige Attribute:

+ + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +
Label:   + +
Generische Boot Images:
(Wählen Sie eines aus)  
+ +
Menü Position:
+ (Bitte ohne führende Null) 
+ +
 

Optionale Attribute:

+ + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Menu Label:
(Wird im Bootmenü statt Label angezeigt)  
+ +
Menu Passwd:   + +
Menu Hide:   + +
Localboot:   + +

APPEND Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Client Konfiguration via:   + +
vga:   + +
splash:   + +
vci:   + +
no ldsc:   + +
elevator:   + +
apic:   + +
Union FS:   + +
cowloop:   + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_menuentry.php b/ldap-site-mngmt/webinterface/computers/new_menuentry.php new file mode 100644 index 00000000..155ed245 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_menuentry.php @@ -0,0 +1,150 @@ +assign(array("MECN" => $mecn, + "LABEL" => "", + "MELABEL" => "", + "MEDEF" => "", + "MEPASSWD" => "", + "MEHIDE" => "", + "VGA" => "", + "SPLASH" => "", + "NOLDSC" => "", + "ELEVATOR" => "", + "VCI" => "", + "CCV" => "", + "APIC" => "", + "COWLOOP" => "", + "UNIONFS" => "", + "DEBUG" => "", + "LOCALBOOT" => "", + "SUBMENULINK" => "", + "MENPOS" => "", + "MAXPOS" => $maxpos, + "PXEDN" => $pxeDN, + "PXECN" => $pxecn, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + + +# verwendbare GBMs holen +# eigene AU (andere noch über "offer" Attribut in RBS suchen) +$rbsoffers = get_rbsoffers($auDN); +# eigene AU +if (count($rbsoffers) != 0){ + $rbservices = get_rbservices($auDN,array("dn")); + # wenn eigene RBS anbietet dann diese GBMs als erstes (oben in der Liste) + if (count($rbservices) != 0){ + foreach ($rbservices as $rbs){ + for ($i=0; $i < count($rbsoffers); $i++){ + if ($rbs['dn'] == $rbsoffers[$i]){ + array_splice($rbsoffers, $i, 1); + } + } + } + # momentan maximal ein RBS in der AU + $rbsaudn[] = $rbservices[0]['dn']; + $rbsoffsorted = array_merge($rbsaudn,$rbsoffers); + } + # sonst die GBMs des für diese PXE genutzen RBS + else{ + for ($i=0; $i < count($rbsoffers); $i++){ + if ($rbsDN == $rbsoffers[$i]){ + array_splice($rbsoffers, $i, 1); + } + } + $rbsaudn[] = $rbsDN; + $rbsoffsorted = array_merge($rbsaudn,$rbsoffers); + } +} +#print_r($rbsoffsorted);echo "

"; +# RBS Offers nun in der Reihenfolge erst eigene AU dann Rest ... +$attributes = array("dn","cn","label","kernel","initrd","nfsroot","nbdroot","ipappend"); +$template->assign(array("GBMDN" => "", + "GBMCN" => "Keine generischen Boot Images verfügbar", + "RBSCN" => "", + "RBSAU" => "")); +if (count($rbsoffsorted) != 0){ + $template->define_dynamic("Rbs", "Webseite"); + $template->define_dynamic("Gbms", "Webseite"); + + foreach ($rbsoffsorted as $rbsoff){ + $template->clear_parse("GBMS_LIST"); + #print_r($rbsoff);echo "

"; + $rbsdnexp = ldap_explode_dn($rbsoff,1); + $rbsoffcn = $rbsdnexp[0]; + $rbsoffau = $rbsdnexp[2]; + + $gbm_array = get_menuentries($rbsoff,$attributes); + if (count($gbm_array) != 0){ + + foreach ($gbm_array as $item){ + $template->assign(array("GBMDN" => $item['dn'], + "GBMCN" => $item['cn'])); + $template->parse("GBMS_LIST", ".Gbms"); + $template->clear_dynamic("Gbms"); + } + + } + $template->assign(array("RBSCN" => $rbsoffcn, + "RBSAU" => $rbsoffau)); + $template->parse("RBS_LIST", ".Rbs"); + $template->clear_dynamic("Rbs"); + + } +} + + + +################################################################################### + +include("computers_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/computers/new_pxe.dwt b/ldap-site-mngmt/webinterface/computers/new_pxe.dwt new file mode 100644 index 00000000..2a50e977 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_pxe.dwt @@ -0,0 +1,175 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + +

Neues PXE Boot Menü anlegen:

 

Allgemein:

+ + + + + + + + + + + + + + --> + + + + + + + + + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
+ PXE_ +
Ziel Objekt:
+ (Mehrfachauswahl möglich) 
+ +
Gültigkeitsdauer
(Time Range):
 
+ +  
+ Eines der folgenden:
+ + - Datum  (Format: dd.mm, z.B. 21.03/01.11)
+ - Monatstag  (Format: dd, z.B. 01 oder 25)
+ - Wochentag  (Format: MO, DI, ... , SO)
+ - X für täglich + +
+ + :00  -   + + :59 Uhr
+ - Uhrzeit  (Format: hh, z.B. 07-19)
+ - X für rund um die Uhr +

Globale PXE Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Default:   + +   +
Menu Title:   + +   +
Menu Master Passwd:   + +   +
Timeout:   + +   +
No Escape:   + +   +
Prompt:   + +   +
Allow Options:   + +   +
On Error:   + +   +
ON Timeout:   + +   +
Client-Conf Dateiname
(File URI):  
+ +   +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/new_pxe.php b/ldap-site-mngmt/webinterface/computers/new_pxe.php new file mode 100644 index 00000000..07890505 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/new_pxe.php @@ -0,0 +1,130 @@ +assign(array("PXECN" => $pxecn, + "PXEDAY" => $pxeday, + "PXEBEG" => $pxebeg, + "PXEEND" => $pxeend, + # "LDAPURI" => "", + "FILEURI" => "", + "RBS" => "", + "RBSAU" => "", + "NFS" => "", + "NFSROOT" => "", + "TFTP" => "", + "TFTPROOT" => "", + "FILE" => "", + "ALLOW" => "", + "CONSOLE" => "", + "DEFAULT" => "menu.c32", + "DISPLAY" => "", + "FONT" => "", + "IMPLICIT" => "", + "KBDMAP" => "", + "MENMPW" => "", + "MENTIT" => "", + "NOESC" => "1", + "ONERR" => "", + "ONTIME" => "", + "PROMPT" => "0", + "SAY" => "", + "SERIAL" => "", + "TIMEOUT" => "600", + "NODEDN" => "cn=rbs,".$auDN, + "HDN" => "none", + "HN" => "", + "GDN" => "none", + "GN" => "", + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + +############################################# +# RB Dienste holen +$rbsoffers = get_rbsoffers($auDN); + +$template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); + +if (count($rbsoffers) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($rbsoffers as $item){ + $rbsdnexp = ldap_explode_dn($item,1); + $rbsoffcn = $rbsdnexp[0]; + $rbsoffau = $rbsdnexp[2]; + #$auexp = explode(',',$item['auDN']); + #$altrbsau = explode('=',$auexp[0]); + $template->assign(array("ALTRBSDN" => $item, + "ALTRBSCN" => $rbsoffcn, + "ALTRBSAU" => "   [ Abt.: ".$rbsoffau." ]")); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +} + +################################################# +# Ziel Objekt (nur Rechner und Gruppen, nicht Default) + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + +$hosts_array = get_hosts($auDN,array("dn","hostname","hlprbservice","hwaddress")); +if ( count($hosts_array) != 0 ){ + $template->define_dynamic("Hosts", "Webseite"); + foreach ($hosts_array as $item){ + # Nur Hosts die in DHCP/TFTP angemeldet und deren MAC eingetragen ist (für PXE-Filename) + if ( $item['hlprbservice'] != "" && $item['hwaddress'] != "" ){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); + } + } +} + +$groups_array = get_groups($auDN,array("dn","cn","hlprbservice")); +if ( count($groups_array) != 0 ){ + $template->define_dynamic("Groups", "Webseite"); + foreach ($groups_array as $item){ + if ( $item['hlprbservice'] != "" ){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); + } + } +} + +################################################################################### + +include("computers_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/pxe.dwt b/ldap-site-mngmt/webinterface/computers/pxe.dwt new file mode 100644 index 00000000..0dff23eb --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/pxe.dwt @@ -0,0 +1,476 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

PXE Boot Menü   {PXECN}

Klicken Sie auf einen Menüeintrag um zur Detailansicht zu gelangen und den Eintrag bearbeiten zu können
+ + + + + + + + + + + + + + + + + + + + + +
#FlagsMenu Label   
{POSITION} {MEDEF} {MEPWD} {MEHIDE} {ANZEIGE}  +
+
+ + + + + + + + +

Flags:

+
    +
  • D -> Default Menüeintrag
  • +
  • P -> Passwort geschützt
  • +
  • H -> Hidden
  • +
+

Neuen Menüeintrag anlegen:   

+   zur Eingabemaske  

Standard Menüeinträge anlegen:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Typ    Position 
Localboot   + Menu Label
 
+ Passwort (optional)
 
 
Textzeile    
Leerzeile    
Verweis zu Submenü  Submenü Name
+
Remote Boot Service + +  

Allgemeine Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
  + PXE_ +   +
Remote Boot Dienst:    + {RBS} [Abteilung: {RBSAU}]
+ Von diesem Dienst verwendete Bootserver:
+ -  NFS Server  {NFS}{NFSROOT}
+ -  TFTP Server {TFTP}{TFTPROOT}
+ Alternativen Dienst verwenden:
+ +
Gültigkeitsdauer
(Time Range(s)):

+ Zum Löschen einer Time Range
Häkchen setzen 
  + Eines der folgenden:
+ + - Datum  (dd.mm, z.B. 21.03/01.11)
+ - Monatstag  (dd, z.B. 01 oder 25)
+ - Wochentag  (MO, DI, ... , SO)
+ - X für täglich + +
+ - Uhrzeit  (Format: hh, z.B. 07-19)
+ - X für rund um die Uhr + +
  + +   + +  
+ + +
+ + :00  -   + + :59 Uhr
+
Neue Time Range hinzufügen   + + + + + :00  -   + + :59 Uhr
+ +

Globale PXE Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Default:   + +   +
Menu Title:   + +   +
Menu Master Passwd:   + +   +
Timeout:   + +   +
No Escape:   + +   +
Prompt:   + +   +
Allow Options:   + +   +
On Error:   + +   +
ON Timeout:   + +   +
File URI:   + tftp://{TFTP}/{TFTPFILE} + +   +

PXE Dateiname:

+ Achtung: Änderungen hier können zu nicht verwendeten PXE Dateien führen!
+ Sie sollten hier nur Änderungen vornehmen, wenn der PXE Datei offensichtlich ein falscher Name zugewiesen ist.
+ Wird z.B. vom betroffenen Rechner die MAC Adresse geändert, so wird dies vom System automatisch an dieser Stelle nachvollzogen. + Diese Feld dient daher primär der Kontrolle.
+ + + + + + + +
+ PXE Dateiname(n):
+ Bei PXE von Gruppen ist für jeden Mitgliedsrechner
+ der PXE Dateiname aufgelistet. +
+ + +   + + +
+ + + + + + + +

PXE Boot Menü  {PXECN}  kopieren:

+ Beachten Sie, dass die Time Ranges des PXE Boot Menüs nicht kopiert werden. Sie müssen diese anschließend + neu setzen.
+ Geben Sie bitte den eindeutigen Namen des neuen PXE Boot Menüs an.
+ + + + + + + + + + + + + + + + + + + +
Ziel Objekt:
+ (Mehrfachauswahl möglich) 
+ + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
+ PXE_ +   +
+ +

PXE Boot Menü  {PXECN}  löschen:

+ + + + + + + + + + + + + +
+ Die MachineConfig wird komplett gelöscht. +
+ +
diff --git a/ldap-site-mngmt/webinterface/computers/pxe.php b/ldap-site-mngmt/webinterface/computers/pxe.php new file mode 100644 index 00000000..bbc2e5e1 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/pxe.php @@ -0,0 +1,252 @@ +define_dynamic("TRanges", "Webseite"); +if (count($pxe['timerange']) > 1){ + foreach($pxe['timerange'] as $tr){ + $exptime = explode('_',$tr); + $template->assign(array("PXEDAY" => $exptime[0], + "PXEBEG" => $exptime[1], + "PXEEND" => $exptime[2])); + $template->parse("TRANGES_LIST", ".TRanges"); + } +}else{ + $exptime = explode('_',$pxe['timerange']); + $template->assign(array("PXEDAY" => $exptime[0], + "PXEBEG" => $exptime[1], + "PXEEND" => $exptime[2])); + $template->parse("TRANGES_LIST", ".TRanges"); +} + +# Filenames +$template->define_dynamic("Filenames", "Webseite"); +if (count($pxe['filename']) > 1){ + foreach($pxe['filename'] as $fi){ + $template->assign(array("FILE" => $fi)); + $template->parse("FILENAMES_LIST", ".Filenames"); + } +}else{ + $exptime = explode('_',$pxe['filename']); + $template->assign(array("FILE" => $pxe['filename'])); + $template->parse("FILENAMES_LIST", ".Filenames"); +} + +$expcn = explode('_',$pxe['cn']); +$name = array_slice($expcn,1); +$pxecn = implode('_',$name); + +# Bootmenü Einträge +$menuentries = get_menuentries($pxeDN,array("dn","menuposition","label","menulabel","menudefault","menupasswd","menuhide")); +# print_r($menuentries); echo "
"; +$maxpos = count($menuentries)+1; + +# Globale Parameter +$template->assign(array("PXEDN" => $pxeDN, + "PXECN" => $pxecn, + "TIMERANGE" => $pxe['timerange'], + "RBS" => $rbsdata['cn'], + "RBSAU" => $rbsau, + "NFS" => $rbsdata['nfsserverip'], + "NFSROOT" => $rbsdata['exportpath'], + "TFTP" => $rbsdata['tftpserverip'], + "TFTPROOT" => $rbsdata['tftppath'], + "TFTPFILE" => $rbsdata['tftpclientconfpath'], + #"LDAPURI" => $pxe['ldapuri'], + "FILEURI" => $pxe['fileuri'], + "ALLOW" => $pxe['allowoptions'], + "CONSOLE" => $pxe['console'], + "DEFAULT" => $pxe['default'], + "DISPLAY" => $pxe['display'], + "FONT" => $pxe['font'], + "IMPLICIT" => $pxe['implicit'], + "KBDMAP" => $pxe['kbdmap'], + "MENMPW" => $pxe['menumasterpasswd'], + "MENTIT" => $pxe['menutitle'], + "NOESC" => $pxe['noescape'], + "ONERR" => $pxe['onerror'], + "ONTIME" => $pxe['ontimeout'], + "PROMPT" => $pxe['prompt'], + "SAY" => $pxe['say'], + "SERIAL" => $pxe['serial'], + "TIMEOUT" => $pxe['timeout'], + "MAXPOS" => $maxpos, + "NODEDN" => $nodeDN, + "DEFDN" => "cn=rbs,".$auDN, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +# Alternative RB Dienste holen +$altrbs = get_rbsoffers($auDN); + +# $altrbs = get_rbservices($auDN,array("dn","cn")); +$subrbs = $altrbs; +if (count($altrbs) != 0){ + for ($i=0; $i < count($altrbs); $i++){ + if ($rbsDN == $altrbs[$i]){ + array_splice($altrbs, $i, 1); + } + } +} +$template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); +if (count($altrbs) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($altrbs as $item){ + $rbsdnexp = ldap_explode_dn($item,1); + $rbsoffcn = $rbsdnexp[0]; + $rbsoffau = $rbsdnexp[2]; + #$altrbsexp = explode(',',$item['dn']); + #$altrbsau = explode('=',$altrbsexp[2]); + $template->assign(array("ALTRBSDN" => $item, + "ALTRBSCN" => $rbsoffcn, + "ALTRBSAU" => "   [ Abt.: ".$rbsoffau." ]")); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +} + +# Für Submenü Einträge +$template->assign(array("SUBRBSDN" => "", + "SUBRBSCN" => "", + "SUBRBSAU" => "")); +if (count($subrbs) != 0){ +$template->define_dynamic("Subrbs", "Webseite"); + foreach ($subrbs as $item){ + $rbsdnexp = ldap_explode_dn($item,1); + $subrbscn = $rbsdnexp[0]; + $subrbsau = $rbsdnexp[2]; + #$subrbsexp = explode(',',$item['dn']); + #$subrbsau = explode('=',$subrbsexp[2]); + $template->assign(array("SUBRBSDN" => $item, + "SUBRBSCN" => $subrbscn, + "SUBRBSAU" => "[ ".$subrbsau." ]")); + $template->parse("SUBRBS_LIST", ".Subrbs"); + } +} + +################################################ +# Bootmenü Einträge + +$template->define_dynamic("Bootmenu", "Webseite"); +$template->assign(array("MENDN" => "", + "MENULABEL" => "", + "ANZEIGE" => "Noch kein Bootmenü Eintrag angelegt", + "MEDEF" => "", + "MEPWD" => "", + "MEHIDE" => "", + "BGCDEF" => "", + "POSITION" => "")); +foreach ($menuentries as $me){ + $anzeige = ""; + if ($me['label'] != "" && $me['menulabel'] == ""){$anzeige .= $me['label'];} + if ($me['menulabel'] != ""){$anzeige .= $me['menulabel'];} + if ($me['menudefault'] == 1){$medef = "D"; $bgcdef = "background-color:#EEDD82;";} + if ($me['menupasswd'] != ""){$mepwd = "P";} + if ($me['menuhide'] == 1){$mehide = "H"; $bgcdef = "background-color:#A0A0A0;";} + $template->assign(array("MENDN" => $me['dn'], + "ANZEIGE" => "".$anzeige."", + "ANZEIGENAME" => $anzeige, + "POSITION" => $me['menuposition'], + "MEDEF" => $medef, + "MEPWD" => $mepwd, + "MEHIDE" => $mehide, + "BGCDEF" => $bgcdef, + "AUDN" => $auDN)); + $template->parse("BOOTMENU_LIST", ".Bootmenu"); + $medef = ""; + $bgcdef = ""; +} + + +################################################ +# PXE kopieren + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + +$dnexp = ldap_explode_dn($pxeDN, 1); +if ($dnexp[2] == "computers"){ + $nodetyp = "host"; +} +if ($dnexp[2] == "groups"){ + $nodetyp = "group"; +} +# falls TR vorhanden dann soll sie gelöscht werden (flag deltr setzen) +if (count($pxe['timerange']) != 0){ + $template->assign(array("DELTR" => "1", + "NODETYP" => $nodetyp)); +} +else{ + $template->assign(array("DELTR" => "0", + "NODETYP" => $nodetyp)); +} + +################################################################################### + +include("computers_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/computers/pxe_add.php b/ldap-site-mngmt/webinterface/computers/pxe_add.php new file mode 100644 index 00000000..8aa54c31 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/pxe_add.php @@ -0,0 +1,228 @@ +"; +$n = array_keys($targets,'none'); +#print_r($n); echo "
"; +for ($i=0; $i"; + +$pxeattribs = $_POST['pxeattribs']; +if (count($pxeattribs) != 0){ + foreach (array_keys($pxeattribs) as $key){ + $pxeatts[$key] = htmlentities($pxeattribs[$key]); + } +} +# print_r($mcatts); echo "

"; + +$seconds = 20; +$get_pxecn = str_replace ( " ", "_", $pxecn ); +$get_pxeday = str_replace ( " ", "_", $pxeday ); +$get_pxebeg = str_replace ( " ", "_", $pxebeg ); +$get_pxeend = str_replace ( " ", "_", $pxeend ); +$url = "new_pxe.php?pxecn=".$get_pxecn."&pxeday=".$get_pxeday."&pxebeg=".$get_pxebeg."&pxeend=".$get_pxeend."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + +if ( $pxecn != "" && $pxecn != "Hier_PXE_NAME_eintragen" && $rbsDN != "none" ){ + + $pxecn = "PXE_".$pxecn; + # Formulareingaben anpassen + $exppxe = explode(" ",$pxecn); + foreach ($exppxe as $word){$expuc[] = ucfirst($word);} + $pxecn = implode(" ",$expuc); + $pxecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $pxecn); + + $pxetimerange = ""; + $nomac = 0; + + if (count($targets) != 0){ + foreach ($targets as $targetDN){ + + $exptargetdn = ldap_explode_dn($targetDN, 1); + $targetcn = $exptargetdn[0]; + $targettype = $exptargetdn[1]; + + # falls Target keine MAC hat dann kann keine PXE angelegt werden + # jetzt schon vorher bei der Zielobjektauswahl abgefangen + if ($targettype == "computers"){ + $macdata = get_node_data($targetDN, array("hwaddress")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Ziel-Rechner ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü wird nicht angelegt.
+
+ Tragen Sie zuerst eine MAC ein!

"; + } + } + if ($targettype == "groups"){ + $members = get_node_data($targetDN, array("member")); + if (count($members) > 1){ + foreach ($members['member'] as $hostDN){ + $macdata = get_node_data($hostDN, array("hwaddress","hostname")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Gruppen-Rechner ".$macdata['hostname']." ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü für die Gruppe wird nicht angelegt.
+
+ Tragen Sie zuerst bei Rechner ".$macdata['hostname']." eine MAC ein!

"; + } + } + } + if (count($members) == 1){ + $macdata = get_node_data($members['member'], array("hwaddress")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Gruppen-Rechner ".$macdata['hostname']." ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü für die Gruppe wird nicht angelegt.
+
+ Tragen Sie zuerst bei Rechner ".$macdata['hostname']." eine MAC ein!

"; + } + } + } + + # Check auf eindeutigen PXE-Namen (könnte man erweitern auf kompletten RBS) + $brothers = get_pxeconfigs($targetDN,array("cn")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['cn'] == $pxecn ){ + $mesg = "Es existiert bereits ein PXE Boot Menü mit dem eingegebenen Namen!
+ Bitte geben Sie einen anderen Namen ein.

"; + $url = "new_pxe.php?pxecn=".$get_pxecn."&pxeday=".$get_pxeday."&pxebeg=".$get_pxebeg."&pxeend=".$get_pxeend."&mnr=".$mnr."&sbmnr=".$sbmnr; + $brother = 1; + break; + } + } + if ($brother == 0 && $nomac == 0){ + + if ( $pxeday != "" && $pxebeg != "" && $pxeend != "" && $pxebeg <= $pxeend ){ + + # TimeRange Syntax checken + $syntax = new Syntaxcheck; + if ($syntax->check_timerange_syntax($pxeday,$pxebeg,$pxeend)){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$pxeday)){$pxeday = strtoupper($pxeday);} + if (preg_match("/([a-z]+)/",$pxebeg)){$pxebeg = strtoupper($pxebeg);} + if (preg_match("/([a-z]+)/",$pxeend)){$pxeend = strtoupper($pxeend);} + + # führende Nullen weg + $pxebeg = preg_replace ( '/0([0-9])/', '$1', $pxebeg); + $pxeend = preg_replace ( '/0([0-9])/', '$1', $pxeend); + + print_r($nodeDN); + # TimeRange auf Ãœberschneidung mit vorhandenen checken + if(check_timerange_pxe($pxeday,$pxebeg,$pxeend,$targetDN,"")){ + $pxetimerange = $pxeday."_".$pxebeg."_".$pxeend; + } + else{ + $mesg = "Es existiert bereits ein PXE Boot Menü, das sich mit der eingegebenen Time Range + überschneidet!
+ Das neue PXE Boot Menü wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + } + else{ + $mesg = "Falsche Syntax in der Time-Range-Eingabe! Das neue PXE Boot Menü wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + } + else{ + $mesg = "Keine vollständige Time-Range-Eingabe! Das neue PXE Boot Menü wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + + $pxeDN = "cn=".$pxecn.",".$targetDN; + + + # PXE Dateinamen bestimmen, MAC(s) + $filenames = array(); + if ($targettype == "computers"){ + $macdata = get_node_data($targetDN, array("hwaddress")); + $filenames[] = "01-".$macdata['hwaddress']; + } + if ($targettype == "groups"){ + $members = get_node_data($targetDN, array("member")); + if (count($members) > 1){ + foreach ($members['member'] as $hostDN){ + $macdata = get_node_data($hostDN, array("hwaddress")); + $filenames[] = "01-".$macdata['hwaddress']; + } + } + if (count($members) == 1){ + $macdata = get_node_data($members['member'], array("hwaddress")); + $filenames[] = "01-".$macdata['hwaddress']; + } + } + echo "filenames: ";print_r($filenames); echo "
"; + #$ldapuri = LDAP_HOST."/dn=cn=computers,".$auDN; + + # rbsDN bestimmen + $rbs = get_node_data($targetDN,array("hlprbservice")); + $rbsDN = $rbs['hlprbservice']; + print_r($rbsDN); + + /*if (add_pxe($pxeDN,$pxecn,$rbsDN,$pxetimerange,$pxeattribs,$filenames,$conffile)){ + $mesg .= "
Neues PXE Boot Menü erfolgreich angelegt
"; + if ($targettype == "computers"){ + $mnr=1; + } + if ($targettype == "groups"){ + $mnr=2; + } + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr; + } + else{ + $mesg .= "
Fehler beim anlegen des PXE Boot Menüs!
"; + }*/ + } + } + } + else{ + $mesg .= "
Sie haben kein Ziel angegeben!
"; + } +} + + +elseif ( $pxecn == "" || $pxecn == "Hier_PXE_NAME_eintragen" || $rbsDN == "none" ){ + + $mesg = "Sie haben den Namen des neuen PXE Boot Menüs nicht angegeben oder den + Remote Boot Dienst nicht ausgewählt. Beide sind aber ein notwendige Attribute.
+ Bitte geben Sie sie an.

"; + $url = "new_pxe.php?pxecn=Hier_PXE_NAME_eintragen&pxeday=".$get_pxeday."&pxebeg=".$get_pxebeg."&pxeend=".$get_pxeend."&mnr=".$mnr."&sbmnr=".$sbmnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/pxe_change.php b/ldap-site-mngmt/webinterface/computers/pxe_change.php new file mode 100644 index 00000000..b3fcd4fa --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/pxe_change.php @@ -0,0 +1,437 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + +$seconds = 2; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# PXE CN (DN) + +if ( $oldpxecn == $pxecn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldpxecn != "" && $pxecn != "" && $oldpxecn != $pxecn ){ + echo "PXE Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $exppxe = explode(" ",$pxecn); + foreach ($exppxe as $word){$expuc[] = ucfirst($word);} + $pxecn = implode(" ",$expuc); + $pxecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $pxecn); + + + $newpxeDN = "cn=".$pxecn.",".$nodeDN; + print_r($newpxeDN); echo "

"; + + if(modify_pxe_dn($pxeDN, $newpxeDN)){ + $mesg = "PXE Name erfolgreich geändert

"; + $pxeDN = $newpxeDN; + }else{ + $mesg = "Fehler beim ändern des PXE Namen!

"; + } + + + # newsubmenu holen... + $url = "pxe.php?dn=".$newpxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + +if ( $oldpxecn != "" && $pxecn == "" ){ + echo "PXE Name loeschen!
+ Dieses ist Teil des DN, Sie werden das PXE Boot Menü komplett löschen

"; + echo "Wollen Sie das PXE Boot Menü ".$oldpxecn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + +########################################## +# Remote Boot Dienst + +if ($rbs != "none"){ + $exp = explode(',',$rbs); + $exprbscn = explode('=',$exp[0]); + $rbscn = $exprbscn[1]; + $exprbsau = explode('=',$exp[2]); + $rbsau = $exprbsau[1]; + + $entryrbs ['rbservicedn'] = $rbs; + if ($result = ldap_mod_replace($ds,$pxeDN,$entryrbs)){ + $mesg = "Remote Boot Service erfolgreich zu ".$rbscn."[Abt.: ".$rbsau."] geändert

"; + }else{ + $mesg = "Fehler beim ändern des Remote Boot Services zu ".$rbscn."!

"; + } +} + + +########################################## +# bereits vorhandene TimeRange(s) bearbeiten + +$entrymodtr = array(); +$modtr = 0; +# TimeRanges zusammensetzen +# $t = 0; # Laufvariable für $entrymodtr, da nicht jede Timerange ok sein muss +for ($i=0; $icheck_timerange_syntax($pxeday[$i],$pxebeg[$i],$pxeend[$i])){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$pxeday[$i])){$pxeday[$i] = strtoupper($pxeday[$i]);} + if (preg_match("/([a-z]+)/",$pxebeg[$i])){$pxebeg[$i] = strtoupper($pxebeg[$i]);} + if (preg_match("/([a-z]+)/",$pxeend[$i])){$pxeend[$i] = strtoupper($pxeend[$i]);} + + # führende Nullen weg + $pxebeg[$i] = preg_replace ( '/0([0-9])/', '$1', $pxebeg[$i]); + $pxeend[$i] = preg_replace ( '/0([0-9])/', '$1', $pxeend[$i]); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken außer mit eigener alter TR da diese + # ja geändert werden soll + if(check_timerange_pxe($pxeday[$i],$pxebeg[$i],$pxeend[$i],$nodeDN,$oldpxetimerange)){ + + $pxetimerange = $pxeday[$i]."_".$pxebeg[$i]."_".$pxeend[$i]; + $entrymodtr ['timerange'][$i] = $pxetimerange; + $modtr = 1; + + } + else{ + $mesg = "Es existiert bereits ein PXE Boot Menü, das sich mit der eingegebenen Time Range + überschneidet!
+ Bitte geben Sie eine andere Time Range ein.

"; + $entrymodtr ['timerange'][$i] = $oldpxetimerange; + } + } + else{ + $mesg = "Falsche Syntax in der Timerange-Eingabe!
+ Bitte geben Sie die erneut Time Range ein.

"; + $entrymodtr ['timerange'][$i] = $oldpxetimerange; + } + +} + + +elseif ( $pxeday[$i] == "" || $pxebeg[$i] == "" || $pxeend[$i] == "" || $pxebeg[$i] > $pxeend[$i]){ + + $mesg = "Sie haben die Time Range Nr.".$i." nicht vollständig angegeben. Diese ist aber ein notwendiges Attribut.
+ Diese Time Range wird nicht bearbeitet.

"; + $entrymodtr ['timerange'][$i] = $oldpxetimerange; +} + +else{$entrymodtr ['timerange'][$i] = $oldpxetimerange;} +} # Ende for-Schleife für jede Timerange +# jetzt noch alle gesammelten Änderungen Durchführen ... +if ($modtr == 1){ + # erst ändern + echo "Ändern: "; print_r($entrymodtr); echo "
"; + if($result = ldap_mod_replace($ds,$pxeDN,$entrymodtr)){ + $mesg = "TimeRanges erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern der TimeRanges!

"; + } +} + + +if ( count($deltr) != 0 && $modtr == 0 ){ + # Time Range löschen + $j = 0; + foreach ($deltr as $delrange){ + $entrydeltr ['timerange'][$j] = $delrange; + $j++; + } + # dann löschen + echo "Löschen: "; print_r($entrydeltr); echo "
"; + if($result = ldap_mod_del($ds,$pxeDN,$entrydeltr)){ + $mesg = "TimeRanges erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen der TimeRanges!

"; + } +}elseif(count($deltr) != 0 && $modtr == 1){ + echo "Nur Ändern (gleichzeitig Löschen und Ändern geht nicht)"; +} + +##################################### +# TimeRange hinzufügen + +if ( $newpxeday != "" && $newpxebeg != "" && $newpxeend != "" && $newpxebeg <= $newpxeend ){ + + # TimeRange Syntax checken + $syntax = new Syntaxcheck; + if ($syntax->check_timerange_syntax($newpxeday,$newpxebeg,$newpxeend)){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$newpxeday)){$newpxeday = strtoupper($newpxeday);} + if (preg_match("/([a-z]+)/",$newpxebeg)){$newpxebeg = strtoupper($newpxebeg);} + if (preg_match("/([a-z]+)/",$newpxeend)){$newpxeend = strtoupper($newpxeend);} + + # führende Nullen weg + $newpxebeg = preg_replace ( '/0([0-9])/', '$1', $newpxebeg); + $newpxeend = preg_replace ( '/0([0-9])/', '$1', $newpxeend); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken + if(check_timerange_pxe($newpxeday,$newpxebeg,$newpxeend,$nodeDN,"")){ + + $newpxetimerange = $newpxeday."_".$newpxebeg."_".$newpxeend; + $entrytr ['timerange'] = $newpxetimerange; + if($result = ldap_mod_add($ds,$pxeDN,$entrytr)){ + $mesg = "Zusätzliche TimeRange erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der zusätzlichen TimeRange!

"; + } + }else{ + $mesg = "Es existiert bereits ein PXE Boot Menü, das sich mit der eingegebenen Time Range + überschneidet!
+ Bitte geben Sie eine andere Time Range ein.

"; + } + }else{ + $mesg = "Falsche Syntax in der Timerange-Eingabe!
+ Bitte geben Sie die erneut Time Range ein.

"; + } +} + + + +##################################### +# PXE Filename(s) + +$filemod = array(); +$modfi = 0; +$filedel = array(); +$delfi = 0; +$j = 0; + +if (count($file) != 0){ + +for ($i=0; $i + Vorsicht dies kann eine nicht verwendbare PXE Datei zur Folge haben!

"; + # hier noch Syntaxcheck + $filemod ['filename'][$i] = $file[$i]; + $modfi = 1; + } + + if ( $oldfile[$i] != "" && $file[$i] == "" ){ + echo "PXE Dateinamen loeschen!
+ Achtung: aus ihren PXE Daten wird keine PXE Datei mehr generiert.
+ Sie sind solange nicht mehr für den PXE Bootvorgang verwendbar bis Sie einen neuen Dateinamen anlegen!

"; + $filemod ['filename'][$i] = $oldfile[$i]; + $filedel ['filename'][$j] = $oldfile[$i]; + $j++; + $delfi = 1; + $seconds = 4; + } +} +#erst ändern +if ($modfi == 1){ + echo "Ändern: "; print_r($filemod); echo "
"; + if(ldap_mod_replace($ds,$pxeDN,$filemod)){ + $mesg = "PXE Dateiname(n) erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern des(r) PXE Dateinamens!

"; + } + $modfi = 0; +} +# dann löschen +if ($delfi == 1){ + echo "Löschen: "; print_r($filedel); echo "
"; + if(ldap_mod_del($ds,$pxeDN,$filedel)){ + $mesg = "PXE Dateiname(n) erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen des PXE Dateinamens !

"; + } + $delfi = 0; +} + +} + +# PXE Dateiname neu anlegen +if ($newfilename == ""){ +} +if ($newfilename != ""){ + echo "PXE Dateiname hinzufügen"; + $fileadd ['filename'] = $newfilename; + if(ldap_mod_add($ds,$pxeDN,$fileadd)){ + $mesg = "PXE Dateiname ".$newfilename." erfolgreich angelegt

"; + }else{ + $mesg = "Fehler beim anlegen des PXE Dateinamens ".$newfilename." !

"; + } +} + + + +################################################################## +# Restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} + +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$pxeDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$pxeDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$pxeDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/pxe_copy.php b/ldap-site-mngmt/webinterface/computers/pxe_copy.php new file mode 100644 index 00000000..eb75ea44 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/pxe_copy.php @@ -0,0 +1,180 @@ +"; +$n = array_keys($copytargets,'none'); +#print_r($n); echo "
"; +for ($i=0; $i"; + + +$seconds = 2; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +if ( $pxecn != ""){ + + # Formulareingaben anpassen + $exppxe = explode(" ",$pxecn); + foreach ($exppxe as $word){$expuc[] = ucfirst($word);} + $pxecn = implode(" ",$expuc); + $pxecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $pxecn); + + $nomac = 0; + + if (count($copytargets) != 0){ + foreach ($copytargets as $targetDN){ + + $exptargetdn = ldap_explode_dn($targetDN, 1); + $targetcn = $exptargetdn[0]; + $targettype = $exptargetdn[1]; + + # falls Target keine MAC hat dann kann keine PXE angelegt werden + if ($targettype == "computers"){ + $macdata = get_node_data($targetDN, array("hwaddress")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Ziel-Rechner ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü wird nicht angelegt.
+
+ Tragen Sie zuerst eine MAC ein!

"; + } + } + if ($targettype == "groups"){ + $members = get_node_data($targetDN, array("member")); + if (count($members) > 1){ + foreach ($members['member'] as $hostDN){ + $macdata = get_node_data($hostDN, array("hwaddress","hostname")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Gruppen-Rechner ".$macdata['hostname']." ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü für die Gruppe wird nicht angelegt.
+
+ Tragen Sie zuerst bei Rechner ".$macdata['hostname']." eine MAC ein!

"; + } + } + } + if (count($members) == 1){ + $macdata = get_node_data($members['member'], array("hwaddress")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Gruppen-Rechner ".$macdata['hostname']." ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü für die Gruppe wird nicht angelegt.
+
+ Tragen Sie zuerst bei Rechner ".$macdata['hostname']." eine MAC ein!

"; + } + } + } + + $brothers = get_pxeconfigs($targetDN,array("cn")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['cn'] == $pxecn ){ + $mesg = "Es existiert bereits ein PXE Boot Menü mit dem eingegebenen Namen!
+ Bitte geben Sie einen anderen Namen ein.

"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + $brother = 1; + break; + } + } + if ($brother == 0 && $nomac == 0){ + + $exptargetdn = ldap_explode_dn($targetDN, 1); + $target = $exptargetdn[0]; + $targettype = $exptargetdn[1]; + + $newpxeDN = "cn=".$pxecn.",".$targetDN; + print_r($newpxeDN); echo "
"; + + if (dive_into_tree_cp($pxeDN,$newpxeDN)){ + + # Filename anpassen + if ($targettype == "computers"){ + $macdata = get_node_data($targetDN, array("hwaddress")); + $entrymod ['filename'] = "01-".$macdata['hwaddress']; + #$entrymod ['fileuri'] = "01-".$macdata['hwaddress'].".tgz"; + } + if ($targettype == "groups"){ + $members = get_node_data($targetDN, array("member")); + if (count($members) != 0){ + foreach ($members['member'] as $hostDN){ + $macdata = get_node_data($hostDN, array("hwaddress")); + $entrymod ['filename'][] = "01-".$macdata['hwaddress']; + #$entrymod ['fileuri'] = $target.".tgz"; + } + } + } + if(ldap_mod_replace($ds,$newpxeDN,$entrymod)){ + if($deltr == 1){ + # Timeranges und FileURI im neuen Objekt löschen (todo: anpassen statt löschen) + $entrydel ['timerange'] = array(); + $entrydel ['fileuri'] = array(); + if ( ldap_mod_del($ds,$newpxeDN,$entrydel) ){ + $mesg .= "
PXE Boot Menü erfolgreich nach ".$target[1]." kopiert
"; + } + else{ + ldap_delete($ds,$newpxeDN); + $mesg .= "
Fehler beim kopieren des PXE Boot Menüs nach ".$target[1]."
"; + } + } + } + else{ + ldap_delete($ds,$newpxeDN); + $mesg .= "
Fehler beim kopieren des PXE Boot Menüs nach ".$target[1]."
"; + } + } + else{ + $mesg .= "
Fehler beim kopieren des PXE Boot Menüs nach ".$target[1]."
"; + } + } + } + } + else{ + $mesg .= "
Sie haben kein Ziel angegeben!
"; + } +} + +elseif ( $pxecn == ""){ + + $mesg = "Sie haben den Namen des neuen PXE Boot Menüs nicht angegeben. Dieser ist aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/computers/pxe_delete.php b/ldap-site-mngmt/webinterface/computers/pxe_delete.php new file mode 100644 index 00000000..a1b7a060 --- /dev/null +++ b/ldap-site-mngmt/webinterface/computers/pxe_delete.php @@ -0,0 +1,42 @@ + + + Computers Management + + + + +
"; + +if ( $pxeDN != ""){ + + if ( dive_into_tree_del($pxeDN,"") ){ + $mesg = "PXE Boot Menü ".$pxecn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des PXE Boot Menüs ".$pxecn." !

"; + } + +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/delete_confirm.php b/ldap-site-mngmt/webinterface/dhcp/delete_confirm.php new file mode 100644 index 00000000..62225afc --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/delete_confirm.php @@ -0,0 +1,37 @@ + + + AU Management + + + + + + + +
+ Wollen Sie das Objekt ".$name." wirklich löschen?

+
+ Falls ja:

+ + + +

+
+
+ Falls, nein:

+ +
+
+ +"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcp.dwt b/ldap-site-mngmt/webinterface/dhcp/dhcp.dwt new file mode 100644 index 00000000..4aadeba5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcp.dwt @@ -0,0 +1,78 @@ + + + + {SEITENTITEL} + + + + + + + + + + +
+ + + + + +

Rechner und IP Management

+
+ + + + +
+

Startseite +  >>  {AU}  [ {DOMAIN} ]

+
+
+ + + + +
+ {LOGIN} +
+
+ + + + +
{MAINMENU}
+ +
+ + + + + + + + + + + +
+ + +
+ + {NAVIGATION} + +
+
+ + +
+ + {HAUPTFENSTER} + +
+
+ + + + diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcp.php b/ldap-site-mngmt/webinterface/dhcp/dhcp.php new file mode 100644 index 00000000..d757ba3b --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcp.php @@ -0,0 +1,27 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcp_footer.inc.php b/ldap-site-mngmt/webinterface/dhcp/dhcp_footer.inc.php new file mode 100644 index 00000000..311721c5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcp_footer.inc.php @@ -0,0 +1,18 @@ +assign(array("PFAD" => $START_PATH)); + +# Daten in die Vorlage parsen +$template->parse("LOGIN", "Login"); +$template->parse("MAINMENU", "Mmenu"); +$template->parse("NAVIGATION", "Menu"); +$template->parse("HAUPTFENSTER", "Webseite"); +$template->parse("PAGE", "Vorlage"); + +# Fertige Seite an den Browser senden +$template->FastPrint("PAGE"); + +# Abmelden vom LDAP +ldap_unbind($ds); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcp_header.inc.php b/ldap-site-mngmt/webinterface/dhcp/dhcp_header.inc.php new file mode 100644 index 00000000..9eaac019 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcp_header.inc.php @@ -0,0 +1,21 @@ + "dhcp.dwt", + "Login" => "../logout_form.inc.dwt", + "Mmenu" => "../hauptmenue.dwt", + "Menu" => "menu.dwt", + "Webseite" => $webseite); +if (isset($additionalTemplates)) { + foreach ($additionalTemplates as $templateKey => $templateFile) { + $definedTemplates[$templateKey] = $templateFile; + } +} +$template->define($definedTemplates); + +$template->assign(array("SEITENTITEL" => $titel, "ROLLE" => "mainadmin", "AU" => $au_ou, "DOMAIN" => $assocdom, "USERCN" => $usercn)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcp_menu.php b/ldap-site-mngmt/webinterface/dhcp/dhcp_menu.php new file mode 100644 index 00000000..423c53c8 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcp_menu.php @@ -0,0 +1,199 @@ + "no_dhcp.php", + "text" => "Übersicht", + "zugriff" => "alle")); + $submenu = array(array(array())); + }else{ + # DHCP Services (momentan nur für einen DHCP konzipiert) + $dhcpservice_array = get_dhcpservices($auDN,array("dn","cn")); + if (count($dhcpservice_array) == 0){ + $dhcpsvlink = "new_dhcpservice.php?mnr=1"; + } + else { + $dhcpsvlink = "dhcpservice.php?mnr=1"; + } + $dhcpsubnet_array = get_dhcpsubnets($auDN,array("dn","cn")); + + # Struktur der Registerkartenleiste + $hauptmenu = array(array("link" => "dhcp.php", + "text" => "Übersicht", + "zugriff" => "alle"), + array("link" => $dhcpsvlink, + "text" => "DHCP Service", + "zugriff" => array("MainAdmin","DhcpAdmin")), + array("link" => "dhcpsubnets.php?mnr=2", + "text" => "DHCP Subnets", + "zugriff" => array("MainAdmin","DhcpAdmin"))); + + # DHCP Subnets + $subnets = array(); + for ($i=0;$i "dhcpsubnet.php?dn=".$dhcpsubnet_array[$i]['dn']."&mnr=2&sbmnr=".$i, + "text" => $dhcpsubnet_array[$i]['cn'], + "zugriff" => array("MainAdmin","DhcpAdmin")); + } + + # falls komplette Netze verfügbar, link zum Neuanlegen + if ( check_if_free_networks() ){ + $subnets[] = array("link" => "new_dhcpsubnet.php?mnr=2&sbmnr=".$i, + "text" => "Neues DHCP Subnet", + "zugriff" => array("MainAdmin","DhcpAdmin")); + } + $submenu = array(array(), + array(), + $subnets); + + } + # $rollen = array_keys($roles); + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $template->define_dynamic("Submenu", "Menu"); + $i=0; + $maxmenu = count($hauptmenu); + + foreach($hauptmenu as $item) { + $template->clear_parse("SUBMENU_LIST"); + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + + $subempty = 0; + $j=0; + $maxsub = count($submenu[$mnr]); + if($maxsub > 0){ + foreach($submenu[$mnr] as $item2) { + + if($item2['zugriff'] === "alle" || vergleicheArrays($rollen, $item2['zugriff'])) { + if($i != $mnr){ + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + else{ + if ($j==0) { + if ($sbmnr==0) { + if($maxsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if($maxsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($sbmnr==$j) { + if($maxsub == $j+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if($maxsub == $j+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + # if ($lastaktive) {$zwisch="branch";} + # else {$zwisch="branch";} + $lastaktive=false; + } + } + $htmlcode= " + + + + +   + + + ".$item2['text']." +   + + "; + $template->assign(array("SUB" => $htmlcode)); + $template->assign(array("FARBE_S" => $farb)); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + } + else { + $subempty++; + } + $j=$j+1; + } + } + if($subempty == count($submenu[$mnr])) { + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + + # weiter im Hauptmenü + if ($i==0) { + if ($mnr==0) { + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch="";} # {$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + if(count($submenu[$mnr][0]) != 0){ + if($maxmenu == $i+1){$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if(count($submenu[$i][0]) != 0){ + if($maxmenu == $i+1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + #if ($lastaktive) {$zwisch="";} + #else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("ICON" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + $template->clear_dynamic("Hauptmenu"); + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else {$template->assign(array("ENDE" => ""));} +} + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcp_start.dwt b/ldap-site-mngmt/webinterface/dhcp/dhcp_start.dwt new file mode 100644 index 00000000..2e1c0f02 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcp_start.dwt @@ -0,0 +1,27 @@ + + + + + + + + + + + +

Modul - DHCP Management:

+

Dieses Modul dient der Verwaltung eines DHCP Dienstes und DHCP Subnets, Classes
+ Benutzen Sie die Navigation links, um die einzelnen Verwaltungsbereiche anzusteuern:

+
    +
  • DHCP Service

    + ... +
  • +
  • DHCP Subnets

    + ... +
  • +
  • DHCP Classes

    + ... +
  • +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpservice.dwt b/ldap-site-mngmt/webinterface/dhcp/dhcpservice.dwt new file mode 100644 index 00000000..2bfd0631 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpservice.dwt @@ -0,0 +1,257 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

DHCP Service   {CN}

+ + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger DHCP Service Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ DHCP_ +   +
Beschreibung: + + +
Dienst kann momentan genutzt werden von:
Abteilung {DHCPOFFERNOW}  (und allen Unterabteilungen) +
Ändern:
(Wählen Sie eine andere Abteilung)
+ +   +

DHCP Optionen des Dienstes (Globaler Scope):

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
OptionWert(e)
Server Identifier: + +   +
Default Lease Time: + +   +
Max Lease Time: + +   +
Use Host DCL Names: + +   +
DHCP Max Message Size: + +   +
DDNS Update Style: + +   +
Domain Name: + +   +
Domain Name Servers: + +   +
NTP Servers: + +   +
Allow: + +   +
Deny: + +   +
+

Dem Dienst zugeordnete DHCP Subnets:

+ + + + + + + + + + + + + + + +
SubnetNetmaskAbteilung (AU)
{SUBNET}  {NETMASK} {SUBNETAU} 

Config File für DHCP Generator Script

Speichern Sie dieses als dhcpgen.conf.pl im gleichen Verzeichnis wie ihr DHCP Dienst Generator Skript dhcp_generator.pl
+ + + + + + + +
+ $ldaphost= "{DHCPGENLDAP}";
+ $basedn= "{DHCPGENBASE}";
+ $userdn= "{DHCPGENUDN}";
+ $passwd= "{DHCPGENPW}";
+ $dhcpservicedn= "{DHCPGENSVDN}"; +

DHCP Service  {CN}  löschen:

+ + + + + + + + + + + +
+ Der DHCP Dienst wird gelöscht,
+
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpservice.php b/ldap-site-mngmt/webinterface/dhcp/dhcpservice.php new file mode 100644 index 00000000..59d77bbe --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpservice.php @@ -0,0 +1,164 @@ +assign(array("DHCPDN" => "", + "CN" => "", + "PRIMARY" => "", + "SECONDARY" => "", + "DESCRIPTION" => "", + "STATEMENTS" => "", + "ALLOW" => "", + "DENY" => "", + "IGNORE" => "", + "DDNSUPDATE" => "", + "DEFAULTLEASE" => "", + "MAXLEASE" => "", + "USEHOSTDCL" => "", + "DOMAINNAME" => "", + "DOMAINNAMESERVERS" => "", + "MAXMESSIZE" => "", + "SRVIDENT" => "", + "NTPSERVERS" => "", + "OPTGENERIC" => "", + "DHCPOFFERNOWDN" => "", + "DHCPOFFERNOW" => "")); + +# DHCP Service Daten +$dhcpsv_array = get_dhcpservices($auDN,array("dn","cn")); +$dhcpserviceDN = $dhcpsv_array[0]['dn']; +$attributes = array("dn","cn","dhcpprimarydn","dhcpsecondarydn","description","dhcpofferdn","dhcpstatements","dhcpoptallow", + "dhcpoptddns-update-style","dhcpoptdefault-lease-time","dhcpoptdeny","dhcpoptfilename", + "dhcpoptignore","dhcpoptmax-lease-time","dhcpoptnext-server","dhcpoptserver-identifier", + "dhcpoptuse-host-decl-names","dhcpoptbroadcast-address","dhcpoptdhcp-max-message-size", + "dhcpoptdomain-name","dhcpoptdomain-name-servers","dhcpoptgeneric","dhcpoptntp-servers", + "dhcpoptroot-path","dhcpoptrouters"); +$dhcpsv_data = get_node_data($dhcpserviceDN, $attributes); +#print_r($dhcpsv_data); + +# RBS Anbieten +# momentanes Offer +# todo: falls dhcpofferDN leer dann standardwert AU teilbaum +$offerexp = ldap_explode_dn($dhcpsv_data['dhcpofferdn'], 1); +$dhcpoffernow = $offerexp[0]; +# alternative Offers +$expdn = ldap_explode_dn($auDN, 0); # Mit Merkmalen +$expdn = array_slice($expdn, 1); +$expou = ldap_explode_dn($auDN, 1); # nur Werte +$expou = array_slice($expou, 1, -3); +#print_r($expou); echo "
"; +#print_r($expdn); echo "
"; +for ($i=0; $iassign(array("DHCPDN" => $dhcpsv_data['dn'], + "CN" => $dhcpcn, + "PRIMARY" => $dhcpsv_data['dhcpprimarydn'], + "SECONDARY" => $dhcpsv_data['dhcpsecondarydn'], + "DESCRIPTION" => $dhcpsv_data['description'], + "STATEMENTS" => $dhcpsv_data['dhcpstatements'], + "ALLOW" => $dhcpsv_data['dhcpoptallow'], + "DENY" => $dhcpsv_data['dhcpoptdeny'], + "IGNORE" => $dhcpsv_data['dhcpoptignore'], + "DDNSUPDATE" => $dhcpsv_data['dhcpoptddns-update-style'], + "DEFAULTLEASE" => $dhcpsv_data['dhcpoptdefault-lease-time'], + "MAXLEASE" => $dhcpsv_data['dhcpoptmax-lease-time'], + "USEHOSTDCL" => $dhcpsv_data['dhcpoptuse-host-decl-names'], + "MAXMESSIZE" => $dhcpsv_data['dhcpoptdhcp-max-message-size'], + "DOMAINNAME" => $dhcpsv_data['dhcpoptdomain-name'], + "DOMAINNAMESERVERS" => $dhcpsv_data['dhcpoptdomain-name-servers'], + "NEXTSERVER" => $dhcpsv_data['dhcpoptnext-server'], + "FILENAME" => $dhcpsv_data['dhcpoptfilename'], + "SRVIDENT" => $dhcpsv_data['dhcpoptserver-identifier'], + "NTPSERVERS" => $dhcpsv_data['dhcpoptntp-servers'], + "OPTGENERIC" => $dhcpsv_data['dhcpoptgeneric'], + "DHCPOFFERNOWDN" => $dhcpsv_data['dhcpofferdn'], + "DHCPOFFERNOW" => $dhcpoffernow, + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + +$template->define_dynamic("Dhcpoffers", "Webseite"); +foreach ($dhcpoffers as $offer){ + $template->assign(array("DHCPOFFER" => $offer['dn'], + "DHCPOFFEROU" => $offer['ou'],)); + $template->parse("DHCPOFFERS_LIST", ".Dhcpoffers"); +} + +# Subnetze und Hosts des Dienstes +$dhcpobjects = get_service_subnets($dhcpserviceDN, array("dn","cn","dhcpoptnetmask")); +#print_r($dhcpobjects); +$template->define_dynamic("Dhcpsubnets", "Webseite"); +foreach ($dhcpobjects as $subnet){ + $template->assign(array("SUBNET" => $subnet['cn'], + "NETMASK" => $subnet['dhcpoptnetmask'], + "SUBNETAU" => $subnet['auDN'])); + $template->parse("DHCPSUBNETS_LIST", ".Dhcpsubnets"); +} + +### Rechner +#$hostorgroup = $exp[0]; +#$hosts_array = get_hosts($auDN,array("dn","hostname","ipaddress")); +# +#$template->define_dynamic("TftpHosts", "Webseite"); +#$template->define_dynamic("NfsHosts", "Webseite"); +#$template->define_dynamic("NbdHosts", "Webseite"); +#foreach ($hosts_array as $item){ +# $template->assign(array("HDN" => $item['dn'], +# "HN" => $item['hostname'], +# "IP" => $item['ipaddress'])); +# $template->parse("TFTPHOSTS_LIST", ".TftpHosts"); +# $template->assign(array("HDN" => $item['dn'], +# "HN" => $item['hostname'], +# "IP" => $item['ipaddress'])); +# $template->parse("NFSHOSTS_LIST", ".NfsHosts"); +# $template->assign(array("HDN" => $item['dn'], +# "HN" => $item['hostname'], +# "IP" => $item['ipaddress'])); +# $template->parse("NBDHOSTS_LIST", ".NbdHosts"); +#} + +################################################ +# DHCP Generator Skript Config +$template->assign(array("DHCPGENLDAP" => "ldap://".LDAP_HOST, + "DHCPGENBASE" => "ou=RIPM,".$suffix, + "DHCPGENUDN" => $userDN, + "DHCPGENPW" => $userPassword, + "DHCPGENSVDN" => $dhcpserviceDN)); + + +################################################################################### + +include("dhcp_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpservice_add.php b/ldap-site-mngmt/webinterface/dhcp/dhcpservice_add.php new file mode 100644 index 00000000..bcb5899e --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpservice_add.php @@ -0,0 +1,70 @@ +
"; + +$nodeDN = "cn=dhcp,".$auDN; +$mnr = $_POST['mnr']; +$sbmnr = $_POST['sbmnr']; +$mcnr = $_POST['mcnr']; + +$get_dhcpcn = str_replace ( " ", "_", $cn ); +$seconds = 200; +$url = "new_dhcpservice.php?&mnr=1"; + +echo " + + + Computers Management + + + + +
"; + +if ( $cn != "" && $cn != "Hier_DHCP_NAME_eintragen" ){ + + $dhcpcn = "DHCP_".$cn; + + # Formulareingaben anpassen + $exp = explode(" ",$dhcpcn); + foreach ($exp as $word){$expuc[] = ucfirst($word);} + $dhcpcn = implode(" ",$expuc); + $dhcpcn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $dhcpcn); + + #$dhcpDN = "cn=".$dhcpcn.",".$nodeDN; + #print_r($dhcpDN); echo "

"; + + if (add_dhcpservice ($dhcpcn,$dhcpoffer,$atts)){ + $mesg .= "
DHCP Service erfolgreich angelegt
"; + $url = "dhcpservice.php?mnr=1"; + }else{ + $mesg .= "
Fehler beim anlegen des DHCP Services!
"; + } +} + +elseif ( $cn == "" || $cn == "Hier_DHCP_NAME_eintragen" ){ + + $mesg = "Sie haben den Namen des neuen DHCP Service nicht angegeben. Dieser ist + aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "new_dhcpservice.php?dhcpcn=Hier_DHCP_NAME_eintragen&mnr=1"; +} + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpservice_change.php b/ldap-site-mngmt/webinterface/dhcp/dhcpservice_change.php new file mode 100644 index 00000000..5096d355 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpservice_change.php @@ -0,0 +1,202 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + +$nodeDN = "cn=dhcp,".$auDN; +$mnr = $_POST['mnr']; +$sbmnr = $_POST['sbmnr']; +$mcnr = $_POST['mcnr']; + +#$deltr = $_POST['deltr']; + +$seconds = 200; +$url = "dhcpservice.php?dn=".$dhcpdn."&mnr=1"; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# DHCP Service CN (DN) + +if ( $oldcn == $cn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldcn != "" && $cn != "" && $oldcn != $cn ){ + echo "DHCP Service Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $exp = explode(" ",$cn); + foreach ($exp as $word){$expuc[] = ucfirst($word);} + $cn = implode(" ",$expuc); + $cn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $cn); + + $newdhcpDN = "cn=".$cn.",".$nodeDN; + print_r($newdhcpDN); echo "

"; + + if(move_subtree($dhcpDN, $newdhcpDN)){ + adjust_dhcpservice_dn($newdhcpDN, $dhcpDN); + $dhcpDN = $newdhcpDN; + $mesg = "DHCP Service Name erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern des DHCP Service Namen!

"; + } +} + +if ( $oldcn != "" && $cn == "" ){ + echo "DHCP Service Name loeschen!
+ Dieser ist Teil des DN, Sie werden den DHCP Service komplett löschen

"; + echo "Wollen Sie den DHCP Service ".$oldcn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + +##################################### +# Offer ändern + +if ( $dhcpoffer != "none" ){ + + if ( $dhcpoffer != "off" && $dhcpoffer == $olddhcpoffer ){ + $mesg = "Sie haben die gleiche Abteilung ausgewählt
+ Keine Änderung!"; + } + + if ( $dhcpoffer != "off" && $dhcpoffer != $olddhcpoffer ){ + $entryoffer ['dhcpofferdn'] = $dhcpoffer; + if(ldap_mod_replace($ds,$dhcpDN,$entryoffer)){ + $mesg = "DHCP Service Offer erfolgreich geändert

"; + } + else{ + $mesg = "Fehler beim ändern des DHCP Service Offers!

"; + } + } + + /*if ( $dhcpoffer == "off" && $olddhcpoffer != "" ){ + $entryoffer ['dhcpofferdn'] = array(); + if(ldap_mod_del($ds,$dhcpDN,$entryoffer)){ + $mesg = "DHCP Service Offer erfolgreich geändert

"; + } + else{ + $mesg = "Fehler beim ändern des DHCP Service Offers!

"; + } + }*/ + +} + +##################################### +# Restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} + +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$dhcpDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$dhcpDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$dhcpDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpservice_delete.php b/ldap-site-mngmt/webinterface/dhcp/dhcpservice_delete.php new file mode 100644 index 00000000..36260cd1 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpservice_delete.php @@ -0,0 +1,37 @@ + + + Computers Management + + + + +
"; + +if ( $dhcpDN != ""){ + if ( dive_into_tree_del($dhcpDN,"") ){ + cleanup_del_dhcpservice($dhcpDN); + $mesg = "DHCP Service ".$dhcpcn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des DHCP Services ".$dhcpcn." !

"; + } +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.dwt b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.dwt new file mode 100644 index 00000000..394b63fc --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.dwt @@ -0,0 +1,207 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

DHCP Subnet   {CN}

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
DHCP Subnet (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +   +
Netmask: + +   +
Eingebunden in DHCP Dienst: Service {DHCPSVNOW} / AU {DHCPSVNOWAU}   +
DHCP Dienst ändern: + +   +
Beschreibung: + + +
IP Range:
(Zur dynamischen Vergabe)
+ +    -    + + + +

DHCP Optionen des Subnets (Subnet Scope):

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
OptionWert(e)
Default Lease Time: + +   +
Max Lease Time: + +   +
DDNS Update Style: + +   +
Domain Name: + +   +
Domain Name Servers: + +   +
Routers: + +   +
Broadcast Address: + +   +
NTP Servers: + +   +
Next Server: + +   +
Filename: + +   +
+

DHCP Subnet  {CN}  löschen:

+ + + + + + + + + + + + + +
+ Das DHCP Subnet wird gelöscht,
+
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.php b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.php new file mode 100644 index 00000000..235667aa --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet.php @@ -0,0 +1,126 @@ +assign(array("SUBNETDN" => "", + "CN" => "", + "NETMASK" => "", + "RANGE1" => "", + "RANGE2" => "", + "DESCRIPTION" => "", + "STATEMENTS" => "", + "ALLOW" => "", + "DENY" => "", + "IGNORE" => "", + "DDNSUPDATE" => "", + "DEFAULTLEASE" => "", + "MAXLEASE" => "", + "USEHOSTDCL" => "", + "BROADCAST" => "", + "ROUTERS" => "", + "DOMAINNAME" => "", + "DOMAINNAMESERVERS" => "", + "NEXTSERVER" => "", + "FILENAME" => "", + "SRVIDENT" => "", + "NTPSERVERS" => "", + "OPTGENERIC" => "", + "DHCPOFFERNOWDN" => "", + "DHCPSVNOW" => "", + "DHCPSVNOWAU" => "", + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +# DHCP Subnet Daten +$dhcpsubnetDN = $_GET['dn']; +$attributes = array("dn","cn","dhcpoptnetmask","dhcphlpcont","dhcprange","description","dhcpstatements","dhcpoptallow", + "dhcpoptddns-update-style","dhcpoptdefault-lease-time","dhcpoptdeny","dhcpoptfilename", + "dhcpoptignore","dhcpoptmax-lease-time","dhcpoptnext-server","dhcpoptserver-identifier", + "dhcpoptuse-host-decl-names","dhcpoptbroadcast-address","dhcpoptdhcp-max-message-size", + "dhcpoptdomain-name","dhcpoptdomain-name-servers","dhcpoptgeneric","dhcpoptntp-servers", + "dhcpoptroot-path","dhcpoptrouters"); +$subnet_data = get_node_data($dhcpsubnetDN, $attributes); +#print_r($subnet_data); + +# momentane DHCP Service Zuordnung +$dhcpsvnowdn = ldap_explode_dn($subnet_data['dhcphlpcont'], 1); + +# DHCP Range +$iprange = explode('_',$subnet_data['dhcprange']); + +$template->assign(array("SUBNETDN" => $dhcpsubnetDN, + "CN" => $subnet_data['cn'], + "NETMASK" => $subnet_data['dhcpoptnetmask'], + "RANGE1" => $iprange[0], + "RANGE2" => $iprange[1], + "DESCRIPTION" => $subnet_data['description'], + "STATEMENTS" => $subnet_data['dhcpstatements'], + "ALLOW" => $subnet_data['dhcpoptallow'], + "DENY" => $subnet_data['dhcpoptdeny'], + "IGNORE" => $subnet_data['dhcpoptignore'], + "DDNSUPDATE" => $subnet_data['dhcpoptddns-update-style'], + "DEFAULTLEASE" => $subnet_data['dhcpoptdefault-lease-time'], + "MAXLEASE" => $subnet_data['dhcpoptmax-lease-time'], + "USEHOSTDCL" => $subnet_data['dhcpoptuse-host-decl-names'], + "BROADCAST" => $subnet_data['dhcpoptbroadcast-address'], + "ROUTERS" => $subnet_data['dhcpoptrouters'], + "DOMAINNAME" => $subnet_data['dhcpoptdomain-name'], + "DOMAINNAMESERVERS" => $subnet_data['dhcpoptdomain-name-servers'], + "NEXTSERVER" => $subnet_data['dhcpoptnext-server'], + "FILENAME" => $subnet_data['dhcpoptfilename'], + "SRVIDENT" => $subnet_data['dhcpoptserver-identifier'], + "NTPSERVERS" => $subnet_data['dhcpoptntp-servers'], + "OPTGENERIC" => $subnet_data['dhcpoptgeneric'], + "DHCPOFFERNOWDN" => $subnet_data['dhcphlpcont'], + "DHCPSVNOW" => $dhcpsvnowdn[0], + "DHCPSVNOWAU" => $dhcpsvnowdn[2], + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + + +# alternative DHCP Services +$altdhcp = alternative_dhcpservices($subnet_data['dhcphlpcont']); + +$template->assign(array("DHCPSVDN" => "", + "DHCPSVCN" => "", + "DHCPSVAU" => "")); +if (count($altdhcp) != 0){ +$template->define_dynamic("Dhcpservices", "Webseite"); + foreach ($altdhcp as $item){ + $template->assign(array("DHCPSVDN" => $item['dn'], + "DHCPSVCN" => $item['cn'], + "DHCPSVAU" => $item['au'])); + $template->parse("DHCPSERVICES_LIST", ".Dhcpservices"); + } +} + +################################################################################### + +include("dhcp_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_add.php b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_add.php new file mode 100644 index 00000000..6939afe0 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_add.php @@ -0,0 +1,71 @@ +
"; + +$nodeDN = "cn=dhcp,".$auDN; +$mnr = $_POST['mnr']; +$sbmnr = $_POST['sbmnr']; + +$get_dhcpcn = str_replace ( " ", "_", $cn ); +$seconds = 200; +$url = "new_dhcpsubnet.php?&mnr=2"; + +echo " + + + Computers Management + + + + +
"; + +if ( $cn != "" && $cn != "Hier_Subnetz_eintragen" && $netmask != "" && $netmask != "Hier_Netzmaske_eintragen" ){ + + if ( $syntax->check_netip_syntax($cn) && $syntax->check_ip_syntax($netmask) ){ + + if (add_dhcpsubnet ($cn,$dhcpservice,$netmask,$range1,$range2,$atts)){ + $mesg .= "
DHCP Subnet erfolgreich angelegt
"; + $url = "dhcpsubnets.php?mnr=2"; + }else{ + $mesg .= "
Fehler beim anlegen des DHCP Subnets!
"; + } + + }else{ + $mesg .= "Falsche IP Syntax! Geben Sie eine korrekte IP Adresse als Subnet Name oder Netzmaske ein."; + $url = "new_dhcpsubnet.php?subnetcn=Hier_Subnetz_eintragen&netmask=".$netmask."&mnr=2"; + } +} + +elseif ( $cn == "" || $cn == "Hier_Subnetz_eintragen" || $netmask == "" || $netmask == "Hier_Netzmaske_eintragen" ){ + + if ( $cn == ""){ $cn = "Hier_Subnetz_eintragen";} + if ( $netmask == ""){ $netmask = "Hier_Netzmaske_eintragen";} + $mesg = "Sie haben die notwendigen Attribute: Name (IP) und Netzmaske des neuen DHCP Subnets nicht angegeben.
+ Bitte geben Sie fehlende ein.

"; + $url = "new_dhcpsubnet.php?subnetcn=".$cn."&netmask=".$netmask."&mnr=2"; +} + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_change.php b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_change.php new file mode 100644 index 00000000..b0dc13c7 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_change.php @@ -0,0 +1,292 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + +$nodeDN = "cn=dhcp,".$auDN; +$mnr = $_POST['mnr']; +$sbmnr = $_POST['sbmnr']; +$mcnr = $_POST['mcnr']; + +$seconds = 200; +$url = "dhcpsubnet.php?dn=".$subnetDN."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# DHCP Subnet CN (DN) + +if ( $oldcn == $cn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldcn != "" && $cn != "" && $oldcn != $cn ){ + + if ( $syntax->check_netip_syntax($cn) ){ + echo "Subnetz aendern
"; + $newsubnetDN = "cn=".$cn.",".$nodeDN; + print_r($newsubnetDN); echo "

"; + + if(modify_subnet_dn($subnetDN,$newsubnetDN)){ + $subnetDN = $newsubnetDN; + $mesg = "DHCP Subnet erfolgreich geändert

"; + $url = "dhcpsubnet.php?dn=".$subnetDN."&mnr=".$mnr."&sbmnr=".$sbmnr; + }else{ + $mesg = "Fehler beim ändern des DHCP Subnets!

"; + } + + }else{ + $mesg = "falsche IP Syntax
"; + } +} + +if ( $oldcn != "" && $cn == "" ){ + echo "DHCP Subnet loeschen!
+ Dieser ist Teil des DN, Sie werden den DHCP Subnet komplett löschen

"; + echo "Wollen Sie den DHCP Subnet ".$oldcn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + +##################################### +# Netmask + +if ( $netmask != $oldnetmask ){ + + if ( $netmask == ""){ + echo "Die Subnetzmaske ist ein notwendiges Attribut.
+ Keine Änderung!
"; + } + + if ( $netmask != "" ){ + if ( $syntax->check_ip_syntax($netmask) ){ + $entry ['dhcpoptnetmask'] = $netmask; + if(ldap_mod_replace($ds,$subnetDN,$entry)){ + $mesg = "Netzmaske erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern der Netzmaske!

"; + } + }else{ + $mesg = "falsche IP Syntax
"; + } + } + +} + + +##################################### +# DHCP Dienstzuordnung ändern + +if ( $dhcpservice != "none" ){ + + if ( $dhcpservice != "off" && $dhcpservice == $olddhcpservice ){ + $mesg = "Sie haben die gleiche Abteilung ausgewählt
+ Keine Änderung!"; + } + + if ( $dhcpservice != "off" && $dhcpservice != $olddhcpservice ){ + $entrysv ['dhcphlpcont'] = $dhcpservice; + if(ldap_mod_replace($ds,$subnetDN,$entrysv)){ + $mesg = "DHCP Dienstzuordnung erfolgreich geändert

"; + } + else{ + $mesg = "Fehler beim ändern der DHCP Dienstzuordnung!

"; + } + } + + if ( $dhcpservice == "off" && $olddhcpservice != "" ){ + $entrysv ['dhcphlpcont'] = array(); + if(ldap_mod_del($ds,$subnetDN,$entrysv)){ + $mesg = "DHCP Dienstzuordnung erfolgreich geändert

"; + } + else{ + $mesg = "Fehler beim ändern der DHCP Dienstzuordnung!

"; + } + } + +} + + +##################################### +# DHCP Range + +if ( $newrange1 == $oldrange1 && $newrange2 == $oldrange2 ){ + # $mesg = "keine Aenderung
"; +}else{ + + if ( $newrange1 == "" xor $newrange2 == "" ){ + $mesg = "Bitte beide DHCP Range Felder ausfüllen, keine Aenderung
"; + } + + if ( $oldrange1 == "" && $oldrange2 == "" && $newrange1 != "" && $newrange2 != "" ){ + if ( $syntax->check_ip_syntax($newrange1) && $syntax->check_ip_syntax($newrange2) ){ + if ( check_ip_in_subnet($newrange1,$cn) && check_ip_in_subnet($newrange2,$cn)){ + $dhcprange = implode('_',array($newrange1,$newrange2)); + if ( new_ip_dhcprange($dhcprange,$subnetDN,$auDN) ){ + $mesg = "DHCP Range erfolgreich eingetragen"; + }else{ + $mesg = "Fehler beim eintragen der DHCP Range"; + } + }else{ + $mesg = "DHCP Range nicht in Subnetz ".$cn." enthalten"; + } + }else{ + $mesg = "falsche IP Syntax
"; + } + } + + if ( $oldrange1 != "" && $oldrange2 != "" && $newrange1 != "" && $newrange2 != "" ){ + if ( $syntax->check_ip_syntax($newrange1) && $syntax->check_ip_syntax($newrange2) ){ + if ( check_ip_in_subnet($newrange1,$cn) && check_ip_in_subnet($newrange2,$cn)){ + $dhcprange = implode('_',array($newrange1,$newrange2)); + $olddhcprange = implode('_',array($oldrange1,$oldrange2)); + if ( modify_ip_dhcprange($dhcprange,$subnetDN,$auDN) ){ + $mesg = "DHCP Range erfolgreich geändert"; + }else{ + $mesg = "Fehler beim ändern der DHCP Range"; + # alte Range wiederherstellen + new_ip_dhcprange($olddhcprange,$subnetDN,$auDN); + } + }else{ + $mesg = "DHCP Range nicht in Subnetz ".$cn." enthalten"; + } + }else{ + $mesg = "falsche IP Syntax
"; + } + } + + if ( $newrange1 == "" && $newrange2 == "" ){ + if ( delete_ip_dhcprange($subnetDN,$auDN) ){ + $mesg = "DHCP Range erfolgreich gelöscht"; + }else{ + $mesg = "Fehler beim löschen der DHCP Range"; + } + } + +} + +##################################### +# Restliche Attribute (u.a. Description) + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} + +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$subnetDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$subnetDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$subnetDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_delete.php b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_delete.php new file mode 100644 index 00000000..eb5d66aa --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnet_delete.php @@ -0,0 +1,34 @@ + + + Computers Management + + + + +
"; + +if ( $subnetDN != ""){ + if( delete_dhcpsubnet($subnetDN,$cn)){ + $mesg = "Subnet ".$cn." erfolgreich gelöscht!

"; + }else{ + $mesg = "Fehler beim löschen des Subnets ".$cn." !

"; + } +} + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.dwt b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.dwt new file mode 100644 index 00000000..e887509d --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.dwt @@ -0,0 +1,37 @@ + + + + + + + + + + + +

DHCP Subnets

+
+ + + + + + + + + + + + + + + + + + + +
SubnetNetmaskDHCP DienstRangeHostobjekte
{SUBNETCN}  {NETMASK} {DHCP} {RANGE}  + + {HOSTS}
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.php b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.php new file mode 100644 index 00000000..1104f496 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/dhcpsubnets.php @@ -0,0 +1,65 @@ +assign(array("SUBNETDN" => "", + "SUBNETCN" => "Noch keine Subnets angelegt", + "NETMASK" => "", + "DHCP" => "", + "RANGE" => "", + "HOSTS" => "")); + +# rbservice und pxe daten (voerst nur ein rbs) +$subnet_array = get_dhcpsubnets($auDN,array("dn","cn","dhcpoptnetmask","dhcprange","dhcphlpcont")); + +$template->define_dynamic("Subnets", "Webseite"); +foreach ($subnet_array as $subnet){ + $range = ""; + if ($subnet['dhcprange'] != ""){ + $exp = explode('_',$subnet['dhcprange']); + $range = $exp[0]." - ".$exp[1]; + } + if ($subnet['dhcphlpcont'] != ""){ + $exp = ldap_explode_dn($subnet['dhcphlpcont'],1); + $dhcpservice = $exp[0]."  [".$exp[2]."]"; + }else{ + $dhcpservice = ""; + } + + $template->assign(array("SUBNETDN" => $subnet['dn'], + "SUBNETCN" => $subnet['cn'], + "NETMASK" => $subnet['dhcpoptnetmask'], + "DHCP" => $dhcpservice, + "RANGE" => $range, + "HOSTS" => "")); + $template->parse("SUBNETS_LIST", ".Subnets"); +} + + +################################################################################### + +include("dhcp_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/dhcp/menu.dwt b/ldap-site-mngmt/webinterface/dhcp/menu.dwt new file mode 100644 index 00000000..037bdf15 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/menu.dwt @@ -0,0 +1,29 @@ + + + + + + + + + + + + + + + + + + + {SUB} + + + + + + + + +
{ICON}  + {TEXT_M} 
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.dwt b/ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.dwt new file mode 100644 index 00000000..7d964715 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.dwt @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + +

DHCP Service anlegen

+ + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger DHCP Service Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ DHCP_ +
Beschreibung: + +
+ Wer soll Dienst nutzen dürfen:
(Wählen Sie eine Abteilung,
+ impliziert alle Unterabteilungen) +
+ +

DHCP Optionen des Dienstes (Globaler Scope):

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
OptionWert(e)
Server Identifier: + +
Default Lease Time: + +
Max Lease Time: + +
Use Host DCL Names: + +
DHCP Max Message Size: + +
DDNS Update Style: + +
Domain Name: + +
Domain Name Servers: + +
NTP Servers: + +
Allow: + +
Deny: + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.php b/ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.php new file mode 100644 index 00000000..83aa9cb5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/new_dhcpservice.php @@ -0,0 +1,79 @@ +assign(array("CN" => $dhcpcn, + "PRIMARY" => "", + "SECONDARY" => "", + "DESCRIPTION" => "", + "STATEMENTS" => "", + "ALLOW" => "", + "DENY" => "", + "IGNORE" => "", + "DDNSUPDATE" => "", + "DEFAULTLEASE" => "", + "MAXLEASE" => "", + "USEHOSTDCL" => "", + "DOMAINNAME" => "", + "DOMAINNAMESERVERS" => "", + "MAXMESSIZE" => "", + "SRVIDENT" => "", + "NTPSERVERS" => "", + "OPTGENERIC" => "", + "OFFERSELF" => $auDN, + "SELFOU" => $au_ou, + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + + +# DHCP Service Anbieten (ausser eigene AU) +$expdn = ldap_explode_dn($auDN, 0); # Mit Merkmalen +$expdn = array_slice($expdn, 2); +$expou = ldap_explode_dn($auDN, 1); # nur Werte +$expou = array_slice($expou, 2, -3); +#print_r($expou); echo "
"; +#print_r($expdn); echo "
"; +for ($i=0; $idefine_dynamic("Dhcpoffers", "Webseite"); +if ( count($dhcpoffers) != 0 ){ + foreach ($dhcpoffers as $offer){ + $template->assign(array("DHCPOFFER" => $offer['dn'], + "DHCPOFFEROU" => $offer['ou'],)); + $template->parse("DHCPOFFERS_LIST", ".Dhcpoffers"); + } +} + +################################################################################### + +include("dhcp_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.dwt b/ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.dwt new file mode 100644 index 00000000..8b710fb8 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.dwt @@ -0,0 +1,149 @@ + + + + + + + + + + + + + + + + + + + + + + + + + +

DHCP Subnet anlegen

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
DHCP Subnet (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +
Netmask: + +
DHCP Dienst wählen: + +
Beschreibung: + +
IP Range:
(Zur dynamischen Vergabe)
+ +    -    + +

DHCP Optionen des Subnets (Subnet Scope):

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
OptionWert(e)
Default Lease Time: + +
Max Lease Time: + +
DDNS Update Style: + +
Domain Name: + +
Domain Name Servers: + +
Routers: + +
Broadcast Address: + +
NTP Servers: + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.php b/ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.php new file mode 100644 index 00000000..a7697c14 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/new_dhcpsubnet.php @@ -0,0 +1,84 @@ +assign(array("CN" => $subnetcn, + "NETMASK" => $netmask, + "RANGE1" => "", + "RANGE2" => "", + "DESCRIPTION" => "", + "STATEMENTS" => "", + "ALLOW" => "", + "DENY" => "", + "IGNORE" => "", + "DDNSUPDATE" => "", + "DEFAULTLEASE" => "", + "MAXLEASE" => "", + "USEHOSTDCL" => "", + "BROADCAST" => "", + "ROUTERS" => "", + "DOMAINNAME" => "", + "DOMAINNAMESERVERS" => "", + "NEXTSERVER" => "", + "FILENAME" => "", + "SRVIDENT" => "", + "NTPSERVERS" => "", + "OPTGENERIC" => "", + "DHCPSVNOW" => "", + "DHCPSVNOWAU" => "", + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + + + +# DHCP Services +$dhcpservices = get_dhcpoffers($auDN); +#print_r($dhcpservices); echo "
"; + +$template->assign(array("DHCPSVDN" => "", + "DHCPSVCN" => "", + "DHCPSVAU" => "")); +if (count($dhcpservices) != 0){ +$template->define_dynamic("Dhcpservices", "Webseite"); + foreach ($dhcpservices as $item){ + $exp = ldap_explode_dn($item,1); + + $template->assign(array("DHCPSVDN" => $item, + "DHCPSVCN" => $exp[0], + "DHCPSVAU" => $exp[2])); + $template->parse("DHCPSERVICES_LIST", ".Dhcpservices"); + } +} + + +################################################################################### + +include("dhcp_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/no_dhcp.dwt b/ldap-site-mngmt/webinterface/dhcp/no_dhcp.dwt new file mode 100644 index 00000000..5b8ffe4f --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/no_dhcp.dwt @@ -0,0 +1,25 @@ + + + + + + + + + + + +

Modul - DHCP Management:

+

Dieses Modul dient der Verwaltung des DHCP Dienstes und DHCP Subnetzen.
+
+ Sie verfügen über keine kompletten Netzwerke!
+ x.x.x.0/24
+ x.x.0.0/16
+ x.0.0.0/8
+
+ Sie können daher keine DHCP Dienst- bzw. DHCP Subnetz-Objekte anlegen.
+
+ Jedoch können Sie ihre Rechner in DHCP Diensten (Subnetzen) anderer AUs + anmelden (Modul Rechner Management). + +

\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dhcp/no_dhcp.php b/ldap-site-mngmt/webinterface/dhcp/no_dhcp.php new file mode 100644 index 00000000..57653255 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dhcp/no_dhcp.php @@ -0,0 +1,27 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dns/dns.dwt b/ldap-site-mngmt/webinterface/dns/dns.dwt new file mode 100644 index 00000000..ec6d0cbc --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/dns.dwt @@ -0,0 +1,79 @@ + + + + {SEITENTITEL} + + + + + + + + + + +
+ + + + + +

Rechner und IP Management

+
+ + + + +
+

Startseite +  >>  {AU}  [ {DOMAIN} ]

+
+
+ + + + +
+ {LOGIN} +
+
+ + + + + +
{MAINMENU}
+ +
+ + + + + + + + + + + +
+ + +
+ + {NAVIGATION} + +
+
+ + +
+ + {HAUPTFENSTER} + +
+
+ + + + diff --git a/ldap-site-mngmt/webinterface/dns/dns.php b/ldap-site-mngmt/webinterface/dns/dns.php new file mode 100644 index 00000000..dd9e5756 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/dns.php @@ -0,0 +1,26 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dns/dns_footer.inc.php b/ldap-site-mngmt/webinterface/dns/dns_footer.inc.php new file mode 100644 index 00000000..311721c5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/dns_footer.inc.php @@ -0,0 +1,18 @@ +assign(array("PFAD" => $START_PATH)); + +# Daten in die Vorlage parsen +$template->parse("LOGIN", "Login"); +$template->parse("MAINMENU", "Mmenu"); +$template->parse("NAVIGATION", "Menu"); +$template->parse("HAUPTFENSTER", "Webseite"); +$template->parse("PAGE", "Vorlage"); + +# Fertige Seite an den Browser senden +$template->FastPrint("PAGE"); + +# Abmelden vom LDAP +ldap_unbind($ds); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dns/dns_header.inc.php b/ldap-site-mngmt/webinterface/dns/dns_header.inc.php new file mode 100644 index 00000000..34632b37 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/dns_header.inc.php @@ -0,0 +1,21 @@ + "dns.dwt", + "Login" => "../logout_form.inc.dwt", + "Mmenu" => "../hauptmenue.dwt", + "Menu" => "menu.dwt", + "Webseite" => $webseite); +if (isset($additionalTemplates)) { + foreach ($additionalTemplates as $templateKey => $templateFile) { + $definedTemplates[$templateKey] = $templateFile; + } +} +$template->define($definedTemplates); + +$template->assign(array("SEITENTITEL" => $titel, "ROLLE" => "mainadmin", "AU" => $au_ou, "DOMAIN" => $assocdom, "USERCN" => $usercn)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dns/dns_menu.php b/ldap-site-mngmt/webinterface/dns/dns_menu.php new file mode 100644 index 00000000..1ce8e5b7 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/dns_menu.php @@ -0,0 +1,72 @@ + "dns.php", + "text" => "Übersicht", + "zugriff" => "alle"), + array("link" => "dns.php", + "text" => "SOA Record", + "zugriff" => array("MainAdmin")), + array("link" => "dns.php", + "text" => "INCLUDE Direktiven", + "zugriff" => array("MainAdmin","ZoneAdmin")), + array("link" => "dns.php", + "text" => "Zonen Delgierung", + "zugriff" => array("MainAdmin")), + array("link" => "dns.php", + "text" => "Resource Records", + "zugriff" => array("MainAdmin","HostAdmin","ZoneAdmin"))); + + #$rollen = array_keys($roles); + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $i=0; + foreach($hauptmenu as $item) { + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + if ($i==0) { + if ($mnr==0) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $zwisch=""; + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if ($lastaktive) {$zwisch="";} + else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("ZWISCHEN" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else { + $template->assign(array("ENDE" => "")); + } + +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dns/dns_start.dwt b/ldap-site-mngmt/webinterface/dns/dns_start.dwt new file mode 100644 index 00000000..0595dde7 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/dns_start.dwt @@ -0,0 +1,30 @@ + + + + + + + + + + + +

Modul - DNS Zonen Management:

+

Dieses Modul dient der Verwaltung ...
+ Benutzen Sie die Navigation links, um die einzelnen Verwaltungsbereiche anzusteuern:

+
    +
  • SOA Record

    + Verwalten Sie hier den Start Of Authority (SOA) ihrer DNS Zone ... +
  • +
  • Include Direktiven

    + Verwalten Sie hier die $INCLUDE Direktiven ihrer includeten Zonendateien ... +
  • +
  • Zonen Delegierung

    + Delegieren Sie hier neue DNS Zonen ... +
  • +
  • Resource Records Zone

    + Verwalten Sie hier alle weiteren Namenseintraege ihrer Zone und deren RRs ... +
  • +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/dns/menu.dwt b/ldap-site-mngmt/webinterface/dns/menu.dwt new file mode 100644 index 00000000..a57ab962 --- /dev/null +++ b/ldap-site-mngmt/webinterface/dns/menu.dwt @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + +
  + {TEXT_M} 
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip.dwt b/ldap-site-mngmt/webinterface/ip/ip.dwt new file mode 100644 index 00000000..804c18ef --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip.dwt @@ -0,0 +1,88 @@ + + + + {SEITENTITEL} + + + + + + + + + + +
+ + + + + +

Rechner und IP Management

+
+ + + + +
+

Startseite +  >>  {AU}  [ {DOMAIN} ]

+
+
+ + + + +
+ {LOGIN} +
+
+ + + + + +
{MAINMENU}
+ +
+ + + + + + + + + + + +
+ + + + + + + +
+ + {NAVIGATION} + +
+ + {IPBLOCKS} + +
+
+ + +
+ + {HAUPTFENSTER} + +
+
+ + + + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip.php b/ldap-site-mngmt/webinterface/ip/ip.php new file mode 100644 index 00000000..8a435442 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip.php @@ -0,0 +1,29 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_blocks.inc.php b/ldap-site-mngmt/webinterface/ip/ip_blocks.inc.php new file mode 100644 index 00000000..8530e079 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_blocks.inc.php @@ -0,0 +1,68 @@ +"; +#print_r(count($fipb_array)); echo "
"; +$ipblocks = ""; + +# print_r($mipb_array); +if ($mipb_array[0] != "" ){ + if (count($mipb_array) > 1 ){ + $ipblocks .= " + "; + foreach ($mipb_array as $mipb){ + $exp = explode('_',$mipb); + $ipblocks .= " + + "; + } + } + elseif (count($mipb_array) == 1){ + $ipblocks .= "
+

Zugewiesene IP Bereiche:

$exp[0]  - $exp[1] 
+ "; + $exp = explode('_',$mipb_array[0]); + $ipblocks .= " + + "; + } + elseif( $fipb_array[0] == "" ){ + $ipblocks .= "
+

Zugewiesener IP Bereich:

$exp[0]  - $exp[1] 
+ "; + } + if (count($fipb_array) > 1 ){ + $ipblocks .= "

Keine IP Adressen mehr verfügbar

+ + "; + foreach ($fipb_array as $fipb){ + $exp = explode('_',$fipb); + $ipblocks .= " + + "; + } + } + elseif (count($fipb_array) == 1){ + $ipblocks .= "
+

Davon noch frei verfügbar:

$exp[0]  - $exp[1] 
+ "; + $exp = explode('_',$fipb_array[0]); + $ipblocks .= " + + "; + } + +} + +if( $mipb_array[0] == "" ){ + $ipblocks .= "
+

Davon noch frei verfügbar:

$exp[0]  - $exp[1] 
+ "; +} +$ipblocks .= "

Ihnen wurden keine IP Adressen zugewiesen

"; + +$template->assign(array("IPBLOCKS" => $ipblocks)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_deleg.dwt b/ldap-site-mngmt/webinterface/ip/ip_deleg.dwt new file mode 100644 index 00000000..3eb0ea74 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_deleg.dwt @@ -0,0 +1,40 @@ + + + + + + + + + + + +

Folgende IP Adressen haben Sie an untergeordnete Abteilungen delegiert:

+ + + + + + + + + + + + + + + +
Untergeordnete AbteilungDelegierte IP Bereiche
{CHILDOU}   + + + +   -    +
+ + + + + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_deleg.php b/ldap-site-mngmt/webinterface/ip/ip_deleg.php new file mode 100644 index 00000000..dafdaff6 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_deleg.php @@ -0,0 +1,102 @@ +assign(array("CHILDOU" => "Noch keine untergeordnete AU angelegt", + "RANGE1" => "", + "RANGE2" => "", + "CHILDDN" => "")); + +$childau_array = get_childau($auDN,array("dn","ou","maxipblock")); +# print_r ($childau_array); + +$template->define_dynamic("Delegs", "Webseite"); +$template->define_dynamic("AUs", "Webseite"); + +foreach ($childau_array as $childau){ + + $template->clear_parse("DELEGS_LIST"); + if ( count($childau['maxipblock']) > 1 ){ + foreach ($childau['maxipblock'] as $j){ + $exp = explode('_',$j); + $template->assign(array("CHILDOU" => $childau['ou'], + "RANGE1" => $exp[0], + "RANGE2" => $exp[1], + "CHILDDN" => $childau['dn'], + "AUDN" => $auDN)); + $template->parse("DELEGS_LIST", ".Delegs"); + $template->clear_dynamic("Delegs"); + } + $template->assign(array("CHILDOU" => $childau['ou'], + "RANGE1" => "", + "RANGE2" => "", + "CHILDDN" => $childau['dn'], + "AUDN" => $auDN)); + $template->parse("DELEGS_LIST", ".Delegs"); + $template->clear_dynamic("Delegs"); + $template->assign(array("OU" => $childau['ou'])); + $template->parse("AUS_LIST", ".AUs"); + + }elseif ( count($childau['maxipblock']) == 1 ){ + + $exp = explode('_',$childau['maxipblock']); + $template->assign(array("CHILDOU" => $childau['ou'], + "RANGE1" => $exp[0], + "RANGE2" => $exp[1], + "CHILDDN" => $childau['dn'], + "AUDN" => $auDN)); + $template->parse("DELEGS_LIST", ".Delegs"); + $template->clear_dynamic("Delegs"); + $template->assign(array("CHILDOU" => $childau['ou'], + "RANGE1" => "", + "RANGE2" => "", + "CHILDDN" => $childau['dn'], + "AUDN" => $auDN)); + $template->parse("DELEGS_LIST", ".Delegs"); + $template->clear_dynamic("Delegs"); + $template->assign(array("OU" => $childau['ou'])); + $template->parse("AUS_LIST", ".AUs"); + + }else{ + $template->assign(array("CHILDOU" => $childau['ou'], + "RANGE1" => "", + "RANGE2" => "", + "CHILDDN" => $childau['dn'], + "AUDN" => $auDN)); + $template->parse("DELEGS_LIST", ".Delegs"); + $template->clear_dynamic("Delegs"); + $template->assign(array("OU" => $childau['ou'])); + $template->parse("AUS_LIST", ".AUs"); + } + +} + + +##################################################################################### + +include("ip_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/ip/ip_deleg_change.php b/ldap-site-mngmt/webinterface/ip/ip_deleg_change.php new file mode 100644 index 00000000..d3fddc03 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_deleg_change.php @@ -0,0 +1,198 @@ +"; +print_r($newrange1);echo "

"; +print_r($oldrange2);echo "
"; +print_r($newrange2);echo "
"; +print_r($childauDN);echo "
"; +print_r($auDN);echo "

"; +*/ + +$syntax = new Syntaxcheck; +$url = "ip_deleg.php"; + +echo " + + + IP Address Management + + + + +
"; + + +$diff1 = array_keys(array_diff_assoc($oldrange1,$newrange1)); +$diff2 = array_keys(array_diff_assoc($newrange1,$oldrange1)); +$tochange1 = array_unique(array_merge($diff1,$diff2)); + +$diff3 = array_keys(array_diff_assoc($oldrange2,$newrange2)); +$diff4 = array_keys(array_diff_assoc($newrange2,$oldrange2)); +$tochange2 = array_unique(array_merge($diff3,$diff4)); + +# print_r($tochange1);echo "

"; +# print_r($tochange2);echo "

"; + +$tochange = array_unique(array_merge($tochange1,$tochange2)); +print_r($tochange);echo "

"; + + +foreach ($tochange as $i){ + + if ( $oldrange1[$i] == "" && $oldrange2[$i] == "" && $newrange1[$i] != "" && $newrange2[$i] != "" ){ + echo "neuer IP Bereich delegieren ...";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($childauDN[$i]);echo "
"; + echo "
"; + # echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newrange1[$i]) && $syntax->check_ip_syntax($newrange2[$i])){ + echo "korrekte IP Syntax
"; + $newrange1[$i] = htmlentities($newrange1[$i]); + $newrange2[$i] = htmlentities($newrange2[$i]); + $newrange_array = array($newrange1[$i],$newrange2[$i]); + print_r($newrange_array); + $newrange = implode('_',$newrange_array); + print_r($newrange); + # $oldip[$i] = htmlentities($oldip[$i]); + if (new_ip_delegation($newrange,$childauDN[$i],$auDN[$i])){ + echo "Neuer IP Bereich delegiert eingetragen
"; + }else{echo "Fehler beim delegieren des neuen IP Bereichs
";} + }else{echo "falsche IP Syntax
";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(2, $url, $mesg, $addSessionId = TRUE); + } + + elseif ( $oldrange1[$i] != "" && $oldrange2[$i] != "" && $newrange1[$i] == "" && $newrange2[$i] == "" ){ + echo "loeschen IP Delegierung ...";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($childauDN[$i]);echo "
"; + echo "
"; + echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + $oldrange1[$i] = htmlentities($oldrange1[$i]); + $oldrange2[$i] = htmlentities($oldrange2[$i]); + $oldip_array = array($oldrange1[$i],$oldrange2[$i]); + $oldrange = implode('_',$oldip_array); + if (delete_ip_delegation($oldrange,$childauDN[$i],$auDN[$i])){ + $mesg = "IP Delegierung geloescht
"; + }else{ + $mesg = "Fehler beim loeschen der IP Delegierung
"; + } + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(2, $url, $mesg, $addSessionId = TRUE); + } + + elseif ( $oldrange1[$i] != "" && $oldrange2[$i] != "" && $newrange1[$i] != "" && $newrange2[$i] != "" ){ + $or1 = ip2long($oldrange1[$i]); + $or2 = ip2long($oldrange2[$i]); + $nr1 = ip2long($newrange1[$i]); + $nr2 = ip2long($newrange2[$i]); + + if ( ($nr1 > $or1 || $nr2 < $or2) && !($nr1 < $or1 || $nr2 > $or2) ){ + + echo "reduzieren IP Delegierung";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($childauDN[$i]);echo "
"; + echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newrange1[$i]) && $syntax->check_ip_syntax($newrange2[$i])){ + echo "korrekte IP Syntax
"; + + $newrange1[$i] = htmlentities($newrange1[$i]); + $newrange2[$i] = htmlentities($newrange2[$i]); + $newrange_array = array($newrange1[$i],$newrange2[$i]); + $newrange = implode('_',$newrange_array); + print_r($newrange); + + $oldrange1[$i] = htmlentities($oldrange1[$i]); + $oldrange2[$i] = htmlentities($oldrange2[$i]); + $oldip_array = array($oldrange1[$i],$oldrange2[$i]); + $oldrange = implode('_',$oldip_array); + print_r($oldrange); + + if (reduce_ip_delegation($oldrange,$newrange,$childauDN[$i],$auDN[$i])){ + $mesg = "IP Range verkleinert
"; + }else{ + $mesg = "Fehler beim verkleinern der IP Range
"; + } + }else{echo "falsche IP Syntax
";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(2, $url, $mesg, $addSessionId = TRUE); + + + }elseif( ($nr1 < $or1 || $nr2 > $or2) && !($nr1 > $or1 || $nr2 < $or2) ){ + + echo "vergroessern IP Delegierung";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($childauDN[$i]);echo "
"; + echo "
"; + echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newrange1[$i]) && $syntax->check_ip_syntax($newrange2[$i])){ + echo "korrekte IP Syntax
"; + $newrange1[$i] = htmlentities($newrange1[$i]); + $newrange2[$i] = htmlentities($newrange2[$i]); + $newrange_array = array($newrange1[$i],$newrange2[$i]); + $newrange = implode('_',$newrange_array); + print_r($newrange); + + $oldrange1[$i] = htmlentities($oldrange1[$i]); + $oldrange2[$i] = htmlentities($oldrange2[$i]); + $oldip_array = array($oldrange1[$i],$oldrange2[$i]); + $oldrange = implode('_',$oldip_array); + print_r($oldrange); + + if (expand_ip_delegation($oldrange,$newrange,$childauDN[$i],$auDN[$i])){ + $mesg = "IP Range erweitert
"; + }else{ + $mesg = "Fehler beim erweitern der IP Range
"; + } + }else{ + echo "falsche IP Syntax
"; + } + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(2, $url, $mesg, $addSessionId = TRUE); + } + else{ + $mesg = "
Verschieben (Shiften) der Delegierung nicht moeglich!
+ Nur Vergroessern und Verkleinern moeglich!
"; + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(2, $url, $mesg, $addSessionId = TRUE); + } + } + else{ + $mesg = "keine Aenderung
"; + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(2, $url, $mesg, $addSessionId = TRUE); + } +} + +echo " +
+ +"; +?> diff --git a/ldap-site-mngmt/webinterface/ip/ip_dhcp.dwt b/ldap-site-mngmt/webinterface/ip/ip_dhcp.dwt new file mode 100644 index 00000000..b2739df1 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_dhcp.dwt @@ -0,0 +1,39 @@ + + + + + + + + + + + +

Folgende IP Adressen haben Sie in DHCP Ranges vergeben:

+ + + + + + + + + + + + + + + +
DHCP SubnetDynamisch zuweisbare IP Adressen (range)
{SUBNET}   + +    -    + + + + + + +   +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_dhcp.php b/ldap-site-mngmt/webinterface/ip/ip_dhcp.php new file mode 100644 index 00000000..b89d6506 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_dhcp.php @@ -0,0 +1,54 @@ +assign(array("SUBNET" => "Noch kein DHCP Objekt angelegt", + "RANGE1" => "", + "RANGE2" => "", + "DHCPDN" => "")); + +$subnet_array = get_subnets($auDN,array("dn","cn","dhcprange")); +# print_r ($subnet_array); + +$template->define_dynamic("Subnets", "Webseite"); + +foreach ($subnet_array as $subnet){ + $exp = explode('_',$subnet['dhcprange']); + + $template->assign(array("SUBNET" => $subnet['cn'], + "RANGE1" => $exp[0], + "RANGE2" => $exp[1], + "DHCPDN" => $subnet['dn'], + "AUDN" => $auDN )); + $template->parse("SUBNETS_LIST", ".Subnets"); +} + + +##################################################################################### + +include("ip_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_dhcp_change.php b/ldap-site-mngmt/webinterface/ip/ip_dhcp_change.php new file mode 100644 index 00000000..43474eec --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_dhcp_change.php @@ -0,0 +1,146 @@ +"; +print_r($newrange1);echo "

"; +print_r($oldrange2);echo "
"; +print_r($newrange2);echo "
"; +*/ + +$syntax = new Syntaxcheck; +$url = "ip_dhcp.php"; + +echo " + + + IP Address Management + + + + +
"; + + +$diff1 = array_keys(array_diff_assoc($oldrange1,$newrange1)); +$diff2 = array_keys(array_diff_assoc($newrange1,$oldrange1)); +$tochange1 = array_unique(array_merge($diff1,$diff2)); + +$diff3 = array_keys(array_diff_assoc($oldrange2,$newrange2)); +$diff4 = array_keys(array_diff_assoc($newrange2,$oldrange2)); +$tochange2 = array_unique(array_merge($diff3,$diff4)); + +# print_r($tochange1);echo "

"; +# print_r($tochange2);echo "

"; + +$tochange = array_unique(array_merge($tochange1,$tochange2)); +# print_r($tochange);echo "

"; + + +foreach ($tochange as $i){ + + if ( $oldrange1[$i] == "" && $oldrange2[$i] == "" && $newrange1[$i] != "" && $newrange2[$i] != "" ){ + echo "neue IP Range";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($dhcpDN[$i]);echo "
"; + echo "
"; + echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newrange1[$i]) && $syntax->check_ip_syntax($newrange2[$i])){ + echo "korrekte IP Syntax
"; + $newrange1[$i] = htmlentities($newrange1[$i]); + $newrange2[$i] = htmlentities($newrange2[$i]); + $newrange_array = array($newrange1[$i],$newrange2[$i]); + print_r($newrange_array); + $newrange = implode('_',$newrange_array); + print_r($newrange); + # $oldip[$i] = htmlentities($oldip[$i]); + if (new_ip_dhcprange($newrange,$dhcpDN[$i],$auDN[$i])){ + $mesg = "Neue IP Range eingetragen
"; + }else{ + $mesg = "Fehler beim eintragen der neuen IP Range
"; + } + }else{echo "falsche IP Syntax
";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + + elseif ( $oldrange1[$i] != "" && $oldrange2[$i] != "" && $newrange1[$i] == "" && $newrange2[$i] == "" ){ + echo "loeschen IP Range";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($dhcpDN[$i]);echo "
"; + echo "
"; + echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + $newrange1[$i] = htmlentities($newrange1[$i]); + $newrange2[$i] = htmlentities($newrange2[$i]); + if (delete_ip_dhcprange($dhcpDN[$i],$auDN[$i])){ + $mesg = "IP Range geloescht
"; + }else{ + $mesg = "Fehler beim loeschen der IP Range
"; + } + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + + elseif ( $oldrange1[$i] != "" && $oldrange2[$i] != "" && $newrange1[$i] != "" && $newrange2[$i] != "" ){ + echo "aendern IP Range";echo "
";echo "
"; + print_r($auDN[$i]);echo "
"; + print_r($dhcpDN[$i]);echo "
"; + echo "
"; + echo "alte IP Range: ";print_r($oldrange1[$i]);echo " - ";print_r($oldrange2[$i]);echo "
"; + echo "neue IP Range: ";print_r($newrange1[$i]);echo " - ";print_r($newrange2[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newrange1[$i]) && $syntax->check_ip_syntax($newrange2[$i])){ + echo "korrekte IP Syntax
"; + $newrange1[$i] = htmlentities($newrange1[$i]); + $newrange2[$i] = htmlentities($newrange2[$i]); + $newrange_array = array($newrange1[$i],$newrange2[$i]); + $newrange = implode('_',$newrange_array); + print_r($newrange); + $oldrange1[$i] = htmlentities($oldrange1[$i]); + $oldrange2[$i] = htmlentities($oldrange2[$i]); + $oldrange_array = array($oldrange1[$i],$oldrange2[$i]); + $oldrange = implode('_',$oldrange_array); + if (modify_ip_dhcprange($newrange,$dhcpDN[$i],$auDN[$i])){ + $mesg = "IP Range geaendert
"; + }else{ + $mesg = "Fehler beim aendern der IP Range
"; + # alte Range wiederherstellen + new_ip_dhcprange($oldrange,$dhcpDN[$i],$auDN[$i]); + } + }else{echo "falsche IP Syntax
";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + + else{ + $mesg = "keine Aenderung
"; + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + +} + +echo " +
+ +"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_footer.inc.php b/ldap-site-mngmt/webinterface/ip/ip_footer.inc.php new file mode 100644 index 00000000..7849823e --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_footer.inc.php @@ -0,0 +1,19 @@ +assign(array("PFAD" => $START_PATH)); + +# Daten in die Vorlage parsen +$template->parse("LOGIN", "Login"); +$template->parse("MAINMENU", "Mmenu"); +$template->parse("NAVIGATION", "Menu"); +$template->parse("IPBLOCKS", "IPBlocks"); +$template->parse("HAUPTFENSTER", "Webseite"); +$template->parse("PAGE", "Vorlage"); + +# Fertige Seite an den Browser senden +$template->FastPrint("PAGE"); + +# Abmelden vom LDAP +ldap_unbind($ds); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_header.inc.php b/ldap-site-mngmt/webinterface/ip/ip_header.inc.php new file mode 100644 index 00000000..96029f43 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_header.inc.php @@ -0,0 +1,22 @@ + "ip.dwt", + "Login" => "../logout_form.inc.dwt", + "Mmenu" => "../hauptmenue.dwt", + "Menu" => "menu.dwt", + "IPBlocks" => "ipblocks.dwt", + "Webseite" => $webseite); +if (isset($additionalTemplates)) { + foreach ($additionalTemplates as $templateKey => $templateFile) { + $definedTemplates[$templateKey] = $templateFile; + } +} +$template->define($definedTemplates); + +$template->assign(array("SEITENTITEL" => $titel, "ROLLE" => "mainadmin", "AU" => $au_ou, "DOMAIN" => $assocdom, "USERCN" => $usercn)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_menu.php b/ldap-site-mngmt/webinterface/ip/ip_menu.php new file mode 100644 index 00000000..528a4066 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_menu.php @@ -0,0 +1,69 @@ + "ip.php", + "text" => "Übersicht", + "zugriff" => "alle"), + array("link" => "ip_rechner.php", + "text" => "IP Adressen Rechner", + "zugriff" => array("MainAdmin","HostAdmin")), + array("link" => "ip_dhcp.php", + "text" => "IP Adressen DHCP", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")), + array("link" => "ip_deleg.php", + "text" => "Delegierte IP Bereiche", + "zugriff" => array("MainAdmin"))); + + # $rollen = array_keys($roles); + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $i=0; + foreach($hauptmenu as $item) { + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + if ($i==0) { + if ($mnr==0) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $zwisch=""; + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if ($lastaktive) {$zwisch="";} + else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("ZWISCHEN" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else { + $template->assign(array("ENDE" => "")); + } + +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_rechner.dwt b/ldap-site-mngmt/webinterface/ip/ip_rechner.dwt new file mode 100644 index 00000000..ecadf98a --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_rechner.dwt @@ -0,0 +1,39 @@ + + + + + + + + + + + + +

Folgende IP Adressen haben Sie an Rechner vergeben:

+ + + + + + + + + + + + + + + + + +
Rechner NameIP Adresse
{HOSTNAME}   +   {DHCPCONT} + + + +   +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ip_rechner.php b/ldap-site-mngmt/webinterface/ip/ip_rechner.php new file mode 100644 index 00000000..66ea23ee --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_rechner.php @@ -0,0 +1,65 @@ +assign(array("IP" => "", + "OLDIP" => "", + "DHCPCONT" => "", + "HOSTNAME" => "Noch keine Rechner angelegt", + "HOSTDN" => "")); + +$host_array = get_hosts($auDN,array("dn","hostname","ipaddress","dhcphlpcont")); +# print_r ($host_array); + +$template->define_dynamic("Hosts", "Webseite"); + +foreach ($host_array as $host){ + $hostip = explode('_',$host['ipaddress']); + + if ( count($host['dhcphlpcont']) != 0 && $host['ipaddress'] == "" ){ + $subnetCN = explode('cn=',$host['dhcphlpcont']); + $dynsubnet = explode(',', $subnetCN[1]); + $dhcpcont = " DYNAMISCH   (DHCP, Subnet $dynsubnet[0])"; + }elseif( count($host['dhcphlpcont']) != 0 && $host['ipaddress'] != "" ){ + $subnetCN = explode('cn=',$host['dhcphlpcont']); + $dynsubnet = explode(',', $subnetCN[1]); + $dhcpcont = " STATISCH   (DHCP, Subnet $dynsubnet[0])"; + }else{$dhcpcont = "";} + + $template->assign(array("IP" => $hostip[0], + "OLDIP" => $hostip[0], + "DHCPCONT" => $dhcpcont, + "HOSTNAME" => $host['hostname'], + "HOSTDN" => $host['dn'], + "AUDN" => $auDN )); + $template->parse("HOSTS_LIST", ".Hosts"); +} + + +##################################################################################### + +include("ip_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/ip/ip_rechner_change.php b/ldap-site-mngmt/webinterface/ip/ip_rechner_change.php new file mode 100644 index 00000000..68023cb0 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_rechner_change.php @@ -0,0 +1,125 @@ +"; +# print_r($oldip);echo "
"; + +$syntax = new Syntaxcheck; +$url = "ip_rechner.php"; + +echo " + + + IP Address Management + + + + +
"; + + +$diff1 = array_keys(array_diff_assoc($oldip,$newip)); +$diff2 = array_keys(array_diff_assoc($newip,$oldip)); +$tochange = array_unique(array_merge($diff1,$diff2)); +# print_r($diff1);echo "
"; +# print_r($diff2);echo "
"; +# print_r($tochange);echo "

"; + +foreach ($tochange as $i){ + + if ( $oldip[$i] == "" && $newip[$i] != "" ){ + echo "neue IP";echo "
";echo "
"; + #print_r($auDN[$i]);echo "
"; + #print_r($hostDN[$i]);echo "
"; + echo "
"; + echo "alte IP: ";print_r($oldip[$i]);echo "
"; + echo "neue IP: ";print_r($newip[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newip[$i])){ + echo "korrekte IP Syntax"; + $newip[$i] = htmlentities($newip[$i]); + $newip_array = array($newip[$i],$newip[$i]); + #print_r($newip_array); + $newipp = implode('_',$newip_array); + #print_r($newipp); + $oldip[$i] = htmlentities($oldip[$i]); + if (new_ip_host($newipp,$hostDN[$i],$auDN[$i])){ + $mesg = "Neue IP Adresse eingetragen
"; + }else{$mesg = "Fehler beim eintragen der neuen IP Adresse
";} + }else{echo "falsche IP Syntax";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + + elseif ( $oldip[$i] != "" && $newip[$i] != "" ){ + echo "aendern IP";echo "
";echo "
"; + #print_r($auDN[$i]);echo "
"; + #print_r($hostDN[$i]);echo "
"; + echo "
"; + echo "alte IP: ";print_r($oldip[$i]);echo "
"; + echo "neue IP: ";print_r($newip[$i]);echo "
"; + + if ($syntax->check_ip_syntax($newip[$i])){ + echo "korrekte IP Syntax"; + $newip[$i] = htmlentities($newip[$i]); + $newip_array = array($newip[$i],$newip[$i]); + #print_r($newip_array); + $newipp = implode('_',$newip_array); + #print_r($newipp); + $oldip[$i] = htmlentities($oldip[$i]); + $oldip_array = array($oldip[$i],$oldip[$i]); + $oldipp = implode('_',$oldip_array); + if (modify_ip_host($newipp,$hostDN[$i],$auDN[$i])){ + $mesg = "IP Adresse geaendert
"; + }else{ + $mesg = "Fehler beim aendern der IP Adresse
"; + # oldip die schon gelöscht wurde wieder einfügen + new_ip_host($oldipp,$hostDN[$i],$auDN[$i]);} + }else{echo "falsche IP Syntax";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + + elseif ( $oldip[$i] != "" && $newip[$i] == "" ){ + echo "loeschen IP";echo "
";echo "
"; + #print_r($auDN[$i]);echo "
"; + #print_r($hostDN[$i]);echo "
"; + echo "
"; + echo "alte IP: ";print_r($oldip[$i]);echo "
"; + echo "neue IP: ";print_r($newip[$i]);echo "
"; + + echo "korrekte IP Syntax"; + $newip[$i] = htmlentities($newip[$i]); + $oldip[$i] = htmlentities($oldip[$i]); + if (delete_ip_host($hostDN[$i],$auDN[$i])){ + $mesg = "IP Adresse geloescht
"; + }else{$mesg = "Fehler beim loeschen der IP Adresse
";} + + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(4, $url, $mesg, $addSessionId = TRUE); + } + + else{ + $mesg = "keine Aenderung
"; + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(3, $url, $mesg, $addSessionId = TRUE); + } + +} + +echo " +
+ +"; +?> diff --git a/ldap-site-mngmt/webinterface/ip/ip_start.dwt b/ldap-site-mngmt/webinterface/ip/ip_start.dwt new file mode 100644 index 00000000..b5e4931f --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ip_start.dwt @@ -0,0 +1,36 @@ + + + + + + + + + + + +

Modul - IP Adress Management:

+

Dieses Modul dient der Verwaltung von IP Adressen in ihrer Abteilung. + Benutzen Sie die Navigation links, um die einzelnen Bereiche anzusteuern.
+ Unterhalb des Navigations-Menue haben Sie stets einen Ueberblick ueber die Ihnen + zugewiesenen IP Bereiche sowie ueber die davon noch frei verfuegbaren IP Adressen.

+

Folgende Bereiche stehen Ihnen zur Verfuegung:

+ +
    +
  • IP Adressen Rechner

    + Hier koennen Sie die IP Adressen ihrer Rechner verwalten. Sie koennen IP Adressen neu zuweisen, + aendern oder loeschen. +
  • +
  • IP Adressen DHCP

    + In diesem Bereich koennen Sie die IP Adressen verwalten, die Sie fuer den DHCP Dienst reservieren. + D.h. die IP Adress Ranges, welche Sie DHCP Subnetzen oder Pools zugewiesen haben zur dynamischen + IP Adresszuweisung. +
  • +
  • Delegierte IP Adressen

    + In diesem Bereich verwalten Sie ihre an untergeordnete Abteilungen delegierten + IP Adressbereiche. Sie koennen neue IP Bereiche delegieren, Delegierungen aendern oder + ganz zureucknehmen (loeschen). +
  • +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/ipblocks.dwt b/ldap-site-mngmt/webinterface/ip/ipblocks.dwt new file mode 100644 index 00000000..b77f53b3 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/ipblocks.dwt @@ -0,0 +1,11 @@ + + + + + + + + + + +
{IPBLOCKS}
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/ip/menu.dwt b/ldap-site-mngmt/webinterface/ip/menu.dwt new file mode 100644 index 00000000..34b227c1 --- /dev/null +++ b/ldap-site-mngmt/webinterface/ip/menu.dwt @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + +
  + {TEXT_M} 
diff --git a/ldap-site-mngmt/webinterface/lib/au_management_functions.php b/ldap-site-mngmt/webinterface/lib/au_management_functions.php new file mode 100644 index 00000000..e6f46cfc --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/au_management_functions.php @@ -0,0 +1,1186 @@ +
"; + $resultC = ldap_add($ds,"cn=".$cont.",".$childDN,$entryCont); + if (!($resultC)) break; + } + + # MainAdmin anlegen + $entryMA ['objectclass'] = "groupOfNames"; + $entryMA ['cn'] = "MainAdmin"; + $entryMA ['member'] = $mainadmin; + if ($resultMA = ldap_add($ds,"cn=MainAdmin,cn=roles,".$childDN,$entryMA)){ + $admins = array("HostAdmin","DhcpAdmin","ZoneAdmin"); + foreach ($admins as $admin){ + $entryAdmin ['objectclass'] = "Admins"; + $entryAdmin ['cn'] = $admin; + ldap_add($ds,"cn=".$admin.",cn=roles,".$childDN,$entryAdmin); + } + return 1; + } + else{ + return 0; + } + } + else{ + return 0; + } +} + + + +# Löschen untergeordnete AU (d.h. deren untergeordnete AUs werden als neue uAUs integriert) +function delete_childau($childDN,$childou,$delmodus){ + + global $ds, $suffix, $auDN, $domDN, $assocdom, $ldapError; + + if ( $delmodus == "integrate"){ + + # Associated DNS Domain integrieren + $childdc = get_domain_data($childDN,array("dn","associatedname")); + print_r($childdc); echo "
"; + # wenn einzige AU dann einfach in Parentdomain aufnehmen und betroffene Einträge löschen + if (count($childdc[0]['associatedname']) == 1 ){ + echo "einzige AU
"; + # dc Childs verschieben + $dcchilds = get_dc_childs($childdc[0]['dn'],array("dn","dc")); + # print_r($dcchilds); echo "
"; + if (count($dcchilds) != 0){ + foreach ($dcchilds as $dcc){ + # print_r($dcc['dn']); echo " >> "; print_r("dc=".$dcc['dc'].",".$domDN); echo "
"; + if(move_subtree($dcc['dn'],"dc=".$dcc['dc'].",".$domDN)){ + $newdom = $dcc['dc'].".".$assocdom; + #print_r($newdom); echo "

"; + dive_into_dctree_adapt("dc=".$dcc['dc'].",".$domDN,$newdom); + } + } + } + + # alten dc-Knoten löschen + dive_into_tree_del($childdc[0]['dn'],""); + + } + # wenn noch andere AUs in der Domain, dann nur betroffene Einträge entfernen + if (count($childdc[0]['associatedname']) > 1 ){ + echo "mehrere AUs
"; + # ChildAU-Rollen unterhalb dc-Knoten löschen (nur diese)(oder übernehmen: MA zu HA, HA zu HA) + $roles = get_roles($childDN); + #print_r($roles); echo "
"; + if(count($roles['MainAdmin']) != 0){ + $mainadmins = $roles['MainAdmin']; + for ($i=0; $i"; + $resultMA = ldap_mod_del($ds,"cn=MainAdmin,cn=roles,".$childdc[0]['dn'],$entryRoleMain); + } + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + for ($i=0; $i"; + $resultHA = ldap_mod_del($ds,"cn=HostAdmin,cn=roles,".$childdc[0]['dn'],$entryRoleHost); + } + if(count($roles['ZoneAdmin']) != 0){ + $zoneadmins = $roles['ZoneAdmin']; + for ($i=0; $i"; + ldap_mod_del($ds, $childdc[0]['dn'], $entrydel); + $zentries = get_zone_entries_assocname($childdc[0]['dn'],array("dn"),$childDN); + # print_r($zentries); echo "
"; + foreach ($zentries as $ze){ + # print_r($ze['dn']); echo "
"; + ldap_delete($ds, $ze['dn']); + } + } + + # Rechner (mit IP) + dranhängende MCs, PXEs verschieben + $hosts = get_hosts($childDN,array("dn","hostname")); + if (count($hosts) != 0){ + foreach ($hosts as $host){ + # print_r($host['dn']); echo "
"; + # print_r($host['hostname']); echo "
"; + # print_r("hostname=".$host['hostname']."-int-".$childou.",cn=computers,".$auDN); echo "

"; + if (move_subtree($host['dn'], "hostname=".$host['hostname']."-ex-".$childou.",cn=computers,".$auDN)){ + $newhostDN = "hostname=".$host['hostname']."-ex-".$childou.",cn=computers,".$auDN; + $dhcp = get_node_data($newhostDN, array("dhcphlpcont")); + # print_r($dhcp); echo "
"; + if ($dhcp['dhcphlpcont'] != ""){ + $entrydel ['dhcphlpcont'] = array(); + $entrydel ['objectclass'] = "dhcpHost"; + # print_r($dhcphlpcont); + ldap_mod_del($ds, $newhostDN, $entrydel); + } + } + } + } + # DHCP Objekte IP Ranges löschen + $subnets = get_subnets($childDN,array("dn")); + # print_r($subnets); echo "
"; + if (count($subnets) != 0){ + foreach ($subnets as $subnet){ + # print_r($subnet['dn']); echo "
"; + delete_ip_dhcprange($subnet['dn'],$childDN); + } + } # DHCP Pools auch noch + + # Freie IP Bereiche zurücknehmen + $fipb_array = get_freeipblocks_au($childDN); + # print_r($fipb_array); echo "
"; + # print_r(count($fipb_array)); echo "
"; + if (count($fipb_array) == 1 && $fipb_array[0] != ""){ + $entry_ipblock ['freeipblock'] = $fipb_array[0]; + # print_r($entry_ipblock); echo "
"; + ldap_mod_add($ds,$auDN,$entry_ipblock); + } + if (count($fipb_array) > 1 ){ + foreach ($fipb_array as $fipb){ + $entry_ipblock ['FreeIPBlock'][] = $fipb; + # print_r($entry_ipblock); echo "
"; + ldap_mod_add($ds,$auDN,$entry_ipblock); + } + } + merge_ipranges($auDN); + + + # Verschieben der Childs an neue Stelle + $child_childs = get_childau($childDN,array("dn","ou")); + # print_r($child_childs); echo "
"; + if (count($child_childs) != 0){ + foreach ($child_childs as $cc){ + $child_childDN = $cc['dn']; + $newccDN = "ou=".$cc['ou'].",".$auDN; + # print_r($child_childDN); echo " >> "; + # print_r($newccDN); echo "
"; + if (move_subtree($child_childDN,$newccDN)){ + adjust_dn_entries($child_childDN,$newccDN); + } + } + } + + # Löschen des AU Knotens + dive_into_tree_del($childDN,""); + + $mesg = "
Erfolgreich gelöscht mit Integration
"; + return $mesg; + } + + if ( $delmodus == "complete" ){ + # IP Bereiche zurück + # DNS Teilbaum Objekte löschen + # alles rekursive löschen + + /*if (dive_into_tree_del($dcDN,"")){ + $delentry ['objectclass'] = "domainrelatedobject"; + $delentry ['associateddomain'] = $domsuffix; + #print_r($delentry); echo "
"; + $delresult = ldap_mod_del($ds,$childDN,$delentry); + if ($delresult){ + $mesg = "Domain komplett gelöscht
"; + }else{$mesg = "Fehler! ldap_mod_del
";} + }else{$mesg = "Fehler! dive_into_tree_del
";} + */ + $mesg = "Komplettes löschen mometan noch nicht unterstützt.
+ Nur eine Ebene mit Integration ...
"; + return $mesg; + } +} + + + + +############################################################################### +# Funktionen zur Verwaltung von Domains +# + + +# Anlegen Domain beim Anlegen einer Child-AU +function new_child_domain($childdomain, $childDN, $assocdom, $domDN){ + + global $ds, $suffix, $domprefix, $domsuffix, $ldapError; + $domsuffix_actual = $domsuffix; + + # ChildAU in gleicher Domain wie AU + if ( $childdomain == "" || $childdomain == $domprefix ){ + + $entryDC ["associatedname"] = $childDN; + $resultDC = ldap_mod_add($ds,$domDN,$entryDC); + if ($resultDC){ + # HostAdmins übernehmen, welche Admins noch? MainAdmin? + $roles = get_roles($childDN); + if(count($roles['MainAdmin']) != 0){ + $mainadmins = $roles['MainAdmin']; + for ($i=0; $i"; + $resultMA = ldap_mod_add($ds,"cn=MainAdmin,cn=roles,".$domDN,$entryRoleMain); + } + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + for ($i=0; $i"; + $resultHA = ldap_mod_add($ds,"cn=HostAdmin,cn=roles,".$domDN,$entryRoleHost); + } + # Domainname zu associatedDomain der ChildAU + $entryAD['objectclass'] = "domainRelatedObject"; + $entryAD['associateddomain'] = $assocdom; + $resultAD = ldap_mod_add($ds,$childDN,$entryAD); + if($resultAD){return 1;}else{return 0;} + } + else{return 0;} + } + + # ChildAU in eigner Domain (inklusive Subdomain von AU Domain) + if ( $childdomain != "" && $childdomain != $domprefix ){ + + # entsprechenden DC Knoten anlegen, sowie Roles (MainAdmin, HostAdmin) + $dc_array = explode('.',$childdomain); + $dc_array = array_reverse($dc_array); + $dcDN = "ou=DNS,".$suffix; + # $childdomainfull = $childdomain.".".$domsuffix; + #print_r($dc_array); + foreach ($dc_array as $dc){ + $resultsum = false; + if (check_for_dc($dcDN,$dc)){ + echo "dc ".$dc." schon vorhanden ... nächster dc
"; + $domsuffix_actual = $dc.".".$domsuffix_actual; + $dcDN = "dc=".$dc.",".$dcDN; + } + else{ + $dcDN = "dc=".$dc.",".$dcDN; + + $entryDC ["objectclass"][0] = "dnsdomain"; + $entryDC ["objectclass"][1] = "domainrelatedobject"; + $entryDC ["objectclass"][2] = "top"; + $entryDC ["dc"] = $dc; + $entryDC ["associatedname"] = $childDN; + $entryDC ["associateddomain"] = $dc.".".$domsuffix_actual; + #print_r($entryDC); echo "
"; + #print_r($dcDN); echo "

"; + $resultDC = ldap_add($ds,$dcDN,$entryDC); + if ($resultDC){ + $domsuffix_actual = $dc.".".$domsuffix_actual; + + #print_r($dcDN); echo"

"; + + $entryRolesCont ['objectclass'] = "AUContainer"; + $entryRolesCont ['cn'] = "roles"; + #print_r($entryRolesCont); echo "

"; + $resultRC = ldap_add($ds,"cn=roles,".$dcDN,$entryRolesCont); + if ($resultRC){ + # Rollen eintragen + $roles = get_roles($childDN); + #print_r($roles); echo "

"; + $mainadmins = $roles['MainAdmin']; + $entryRoleMain ['objectclass'] = "groupOfNames"; + $entryRoleMain ['cn'] = "MainAdmin"; + for ($i=0; $i"; + $resultMA = ldap_add($ds,"cn=MainAdmin,cn=roles,".$dcDN,$entryRoleMain); + + $entryRoleHost ['objectclass'] = "Admins"; + $entryRoleHost ['cn'] = "HostAdmin"; + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + for ($i=0; $i"; + } + $resultHA = ldap_add($ds,"cn=HostAdmin,cn=roles,".$dcDN,$entryRoleHost); + + $entryRoleZone ['objectclass'] = "Admins"; + $entryRoleZone ['cn'] = "ZoneAdmin"; + $resultZA = ldap_add($ds,"cn=ZoneAdmin,cn=roles,".$dcDN,$entryRoleZone); + + if ($resultMA){$resultsum = true;} + } + } + break; # damit dc-Zuwachs immer nur um eine neue Ebene moeglich + } + } + # Domainname zu associatedDomain der ChildAU + if ($resultsum == true){ + $entryAD['objectclass'] = "domainRelatedObject"; + $entryAD['associateddomain'] = $domsuffix_actual; + $resultAD = ldap_mod_add($ds,$childDN,$entryAD); + } + # fixme: fehlt noch anlegen der INCLUDE-Direktive in der parentdomain + if($resultAD){return 1;} + else{return 0;} + } +} + + +# Domain einer Child-AU ändern +function change_child_domain($childdomain, $oldchilddomain, $childDN, $assocdom, $domDN, $domprefix){ + + global $ds, $suffix, $domsuffix, $ldapError; + #print_r($oldchilddomain); echo "
"; + #print_r($domprefix); echo "
"; + # dcDNnew + $dcDN = "ou=DNS,".$suffix; + $dc_array = explode('.',$childdomain); + $dc_array = array_reverse($dc_array); + $dcDNnew = ""; + foreach ($dc_array as $dc){ + if (check_for_dc($dcDN,$dc)){ + $dcDN = "dc=".$dc.",".$dcDN; + } + else{ + $dcDN = "dc=".$dc.",".$dcDN; + $dcDNnew .= $dcDN; + break; + } + } + # dcDNold + $dcDNold = "ou=DNS,".$suffix; + $dcold_array = explode('.',$oldchilddomain); + $dcold_array = array_reverse($dcold_array); + foreach ($dcold_array as $dc){ + $dcDNold = "dc=".$dc.",".$dcDNold; + } + + #print_r($dcDNnew); echo "
"; + #print_r($dcDNold); echo "
"; + # Aus eigener AU Domain heraus in neue nicht AU Domain, d.h. dcDNold = domDN + # Subdomain oder neue Domain anlegen + if ($oldchilddomain == $domprefix){ + + # associatedDomain aus ChildAU entfernen + $entryAD['objectclass'] = "domainRelatedObject"; + $entryAD['associateddomain'] = $assocdom; + #print_r($entryAD); echo "
"; + if ($resultAD = ldap_mod_del($ds,$childDN,$entryAD)){ + + # neuen dc Knoten anlegen mit Rollen ... + if(new_child_domain($childdomain, $childDN, $assocdom, $domDN)){ + + # associatedName ChildDN aus altem dc-Knoten entfernen + $entryAN ['associatedname'] = $childDN; + #print_r($entryAN); echo "
"; + $result = ldap_mod_del($ds,$domDN,$entryAN); + + # Eigene Rollen aus dc-Knoten enrfernen + $roles = get_roles($childDN); + if(count($roles['MainAdmin']) != 0){ + $mainadmins = $roles['MainAdmin']; + if (count($mainadmins) > 1){ + for ($i=0; $i"; + $resultMA = ldap_mod_del($ds,"cn=MainAdmin,cn=roles,".$dcDNold,$entryRoleMain); + } + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + if (count($hostadmins) > 1){ + for ($i=0; $i"; + $resultHA = ldap_mod_del($ds,"cn=HostAdmin,cn=roles,".$dcDNold,$entryRoleHost); + } + if(count($roles['ZoneAdmin']) != 0){ + $zoneadmins = $roles['ZoneAdmin']; + if (count($zoneadmins) > 1){ + for ($i=0; $i"; + $resultZA = ldap_mod_del($ds,"cn=ZoneAdmin,cn=roles,".$dcDNold,$entryRoleZone); + } + + + # DNS Einträge mit associatedName ChildDN verschieben + $zone_entries = get_zone_entries_assocname($domDN,array("dn","relativedomainname"),$childDN); + #echo "
"; print_r($zone_entries); echo "
"; + if (count($zone_entries) >= 1){ + foreach ($zone_entries as $ze){ + #print_r($ze['relativedomainname']); echo "
"; + #print_r($dcDNnew); echo "
"; + move_subtree($ze['dn'], "relativedomainname=".$ze['relativedomainname'].",".$dcDNnew); + $domsuffix = "uni-freiburg.de"; # neu setzen da es beim new_child_domain schon mal hochgezählt wurde + $newassocdom = $childdomain.".".$domsuffix; + $entryZE ['zonename'] = $newassocdom; + #print_r($entryZE); echo "
"; + $resultZE = ldap_mod_replace($ds,"relativedomainname=".$ze['relativedomainname'].",".$dcDNnew,$entryZE); + } + } + # fixme: fehlt noch anpassen der INCLUDE-Direktive in der parentdomain + return 1; + } + else{ + return 0; + } + } + else{ + return 0; + } + } + # Aus nicht AU Domain (aber eventuell Subdomain) in nicht AU Domain + # Verschieben des dc-Teilbaumes + if ($oldchilddomain != $domprefix){ + # Verschiebe dc-Baum von dcDNold nach dcDNnew + # dcDNnew + $dcDN = "ou=DNS,".$suffix; + $dc_array = explode('.',$childdomain); + $dc_array = array_reverse($dc_array); + $dcDNnew = ""; + foreach ($dc_array as $dc){ + if (check_for_dc($dcDN,$dc)){ + $dcDN = "dc=".$dc.",".$dcDN; + } + else{ + $dcDN = "dc=".$dc.",".$dcDN; + $dcDNnew .= $dcDN; + break; + } + } + + # dcDNold + $dcDNold = "ou=DNS,".$suffix; + $dcold_array = explode('.',$oldchilddomain); + $dcold_array = array_reverse($dcold_array); + foreach ($dcold_array as $dc){ + $dcDNold = "dc=".$dc.",".$dcDNold; + } + + # dc Baum verschieben + if ($dcDNnew != ""){ + if (move_subtree($dcDNold, $dcDNnew)){ + # rekursives anpassen im neue dc-Baum: + # associatedDomain, zoneName, includeFilename, includeOrigin + $newassocdom = $childdomain.".".$domsuffix; + if(dive_into_dctree_adapt($dcDNnew,$newassocdom)){ + return 1; + # fixme: fehlt noch anpassen der INCLUDE-Direktive in der parentdomain + } + else{ + return 0; + } + } + else{ + return 0; + } + }else{ + echo "Domain existiert schon, bitte anderen Domainnamen wählen!"; + return 0; + } + } +} + +function dive_into_dctree_adapt($dcDNnew,$newassocdom){ + + global $ds, $suffix, $domprefix, $domsuffix, $ldapError; + print_r($dcDNnew); echo "
"; + print_r($newassocdom); echo "

"; + + # associatedDomain in dc-Knoten und in allen (mehrere) associatedName-ou-Knoten + $entryAD['associateddomain'] = $newassocdom; + print_r($entryAD); echo "
"; + $resultAD = ldap_mod_replace($ds,$dcDNnew,$entryAD); + #$top_dcDN = str_replace("ou=DNS,","",$dcDNnew); + #print_r($top_dcDN); echo "
"; + $assocnames = get_dc_data($dcDNnew,array("associatedname")); # funkt nicht bei uni-freiburg.de + echo "
"; print_r($assocnames); echo "
"; + if (count($assocnames['associatedname']) > 1){ + foreach ($assocnames['associatedname'] as $aname){ + print_r($aname); echo "
"; + $resultAU = ldap_mod_replace($ds,$aname,$entryAD); + } + }else{ + $aname = $assocnames['associatedname']; + print_r($aname); echo "
"; + $resultAU = ldap_mod_replace($ds,$aname,$entryAD); + } + + # ZoneName in allen Knoten eine Ebene tiefer + $zone_entries = get_zone_entries($dcDNnew,array("dn","zonename")); + echo "
"; print_r($zone_entries); echo "
"; + foreach ($zone_entries as $ze){ + $entryZE ['zonename'] = $newassocdom; + print_r($entryZE); echo "
"; + $resultZE = ldap_mod_replace($ds,$ze['dn'],$entryZE); + } + + # Zonenamen in Reversezones ... Fehlt noch + + # Rekursion + # child dc für Rekursion + $dcchilds = get_dc_childs($dcDNnew,array("dn","dc")); + echo "
"; print_r($dcchilds); echo "
"; + foreach ($dcchilds as $dcc){ + $newassocdom = $dcc['dc'].".".$newassocdom; + print_r($dcc['dn']); echo " >> "; print_r($newassocdom); echo "
"; + dive_into_dctree_adapt($dcc['dn'],$newassocdom); + } + +} + + +function delete_child_domain($oldchilddomain,$assocdom,$childDN, $domDN, $delmodus){ + + global $ds, $suffix, $domprefix, $domsuffix, $ldapError; + #print_r($domDN); echo "
"; + + # dcDNold + $dcDNold = "ou=DNS,".$suffix; + $dcold_array = explode('.',$oldchilddomain); + $dcold_array = array_reverse($dcold_array); + foreach ($dcold_array as $dc){ + $dcDNold = "dc=".$dc.",".$dcDNold; + } + #print_r($dcDNold); echo "
"; + # dcDNnew = domDN + + if ( $delmodus == "integrate" ){ + + # associatedNames zu neuem dc-Knoten hinzufügen + $assocnames = get_dc_data($dcDNold,array("associatedname")); # funkt nicht bei uni-freiburg.de + # echo "
"; print_r($assocnames); echo "
"; + if (count($assocnames['associatedname']) > 1){ + foreach ($assocnames['associatedname'] as $aname){ + #print_r($aname); echo "
"; + $entryAN['associatedname'][] = $aname; + } + }else{ + $entryAN['associatedname'] = $assocnames['associatedname']; + $assocname = $assocnames['associatedname']; + $assocnames ['associatedname'] = array($assocname); + } + #print_r($entryAN); echo "
"; + $resultAN = ldap_mod_add($ds,$domDN,$entryAN); + if($resultAN){ + + # DNS Einträge verschieben und an neue Domain anpassen + $zone_entries = get_zone_entries($dcDNold,array("dn","relativedomainname")); + #echo "
"; print_r($zone_entries); echo "
"; + if (count($zone_entries) >= 1){ + foreach ($zone_entries as $ze){ + #print_r($ze['relativedomainname']); echo "
"; + #print_r($domDN); echo "
"; + move_subtree($ze['dn'], "relativedomainname=".$ze['relativedomainname'].",".$domDN); + $entryZE ['zonename'] = $assocdom; + print_r($entryZE); echo "
"; + $resultZE = ldap_mod_replace($ds,"relativedomainname=".$ze['relativedomainname'].",".$domDN,$entryZE); + } + } + + # Rollenmembers kopieren für jeden associatedName (ohne Duplikate zu generieren) + $newdom_roles = get_roles_dns($domDN); + #print_r($newdom_roles); echo "
"; + if (count($newdom_roles['MainAdmin']) != 0){$newmainadmins = $newdom_roles['MainAdmin'];}else{$newmainadmins = array();} + if (count($newdom_roles['HostAdmin']) != 0){$newhostadmins = $newdom_roles['HostAdmin'];}else{$newhostadmins = array();} + if (count($newdom_roles['ZoneAdmin']) != 0){$newzoneadmins = $newdom_roles['ZoneAdmin'];}else{$newzoneadmins = array();} + #print_r($newmainadmins); echo "
"; + #print_r($newhostadmins); echo "
"; + #print_r($newzoneadmins); echo "

"; + foreach ($assocnames['associatedname'] as $aname){ + #echo "_________________________________________
"; + #print_r($aname); echo "
"; + $roles = get_roles($aname); + #print_r($roles); echo "
"; + $mainadmins = $roles['MainAdmin']; + #print_r($mainadmins); echo "
"; + #print_r($newmainadmins); echo "
"; + $mainadmins = array_diff($mainadmins, $newmainadmins); + $mainadmins = array_merge($newmainadmins,$mainadmins); + #print_r($mainadmins); echo "
"; + if (count($mainadmins) > 1){ + for ($i=0; $i
"; + $resultMA = ldap_mod_replace($ds,"cn=MainAdmin,cn=roles,".$domDN,$entryRoleMain); + + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + #print_r($hostadmins); echo "
"; + #print_r($newhostadmins); echo "
"; + $hostadmins = array_diff($hostadmins, $newhostadmins); + $hostadmins = array_merge($newhostadmins,$hostadmins); + #print_r($hostadmins); echo "
"; + if (count($hostadmins) > 1){ + for ($i=0; $i
"; + $resultHA = ldap_mod_replace($ds,"cn=HostAdmin,cn=roles,".$domDN,$entryRoleHost); + + } + if(count($roles['ZoneAdmin']) != 0){ + $zoneadmins = $roles['ZoneAdmin']; + #print_r($zoneadmins); echo "
"; + #print_r($newzoneadmins); echo "
"; + $zoneadmins = array_diff($zoneadmins, $newzoneadmins); + $zoneadmins = array_merge($newzoneadmins,$zoneadmins); + #print_r($zoneadmins); echo "
"; + if (count($zoneadmins) > 1){ + for ($i=0; $i
"; + $resultZA = ldap_mod_replace($ds,"cn=ZoneAdmin,cn=roles,".$domDN,$entryRoleZone); + + } + + # associatedDomain anpassen in allen AUs von $assocnames (alt) + $entryAD ['associateddomain'] = $assocdom; + #print_r($entryAD); echo "
"; + $resultAD = ldap_mod_replace($ds,$aname,$entryAD); + + #echo "_________________________________________
"; + } + + # Falls alter dc-Knoten noch Subdomains, d.h. dc-Teilbäume hat, diese verschieben mit + # rekursivem Anpassen aller Einträge + $dcchilds = get_dc_childs($dcDNold,array("dn","dc")); + #echo "

"; print_r($dcchilds); echo "
"; + if (count($dcchilds) != 0){ + foreach ($dcchilds as $dcc){ + print_r($dcc['dn']); echo " >> "; print_r("dc=".$dcc['dc'].",".$domDN); echo "
"; + if(move_subtree($dcc['dn'],"dc=".$dcc['dc'].",".$domDN)){ + $newdom = $dcc['dc'].".".$assocdom; + #print_r($newdom); echo "

"; + dive_into_dctree_adapt("dc=".$dcc['dc'].",".$domDN,$newdom); + } + } + } + + # alten dc-Knoten entfernen + dive_into_tree_del($dcDNold,""); + + # fixme: fehlt noch löschen der INCLUDE-Direktive in der parentdomain + + } + else{ + return 0; + } + } + + + if ( $delmodus == "complete" ){ + # if (dive_into_tree_del($dcDNold,"")){ + $delentry ['objectclass'] = "domainrelatedobject"; + $delentry ['associateddomain'] = $oldchilddomain.".".$domsuffix; + print_r($delentry); echo "
"; + # $delresult = ldap_mod_del($ds,$childDN,$delentry); + # if ($delresult){ + # $mesg = "Domain komplett gelöscht
"; + # }else{$mesg = "Fehler! ldap_mod_del
";} + # }else{$mesg = "Fehler! dive_into_tree_del
";} + } + + # return $mesg; +} + + +/* +function modify_childau_domain($childdomain, $oldchilddomain, $childDN){ + + global $ds, $suffix, $domsuffix, $ldapError; + $dcDN = "ou=DNS,".$suffix; + $dcoldDN = "ou=DNS,".$suffix; + + $dc_array = explode('.',$childdomain); + $dc_array = array_reverse($dc_array); + $dcold_array = explode('.',$oldchilddomain); + $dcold_array = array_reverse($dcold_array); + + foreach ($dcold_array as $dc){ + $dcoldDN = "dc=".$dc.",".$dcoldDN; + $aname = get_dc_data($dcoldDN,array("associatedname")); + if ($aname == $childDN){ + break; + } + } + #print_r($dcoldDN); echo "
"; + #print_r($domsuffix); echo "
"; + + $dcnewDN = ""; + foreach ($dc_array as $dc){ + if (check_for_dc($dc)){ + # echo "dc ".$dc." schon vorhanden ... nächster dc
"; + $domsuffix = $dc.".".$domsuffix; + $dcDN = "dc=".$dc.",".$dcDN; + } + else{ + $dcDN = "dc=".$dc.",".$dcDN; + $domsuffix = $dc.".".$domsuffix; + $dcnewDN .= $dcDN; + break; + } + } + #print_r($dcnewDN); echo "
"; + #print_r($domsuffix); echo "
"; + + if ($dcnewDN != ""){ + if (move_subtree($dcoldDN,$dcnewDN)){ + $entryAD['associateddomain'] = $childdomain.".".$domsuffix; + $resultAD = ldap_mod_replace($ds,$childDN,$entryAD); + $resultAD2 = ldap_mod_replace($ds,$dcnewDN,$entryAD); + if ($resultAD && $resultAD2){return 1;}else{return 0;} + } + }else{ + echo "Domain existiert schon, bitte anderen Domainnamen wählen!"; + } + +} + + +function same_domain($assocdom, $dcDN, $childDN){ + + global $ds, $suffix, $domsuffix, $ldapError; + + $entryDC ["associatedname"] = $childDN; + $resultDC = ldap_mod_add($ds,$dcDN,$entryDC); + if ($resultDC){ + # HostAdmins übernehmen, welche Admins noch? MainAdmin? + $roles = get_roles($childDN); + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + for ($i=0; $i"; + $resultHA = ldap_mod_add($ds,"cn=HostAdmin,cn=roles,".$dcDN,$entryRoleHost); + } + # Domainname zu associatedDomain der ChildAU + $entryAD['objectclass'] = "domainRelatedObject"; + $entryAD['associateddomain'] = $assocdom; + $resultAD = ldap_mod_add($ds,$childDN,$entryAD); + if($resultAD){return 1;}else{return 0;} + } + else{return 0;} +} + + +function new_childau_domain($childdomain, $childDN){ + + global $ds, $suffix, $domsuffix, $ldapError; + + # entsprechenden DC Knoten anlegen, sowie Roles (MainAdmin, HostAdmin) + $dc_array = explode('.',$childdomain); + $dc_array = array_reverse($dc_array); + $dcDN = "ou=DNS,".$suffix; + # $childdomainfull = $childdomain.".".$domsuffix; + #print_r($dc_array); + foreach ($dc_array as $dc){ + $resultsum = false; + if (check_for_dc($dc)){ + echo "dc ".$dc." schon vorhanden ... nächster dc
"; + $domsuffix = $dc.".".$domsuffix; + $dcDN = "dc=".$dc.",".$dcDN; + } + else{ + $dcDN = "dc=".$dc.",".$dcDN; + + $entryDC ["objectclass"][0] = "dnsdomain"; + $entryDC ["objectclass"][1] = "domainrelatedobject"; + $entryDC ["objectclass"][2] = "top"; + $entryDC ["dc"] = $dc; + $entryDC ["associatedname"] = $childDN; + $entryDC ["associateddomain"] = $dc.".".$domsuffix; + #print_r($entryDC); echo "
"; + #print_r($dcDN); echo "

"; + $resultDC = ldap_add($ds,$dcDN,$entryDC); + if ($resultDC){ + $domsuffix = $dc.".".$domsuffix; + + #print_r($dcDN); echo"

"; + + $entryRolesCont ['objectclass'] = "AUContainer"; + $entryRolesCont ['cn'] = "roles"; + #print_r($entryRolesCont); echo "

"; + $resultRC = ldap_add($ds,"cn=roles,".$dcDN,$entryRolesCont); + if ($resultRC){ + $roles = get_roles($childDN); + print_r($roles); echo "

"; + $mainadmins = $roles['MainAdmin']; + $entryRoleMain ['objectclass'] = "groupOfNames"; + $entryRoleMain ['cn'] = "MainAdmin"; + for ($i=0; $i"; + $resultMA = ldap_add($ds,"cn=MainAdmin,cn=roles,".$dcDN,$entryRoleMain); + + if(count($roles['HostAdmin']) != 0){ + $hostadmins = $roles['HostAdmin']; + $entryRoleHost ['objectclass'] = "groupOfNames"; + $entryRoleHost ['cn'] = "HostAdmin"; + for ($i=0; $i"; + $resultHA = ldap_add($ds,"cn=HostAdmin,cn=roles,".$dcDN,$entryRoleHost); + } + if ($resultMA){$resultsum = true;} + } + } + break; # damit dc-Zuwachs immer nur um eine neue Ebene moeglich + } + } + # Domainname zu associatedDomain der ChildAU + if ($resultsum == true){ + $entryAD['objectclass'] = "domainRelatedObject"; + $entryAD['associateddomain'] = $domsuffix; + $resultAD = ldap_mod_add($ds,$childDN,$entryAD); + } + if($resultAD){return 1;} + else{return 0;} + +} + + + +function delete_childau_domain($oldchilddomain,$childDN,$delmodus){ + + global $ds, $suffix, $domsuffix, $ldapError; + + $dcold_array = explode('.',$oldchilddomain); + $dcold_array = array_reverse($dcold_array); + $dcDN = "ou=DNS,".$suffix; + + foreach ($dcold_array as $dc){ + $dcDN = "dc=".$dc.",".$dcDN; + $aname = get_dc_data($dcDN,array("associatedname")); + $domsuffix = $dc.".".$domsuffix; + + if ($aname == $childDN){ + break; + } + } + #print_r($dcDN); echo "
"; + #print_r($domsuffix); echo "
"; + + if ( $delmodus == "complete" ){ + if (dive_into_tree_del($dcDN,"")){ + $delentry ['objectclass'] = "domainrelatedobject"; + $delentry ['associateddomain'] = $domsuffix; + #print_r($delentry); echo "
"; + $delresult = ldap_mod_del($ds,$childDN,$delentry); + if ($delresult){ + $mesg = "Domain komplett gelöscht
"; + }else{$mesg = "Fehler! ldap_mod_del
";} + }else{$mesg = "Fehler! dive_into_tree_del
";} + } + + if ( $delmodus == "integrate"){ + $mesg = "DNS Integration, noch nicht fertiggestellt"; + } + + return $mesg; +} +*/ + + + + +############################################################################### +# Funktionen für das Rollen Management +# + + +function new_role_member($userDN,$role,$auDN,$domDN){ + + global $ds, $suffix, $ldapError; + + $entry['member'] = $userDN; + + if ($domDN != ""){ + switch ($role){ + case 'MainAdmin': + $roleDN1 = "cn=".$role.",cn=roles,".$auDN; + $roleDN2 = "cn=".$role.",cn=roles,".$domDN; + $results1 = ldap_mod_add($ds,$roleDN1,$entry); + $results2 = ldap_mod_add($ds,$roleDN2,$entry); + if ($results1 && $results2){ + return 1; + }else{ + return 0; + } + break; + case 'HostAdmin': + $roleDN1 = "cn=".$role.",cn=roles,".$auDN; + $roleDN2 = "cn=".$role.",cn=roles,".$domDN; + $results1 = ldap_mod_add($ds,$roleDN1,$entry); + $results2 = ldap_mod_add($ds,$roleDN2,$entry); + if ($results1 && $results2){ + return 1; + }else{ + return 0; + } + break; + case 'DhcpAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_add($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'ZoneAdmin': + $roleDN1 = "cn=".$role.",cn=roles,".$auDN; + $roleDN2 = "cn=".$role.",cn=roles,".$domDN; + $results1 = ldap_mod_add($ds,$roleDN1,$entry); + $results2 = ldap_mod_add($ds,$roleDN2,$entry); + if ($results1 && $results2){ + return 1; + }else{ + return 0; + } + break; + } + }else{ + switch ($role){ + case 'MainAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_add($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'HostAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_add($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'DhcpAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_add($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'ZoneAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_add($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + } + } +} + + +function delete_role_member($userDN,$role,$auDN,$domDN){ + + global $ds, $suffix, $ldapError; + + $entry['member'] = $userDN; + + if ($domDN != ""){ + switch ($role){ + case 'MainAdmin': + $roleDN1 = "cn=".$role.",cn=roles,".$auDN; + $roleDN2 = "cn=".$role.",cn=roles,".$domDN; + $results1 = ldap_mod_del($ds,$roleDN1,$entry); + $results2 = ldap_mod_del($ds,$roleDN2,$entry); + if ($results1 && $results2){ + return 1; + }else{ + return 0; + } + break; + case 'HostAdmin': + $roleDN1 = "cn=".$role.",cn=roles,".$auDN; + $roleDN2 = "cn=".$role.",cn=roles,".$domDN; + $results1 = ldap_mod_del($ds,$roleDN1,$entry); + $results2 = ldap_mod_del($ds,$roleDN2,$entry); + if ($results1 && $results2){ + return 1; + }else{ + return 0; + } + break; + case 'DhcpAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_del($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'ZoneAdmin': + $roleDN1 = "cn=".$role.",cn=roles,".$auDN; + $roleDN2 = "cn=".$role.",cn=roles,".$domDN; + $results1 = ldap_mod_del($ds,$roleDN1,$entry); + $results2 = ldap_mod_del($ds,$roleDN2,$entry); + if ($results1 && $results2){ + return 1; + }else{ + return 0; + } + break; + } + }else{ + switch ($role){ + case 'MainAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_del($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'HostAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_del($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'DhcpAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_del($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + case 'ZoneAdmin': + $roleDN = "cn=".$role.",cn=roles,".$auDN; + $results = ldap_mod_del($ds,$roleDN,$entry); + if ($results){ + return 1; + }else{ + return 0; + } + break; + } + } +} + + +function get_role_members($roleDN) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $roleDN, "objectclass=*", array("member"), "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "search problem"; + die; + } else { + $members_array = array(); + $result = ldapArraySauber($result); + foreach ($result as $item){ + if (count($item['member']) > 1){ + $members_array = $item['member']; + } + else{ + $members_array[] = $item['member']; + } + } + } + return $members_array; +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/commonlib.inc.php b/ldap-site-mngmt/webinterface/lib/commonlib.inc.php new file mode 100644 index 00000000..32df2a1c --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/commonlib.inc.php @@ -0,0 +1,552 @@ +\n" . + " \n" . + ' ' . "\n" . + " \n"; + if ($msg) { + echo " \n" . + $msg . + " \n"; + } + echo "\n"; + } + + + +/** +* getRights($ds, $userDn) - ermittelt die Rechte eines Users. +* +* Die Funktion erwartet ein Directory-Handle und den vollständigen Distiguished Name des +* Users. Rückgabewert ist ein numerisches eindimensionales Array, welches die Rechte enthält. +* +* @param resource ds LDAP Directory Handle +* @param string userDn Distinguishedname des Users +* +* @return array rechte +* +* @author Timothy Burk +*/ + +function getRoles($ds, $userDN) { + global $ldapError, $suffix, $uid; + + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(member=$userDN)(cn=*))", array("dn","cn"), "dn", "sub", 0, 0))) { + redirect(5, "index.php", $ldapError, FALSE); + die; + } + $result = ldapArraySauber($result); + $clean = array(); + + foreach($result as $item) { + $dn = ldap_explode_dn($item['dn'], 0); + $dnsub = array_slice($dn,3); + $auDN = implode(',',$dnsub); + $element['au'] = $auDN; + $element['role'] = $item['cn']; + $clean[] = $element; + } + + $res = array(); + foreach($clean as $item){ + $au = $item['au']; + $role = $item['role']; + if(array_key_exists($au,$res)){ + $res[$au][] = $role; + } + else{ + $res[$au] = array($role); + } + } + $i=0; + foreach (array_keys($res) as $key){ + $au_roles[$i]['au'] = $key; + $au_roles[$i]['role'] = $res[$key]; + $i++; + } + return $au_roles; +} + + +/** +* createMenu($rechte) - erstellt die Menuleiste abhängig von der Rechten des Users. +* +* Die Navigationsleiste wird dynamisch erzeugt und von dieser Funktion direkt in das +* entsprechende Template geparst. Dabei werden nur die Schaltflächen zur Verfügung +* gestellt, die der User mit seinen Rechten anzeigen darf. +* +* @param array rechte Eindimensionales Array mit den Rechten des Users +* @param int mainnr Nummer des aktiven Hauptmenus +* +* @author Timothy Burk +*/ + +function createMainMenu($rollen , $mainnr) { + global $template; + global $START_PATH; + + # pre-checks + if ( check_if_max_networks() ){ + $dhcplink = "dhcp/dhcp.php"; + }else{ + $dhcplink = "dhcp/no_dhcp.php"; + } + + # Struktur der Registerkartenleiste + $mainmenu = array(array("link" => "au/au.php", + "text" => "AU Home", + "zugriff" => "alle"), + array("link" => "roles/roles.php", + "text" => "Admin Rollen", + "zugriff" => array("MainAdmin")), + array("link" => "ip/ip.php", + "text" => "IP Management", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")), + array("link" => "computers/computers.php", + "text" => "Rechner", + "zugriff" => array("MainAdmin","HostAdmin","DhcpAdmin")), + array("link" => "rbs/rbs.php", + "text" => "RemoteBoot/PXE", + "zugriff" => array("MainAdmin","HostAdmin")), + array("link" => $dhcplink, + "text" => "DHCP", + "zugriff" => array("MainAdmin","DhcpAdmin")), + array("link" => "dns/dns.php", + "text" => "DNS", + "zugriff" => array("MainAdmin","ZoneAdmin","HostAdmin"))); + + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Mainmenu", "Mmenu"); + $i=0; + foreach($mainmenu as $item) { + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + if ($i==0) { + if ($mainnr==0) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $zwisch=""; + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mainnr==$i) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if ($lastaktive) {$zwisch="";} + else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("MZWISCHEN" => $zwisch, + "MFARBE" => $farb, + "MLINK_M" => $START_PATH.$item["link"], + "MTEXT_M" => $item["text"])); + $template->parse("MAINMENU_LIST", ".Mainmenu"); + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("MENDE" => ""));} + else { + $template->assign(array("MENDE" => "")); + } + +} + + + +/** +* vergleicheArrays($a, $b) - Ermitteln der Schnittmenge zweier Arrays +* +* @param array a +* @param array b +* +* @return boolean TRUE, wenn die Schnittmenge von a und b nicht leer ist, sonst FALSE +* +* @author Timothy Burk +*/ + +function vergleicheArrays($a, $b) { + if((sizeof(array_unique($a)) + sizeof($b)) > sizeof(array_unique(array_merge($a, $b)))) { + return TRUE; + } else { + return FALSE; + } +} + + +/** +* inputArraySauber($Array) +* +* Löscht aus einem Array, welches POST-Daten enthält leere Felder. Nötig für die Formatierung +* vor dem Anlegen neuer Objekte. +* +* @param array _POST-Array +* +* @return array Bereinigtes Array. +* +* @author Timothy Burk +*/ +function inputArraySauber($Array) { + $b = array(); + foreach($Array as $key => $a) { + if(!is_array($a)) { + trim($a); + } + if (!$a == "") { + if(is_array($a)) { + $b[$key] = $a; + } else { + $b[$key] = htmlentities($a); + } + } + } + return $b; +} + + +/** +* numArraySauber($Array) +* +* Löscht aus einemn numerischen Array leere Felder. +* +* @param array Numerisches Array +* +* @return array Bereinigtes Array. +* +* @author Timothy Burk +*/ +function numArraySauber($Array) { + $b = array(); + $arr = array(); + if(!(is_array($Array))) { + $arr[] = $Array; + } else { + $arr = $Array; + } + foreach($arr as $key => $a) { + if (!$a == "") { + $b[] = $a; + } + } + return $b; +} + +/** +* ldapArraySauber($Array, [$delEmpty]) +* +* Bereinigt ein dreidimensionales Array, so wie es aus der Funktion uniLdapSearch kommt. +* Dabei werden alle count-Felder sowie alle numerischen Felder in denen der Schlüssel +* gespeichert ist entfernt. Attributarrays mit nur einem Element werden gelöscht, das Element +* wir als Skalar gespeichert. +* Wenn $delEmpty = TRUE ist, werden nur nichtleere Felder gespeichert. +* +* @param array $Array uniLdapSearch()-Ausgabe +* @param boolean $delEmpty (Standard: $delEmpty = FALSE) +* +* @return array Bereinigtes Array. +* +* @author Timothy Burk +*/ +function ldapArraySauber($Array, $delEmpty = FALSE) { + $b = array(); + foreach($Array as $key => $item) { + if(is_array($item)) { + foreach($item as $key_attr => $attr) { + if(!is_int($key_attr)) { + if(is_array($attr)) { + if($attr['count'] == 1) { + $attr[0] = str_replace(chr(160),"",trim($attr[0])); + if(($delEmpty && $attr[0] != "") || !($delEmpty)) { + $b[$key][$key_attr] = $attr[0]; + } + } else { + for($i=0; $i < $attr['count']; $i++) { + $attr[$i] = str_replace(chr(160),"",trim($attr[$i])); + if(($delEmpty && $attr[$i] != "") || !($delEmpty)) { + $b[$key][$key_attr][$i] = $attr[$i]; + } + } + } + } else { + $attr = str_replace(chr(160),"",trim($attr)); + if(($delEmpty && $attr != "") || !($delEmpty)) { + $b[$key][$key_attr] = $attr; + } + } + } + } + } else { + if(is_int($key)) { + $item = str_replace(chr(160),"",trim($item)); + if(($delEmpty && $item != "") || !($delEmpty)) { + $b[$key] = $item; + } + } + } + } + return $b; +} + +/** +* personOptionen($rechte) +* +* Enthält die möglichen Optionen, die auf einen User angewandt werden können als +* zweidimensionales Array mit folgenden Attributen: +* [ziel]: Aufzurufendes PHP-Skript +* [text]: Beschriftung der Schaltfläche +* [desc]: Beschreibung der Funktion +* [rechte][]: Array mit den erforderlichen Rechten für die jeweilige Option. array("alle") steht für "ohne Einschränkung". +* +* Dieses in dieser Funktion gespeicherte Array wird abhängig von den übergebenen +* Rechten um nicht erlaubte Optionen reduziert und dann ausgegeben. +* +* @param array $rechte Eindimensionales Array $_SESSION['rechte'] +* +* @return array Zweidimensionales Array mit den erlaubten Optionen. +* +* @author Timothy Burk +*/ +function personOptionen($rechte) { + global $utc_uid, $utc_cn, $START_PATH; + $optionen = array(); + $optionen[] = array("ziel" => $START_PATH."person/datensatz.php?aktion=edit", + "text" => "Userdaten bearbeiten", + "desc" => "Anzeigen und Ändern der persönlichen Daten des Users.", + "rechte" => array("writeMitarbeiter"), + "hidden" => array("aktion" => "edit")); + $optionen[] = array("ziel" => $START_PATH."person/datensatz.php", + "text" => "Datensatz löschen", + "desc" => "Der User wird vollständig mit allen Daten aus der Datenbank gelöscht.", + "rechte" => array("writeMitarbeiter"), + "hidden" => array("aktion" => "delete")); + $optionen[] = array("ziel" => $START_PATH."person/datensatz.php", + "text" => "User (de)aktivieren", + "desc" => "Diese Funktion legt einen User durch die Deaktivierung im Archiv ab. Von dort kann der Datensatz weiterhin eingesehen und ggf. reaktiviert werden.", + "rechte" => array("writeMitarbeiter"), + "hidden" => array("aktion" => "archiv")); + $optionen[] = array("ziel" => $START_PATH."person/vertrag_show.php", + "text" => "Verträge bearbeiten", + "desc" => "Bearbeiten oder Anlegen eines Vertrages. Sie können dabei zwischen verschiedenen Vertragsarten wählen.", + "rechte" => array("writeVertrag", "readVertrag")); + $optionen[] = array("ziel" => $START_PATH."urlaub/krank_angabe.php", + "text" => "Krankheitstage", + "desc" => "Krankheitsdaten bearbeiten.", + "rechte" => array("writeKrankheitUrlaub"), + "hidden" => array("uidToChange" => $utc_uid, "GName" => $utc_cn)); + $optionen[] = array("ziel" => $START_PATH."urlaub/liste.php", + "text" => "Urlaubstage anzeigen", + "desc" => "Urlaubstage des Users in grafischer Übersicht anzeigen.", + "rechte" => array("readKrankheitUrlaub"), + "hidden" => array("wer" => $utc_uid, "wann" => "g", "sub" => $utc_cn)); + $optionen[] = array("ziel" => $START_PATH."person/rechte_show.php", + "text" => "Rechte vergeben", + "desc" => "Diese Option dient dazu, dem User bestimmte Rechte zuzuweisen, beispielsweise das Recht Urlaub zu beantragen, Vertragsdaten andere User zu bearbeiten oder einzusehen usw..", + "rechte" => array("writeRechte")); + $optionen[] = array("ziel" => $START_PATH."person/suchen.php", + "text" => "Abbrechen", + "desc" => " ", + "rechte" => array("alle")); + + $opt_reduced = array(); + foreach($optionen as $option) { + if(in_array("alle",$option['rechte']) || vergleicheArrays($option['rechte'],$rechte)) { + array_push($opt_reduced, $option); + } + } + return $opt_reduced; +} + + +/** +* makeArrFromAttribute($a, $attribute) +* +* Ein zweidimensionales Array wird nach der ersten Dimension durchlaufen. +* Dabei werden die Werte des angegebenen Attributes $attribute für alle +* Einträge extrahiert und in einem neuen Array gespeichert, welches +* anschließend zurückgegeben wird. +* +* @param array $a Zweidimensionales Array +* @param string $attribute Schlüsselname der zweiten Dimension +* +* @return array Eindimensionales numerisches Array mit den Attributwerten. +* +* @author Timothy Burk +*/ +function makeArrFromAttribute($a, $attribute) { + $c = array(); + foreach($a as $b) { + $c[] = $b[$attribute]; + } + return $c; +} +?> + + $sortKey = "$j#$k#sortkey" +* @param string $sortDirection : die Sortierrichtung, gültige Werte sind "up", "down" +* +* +* @author Daniel Höfler +*/ +function sortArrayByKey($array, $sortKey, $sortDirection = "up") { + $sortKeyArray = explode("#", $sortKey); + $count = count($sortKeyArray); + if($count < 5) { + switch($count) { + case 0: + foreach($array as $key => $item) { + $toSortKeys[$key] = $item; + } + break; + case 1: + foreach($array as $key => $item) { + $toSortKeys[$key] = $item[$sortKeyArray[0]]; + } + break; + case 2: + foreach($array as $key => $item) { + $toSortKeys[$key] = $item[$sortKeyArray[0]][$sortKeyArray[1]]; + } + break; + case 3: + foreach($array as $key => $item) { + $toSortKeys[$key] = $item[$sortKeyArray[0]][$sortKeyArray[1]][$sortKeyArray[2]]; + } + break; + case 4: + foreach($array as $key => $item) { + $toSortKeys[$key] = $item[$sortKeyArray[0]][$sortKeyArray[1]][$sortKeyArray[2]][$sortKeyArray[3]]; + } + break; + } + } else { + echo "zu viele Dimensionen!! Höchstens 4 Dimensionen möglich"; + return false; + } + if($sortDirection == "up") { + asort($toSortKeys); + } elseif($sortDirection == "down") { + arsort($toSortKeys); + } else { + echo "Keine gültige Sortierrichtung!! Wählen sie \"up\" oder \"down\"\n"; + return false; + } + $sortArray = array(); + foreach($toSortKeys as $key => $item) { + $sortArray[$key] = $array[$key]; + } + return($sortArray); +} + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/config.inc.php b/ldap-site-mngmt/webinterface/lib/config.inc.php new file mode 100644 index 00000000..50d7e465 --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/config.inc.php @@ -0,0 +1,27 @@ + diff --git a/ldap-site-mngmt/webinterface/lib/dhcp_management_functions.php b/ldap-site-mngmt/webinterface/lib/dhcp_management_functions.php new file mode 100644 index 00000000..4194a1b3 --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/dhcp_management_functions.php @@ -0,0 +1,625 @@ +"; + #print_r($fe); echo "
"; + + if ($fs[3] == 0){$networks [] = $exp[0];} + $fs[2] = $fs[2] + 1; + $fs[3] = 0; + + while ( $fs[2] <= $fe[2] ){ + $iprange = implode('_',array(implode('.',$fs),implode('.',$fs))); + if (check_ip_in_iprange($iprange,$fipb)){ + $networks [] = implode('.',$fs); + if ($fs[2] == 255){ $fs[1] = $fs[1] + 1; $fs[2] = 0; } + else{ $fs[2] = $fs[2] + 1; } + } + } + } + #print_r($networks); echo "
"; + return $networks; +} + +# Check ob AU über noch freie x.x.x.0/24 Netzwerke verfügt (freie IP Blöcke) +function check_if_free_networks(){ + + global $ds, $suffix, $auDN, $ldapError; + + $networks = 0; + $fipb_array = get_freeipblocks_au($auDN); + if ( $fipb_array[0] != "" ){ + foreach ( $fipb_array as $fipb ){ + $exp = explode('_',$fipb); + $fs = explode('.',$exp[0]); + $fe = explode('.',$exp[1]); + + if ($fs[3] == 0){return 1; break;} + else{ + $fs[2] = $fs[2] + 1; + $fs[3] = 0; + + while ( $fs[2] <= $fe[2] ){ + $iprange = implode('_',array(implode('.',$fs),implode('.',$fs))); + if (check_ip_in_iprange($iprange,$fipb)){ + return 1; break 2; + } + if ($fs[2] == 255){ $fs[1] = $fs[1] + 1; $fs[2] = 0; } + else{ $fs[2] = $fs[2] + 1; } + } + } + } + } + return $networks; +} + +# Check ob AU über x.x.x.0/24 Netzwerke insgesamt verfügt (maximale IP Blöcke) +function check_if_max_networks(){ + + global $ds, $suffix, $auDN, $ldapError; + + $networks = 0; + $mipb_array = get_maxipblocks_au($auDN); + if ( $mipb_array[0] != "" ){ + foreach ( $mipb_array as $mipb ){ + $exp = explode('_',$mipb); + $fs = explode('.',$exp[0]); + $fe = explode('.',$exp[1]); + + if ($fs[3] == 0){return 1; break;} + else{ + $fs[2] = $fs[2] + 1; + $fs[3] = 0; + + while ( $fs[2] <= $fe[2] ){ + $iprange = implode('_',array(implode('.',$fs),implode('.',$fs))); + if (check_ip_in_iprange($iprange,$mipb)){ + return 1; break 2; + } + if ($fs[2] == 255){ $fs[1] = $fs[1] + 1; $fs[2] = 0; } + else{ $fs[2] = $fs[2] + 1; } + } + } + } + } + return $networks; +} + +################################################################################################### + +function get_dhcpoffers($auDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $attribs = array("dn","dhcpofferdn"); + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(objectclass=dhcpService)", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + #print_r($result);echo "

"; + + $dhcp_offers = array(); + foreach ($result as $dhcp){ + if ( strpos($auDN, $dhcp['dhcpofferdn']) !== false ) # && $dhcp['dn'] != $dhcpserviceDN + $dhcp_offers [] = $dhcp['dn']; + } + } + #print_r($dhcp_offers);echo "

"; + return $dhcp_offers; +} + +function alternative_dhcpservices($dhcpserviceDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $alt_dhcp = array(); + + $dhcparray = get_dhcpoffers($auDN); + # print_r($dhcparray); echo "
"; + if (count($dhcparray) != 0){ + for ($i=0; $i < count($dhcparray); $i++){ + if ($dhcparray[$i] != $dhcpserviceDN){ + $exp = ldap_explode_dn ( $dhcparray[$i], 1 ); + $alt = array ("dn" => $dhcparray[$i], "cn" => $exp[0], "au" => " / ".$exp[2]); + $alt_dhcp[] = $alt; + } + } + } + + return $alt_dhcp; +} + +function alternative_dhcpsubnets($dhcpsubnetDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $alt_subnet = array(); + $dhcpservices = get_dhcpoffers($auDN); + #print_r($dhcpservices); echo "
"; + if (count($dhcpservices) != 0){ + foreach ($dhcpservices as $servDN){ + $attribs = array("dn","cn","dhcphlpcont"); + #$servDN = $item['dn']; + #print_r($servDN); echo "
"; + $filter = "(&(objectclass=dhcpSubnet)(dhcphlpcont=$servDN))"; + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, $filter, $attribs, "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + }else{ + $result = ldapArraySauber($result); + #print_r($result); echo "
"; + foreach ($result as $subnet){ + if ( check_subnet_mipb($subnet['cn']) && $subnet['dn'] != $dhcpsubnetDN){ + $exp = ldap_explode_dn ( $subnet['dn'], 1 ); + $alt = array ("dn" => $subnet['dn'], "cn" => $exp[0], "au" => " / ".$exp[2]); + $alt_subnet[] = $alt; + } + } + } + + } + } + + return $alt_subnet; +} + +function check_subnet_mipb($subnet){ + + global $ds, $suffix, $auDN, $ldapError; + + $subexp = explode('.',$subnet); + $ret = 0; + $mipb_array = get_maxipblocks_au($auDN); + if ( $mipb_array[0] != "" ){ + foreach ( $mipb_array as $mipb ){ + $exp = explode('_',$mipb); + $ms = explode('.',$exp[0]); + $me = explode('.',$exp[1]); + if ( $subexp[2] >= $ms[2] && $subexp[2] <= $me[2] ){ + $ret = 1; + break; + } + } + } + if ($ret){return 1;} + else{return 0;} + +} + +############################################################################### +# Funktionen zur Verwaltung von DHCP Service Objekten +# + +function add_dhcpservice ($dhcpserviceName,$dhcpoffer,$atts){ + + global $ds, $suffix, $auDN, $ldapError; + + #$dnarray = ldap_explode_dn ( $dhcpserviceDN, 1 ); + $dhcpserviceDN = "cn=".$dhcpserviceName.",cn=dhcp,".$auDN; + + $entrydhcp ['objectclass'][0] = "dhcpService"; + $entrydhcp ['objectclass'][1] = "dhcpOptions"; + $entrydhcp ['objectclass'][2] = "top"; + $entrydhcp ['cn'] = $dhcpserviceName; + $entrydhcp ['dhcpofferdn'] = $dhcpoffer; + + # weitere Attribute + foreach (array_keys($atts) as $key){ + if ($atts[$key] != ""){ + $entrydhcp[$key] = $atts[$key]; + } + } + print_r($entrydhcp); echo "
"; + print_r($dhcpserviceDN); echo "
"; + + if ($result = ldap_add($ds, $dhcpserviceDN, $entrydhcp)){ + return 1; + } + else{ + $mesg = "Fehler beim eintragen des neuen DHCP Service Objekts!"; + return 0; + } +} + + + +function cleanup_del_dhcpservice ($dhcpserviceDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $filter = "(&(|(objectClass=dhcpSubnet)(objectclass=dhcpHost))(dhcphlpcont=$dhcpserviceDN))"; + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, $filter, array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $delentry ['dhcphlpcont'] = $dhcpserviceDN; + foreach ($result as $item){ + ldap_mod_del($ds, $item['dn'], $delentry); + } +} + + + +function adjust_dhcpservice_dn ($newdhcpserviceDN,$dhcpserviceDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $filter = "(&(|(objectClass=dhcpSubnet)(objectclass=dhcpHost))(dhcphlpcont=$dhcpserviceDN))"; + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, $filter, array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $modentry ['dhcphlpcont'] = $newdhcpserviceDN; + foreach ($result as $item){ + ldap_mod_replace($ds, $item['dn'], $modentry); + } + +} + + + +function alternative_dhcpobjects($objecttype,$objectDN,$ip){ + + global $ds, $suffix, $auDN, $assocdom, $ldapError; + + $alt_dhcp = array(); + $expip = explode('.',$ip); + $subnetDN = ""; + + if ($objecttype == "subnet"){ + # alternative DHCP Dienstobjekte eigene AU/übergeordnete AUs + $servarray = alternative_dhcpservices(""); + #print_r($servarray); echo "
"; + if (count($servarray) != 0){ + for ($i=0; $i < count($servarray); $i++){ + $alt_dhcp[] = $servarray[$i]; + } + } + if ($ip == ""){ + # alternative DHCP Subnetzobjekte eigene AU/übergeordnete AUs hinzufügen + $subarray = alternative_dhcpsubnets($objectDN); + #print_r($subarray); + if (count($subarray) != 0){ + for ($i=0; $i < count($subarray); $i++){ + $alt_dhcp[] = $subarray[$i]; + } + } + } + } + + if ($objecttype == "service"){ + # alternative DHCP Dienstobjekte eigene AU/übergeordnete AUs + $servarray = alternative_dhcpservices($objectDN); + #print_r($servarray); echo "
"; + if (count($servarray) != 0){ + for ($i=0; $i < count($servarray); $i++){ + $alt_dhcp[] = $servarray[$i]; + } + } + # Subnetz entsprechend IP + $subarray = alternative_dhcpsubnets($objectDN); + #print_r($subarray); + if (count($subarray) != 0){ + for ($i=0; $i < count($subarray); $i++){ + $expsub = explode('.', $subarray[$i]['cn']); + if ($expip[0] == $expsub[0] && $expip[1] == $expsub[1] && $expip[2] == $expsub[2]){ + $alt_dhcp[] = $subarray[$i]; + $subnetDN = $subarray[$i]['dn']; + break; + } + } + } + # falls keine IP weitere Subnetze hinzufügen + #print_r($subarray); + if ( $ip == "" && count($subarray) != 0 ){ + for ($i=0; $i < count($subarray); $i++){ + if ($subnetDN != $subarray[$i]['dn']){ + $alt_dhcp[] = $subarray[$i]; + } + } + } + } + + if ($objecttype == "nodhcp"){ + # alternative DHCP Dienstobjekte eigene AU/übergeordnete AUs + $servarray = alternative_dhcpservices(""); + #print_r($servarray); echo "
"; + if (count($servarray) != 0){ + for ($i=0; $i < count($servarray); $i++){ + $alt_dhcp[] = $servarray[$i]; + } + } + # Subnetz entsprechend IP + $subarray = alternative_dhcpsubnets($objectDN); + #print_r($subarray); + if (count($subarray) != 0){ + for ($i=0; $i < count($subarray); $i++){ + $expsub = explode('.', $subarray[$i]['cn']); + if ($expip[0] == $expsub[0] && $expip[1] == $expsub[1] && $expip[2] == $expsub[2]){ + $alt_dhcp[] = $subarray[$i]; + $subnetDN = $subarray[$i]['dn']; + break; + } + } + } + # falls keine IP weitere Subnetze hinzufügen + #print_r($subarray); echo "
";print_r($subnetDN); + if ( $ip == "" && count($subarray) != 0 ){ + for ($i=0; $i < count($subarray); $i++){ + if ($subnetDN != $subarray[$i]['dn']){ + $alt_dhcp[] = $subarray[$i]; + } + } + } + } + #echo "
";print_r($alt_dhcp); + return $alt_dhcp; +} + + +############################################################################### +# Funktionen zur Verwaltung von DHCP Subnet Objekten +# + +function add_dhcpsubnet ($cn,$dhcpservice,$netmask,$range1,$range2,$atts){ + + global $ds, $suffix, $auDN, $ldapError; + + $cnarray = array($cn,$cn); + $subnet = implode('_',$cnarray); + + # IP checken und FIBS anpassen + $fipb_array = get_freeipblocks_au($auDN); + + for ($i=0; $i < count($fipb_array); $i++){ + if ( split_iprange($subnet,$fipb_array[$i]) != 0 ){ + $ipranges = split_iprange($subnet,$fipb_array[$i]); + array_splice($fipb_array, $i, 1, $ipranges); + break; + } + } + + if ($i < count($fipb_array) ){ + # ldap_mod_replace -> Array fipb_array aktualisiert die FIPB in AU mit $auDN + foreach ( $fipb_array as $item ){ + $entry ['FreeIPBlock'][] = $item; + } + + $results = ldap_mod_replace($ds,$auDN,$entry); + if ($results){ + echo "
Neue FIPBs erfolgreich eingetragen!
" ; + + $dhcpsubnetDN = "cn=".$cn.",cn=dhcp,".$auDN; + + $entrydhcp ['objectclass'][0] = "dhcpSubnet"; + $entrydhcp ['objectclass'][1] = "dhcpOptions"; + $entrydhcp ['objectclass'][2] = "top"; + $entrydhcp ['cn'] = $cn; + $entrydhcp ['dhcpoptnetmask'] = $netmask; + if ( $dhcpservice != "none" ){ + $entrydhcp ['dhcphlpcont'] = $dhcpservice; + } + # weitere Attribute + foreach (array_keys($atts) as $key){ + if ($atts[$key] != ""){ + $entrydhcp[$key] = $atts[$key]; + } + } + print_r($entrydhcp); echo "
"; + print_r($dhcpsubnetDN); echo "
"; + + if ($result = ldap_add($ds, $dhcpsubnetDN, $entrydhcp)){ + if ( check_ip_in_subnet($range1,$cn) && check_ip_in_subnet($range2,$cn)){ + $dhcprange = implode('_',array($range1,$range2)); + if ( $range = new_ip_dhcprange($dhcprange,$dhcpsubnetDN,$auDN) ){ + echo "DHCP Range ".$range1." - ".$range2." erfolgreich im Subnetobjekt eingetragen"; + }else{ + echo "DHCP Range ".$range1." - ".$range2." konnte nicht im Subnetobjekt eingetragen werden!"; + } + return 1; + }else{ + echo "DHCP Range nicht in Subnetz ".$cn." enthalten.
Keine DHCP Range angelegt.
"; + return 1; + } + }else{ + echo "
Fehler beim anlegen des DHCP Subnet Objekts!
"; + return 0; + } + }else{ + echo "
Fehler beim eintragen der FIPBs!
"; + return 0; + } + } + else{ + printf("
Subnet %s nicht im verfuegbaren IP Bereich!
", $subnet ); + return 0; + } + +} + +function delete_dhcpsubnet($subnetDN,$cn){ + + global $ds, $suffix, $auDN, $ldapError; + + delete_ip_dhcprange($subnetDN,$auDN); + if ( dive_into_tree_del($subnetDN,"") ){ + cleanup_del_dhcpsubnet($subnetDN); + $oldsubnetip = implode("_",array($cn,$cn)); + $entry ['FreeIPBlock'] = $oldsubnetip; + $results = ldap_mod_add($ds,$auDN,$entry); + if ($results){ + merge_ipranges($auDN); + return 1; + }else{ + return 0; + } + }else{ + return 0; + } + +} + +function modify_subnet_dn($subnetDN,$newsubnetDN){ + + global $ds, $suffix, $auDN, $ldapError; + + # check IP-Net-Syntax ... + + # Subnet CNs (IP) in internes Range ".._.." Format bringen + $newcn = ldap_explode_dn($newsubnetDN,1); + $newcnarray = array($newcn[0],$newcn[0]); + $newsubnetip = implode("_",$newcnarray); + $oldcn = ldap_explode_dn($subnetDN,1); + $oldcnarray = array($oldcn[0],$oldcn[0]); + $oldsubnetip = implode("_",$oldcnarray); + + # IP checken und FIBS anpassen + $fipb_array = get_freeipblocks_au($auDN); + for ($i=0; $i < count($fipb_array); $i++){ + if ( split_iprange($newsubnetip,$fipb_array[$i]) != 0 ){ + $ipranges = split_iprange($newsubnetip,$fipb_array[$i]); + array_splice($fipb_array, $i, 1, $ipranges); + break; + } + } + + if ($i < count($fipb_array) ){ + + # zunächst alte DHCP Ranges löschen + delete_ip_dhcprange($subnetDN,$auDN); + # Move Subtree + if(move_subtree($subnetDN, $newsubnetDN)){ + adjust_dhcpsubnet_dn($newsubnetDN, $subnetDN); + printf("
Subnet Name (IP) erfolgreich von %s zu %s geändert!
", $oldcn[0], $newcn[0]); + # neue Subnetz-IP aus FIPBs entfernen + foreach ( $fipb_array as $item ){ + $entry ['FreeIPBlock'][] = $item; + } + # alte Subnetz-IP in FIPBs integrieren + $entry ['FreeIPBlock'][] = $oldsubnetip; + $results = ldap_mod_replace($ds,$auDN,$entry); + if ($results){ + merge_ipranges($auDN); + echo "
FIPBs erfolgreich angepasst!
" ; + return 1; + }else{ + echo "
Fehler beim Anpassen der FIPBs!
" ; + } + }else{ + echo "
Fehler beim ändern des Subnet Namens (IP)!
" ; + } + }else{ + printf("
Neues Subnet %s nicht im verfuegbaren IP Bereich!
", $newcn[0] ); + return 0; + } +} + + +function cleanup_del_dhcpsubnet ($dhcpsubnetDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $filter = "(&(objectclass=dhcpHost)(dhcphlpcont=$dhcpsubnetDN))"; + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, $filter, array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $delentry ['dhcphlpcont'] = $dhcpsubnetDN; + foreach ($result as $item){ + ldap_mod_del($ds, $item['dn'], $delentry); + } +} + + + +function adjust_dhcpsubnet_dn ($newdhcpsubnetDN,$dhcpsubnetDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $filter = "(&(objectclass=dhcpHost)(dhcphlpcont=$dhcpsubnetDN))"; + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, $filter, array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $modentry ['dhcphlpcont'] = $newdhcpsubnetDN; + foreach ($result as $item){ + ldap_mod_replace($ds, $item['dn'], $modentry); + } +} + + +# Nach Änderung der Host IP Adresse, überprüfen ob neue IP noch mit Subnet übereinstimmt +# Falls keine Übereinstimmung mehr, dann Subnetzuordnung aus Host löschen. +function adjust_hostip_dhcpsubnet($ip,$hostDN,$dhcphlpcont) { + + global $ds, $suffix, $auDN, $ldapError; + + $subnet = ldap_explode_dn($dhcphlpcont, 1); + $expsub = explode('.', $subnet[0]); + print_r($expsub); echo "
"; + $expip = explode('.', $ip); + print_r($expsip); echo "
"; + if ($expip[0] != $expsub[0] || $expip[1] != $expsub[1] || $expip[2] != $expsub[2]){ + $entrydhcp ['dhcphlpcont'] = array(); + ldap_mod_del($ds,$hostDN,$entrydhcp); + echo "Host mit neuer IP ".$ip." wurde aus DHCP Subnet ".$subnet[0]." entfernt

"; + } +} + +function check_ip_in_subnet($ip,$subnet) { + + global $ds, $suffix, $auDN, $ldapError; + $ipchunks = explode('.',$ip); + $netchunks = explode('.',$subnet); + $return = 0; + for ($i=1; $i<4; $i++){ + if ( $netchunks[$i] == "0" ){ + if ( $ipchunks[$i-1] == $netchunks[$i-1] ){ + $return = 1; + } + break; + } + } + if ($return) { return 1; }else{ return 0; } +} +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/host_management_functions.php b/ldap-site-mngmt/webinterface/lib/host_management_functions.php new file mode 100644 index 00000000..31f358b8 --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/host_management_functions.php @@ -0,0 +1,385 @@ +"; + if (count($groups != 0)){ + + foreach ($groups as $group){ + #$entry = array("member"); + if ( count($group['member']) > 1 ){ + for($i=0; $i"; + ldap_mod_replace($ds,$group['dn'],$entry); + } + if ( count($group['member']) == 1 && $group['member'] == $hostDN ){ + $entry['member'] = $newhostDN; + # print_r($entry); echo ""; + ldap_mod_replace($ds,$group['dn'],$entry); + } + } + } + + } +} + + +# Rechner neu anlegen +function add_host($hostDN,$hostname,$hostdesc,$mac,$ip,$atts){ + + global $ds, $suffix, $auDN, $assocdom, $ldapError; + + $entryhost ['objectclass'][0] = "Host"; + $entryhost ['objectclass'][1] = "dhcpHost"; + $entryhost ['objectclass'][2] = "dhcpOptions"; + $entryhost ['objectclass'][3] = "top"; + $entryhost ["hostname"] = $hostname; + $entryhost ["domainname"] = $assocdom; + if ($hostdesc != ""){$entryhost ["description"] = $hostdesc;} + if ($mac != ""){$entryhost ["hwaddress"] = $mac;} + foreach (array_keys($atts) as $key){ + if ($atts[$key] != ""){ + $entryhost[$key] = $atts[$key]; + } + } + + print_r($entryhost); echo "
"; + if ($result = ldap_add($ds, $hostDN, $entryhost)){ + + if($ip != ""){ + $syntax = new Syntaxcheck; + if( $syntax->check_ip_syntax($ip) ){ + $newip_array = array($ip,$ip); + $newip = implode('_',$newip_array); + print_r($newip); echo "

"; + if (new_ip_host($newip,$hostDN,$auDN)){ + echo "IP erfolgreich eingetragen

"; + }else{ + echo "Fehler beim eintragen der IP

"; + } + }else{ + echo "Falsche IP Syntax! IP nicht eingetragen"; + } + } + + return 1; + } + else{ + $mesg = "Fehler beim eintragen des neuen Rechners!"; + return 0; + } +} + + +# Rechner löschen +function delete_host($hostDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $hostdata = get_node_data($hostDN,array("hwaddress","ipaddress")); + + # IP Adresse freigeben + if ($hostdata['ipaddress'] != ""){ + delete_ip_host($hostDN,$auDN); + } + + if (dive_into_tree_del($hostDN,"")){ + + # alle DN Objekte in denen Rechner stand ebenfalls löschen + # Member in Groups + $groups = get_groups_member($auDN,array("dn","cn"),$hostDN); + # echo "Rechner aus den Gruppen entfernen:
"; print_r($groups); echo "
"; + if (count($groups) != 0){ + $entrydel ['member'] = $hostDN; + foreach ($groups as $group){ + echo "Entferne gelöschten Rechner aus Gruppe ".$group['cn']."
"; + $resultG = ldap_mod_del($ds, $group['dn'], $entrydel); + + # Filename in Gruppen-PXEs + $pxes = get_pxeconfigs($group['dn'],array("dn","cn")); + if ( count($pxes) != 0 && $hostdata['hwaddress'] != ""){ + foreach ($pxes as $pxe){ + $delfilename ['filename'] = "01-".$hostdata['hwaddress']; + $resultP = ldap_mod_del($ds,$pxe['dn'],$delfilename); + echo "Entferne MAC des gelöschten Rechners aus Gruppen-PXE ".$pxe['cn']."
"; + } + } + } + } + + # DHCP, DNS, RBS Server ... noch todo + # ... + return 1; + } + else{ + return 0; + } +} + + +############################################################################### +# Funktionen zur Verwaltung von Rechnergruppen +# + +# Gruppen DN ändern +function modify_group_dn($groupDN, $newgroupDN){ + + global $ds, $suffix, $ldapError; + + if (move_subtree($groupDN,$newgroupDN)){ + adjust_dn_entries($groupDN,$newgroupDN);} +} + + +# Gruppe neu anlegen +function add_group($groupDN,$groupcn,$groupdesc,$addmember){ + + global $ds, $suffix, $auDN, $assocdom, $ldapError; + + $entrygroup ['objectclass'][0] = "groupOfComputers"; + $entrygroup ['objectclass'][1] = "top"; + $entrygroup ["cn"] = $groupcn; + if ($groupdesc != ""){$entrygroup ["description"] = $groupdesc;} + + # Members anlegen (zuerst 'none' rausnehmen) + $n = array_search('none',$addmember); + if ($n === 0 ){array_splice($addmember, $n, 1);} + + if (count($addmember) != 0){ + $i = 0; + foreach ($addmember as $member){ + $exp = explode('_',$member); + $entrygroup['member'][$i] = $exp[0]; + $i++; + } + } + print_r($entrygroup); echo "
"; + + if ($result = ldap_add($ds, $groupDN, $entrygroup)){ + return 1; + } + else{ + return 0; + } +} + + +# Gruppe löschen +function delete_group($groupDN){ + + global $ds, $suffix, $auDN, $ldapError; + + if (dive_into_tree_del($groupDN,"")){ + + # alle DN Objekte in denen Gruppe stand ebenfalls löschen + # DHCP ... noch todo + + return 1; + } + else{ + return 0; + } +} + + +function add_groupmember($groupDN,$member){ + + global $ds, $suffix, $auDN, $ldapError; + +} + + +function delete_groupmember($groupDN,$member){ + + global $ds, $suffix, $auDN, $ldapError; + +} + + +############################################################################### +# Funktionen zur Verwaltung von MachineConfigs +# + +function check_timerange($mcday,$mcbeg,$mcend,$nodeDN,$excepttimerange){ + + global $ds, $suffix, $auDN, $ldapError; + + $brothers = get_machineconfigs($nodeDN,array("timerange")); + # keine Überschneidungen pro Spez.Ebene zulassen + #print_r($brothers); echo "

"; + if (count($brothers) != 0){ + + $intersect = 0; + foreach ($brothers as $item){ + + # Fall, dass Brother mehrere TimeRanges hat + if (count($item['timerange']) > 1){ + foreach ($item['timerange'] as $tr){ + + if($tr != $excepttimerange){ + $exptime = explode('_',$tr); + $bmcday = $exptime[0]; + $bmcbeg = $exptime[1]; + $bmcend = $exptime[2]; + #echo "mcday:"; print_r($mcday); echo "
"; + #echo "bmcday:"; print_r($bmcday); echo "
"; + #echo "mcbeg:"; print_r($mcbeg); echo "
"; + #echo "bmcbeg:"; print_r($bmcbeg); echo "
"; + #echo "mcend:"; print_r($mcend); echo "
"; + #echo "bmcend:"; print_r($bmcend); echo "
"; + + if ($mcday == $bmcday){ + if ( $mcbeg > $bmcend || $mcend < $bmcbeg ){ + # keine Ãœberschneidung in der Uhrzeit + }else{ + # Uhrzeit Ãœberschneidung + $intersect = 1; + $intersecttr = $bmcday."_".$bmcbeg."_".$bmcend; + break; + } + } + } + + } + } + # Fall, dass Brother nur eine TimeRange hat + elseif (count($item['timerange']) == 1){ + + if($item['timerange'] != $excepttimerange){ + $exptime = explode('_',$item['timerange']); + $bmcday = $exptime[0]; + $bmcbeg = $exptime[1]; + $bmcend = $exptime[2]; + #echo "mcday:"; print_r($mcday); echo "
"; + #echo "bmcday:"; print_r($bmcday); echo "
"; + #echo "mcbeg:"; print_r($mcbeg); echo "
"; + #echo "bmcbeg:"; print_r($bmcbeg); echo "
"; + #echo "mcend:"; print_r($mcend); echo "
"; + #echo "bmcend:"; print_r($bmcend); echo "
"; + + if ($mcday == $bmcday){ + if ( $mcbeg > $bmcend || $mcend < $bmcbeg ){ + # keine Ãœberschneidung in der Uhrzeit + }else{ + # Uhrzeit Ãœberschneidung + $intersect = 1; + $intersecttr = $bmcday."_".$bmcbeg."_".$bmcend; + break; + } + } + } + } + } + #echo "intersect: "; print_r($intersect); echo "
"; + if ($intersect == 1){ + echo "[".$mcday."_".$mcbeg."_".$mcend."] überschneidet sich mit der + bereits existierende Time Range [".$intersecttr."] !"; + return 0; + }else{ + return 1; + } + }else{ + return 1; + } +} + + + +function add_mc($mcDN,$mccn,$mctimerange,$mcdesc,$mcattribs){ + + global $ds, $suffix, $auDN, $ldapError; + + $mcentry ['objectclass'][0] = "MachineConfig"; + $mcentry ['objectclass'][1] = "top"; + $mcentry ['cn'] = $mccn; + if ($mctimerange != ""){$mcentry ['timerange'] = $mctimerange;} + if ($mcdesc != ""){$mcentry ['description'] = $mcdesc;} + if ($mcdesc == ""){$mcentry ['description'] = $mccn;} + foreach (array_keys($mcattribs) as $key){ + if ($mcattribs[$key] != ""){ + $mcentry[$key] = $mcattribs[$key]; + } + } + + #print_r($mcentry); echo "
"; + #print_r($mcDN); echo "
"; + if (ldap_add($ds,$mcDN,$mcentry)){ + return 1; + } + else{ + return 0; + } +} + +# MachineConfig CN (DN) ändern +function modify_mc_dn($mcDN, $newmcDN){ + + global $ds, $suffix, $ldapError; + + if (move_subtree($mcDN,$newmcDN)){ + return 1; + }else{ + return 0; + } +} + +function change_mc_timerange($mcDN,$newmcDN,$mctimerange){ + + global $ds, $suffix, $auDN, $ldapError; + + # move tree + if (move_subtree($mcDN,$newmcDN)){ + # timerange ändern + $entrymc ['timerange'] = $mctimerange; + if (ldap_mod_replace($ds,$newmcDN,$entrymc)){ + return 1; + } + else{ + return 0; + } + } + else{ + return 0; + } +} + + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/ip_management_functions.php b/ldap-site-mngmt/webinterface/lib/ip_management_functions.php new file mode 100644 index 00000000..b4f4a733 --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/ip_management_functions.php @@ -0,0 +1,1385 @@ += $ipr2s && $ipr1e <= $ipr2e ){ return 1;} + else{ return 0;} +} + + +/** +* split_iprange($iprange1, $iprange2) +* Entnimmt erste IP Range aus der zweiten IP Range und gibt bei Erfolg Array verbleibender +* IP Ranges zurueck. +* +* @param string iprange1 erste IP Range +* @param string iprange2 zweite IP Range +* +* @return array bei Erfolg bzw. boolean 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function split_iprange($iprange1,$iprange2) +{ + $iprange3; + $iprange4; + $ipranges = array(); + + if (check_ip_in_iprange($iprange1,$iprange2) == 1) + { + $ipr1exploded = explode('_',$iprange1); + $ipr2exploded = explode('_',$iprange2); + $ipr1s = ip2long($ipr1exploded[0]); + $ipr1e = ip2long($ipr1exploded[1]); + $ipr2s = ip2long($ipr2exploded[0]); + $ipr2e = ip2long($ipr2exploded[1]); + + $ipr3s = $ipr2s; + $ipr3e = $ipr1s - 1; + $ipr4s = $ipr1e + 1; + $ipr4e = $ipr2e; + + if ($ipr3s <= $ipr3e){$iprange3 = long2ip($ipr3s)."_".long2ip($ipr3e); $ipranges[] = $iprange3;} + if ($ipr4s <= $ipr4e){$iprange4 = long2ip($ipr4s)."_".long2ip($ipr4e); $ipranges[] = $iprange4;} + + return $ipranges; + } + else + { + echo "IPRange1 not in IPRange2: "; + return 0; + } +} + + +/** +* intersect_ipranges($iprange1, $iprange2) +* Bildet die Schnittmenge zweier IP Ranges. +* +* @param string iprange1 erste IP Range +* @param string iprange2 zweite IP Range +* +* @return string iprange3 Schnitt-IP-Range +* +* @author Tarik Gasmi +*/ +function intersect_ipranges($iprange1,$iprange2) +{ + $ipr1exploded = explode('_',$iprange1); + $ipr2exploded = explode('_',$iprange2); + $ipr1s = ip2long($ipr1exploded[0]); + $ipr1e = ip2long($ipr1exploded[1]); + $ipr2s = ip2long($ipr2exploded[0]); + $ipr2e = ip2long($ipr2exploded[1]); + + if ( $ipr1s >= $ipr2s ){$ipr3s = $ipr1s;}else{$ipr3s = $ipr2s;} + if ( $ipr1e <= $ipr2e ){$ipr3e = $ipr1e;}else{$ipr3e = $ipr2e;} + + if ($ipr3s <= $ipr3e){ + $iprange3 = long2ip($ipr3s)."_".long2ip($ipr3e); + return $iprange3; + } + else{ + return ""; + echo "No Intersection
"; + } +} + + +/** +* merge_2_ipranges($iprange1, $iprange2) +* Vereinigt 2 IP Ranges zu einer IP Range, falls sie adjazent sind oder sich ueberschneiden. +* +* @param string iprange1 erste IP Range +* @param string iprange2 zweite IP Range +* +* @return string iprange3 bei Erfolg bzw. boolean 0 bei Misserfolg. +* +* @author Tarik Gasmi +*/ +function merge_2_ipranges($iprange1,$iprange2) +{ + + $ipr1exploded = explode('_',$iprange1); + $ipr2exploded = explode('_',$iprange2); + $ipr1s = ip2long($ipr1exploded[0]); + $ipr1e = ip2long($ipr1exploded[1]); + $ipr2s = ip2long($ipr2exploded[0]); + $ipr2e = ip2long($ipr2exploded[1]); + + if ( ($ipr1e + 1) >= $ipr2s && $ipr1s <= ($ipr2e + 1) ){ + if ($ipr1s <= $ipr2s){ $ipr3s = $ipr1s; }else{ $ipr3s = $ipr2s; } + if ($ipr1e <= $ipr2e){ $ipr3e = $ipr2e; }else{ $ipr3e = $ipr1e; } + + if ($ipr3s <= $ipr3e){ + $iprange3 = long2ip($ipr3s)."_".long2ip($ipr3e); + printf("Merging: %s and %s -> %s
",$iprange1,$iprange2,$iprange3); + return $iprange3; + } + else{ + # printf("No Merging possible: %s and %s
",$iprange1,$iprange2); + return 0; } + } + else{ + # printf("No Merging possible: %s and %s
",$iprange1,$iprange2); + return 0; + } +} + + +######################################################################################### +# IP Management LDAP Grundfunktionen + +/** +* get_freeipblocks_au($auDN) +* Holt die FreeIPBlocks einer AU und gibt sie in einem Array zurueck. +* +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return array fipb_array FreeIPBlocks der AU. +* +* @author Tarik Gasmi +*/ +function get_freeipblocks_au($auDN) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $auDN, "objectclass=*", array("FreeIPBlock"), "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "search problem"; + die; + } else { + $fipb_array = array(); + $result = ldapArraySauber($result); + foreach ($result as $item){ + if (count($item['freeipblock']) > 1){ + $fipb_array = $item['freeipblock']; + } + else{ + $fipb_array[] = $item['freeipblock']; + } + } + } + return $fipb_array; +} + +/** +* get_maxipblocks_au($auDN) +* Holt die MaxIPBlocks einer AU und gibt sie in einem Array zurueck. +* +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return array mipb_array MaxIPBlocks der AU. +* +* @author Tarik Gasmi +*/ +function get_maxipblocks_au($auDN) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $auDN, "objectclass=*", array("MaxIPBlock"), "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "search problem"; + die; + } else { + $result = ldapArraySauber($result); + foreach ($result as $item){ + if (count($item['maxipblock']) > 1){ + $mipb_array = $item['maxipblock']; + } + else{ + $mipb_array[] = $item['maxipblock']; + } + } + } + return $mipb_array; +} + + +/** +* get_host_ip($hostDN) +* Holt die IP Adressen eines Hosts und gibt sie in einem Array zurueck. +* +* @param string hostDN Distinguished Name des LDAP Host-Objektes +* +* @return array host_array IPs des Hosts. +* +* @author Tarik Gasmi +*/ +function get_host_ip($hostDN) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $hostDN, "(objectclass=Host)", array("hostName","IPAddress","dhcpOptFixed-address"), "hostName", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + return 0; + } + else { + $result = ldapArraySauber($result); + $host_array = array(); + + foreach ($result as $item){ + $host_array['hostname'] = $item['hostname']; + $host_array['ipaddress'] = $item['ipaddress']; + #if ( $item['dhcpoptfixed-address'] != "" ){ + $host_array['dhcpoptfixed-address'] = $item['dhcpoptfixed-address']; + #} + # $host_array = array('hostname' => $item['hostname'], 'ipaddress' => $item['ipaddress']); + } + return $host_array; + } +} + + +/** +* get_dhcp_range($dhcpobjectDN) +* Holt die IP Ranges eines DHCP Subnets/Pools und gibt sie in einem Array zurueck. +* +* @param string dhcpobjectDN Distinguished Name des LDAP DHCP-Objektes +* +* @return array dhcp_array IP Ranges des Subnets/Pools. +* +* @author Tarik Gasmi +*/ +function get_dhcp_range($dhcpobjectDN) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $dhcpobjectDN, "(objectclass=*)", array("cn","dhcpRange"), "cn", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + return 0; + } + else { + $result = ldapArraySauber($result); + $dhcp_array = array(); + + foreach ($result as $item){ + $dhcp_array['cn'] = $item['cn']; + $dhcp_array['dhcprange'] = $item['dhcprange']; + } + return $dhcp_array; + } +} + + +/** +* merge_ipranges($auDN) +* Nimmt die Arrays von IP Ranges eines AU Objektes, MaxIPBlocks und FreeIPBlocks, und vereinigt +* rekusriv alle adjazenten/sich ueberschneidenden IP Ranges zu einer IP Range. +* +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @author Tarik Gasmi +*/ +function merge_ipranges($auDN) +{ + global $ds, $suffix, $ldapError; + + $fipb_array = get_freeipblocks_au($auDN); + $mipb_array = get_maxipblocks_au($auDN); + if ( count($fipb_array) > 1) sort($fipb_array); + if ( count($mipb_array) > 1) sort($mipb_array); + + $c = count($fipb_array); + for ($i=0; $i < $c; $i++){ + for ($j=$i+1; $j < $c; $j++){ + if ( merge_2_ipranges($fipb_array[$i],$fipb_array[$j])){ + $fipb_array[$i] = merge_2_ipranges($fipb_array[$i],$fipb_array[$j]); + array_splice($fipb_array, $j, 1); + $c--; + $i=-1; + break; + } + } + } + print_r($fipb_array);printf("
"); + foreach ( $fipb_array as $item ){ + $entry ['FreeIPBlock'][] = $item; + } + $results = ldap_mod_replace($ds,$auDN,$entry); + if ($results) echo "
FIPBs erfolgreich zusammengefasst!

" ; + else echo "
Fehler beim eintragen der FIPBs!

"; + + $d = count($mipb_array); + for ($i=0; $i < $d; $i++){ + for ($j=$i+1; $j < $d; $j++){ + if ( merge_2_ipranges($mipb_array[$i],$mipb_array[$j])){ + $mipb_array[$i] = merge_2_ipranges($mipb_array[$i],$mipb_array[$j]); + array_splice($mipb_array, $j, 1); + $d--; + $i=-1; + break; + } + } + } + print_r($mipb_array);printf("
"); + foreach ( $mipb_array as $item ){ + $entry2 ['MaxIPBlock'][] = $item; + } + $results = ldap_mod_replace($ds,$auDN,$entry2); + if ($results) echo "
MIPBs erfolgreich zusammengefasst!

" ; + else echo "
Fehler beim eintragen der MIPBs!

"; +} + + +/** +* new_ip_host($ip,$hostDN,$auDN) +* Weist einem Host eine IP Adresse neu zu, falls sie vergeben werden darf (in den FreeIPBlocks +* enthalten ist), und passt die FreeIPBlocks der AU an. +* +* @param string ip IP Adresse, die zugewiesen werden soll +* @param string hostDN Distinguished Name des LDAP Host-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function new_ip_host($ip,$hostDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + $fipb_array = get_freeipblocks_au($auDN); + + for ($i=0; $i < count($fipb_array); $i++){ + if ( split_iprange($ip,$fipb_array[$i]) != 0 ){ + $ipranges = split_iprange($ip,$fipb_array[$i]); + array_splice($fipb_array, $i, 1, $ipranges); + break; + } + } + + if ($i < count($fipb_array) ){ + # ldap_mod_replace -> Array fipb_array aktualisiert die FIPB in AU mit $auDN + foreach ( $fipb_array as $item ){ + $entry ['FreeIPBlock'][] = $item; + } + + $results = ldap_mod_replace($ds,$auDN,$entry); + if ($results){ + echo "
Neue FIPBs erfolgreich eingetragen!
" ; + + # ldap_mod_add -> IPAddress = $ip , in Host mit $hostDN + $ipentry ['IPAddress'] = $ip; + $results = ldap_mod_add($ds,$hostDN,$ipentry); + if ($results){ + echo "
IP Adresse erfolgreich eingetragen!
" ; + return 1; + }else{ + echo "
Fehler beim eintragen der IP Adresse!
"; + return 0; + } + }else{ + echo "
Fehler beim eintragen der FIPBs!
"; + return 0; + } + } + else{ + printf("
IP Adresse %s nicht im verfuegbaren Bereich!
", $ip ); + return 0; + } +} + +/** +* new_ip_dhcprange($ip,$dhcpobjectDN,$auDN) +* Weist einem DHCP Subnet/Pool eine IP Range neu zu, falls sie vergeben werden darf (in den FreeIPBlocks +* enthalten ist), und passt die FreeIPBlocks der AU an. +* +* @param string ip IP Range, die zugewiesen werden soll +* @param string dhcpobjectDN Distinguished Name des LDAP DHCP-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function new_ip_dhcprange($ip,$dhcpobjectDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + $fipb_array = get_freeipblocks_au($auDN); + + print_r($fipb_array); + + for ($i=0; $i < count($fipb_array); $i++){ + if ( split_iprange($ip,$fipb_array[$i]) != 0 ){ + $ipranges = split_iprange($ip,$fipb_array[$i]); + array_splice($fipb_array, $i, 1, $ipranges); + break; + } + } + + if ($i < count($fipb_array) ){ + # ldap_mod_replace -> Array fipb_array aktualisiert die FIPB in AU mit $auDN + foreach ( $fipb_array as $item ){ + $entry ['FreeIPBlock'][] = $item; + } + + $results = ldap_mod_replace($ds,$auDN,$entry); + if ($results){ + echo "
Neue FIPBs erfolgreich eingetragen!
" ; + + # ldap_mod_add -> IPAddress = $ip , in Host mit $hostDN + $ipentry ['dhcpRange'] = $ip; + $results = ldap_mod_add($ds,$dhcpobjectDN,$ipentry); + if ($results){ + echo "
IP Adresse erfolgreich eingetragen!
" ; + return 1; + }else{ + echo "
Fehler beim eintragen der IP Adresse!
"; + return 0; + } + }else{ + echo "
Fehler beim eintragen der FIPBs!
"; + return 0; + } + }else{ + printf("
IP Range %s ist nicht im verfuegbaren Bereich!
", $ip ); + return 0; + } +} + +/** +* delete_ip_host($hostDN,$auDN) +* Löscht die IP Adresse eines Hosts, und passt die FreeIPBlocks der AU an. +* +* @param string hostDN Distinguished Name des LDAP Host-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function delete_ip_host($hostDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + $host_array = get_host_ip($hostDN); + $old_ip = $host_array['ipaddress']; # oder IP aus dem Formular + # print_r($host_array);printf("
"); + # printf($old_ip); + $delentry ['ipaddress'] = $old_ip; + if ( $host_array['dhcpoptfixed-address'] != "" ){ + $delentry ['dhcpoptfixed-address'] = array(); + } + # print_r($delentry);printf("
"); + + $results = ldap_mod_del($ds,$hostDN,$delentry); + if ($results){ + echo "
IP Adresse erfolgreich geloescht!
"; + $modentry['FreeIPBlock'] = $old_ip; + $results = ldap_mod_add($ds,$auDN,$modentry); + if ($results){ + echo "
geloeschte IP Adresse erfolgreich als neuer FIPB in die AU eingetragen!
" ; + merge_ipranges($auDN); + return 1; + } + else{ + echo "
Fehler beim eintragen der geloeschten IP Adresse als neuen FIPB!
"; + return 0; + } + } + else{ + echo "
Fehler beim loeschen der IP Adresse!
"; + return 0; + } +} + +/** +* delete_ip_dhcprange($dhcpobjectDN,$auDN) +* Loescht die IP Range eines DHCP Subnets/Pools, und passt die FreeIPBlocks der AU an. +* +* @param string dhcpobjectDN Distinguished Name des LDAP DHCP-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function delete_ip_dhcprange($dhcpobjectDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + $dhcp_array = get_dhcp_range($dhcpobjectDN); + + if ( $dhcp_array['dhcprange'] != "" ){ + $old_ip = $dhcp_array['dhcprange']; # oder IP aus dem Formular besser da ja mehrere moeglich + # print_r($dhcp_array);printf("
"); + # printf($old_ip); + $delentry['dhcpRange'] = $old_ip; + # print_r($delentry);printf("
"); + + $results = ldap_mod_del($ds,$dhcpobjectDN,$delentry); + if ($results){ + echo "
DHCP IP Range erfolgreich geloescht!
"; + $modentry['FreeIPBlock'] = $old_ip; + $results = ldap_mod_add($ds,$auDN,$modentry); + if ($results){ + echo "
geloeschte IP Range erfolgreich als neuer FIPB in die AU eingetragen!
" ; + merge_ipranges($auDN); + return 1; + } + else{ + echo "
Fehler beim eintragen der geloeschten IP Range als neuen FIPB!
"; + # Transaktion simulieren und alte Range wieder eintragen ?? + return 0; + } + } + else{ + echo "
Fehler beim loeschen der DHCP IP Range!
"; + return 0; + } + } +} + +/** +* modify_ip_host($ip,$hostDN,$auDN) +* Aendert die IP Adresse eines Hosts, falls neue IP verfuegbar, und passt die FreeIPBlocks der AU an. +* +* @param string ip IP Adresse, die neu zugewiesen werden soll +* @param string hostDN Distinguished Name des LDAP Host-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function modify_ip_host($ip,$hostDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + if ( delete_ip_host($hostDN,$auDN) ){ + if ( new_ip_host($ip,$hostDN,$auDN) ){ + echo "
IP Adresse erfolgeich geaendert!
"; + return 1; + }else{ + echo "
Fehler beim Aendern der IP Adresse!
"; + return 0; + } + }else{ + echo "
Fehler beim Aendern der IP Adresse!
"; + return 0; + } +} + +/** +* modify_ip_dhcprange($ip,$dhcpobjectDN,$auDN) +* Aendert IP Range eines DHCP Subnet/Pool, falls neue Range verfuegbar ist, +* und passt die FreeIPBlocks der AU an. +* +* @param string ip IP Range, die neu zugewiesen werden soll +* @param string dhcpobjectDN Distinguished Name des LDAP DHCP-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function modify_ip_dhcprange($ip,$dhcpobjectDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + if ( delete_ip_dhcprange($dhcpobjectDN,$auDN) ){ + if ( new_ip_dhcprange($ip,$dhcpobjectDN,$auDN) ){ + echo "
DHCP IP Range erfolgeich geaendert!
"; + return 1; + }else{ + echo "
Fehler beim Aendern der DHCP IP Range!
"; + return 0; + } + }else{ + echo "
Fehler beim Aendern der DHCP IP Range!
"; + return 0; + } +} + + +/** +* new_ip_delegation($ip,$childauDN,$auDN) +* Delegiert einen neuen IP Bereich an eine untergeordnete AU, falls dieser verfuegbar ist +* (in den FreeIPBlocks enthalten ist), und passt die FreeIPBlocks der AU an. +* +* @param string ip IP Bereich, der zugewiesen werden soll +* @param string childauDN Distinguished Name des untergeordneten (Child) LDAP AU-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function new_ip_delegation($ip,$childauDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + $fipb_array = get_freeipblocks_au($auDN); + echo "
---
";print_r($fipb_array);echo "
---
"; + for ($i=0; $i < count($fipb_array); $i++){ + if ( split_iprange($ip,$fipb_array[$i]) != 0 ){ + $ipranges = split_iprange($ip,$fipb_array[$i]); + array_splice($fipb_array, $i, 1, $ipranges); + break; + } + } + + if ($i < count($fipb_array) ){ + # ldap_mod_replace -> Array fipb_array aktualisiert die FIPB in AU mit $auDN + foreach ( $fipb_array as $item ){ + $entry ['FreeIPBlock'][] = $item; + } + + $results = ldap_mod_replace($ds,$auDN,$entry); + if ($results){ + echo "
Neue FIPBs erfolgreich eingetragen!
" ; + + # ldap_mod_add -> IPAddress = $ip , in Host mit $hostDN + $mipbentry['MaxIPBlock'] = $ip; + $mipbentry['FreeIPBlock'] = $ip; + print_r($mipbentry); + + $results = ldap_mod_add($ds,$childauDN,$mipbentry); + if ($results){ + echo "
IP Adressblock erfolgreich delegiert!
" ; + merge_ipranges($childauDN); + + return 1; + }else{ + echo "
Fehler beim eintragen der IP Adresse!
"; + return 0; + } + }else{ + echo "
Fehler beim eintragen der FIPBs!
"; + return 0; + } + } + else{ + printf("
Zu delegierende IP Range %s ist nicht im verfuegbaren Bereich!
", $ip ); + } +} + +/** +* delete_ip_delegation($oldmipb,$childauDN,$auDN) +* Einen an eine untergeordnete AU delegierten IP Bereich zuruecknehmen. Diese Funktion wird rekursiv fuer +* alle weiter-delegierten Teilbereiche abgearbeitet. FreeIPBlocks der AU und Child-AU, sowie MaxIPBlocks +* der Child-AU werden angepasst. +* +* @param string oldmipb delegierter maximaler IP Bereich, der zurueckgenommen werden soll +* @param string childauDN Distinguished Name des untergeordneten (Child) LDAP AU-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function delete_ip_delegation($oldmipb,$childauDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + # Durch Reduzierung zu loeschende IP Ranges (Array) + $delip[] = $oldmipb; + print_r($delip);printf("

"); + + # Finde unter allen Child-AUs diejenigen, die von Reduzierung betroffene Child-Child-AUs haben + # Diese sind werden rekursiv abgearbeitet + $cchild_array = get_childau($childauDN,array("dn","maxipblock")); + # print_r($cchild_array);printf("

"); + $cchild_todo = array(); + foreach ($delip as $delipitem){ + foreach ($cchild_array as $item){ + if( count($item['maxipblock']) > 1 ){ + foreach ($item['maxipblock'] as $item2 ){ + if ( intersect_ipranges($delipitem,$item2) != false ){ + $cchild_todo[] = array('coldmipb' => $item2, + 'ccauDN' => $item['dn'], + 'childauDN' => $childauDN ); + } + } + } + elseif ( count($item['maxipblock']) == 1 ){ + if ( intersect_ipranges($delipitem,$item['maxipblock']) != false ){ + $cchild_todo[] = array('coldmipb' => $item['maxipblock'], + 'ccauDN' => $item['dn'], + 'childauDN' => $childauDN ); + } + } + } + } + print_r($cchild_todo);printf("

"); + + # Rekursionsaufruf (für jede Child-AU, die betroffene Child-Child-AU hat) + foreach ($cchild_todo as $item){ + delete_ip_delegation($item['coldmipb'],$item['ccauDN'],$item['childauDN']); + } + + # Ab hier: alles was bei jedem Fkt.Aufruf zu machen ist (in Ebene AU und Child-AU) + + # in CAU Check ob RechnerIPs oder DhcpIPs betroffen: + $del_objects = objects_to_delete($delip,$childauDN,$cchild_array); + # print_r($del_objects);printf("

"); + printf("
Host IP Addresses that will be deleted:
"); + foreach ($del_objects['hostips'] as $item){ + printf("HostDN: %s    IP Address: %s
",$item['dn'],$item['ip']); + } + printf("
Subnet IP Ranges that will be adjusted:
"); + foreach ($del_objects['dhcpranges'] as $item){ + printf("DhcpObjectDN: %s    Zu loeschende IP Range: %s
",$item['dn'],$item['delrange']); + } + # hier kommte Abfrage ob wirklich Aenderung ausfuehren, ja dann weiter mit loeschen + # sonst Abbruch + # momentan: einfach loeschen + foreach ($del_objects['hostips'] as $item){ + delete_ip_host($item['dn'],$item['auDN']); + } + foreach ($del_objects['dhcpranges'] as $item){ + delete_ip_dhcprange($item['dn'],$item['auDN']); + } + + # in Child-AU: oldmipb loeschen + $mipb_array = get_maxipblocks_au($childauDN); + print_r($mipb_array);printf("

"); + foreach ($delip as $delipitem){ + # if ( count($mipb_array) > 1 ){ + for ($i=0; $i < count($mipb_array); $i++){ + if ( intersect_ipranges($delipitem,$mipb_array[$i]) != 0 ){ + #$ipranges = intersect_ipranges($newmipb,$mipb_array[$i]); + array_splice($mipb_array, $i, 1); + } + } + # }else{ + # if ( intersect_ipranges($delipitem,$mipb_array) != 0 ){ + # # $ipranges = intersect_ipranges($newmipb,$mipb_array); + # $mipb_array = array(); + # } + # } + } + # print_r($mipb_array);printf("

"); + # for ($i=0; $i < count($mipb_array); $i++){ + # if ($mipb_array[$i] == false){array_splice($mipb_array, $i, 1);} + # } + print_r($mipb_array);printf("

"); + if (count($mipb_array) == 0){ + $entry ['MaxIPBlock'] = array(); + print_r($entry);printf("

"); + $results = ldap_mod_del($ds,$childauDN,$entry); + }else{ + foreach ( $mipb_array as $item ){ + $entry ['MaxIPBlock'][] = $item; + } + print_r($entry);printf("

"); + $results = ldap_mod_replace($ds,$childauDN,$entry); + } + + if ($results){ + echo "
MIPBs in Child-AU erfolgreich geloescht!
" ; + + # in Child-AU: FIPBs anpassen + $fipb_array = get_freeipblocks_au($childauDN); + print_r($fipb_array);printf("

"); + foreach ($delip as $delipitem){ + # if ( count($fipb_array) > 1 ){ + for ($i=0; $i < count($fipb_array); $i++){ + if ( intersect_ipranges($delipitem,$fipb_array[$i]) != 0 ){ + # $ipranges = intersect_ipranges($newmipb,$fipb_array[$i]); + array_splice($fipb_array, $i, 1); + } + } + # } + # else{ + # if ( intersect_ipranges($delipitem,$fipb_array) != 0 ){ + # # $ipranges = intersect_ipranges($newmipb,$fipb_array); + # $fipb_array = array(); + # } + # } + } + # print_r($fipb_array);printf("

"); + # for ($i=0; $i < count($fipb_array); $i++){ + # if ($fipb_array[$i] == false){array_splice($fipb_array, $i, 1);} + # } + print_r($fipb_array);printf("

"); + if (count($fipb_array) == 0){ + $entry1 ['FreeIPBlock'] = array(); + print_r($entry1);printf("

"); + $results = ldap_mod_del($ds,$childauDN,$entry1); + }else{ + foreach ( $fipb_array as $item ){ + $entry1 ['FreeIPBlock'][] = $item; + } + print_r($entry1);printf("

"); + $results = ldap_mod_replace($ds,$childauDN,$entry1); + } + + if ($results){ + echo "
FIPBs in Child-AU erfolgreich geloescht!
" ; + + # in AU: Geloeschte IP Bereiche als neue FIPBs aufnehmen + foreach ($delip as $item){ + $entry2 ['FreeIPBlock'][] = $item; + } + print_r($entry2);printf("

"); + $results = ldap_mod_add($ds,$auDN,$entry2); + if ($results){ + echo "
FIPBs in AU erfolgreich aktualisiert!
" ; + + # IP Bloecke aufraeumen in Child-AU und AU (Merging) + merge_ipranges($auDN); + merge_ipranges($childauDN); + return 1; + }else{ + echo "
Fehler beim aktualisieren!
"; + return 0; + } + }else{ + echo "
Fehler beim loeschen!
"; + return 0; + } + }else{ + echo "
Fehler beim loeschen!
"; + return 0; + } +} + + +/** +* reduce_ip_delegation($oldmipb,$newmipb,$childauDN,$auDN) +* Einen an eine untergeordnete AU delegierten IP Bereich verkleinern. Diese Funktion wird rekursiv fuer +* alle weiter-delegierten Teilbereiche abgearbeitet. FreeIPBlocks der AU und Child-AU, sowie MaxIPBlocks +* der Child-AU werden angepasst. +* +* @param string oldmipb delegierter maximaler IP Bereich, der verkleinert werden soll +* @param string newmipb delegierter maximaler IP Bereich nach der Verkleinerung +* @param string childauDN Distinguished Name des untergeordneten (Child) LDAP AU-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function reduce_ip_delegation($oldmipb,$newmipb,$childauDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + # Durch Reduzierung zu loeschende IP Ranges (Array) + $delip = split_iprange($newmipb,$oldmipb); + print_r($delip);printf("

"); + + # Finde unter allen Child-AUs diejenigen, die von Reduzierung betroffene Child-Child-AUs haben + # Diese sind werden rekursiv abgearbeitet + $cchild_array = get_childau($childauDN,array("dn","maxipblock")); + + $cchild_todo = array(); + foreach ($delip as $delipitem){ + foreach ($cchild_array as $item){ + if( count($item['maxipblock']) > 1 ){ + foreach ($item['maxipblock'] as $item2 ){ + if ( intersect_ipranges($delipitem,$item2) != false ){ + $cchild_todo[] = array('coldmipb' => $item2, + 'cnewmipb' => intersect_ipranges($newmipb,$item2), + 'ccauDN' => $item['dn'], + 'childauDN' => $childauDN ); + } + } + } + elseif ( count($item['maxipblock']) == 1 ){ + if ( intersect_ipranges($delipitem,$item['maxipblock']) != false ){ + $cchild_todo[] = array('coldmipb' => $item['maxipblock'], + 'cnewmipb' => intersect_ipranges($newmipb,$item['maxipblock']), + 'ccauDN' => $item['dn'], + 'childauDN' => $childauDN ); + } + } + } + } + print_r($cchild_todo);printf("

"); + + + # Rekursionsaufruf (für jede Child-AU, die betroffene Child-Child-AU hat) + foreach ($cchild_todo as $item){ + if ($item['cnewmipb'] == false ){ + delete_ip_delegation($item['coldmipb'],$item['ccauDN'],$item['childauDN']); + } + else{ + reduce_ip_delegation($item['coldmipb'],$item['cnewmipb'],$item['ccauDN'],$item['childauDN']); + } + } + + + # Ab hier: alles was bei jedem Fkt.Aufruf zu machen ist (auf Ebene AU und Child-AU) + + # in CAU Check ob RechnerIPs oder DhcpIPs betroffen: + # - falls ja: nochmals Abfrage (Hammermethode: diese auch loeschen) ob diese zu loeschen sind + # -> ja, betreffende IPs loeschen + # -> nein, Abbruch. + # - falls nein: fuer jedes FIPB in CAU intersect(FIPB,newmipb)-> Schnittmengen bilden die neuen FIPB + $del_objects = objects_to_adjust($newmipb,$delip,$childauDN,$cchild_array); + # print_r($del_objects);printf("

"); + printf("
Host IP Addresses that will be deleted:
"); + foreach ($del_objects['hostips'] as $item){ + printf("HostDN: %s    IP Address: %s
",$item['dn'],$item['ip']); + } + printf("
Subnet IP Ranges that will be adjusted:
"); + foreach ($del_objects['dhcpranges'] as $item){ + printf("DhcpObjectDN: %s    New IP Range: %s
",$item['dn'],$item['newrange']); + } + + # momentan wird einfach geloescht: + foreach ($del_objects['hostips'] as $item){ + delete_ip_host($item['dn'],$item['auDN']); + } + foreach ($del_objects['dhcpranges'] as $item){ + if ( count($item['newrange']) >= 1 ){ + modify_ip_dhcprange($item['newrange'],$item['dn'],$item['auDN']); + }else{ + delete_ip_dhcprange($item['dn'],$item['auDN']); + } + } + + + # in Child-AU: oldmipb -> newmipb + $mipb_array = get_maxipblocks_au($childauDN); + # print_r($mipb_array);printf("

"); + foreach ($delip as $delipitem){ + for ($i=0; $i < count($mipb_array); $i++){ + if ( intersect_ipranges($delipitem,$mipb_array[$i]) != 0 ){ + $ipranges = intersect_ipranges($newmipb,$mipb_array[$i]); + array_splice($mipb_array, $i, 1, $ipranges); + } + } + } + # print_r($mipb_array);printf("

"); + for ($i=0; $i < count($mipb_array); $i++){ + if ($mipb_array[$i] == false){array_splice($mipb_array, $i, 1);} + } + print_r($mipb_array);printf("

"); + if (count($mipb_array) == 0){ + $entry ['MaxIPBlock'] = array(); + print_r($entry);printf("

"); + $results = ldap_mod_del($ds,$childauDN,$entry); + }else{ + foreach ( $mipb_array as $item ){ + $entry ['MaxIPBlock'][] = $item; + } + print_r($entry);printf("

"); + $results = ldap_mod_replace($ds,$childauDN,$entry); + } + + if ($results){ + echo "
MIPBs in Child-AU erfolgreich aktualisiert!
" ; + + # in Child-AU: FIPBs anpassen + $fipb_array = get_freeipblocks_au($childauDN); + #print_r($fipb_array);printf("

"); + foreach ($delip as $delipitem){ + for ($i=0; $i < count($fipb_array); $i++){ + if ( intersect_ipranges($delipitem,$fipb_array[$i]) != 0 ){ + $ipranges = intersect_ipranges($newmipb,$fipb_array[$i]); + array_splice($fipb_array, $i, 1, $ipranges); + } + } + } + # print_r($fipb_array);printf("

"); + for ($i=0; $i < count($fipb_array); $i++){ + if ($fipb_array[$i] == false){array_splice($fipb_array, $i, 1);} + } + print_r($fipb_array);printf("

"); + if (count($fipb_array) == 0){ + $entry1 ['FreeIPBlock'] = array(); + print_r($entry1);printf("

"); + $results = ldap_mod_del($ds,$childauDN,$entry1); + }else{ + foreach ( $fipb_array as $item ){ + $entry1 ['FreeIPBlock'][] = $item; + } + print_r($entry1);printf("

"); + $results = ldap_mod_replace($ds,$childauDN,$entry1); + } + + if ($results){ + echo "
FIPBs in Child-AU erfolgreich aktualisiert!
" ; + + # in AU: Geloeschte IP Bereiche als neue FIPBs aufnehmen + foreach ($delip as $item){ + $entry2 ['FreeIPBlock'][] = $item; + } + print_r($entry2);printf("

"); + $results = ldap_mod_add($ds,$auDN,$entry2); + if ($results){ + echo "
FIPBs in AU erfolgreich aktualisiert!
" ; + + # IP Bloecke aufraeumen in Child-AU und AU (Merging) + merge_ipranges($auDN); + merge_ipranges($childauDN); + + return 1; + }else{ + echo "
Fehler beim aktualisieren!
"; + return 0; + } + }else{ + echo "
Fehler beim aktualisieren!
"; + return 0; + } + }else{ + echo "
Fehler beim aktualisieren!
"; + return 0; + } +} + + +/** +* expand_ip_delegation($oldmipb,$newmipb,$childauDN,$auDN) +* Einen an eine untergeordnete AU delegierten IP Bereich erweitern. Diese Funktion wird rekursiv fuer +* alle weiter-delegierten Teilbereiche abgearbeitet. FreeIPBlocks der AU und Child-AU, sowie MaxIPBlocks +* der Child-AU werden angepasst. Entspricht einer Neu-Delegierung des erweiterten IP Bereichs. +* +* @param string oldmipb delegierter maximaler IP Bereich, der erweitert werden soll +* @param string newmipb delegierter maximaler IP Bereich nach der Erweiterung +* @param string childauDN Distinguished Name des untergeordneten (Child) LDAP AU-Objektes +* @param string auDN Distinguished Name des LDAP AU-Objektes +* +* @return boolean 1 bei Erfolg bzw. 0 bei Misserfolg +* +* @author Tarik Gasmi +*/ +function expand_ip_delegation($oldmipb,$newmipb,$childauDN,$auDN) +{ + global $ds, $suffix, $ldapError; + + $difference = split_iprange($oldmipb,$newmipb); + new_ip_delegation($difference[0],$childauDN,$auDN); +} + + +/** +* objects_to_delete($delip,$childauDN,$cchild_array) +* Liefert die durch eine Rücknahme einer IP Delegierung betroffenen Host/DHCP-Objekte der Child-AU +* und Child-Child-AUs in einem Array. Dieses enthaelt fuer jedes Objekt dessen Distinguished Name, +* dessen IP Adresse(n)/Range(s) und den Distinguished Name der AU der das Objekt angehoert. Parameter +* die fuer die Funktionen delete_ip_host(), delete_ip_range() Benoetigt werden. +* +* @param string delip IP Bereich der geloescht wird +* @param string childauDN Distinguished Name des untergeordneten (Child) LDAP AU-Objektes +* @param array cchild_array Array von allen Child-Child-AUs (jedes Item enthaelt DN und MaxIPBlock) +* +* @return array objects_to_delete Array aller betroffenen Objekte (DN, IP, auDN) +* +* @author Tarik Gasmi +*/ +function objects_to_delete($delip,$childauDN,$cchild_array) +{ + global $ds, $suffix, $ldapError; + + # Hosts von child-AU, child-child-AU + $chosts = get_hosts($childauDN,array("dn","ipaddress")); + # print_r($chosts);printf("

"); + foreach ($cchild_array as $item){ + $cchostsitem = get_hosts($item['dn'],array("dn","ipaddress")); + foreach ($cchostsitem as $item2){ + $cchosts[] = $item2; + } + } + $chosts = array_merge($chosts,$cchosts); + # print_r($chosts);printf("

"); + + # Subnets von child-AU, child-child-AU + $csubnets = get_subnets($childauDN,array("dn","dhcprange")); + # print_r($csubnets);printf("

"); + foreach ($cchild_array as $item){ + $ccsubnetsitem = get_hosts($item['dn'],array("dn","dhcprange")); + foreach ($ccsubnetsitem as $item2){ + $ccsubnets[] = $item2; + } + } + $csubnets = array_merge($csubnets,$ccsubnets); + # print_r($csubnets);printf("

"); + + # Pools von child-AU, child-child-AU + /*$cpools = get_pools($childauDN,array("dn","dhcprange")); + # print_r($cpools);printf("
"); + foreach ($cchild_array as $item){ + $ccpoolsitem = get_hosts($item['dn'],array("dn","dhcprange")); + foreach ($ccpoolsitem as $item2){ + $ccpools[] = $item2; + } + } + $cpools = array_merge($cpools,$ccpools); + # print_r($cpools);printf("

"); + */ + + # Zu loeschende Hosts bestimmen + $chosts_todo = array(); + foreach ($delip as $delipitem){ + foreach ($chosts as $item){ + if( count($item['ipaddress']) > 1 ){ + foreach ($item['ipaddress'] as $item2 ){ + if ( intersect_ipranges($delipitem,$item2) != false ){ + $chosts_todo[] = array('dn' => $item['dn'], + 'ip' => $item['ipaddress'], + 'auDN' => $item['auDN']); + } + } + } + elseif ( count($item['ipaddress']) == 1 ){ + if ( intersect_ipranges($delipitem,$item['ipaddress']) != false ){ + $chosts_todo[] = array('dn' => $item['dn'], + 'ip' => $item['ipaddress'], + 'auDN' => $item['auDN']); + } + } + } + } + # print_r($chosts_todo);printf("

"); + + # Zu loeschende Subnets bestimmen, und wie IP Range anzupassen ist + $csubnets_todo = array(); + foreach ($delip as $delipitem){ + foreach ($csubnets as $item){ + if( count($item['dhcprange']) > 1 ){ + foreach ($item['dhcprange'] as $item2 ){ + # print_r(intersect_ipranges($delipitem,$item2)); + if ( intersect_ipranges($delipitem,$item2) != false ){ + $csubnets_todo[] = array('dn'=> $item['dn'], + 'delrange' => $item2['dhcprange'], + 'auDN' => $item['auDN']); + } + } + } + elseif ( count($item['dhcprange']) == 1 ){ + # print_r(intersect_ipranges($delipitem,$item['dhcprange'])); + if ( intersect_ipranges($delipitem,$item['dhcprange']) != false ){ + $csubnets_todo[] = array('dn'=> $item['dn'], + 'delrange' => $item['dhcprange'], + 'auDN' => $item['auDN']); + } + } + } + } + # print_r($csubnets_todo);printf("

"); + + # Zu loeschende Pools bestimmen, und wie IP Range anzupassen ist + /*$cpools_todo = array(); + foreach ($delip as $delipitem){ + foreach ($cpools as $item){ + if( count($item['dhcprange']) > 1 ){ + foreach ($item['dhcprange'] as $item2 ){ + if ( intersect_ipranges($delipitem,$item2) != false ){ + $cpools_todo[] = array('dn'=> $item['dn'], + 'delrange' => $item2['dhcprange'], + 'auDN' => $item['auDN']); + } + } + } + elseif ( count($item['dhcprange']) == 1 ){ + if ( intersect_ipranges($delipitem,$item['dhcprange']) != false ){ + $cpools_todo[] = array('dn'=> $item['dn'], + 'delrange' => $item['dhcprange'], + 'auDN' => $item['auDN']); + } + } + } + } + # print_r($cpools_todo);printf("

"); + */ + + $dhcps_todo = array_merge($csubnets_todo,$cpools_todo); + + $objects_to_delete = array('hostips' => $chosts_todo, + 'dhcpranges' => $dhcps_todo); + return $objects_to_delete; +} + + +/** +* objects_to_adjust($newmipb,$delip,$childauDN,$cchild_array) +* Liefert die durch eine Reduzierung einer IP Delegierung betroffenen Host/DHCP-Objekte der Child-AU +* und Child-Child-AUs in einem Array. Dieses enthaelt fuer jedes Objekt dessen Distinguished Name, +* dessen IP Adresse(n)/Range(s) und den Distinguished Name der AU der das Objekt angehoert. Parameter +* die fuer die Funktionen delete_ip_host(), delete_ip_dhcprange(), modify_ip_dhcprange() benoetigt werden. +* +* @param string newmipb IP Bereich der nach Reduzierung verbleibt +* @param string delip IP Bereich der durch Reduzierung wegfaellt +* @param string childauDN Distinguished Name des untergeordneten (Child) LDAP AU-Objektes +* @param array cchild_array Array von allen Child-Child-AUs (jedes Item enthaelt DN und MaxIPBlock) +* +* @return array objects_to_adjust Array aller betroffenen Objekte (DN, IP, auDN) +* +* @author Tarik Gasmi +*/ +function objects_to_adjust($newmipb,$delip,$childauDN,$cchild_array) +{ + global $ds, $suffix, $ldapError; + + # Hosts von child-AU, child-child-AU + $chosts = get_hosts($childauDN,array("dn","ipaddress")); + # print_r($chosts);printf("

"); + foreach ($cchild_array as $item){ + $cchostsitem = get_hosts($item['dn'],array("dn","ipaddress")); + foreach ($cchostsitem as $item2){ + $cchosts[] = $item2; + } + } + $chosts = array_merge($chosts,$cchosts); + # print_r($chosts);printf("

"); + + # Subnets von child-AU, child-child-AU + $csubnets = get_subnets($childauDN,array("dn","dhcprange")); + # print_r($csubnets);printf("

"); + foreach ($cchild_array as $item){ + $ccsubnetsitem = get_hosts($item['dn'],array("dn","dhcprange")); + foreach ($ccsubnetsitem as $item2){ + $ccsubnets[] = $item2; + } + } + $csubnets = array_merge($csubnets,$ccsubnets); + # print_r($csubnets);printf("

"); + + # Pools von child-AU, child-child-AU + /*$cpools = get_pools($childauDN,array("dn","dhcprange")); + # print_r($cpools);printf("
"); + foreach ($cchild_array as $item){ + $ccpoolsitem = get_hosts($item['dn'],array("dn","dhcprange")); + foreach ($ccpoolsitem as $item2){ + $ccpools[] = $item2; + } + } + $cpools = array_merge($cpools,$ccpools); + # print_r($cpools);printf("

"); + */ + + # Zu loeschende Hosts bestimmen + $chosts_todo = array(); + foreach ($delip as $delipitem){ + foreach ($chosts as $item){ + if( count($item['ipaddress']) > 1 ){ + foreach ($item['ipaddress'] as $item2 ){ + if ( intersect_ipranges($delipitem,$item2) != false ){ + $chosts_todo[] = array('dn' => $item['dn'], + 'ip' => $item['ipaddress'], + 'auDN' => $item['auDN']); + } + } + } + elseif ( count($item['ipaddress']) == 1 ){ + if ( intersect_ipranges($delipitem,$item['ipaddress']) != false ){ + $chosts_todo[] = array('dn' => $item['dn'], + 'ip' => $item['ipaddress'], + 'auDN' => $item['auDN']); + } + } + } + } + # print_r($chosts_todo);printf("

"); + + # Zu loeschende Subnets bestimmen, und wie IP Range anzupassen ist + $csubnets_todo = array(); + foreach ($delip as $delipitem){ + foreach ($csubnets as $item){ + if( count($item['dhcprange']) > 1 ){ + foreach ($item['dhcprange'] as $item2 ){ + # print_r(intersect_ipranges($delipitem,$item2)); + if ( intersect_ipranges($delipitem,$item2) != false ){ + $csubnets_todo[] = array('dn'=> $item['dn'], + 'newrange' => intersect_ipranges($newmipb,$item2), + 'auDN' => $item['auDN']); + } + } + } + elseif ( count($item['dhcprange']) == 1 ){ + # print_r(intersect_ipranges($delipitem,$item['dhcprange'])); + if ( intersect_ipranges($delipitem,$item['dhcprange']) != false ){ + $csubnets_todo[] = array('dn'=> $item['dn'], + 'newrange' => intersect_ipranges($newmipb,$item['dhcprange']), + 'auDN' => $item['auDN']); + } + } + } + } + # print_r($csubnets_todo);printf("

"); + + # Zu loeschende Pools bestimmen, und wie IP Range anzupassen ist + /*$cpools_todo = array(); + foreach ($delip as $delipitem){ + foreach ($cpools as $item){ + if( count($item['dhcprange']) > 1 ){ + foreach ($item['dhcprange'] as $item2 ){ + if ( intersect_ipranges($delipitem,$item2) != false ){ + $cpools_todo[] = array('dn'=> $item['dn'], + 'newrange' => intersect_ipranges($newmipb,$item2), + 'auDN' => $item['auDN']); + } + } + } + elseif ( count($item['dhcprange']) == 1 ){ + if ( intersect_ipranges($delipitem,$item['dhcprange']) != false ){ + $cpools_todo[] = array('dn'=> $item['dn'], + 'newrange' => intersect_ipranges($newmipb,$item['dhcprange']), + 'auDN' => $item['auDN']); + } + } + } + } + # print_r($cpools_todo);printf("

"); + */ + + $dhcps_todo = array_merge($csubnets_todo,$cpools_todo); + + $objects_to_adjust = array('hostips' => $chosts_todo, + 'dhcpranges' => $dhcps_todo); + return $objects_to_adjust; +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/ldap.inc.php b/ldap-site-mngmt/webinterface/lib/ldap.inc.php new file mode 100644 index 00000000..204e3e3c --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/ldap.inc.php @@ -0,0 +1,996 @@ +\n"; + } else { + $ldapError .= "Bind als User nicht erfolgreich: ".ldap_error($ds)."
\n"; + } + return false; + } + } else { + # Anonymer Bind. + if($result = ldap_bind($ds)) { + # Anonymer Bind erfolgreich ausgeführt + return $ds; + } else { + # Anonymer Bind nicht erfolreich. + $ldapError .= "Anonymer Bind nicht erfolgreich: ".ldap_error($ds)."
\n"; + return false; + } + } + } else { + # Optionen setzen fehlgeschlagen + $ldapError .= "Protokollversion setzen fehlgeschlagen: ".ldap_error($ds)."
\n"; + } + } else { + # Connect fehlgeschlagen. + $ldapError .= "Connect fehlgeschlagen: ".ldap_error($ds)."
\n"; + } +} + + +/** +* rzLdapConnect($userRdn, $userPwd) - Führt den Bind am RZ-LDAP-Server durch +* +* @param string userRdn UID für den Login +* @param string userPwd Loginpasswort +* +* @return boolean Erfolg bzw. Misserfolg +* +* @author Timothy Burk +*/ +function rzLdapConnect($userRdn = "", $userPwd = "") { + global $ldapError, $suffix_rz; + if(!(defined("LDAP_HOST_RZ") && defined("LDAP_PORT_RZ"))) { + $ldapError = "Hostname und/oder Port des LDAP-Servers wurden nicht angegeben!"; + return FALSE; + } + if($ds = ldap_connect(LDAP_HOST_RZ, LDAP_PORT_RZ)) { + # Connect zum LDAP-Server OK + if(ldap_set_option($ds, LDAP_OPT_PROTOCOL_VERSION, 3)) { + # Optionen gesetzt + if($userRdn != "" && $userPwd != "") { + # Anmeldung als User. + if($result = @ldap_bind($ds, "uid=".$userRdn.",ou=people,".$suffix_rz, $userPwd)) { + # Bind erfolgreich ausgeführt + return $ds; + } else { + # Bind nicht erfolreich. + if(ldap_error($ds) == "Invalid credentials") { + $ldapError .= "Bind nicht erfolgreich: die Zugangsdaten sind nicht korrekt.
\n"; + } else { + $ldapError .= "Bind als User nicht erfolgreich: ".ldap_error($ds)."
\n"; + } + return false; + } + } else { + # Anonymer Bind. + if($result = ldap_bind($ds)) { + # Anonymer Bind erfolgreich ausgeführt + return $ds; + } else { + # Anonymer Bind nicht erfolreich. + $ldapError .= "Anonymer Bind nicht erfolgreich: ".ldap_error($ds)."
\n"; + return false; + } + } + } else { + # Optionen setzen fehlgeschlagen + $ldapError .= "Protokollversion setzen fehlgeschlagen: ".ldap_error($ds)."
\n"; + } + } else { + # Connect fehlgeschlagen. + $ldapError .= "Connect fehlgeschlagen: ".ldap_error($ds)."
\n"; + } +} + + /** + * uniLdapSearch($ds, $base, $filter, $attributes, $sort, $mode, $resultLimit, $timeout) + * Sucht Einträge im LDAP-Server. + * + * Durchsucht den LDAP-Server vom Punkt $base ab nach Einträgen, die $filter entsprechen. Falls in $sort ein Feldname angegeben + * wurde, so wird danach sortiert. (ACHTUNG: die Funktion ldap_sort() ist nicht dokumentiert! Ich weiß nicht ob sie Sortierung + * nach mehreren Feldern zulässt und wie sie sich verhält, wenn zu einem Attribut mehrere Werte existieren.) $mode definiert die + * Art der Suche, wohingegen $resultLimit und $timeout die Anzahl der Ergebnis-Einträge bzw. die maximalen Suchdauer einschränken. + * Zurückgegeben werden die Attribute, die im Array $attributes aufgeführt sind. Im Erfolgsfalle wird ein multidimensionales Array + * zurückgeliefert, im Fehlerfalle FALSE. Dann steht die Fehlermeldung in der Variablen $ldapError. + * + * @param string $base die DN, das Verzeichnis, in dem die Suche startet + * + * @param string $filter die Suchbedingungen + * + * @param array attributes die Attributnamen, deren Werte im Ergebnis enthalten sein sollen. + * + * @param string $sort Sortiert die Ergebnis-Einträge nach dem angegebenen Feldnamen (undokumentiert! s.o.) + * + * @param string $mode Der Modus: "one" liefert einen Eintrag, "list" alle Einträge des Verzeichnisses und "sub" + * schließt alle Untervezeichnisse mit ein. + * + * @param int $resultLimit die maximale Anzahl zurückgegebener Einträge + * + * @param int $timeout die maximale Suchzeit, bevor der LDAP-Server abbrechen soll + * + * @return mixed multidimensionales array mit den Einträgen im Erfolgsfall, FALSE wenn ein Fehler auftrat + * + * @see ldap_read() + * @see ldap_list() + * @see ldap_search() + * @see ldap_sort() + * @see ldap_get_entries() + * @see ldap_free_result() + * + * @author Timothy Burk + */ +function uniLdapSearch($ds, $base, $filter, $attributes, $sort, $mode, $resultLimit, $timeout) { + global $ldapError; + $abfrage = false; + if($mode == "one") { + if($resource = ldap_read($ds, $base, $filter, $attributes, 0, $resultLimit, $timeout)) { + # Abfrage erfolgreich! + $abfrage = true; + } else { + # Abfrage fehlgeschlagen. + $ldapError .= "Abfrage mit Mode $mode ist fehlgeschlagen: ".ldap_error($ds)."
\n"; + return false; + } + } else if($mode == "list") { + if($resource = ldap_list($ds, $base, $filter, $attributes, 0, $resultLimit, $timeout)) { + # Abfrage erfolgreich! + ldap_sort($ds,$resource,$sort); + $abfrage = true; + } else { + # Abfrage fehlgeschlagen. + $ldapError .= "Abfrage mit Mode $mode ist fehlgeschlagen: ".ldap_error($ds)."
\n"; + return false; + } + } else if($mode == "sub") { + if($resource = ldap_search($ds, $base, $filter, $attributes, 0, $resultLimit, $timeout)) { + # Abfrage erfolgreich! + ldap_sort($ds,$resource,$sort); + $abfrage = true; + } else { + # Abfrage fehlgeschlagen. + $ldapError .= "Abfrage mit Mode $mode ist fehlgeschlagen: ".ldap_error($ds)."
\n"; + return false; + } + } else { + # Kein gültiger Modus angegeben. + $ldapError .= "Es wurde kein gültiger Modus angegeben."; + return false; + } + if($abfrage && ($entries = ldap_get_entries($ds, $resource))) { + # Auslesen des Verzeichnisses erfolgreich. + ldap_free_result($resource); + return $entries; + } else { + # Auslesen des Verzeichnisses nicht erfolgreich. + $ldapError .= "Auslesen des Verzeichnisses nicht erfolgreich: ".ldap_error($ds)."
\n"; + return false; + } +} +/** +* uniLdapAdd($ds, $dn, $daten, [$objectclass]) +* +* Fügt ein neues Objekt in die LDAP-Datenbank ein. +* +* @param resource $ds Datenbankhandler +* @param string $dn Distinguished Name des neuen Eintrages +* @param array $daten Assoziatives Array mit den gewünschten Attributen +* @param string $objectclass Objektklasse des neuen Eintrages (Standard = "") +* +* @return boolean TRUE wenn Eintrag erfolgreich, FALSE wenn ein Fehler aufgetreten ist. +* +* @see ldap_add() +* +* @author Timothy Burk +*/ +function uniLdapAdd($ds, $dn, $daten, $objectclass = "") { + if($objectclass != "") { + $daten['objectclass'] = $objectclass; + } + if(ldap_add($ds, $dn, $daten)) { + return true; + } else { + return false; + } +} + +/** +* uniLdapModify($ds, $dn, $daten_alt, $daten_neu, [$i]) +* +* Universalfunktion zum Ändern von Attributen und Werten. +* Bei Änderungsskripten muss zuerst ein Formular mit den alten Daten gefüllt werden. Die hierfür +* durchgeführte Suche wird in einem unbehandelten Array in der SESSION gespeichert und wieder +* ausgelesen, sobald die Änderungen gespeichert werden sollen. Es wird anschließend an diese Funktion +* (als $daten_alt)gegeben, die das Array mit ldapArraySauber von allen unnötigen Einträgen befreit. +* $daten_alt entspricht dann strukturell dem POST-Array des Änderungsformulars ($daten_neu). +* Letzteres wird nun durch laufen, alle Einträge werden mit ihrer Entsprechnung aus $daten_alt verglichen +* und ggf. werden dann Attribute geändert, gelöscht oder hinzugefügt. +* +* @param resource $ds Datenbankhandler +* @param string $dn Distinguished Name des Eintrages +* @param array $daten_alt Dreidimensionales mixed Array der Form $array[int][string][int], so wie es von uniLdapSearch zurückgeliefert wird. +* @param array $daten_neu Zweidimensionales mixed Array der Form $array[string][int], so wie ein Formular in $_POST gespeichert ist. +* @param int $i Gibt an, welcher Eintrag der ersten Dimension von $daten_alt verwendet werden soll. (Standard: $i=0) +* +* @return boolean TRUE wenn Änderung erfolgreich, FALSE wenn ein Fehler aufgetreten ist. +* +* @see ldap_mod_replace() +* @see ldap_mod_add() +* @see ldap_mod_del() +* @see ldapArraySauber() +* @see numArraySauber() +* +* @author Timothy Burk +*/ +function uniLdapModify($ds, $dn, $daten_alt, $daten_neu, $i = 0) { + $meldung = ""; + $daten_alt = ldapArraySauber($daten_alt, FALSE); + $daten_alt = $daten_alt[$i]; + foreach($daten_neu as $key => $value_neu) { + $key = strtolower($key); + if(!(is_array($value_neu))) { + # Wenn $value_neu ein Skalar ist... + # (d.h., das Attribut $key darf nur einen Wert annehmen) + $value_neu = htmlentities(str_replace(chr(160),"",trim($value_neu))); // ungewollte Leerzeichen und   löschen + if (isset($daten_alt[$key])) { + $daten_alt[$key] = str_replace(chr(160),"",trim($daten_alt[$key])); // ungewollte Leerzeichen und   löschen + } else { + $daten_alt[$key] = ""; + } + if($daten_alt[$key] == "" && $value_neu != "") { + # FALL 1: + # Alter Wert ist leer, neuer Wert ist nicht leer. + # Füge neues Attribut hinzu. + if(ldap_mod_add($ds, $dn, array($key => $value_neu))) { + $meldung .= "Add successfull: ".$key." -> ".$value_neu."
"; + } else { + $meldung .= "Add error: ".$key." -> ".$value_neu."
"; + } + + } else if($daten_alt[$key] != "" && $value_neu == "") { + # FALL 2: + # Alter Wert ist nicht leer, neuer Wert ist leer. + # Lösche Attribut. + if(ldap_mod_del($ds, $dn, array($key => $daten_alt[$key]))) { + $meldung .= "Delete successfull: ".$key." -> ".$daten_alt[$key]."
"; + } else { + $meldung .= "Delete error: ".$key." -> ".$daten_alt[$key]."
"; + } + + } else if($daten_alt[$key] != "" && $value_neu != "" && $daten_alt[$key] != $value_neu) { + # FALL 3: + # Alter und neuer Wert sind nicht leer und beide sind ungleich. + # Ändere das Attribut. Der bisherige Wert wird überschrieben. + if(ldap_mod_replace($ds, $dn, array($key => $value_neu))) { + $meldung .= "Replace successfull: ".$key." -> ".$value_neu."
"; + } else { + $meldung .= "Replace error: ".$key." -> ".$value_neu."
"; + } + + } else { + # In allen anderen Fällen ist keine Änderung nötig + } + } else { + # Wenn $value_neu ein Array ist... + # (d.h., das Attribut $key darf mehrere Werte annehmen) + $value_neu = numArraySauber($value_neu); + if (isset($daten_alt[$key])) { + $value_alt = numArraySauber($daten_alt[$key]); + foreach($value_alt as $item) { + #$item = htmlentities($item); + # Lösche alle alten Werte des Attributes $key. + if(ldap_mod_del($ds, $dn, array($key => $item))) { + $meldung .= "Delete successfull: ".$key." -> ".$item."
"; + } else { + $meldung .= "Delete error: ".$key." -> ".$item."
"; + } + } + } + foreach($value_neu as $item) { + $item = htmlentities($item); + # Füge alle neuen Werte des Attributes $key ein. + if(ldap_mod_add($ds, $dn, array($key => $item))) { + $meldung .= "Add successfull: ".$key." -> ".$item."
"; + } else { + $meldung .= "Add error: ".$key." -> ".$item."
"; + } + + } + } + } + #return $meldung; + if(eregi("error",$meldung)) { + return FALSE; + } else { + return TRUE; + } +} + +/** +* uniLdapDelete löscht beliebige Einträge mit dessen Subtree aus der Datenbank. +* Dabei wird der wird der Baum ab dem Eintrag $dn zu allen Blättern durchlaufen (Es +* können nur Blätter gelöscht werden!!) und die Einträge von hinten her bis einschließlich +* $dn gelöscht +* +* @param resource ds LDAP Directory Handle +* @param string dn Distiguished Name +* +* @return boolean +* +* @author Daniel Höfler +*/ + +function uniLdapDelete($ds, $dn) { + # Überprüfung, ob zu löschender Eintrag vorhanden ist + if(!uniLdapSearch($ds, $dn, "objectclass=*", array("*"), "", "one", 0, 0)) { + $ldapError .= "Löschen fehlgeschlagen: Eintrag nicht gefunden".ldap_error($ds)."
\n"; + return false; + } + # Auslesen der Daten unterhalb von $dn + $daten = uniLdapSearch($ds, $dn, "objectclass=*", array("*"), "", "list", 0, 0); + # for-Schleife wird nur ausgeführt, falls sich unterhalb von $dn Einträge befinden + for($i = 0; $i < $daten['count']; $i++){ + uniLdapDelete($ds, $daten[$i]['dn']); + } + # löschen der Blätter + if(ldap_delete($ds, $dn)) { + return true; + } else { + $ldapError .= "Löschen fehlgeschlagen".ldap_error($ds)."
\n"; + return false; + } +} + +############################################################################################ +# +# Ab hier LDAP Funktionen (Tarik Gasmi) nutzen die zuvor definierten Funktionen +# von Timothy Burk, u.A. +# +############################################################################################ +# Weitere LDAP Funktionen + +# +# LDAP Funktionen um alle Objekte der AU eines bestimmten Typs mit gewählten Attributen zu holen +# +function get_hosts($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=computers,".$auDN, "(objectclass=Host)", $attributes, "hostname", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $host_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $host_array[] = $atts; + } + if($attributes != false ){return $host_array;} + else{return $result;} + } +} + +function get_groups($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=groups,".$auDN, "(objectclass=groupOfComputers)", $attributes, "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $group_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $group_array[] = $atts; + } + if($attributes != false ){return $group_array;} + else{return $result;} + } +} + +function get_groups_member($auDN,$attributes,$member) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=groups,".$auDN, "(&(objectclass=groupOfComputers)(member=$member))", $attributes, "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $group_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $group_array[] = $atts; + } + if($attributes != false ){return $group_array;} + else{return $result;} + } +} + +function get_machineconfigs($baseDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $baseDN, "(objectclass=MachineConfig)", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $mc_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['baseDN'] = $baseDN; + $atts['auDN'] = $auDN; + $mc_array[] = $atts; + } + if($attributes != false ){return $mc_array;} + else{return $result;} + } +} + +function get_pxeconfigs($baseDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $baseDN, "(objectclass=PxeConfig)", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $pxe_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['baseDN'] = $baseDN; + $atts['auDN'] = $auDN; + $pxe_array[] = $atts; + } + if($attributes != false ){return $pxe_array;} + else{return $result;} + } +} + +function get_menuentries($baseDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $baseDN, "(objectclass=MenuEntry)", $attributes, "menuposition", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $menent_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['baseDN'] = $baseDN; + $atts['auDN'] = $auDN; + $menent_array[] = $atts; + } + if($attributes != false ){return $menent_array;} + else{return $result;} + } +} + +function get_rbservices($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=rbs,".$auDN, "(objectclass=RBService)", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $rbs_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $rbs_array[] = $atts; + } + if($attributes != false ){return $rbs_array;} + else{return $result;} + } +} + +function get_subnets($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=dhcp,".$auDN, "(objectclass=dhcpSubnet)", $attributes, "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + $subnet_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $subnet_array[] = $atts; + } + if($attributes != false ){return $subnet_array;} + else{return $result;} + } +} + +function get_dhcppools($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=dhcp,".$auDN, "(objectclass=dhcpPool)", $attributes, "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + + $pool_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $pool_array[] = $atts; + } + if($attributes != false ){return $pool_array;} + else{return $result;} + } +} + +function get_childau($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $auDN, "(objectclass=AdministrativeUnit)", $attributes, "ou", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + + $childau_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $childau_array[] = $atts; + } + if($attributes != false ){return $childau_array;} + else{return $result;} + } +} + +function get_au_data($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $auDN, "(objectclass=AdministrativeUnit)", $attributes, "ou", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + + $au_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $au_array[] = $atts; + } + if($attributes != false ){return $au_array;} + else{return $result;} + } +} + +function get_domain_data($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $suffix, "(&(objectclass=dnsdomain)(associatedname=$auDN))", $attributes, "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + + $domain_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $domain_array[] = $atts; + } + if($attributes != false ){return $domain_array;} + else{return $result;} + } +} + + +function get_roles($auDN) +{ + global $ds, $suffix, $domDN, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=roles,".$auDN, "(|(objectclass=GroupOfNames)(objectclass=Admins))", array("cn","member"), "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + $roles_array = array(); + #print_r($result); + foreach ($result as $item){ + if ( count($item['member']) > 1 ){ + foreach ($item['member'] as $member){ + $roles_array[$item['cn']][] = $member; + } + } + if ( count($item['member']) == 1 ){ + $roles_array[$item['cn']][] = $item['member']; + } + } + return $roles_array; + } +} + +function get_roles_dns($domDN) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=roles,".$domDN, "(objectclass=GroupOfNames)", array("cn","member"), "cn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + $roles_array = array(); + foreach ($result as $item){ + if ( count($item['member']) > 1){ + foreach ($item['member'] as $member){ + $roles_array[$item['cn']][] = $member; + } + }else{ + $roles_array[$item['cn']][] = $item['member']; + } + } + return $roles_array; + } +} + + +function get_users(){ + + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "ou=people,".$suffix, "(objectclass=inetOrgPerson)", array("dn","cn","sn","uid"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + $users_array = array(); + # foreach ($result as $item){ + # $users_array[$item['cn']] = $item['member']; + # } + # return $users_array; + return $result; + } +} + +function get_user_data($userDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $userDN, "(objectclass=inetOrgPerson)", $attributes, "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $user_data = $atts; + } + if($attributes != false ){return $user_data;} + else{return $result;} + } +} + + +function get_dc_data($dcDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $dcDN, "(objectclass=dnsdomain)", $attributes, "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $dc_data = $atts; + } + if($attributes != false ){return $dc_data;} + else{return $result;} + } +} + +function get_node_data($nodeDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + $node_data = array(); + + if(!($result = uniLdapSearch($ds, $nodeDN, "(objectclass=*)", $attributes, "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + foreach ($result as $item){ + foreach ($attributes as $att){ + $node_data[$att] = $item[$att]; + } + } + if($attributes != false ){return $node_data;} + else{return $result;} + } +} + + + +function get_zone_entries($dcDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $dcDN, "(|(objectclass=dNSZone)(objectclass=dNSZoneIncludeDirective))", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $zone_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['dcDN'] = $dcDN; + $zone_array[] = $atts; + } + if($attributes != false ){return $zone_array;} + else{return $result;} + } +} + + +function get_zone_entries_assocname($dcDN,$attributes,$assocname) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $dcDN, "(&(|(objectclass=dNSZone)(objectclass=dNSZoneIncludeDirective))(associatedname=$assocname))", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $zone_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['dcDN'] = $dcDN; + $zone_array[] = $atts; + } + if($attributes != false ){return $zone_array;} + else{return $result;} + } +} + +function get_dn_menuposition($pxeDN,$pos) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $pxeDN, "(menuposition=$pos)", array("dn"), "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + return $result[0]['dn']; + } +} + +function get_dhcpservices($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=dhcp,".$auDN, "(objectclass=dhcpService)", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $dhcp_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $dhcp_array[] = $atts; + } + if($attributes != false ){return $dhcp_array;} + else{return $result;} + } +} + +function get_dhcpsubnets($auDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, "cn=dhcp,".$auDN, "(objectclass=dhcpSubnet)", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result);printf("

"); + $dhcp_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $atts['auDN'] = $auDN; + $dhcp_array[] = $atts; + } + if($attributes != false ){return $dhcp_array;} + else{return $result;} + } +} + +function get_service_subnets($dhcpserviceDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + $filter = "(&(dhcphlpcont=".$dhcpserviceDN.")(objectclass=dhcpSubnet))"; + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, $filter, $attributes, "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){return $result;} + else{ + $result = ldapArraySauber($result); + # print_r($result); + $dhcpsubnets = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $expdn = ldap_explode_dn($item['dn'],1); + $au = array_slice($expdn, 3, 1); + $atts['auDN'] = implode ( ',', $au ); + $dhcpsubnets [] = $atts; + } + #print_r($dhcpsubnets); + if($attributes != false ){ + return $dhcpsubnets; + } + else{return $result;} + } +} +?> diff --git a/ldap-site-mngmt/webinterface/lib/ldap2.inc.php b/ldap-site-mngmt/webinterface/lib/ldap2.inc.php new file mode 100644 index 00000000..3d0b26d9 --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/ldap2.inc.php @@ -0,0 +1,350 @@ +
"; + + $childs_rdn = array(); + foreach ($childs as $item){ + $exp = explode(',',$item['dn']); + $rdn = $exp[0]; + $childs_rdn[] = $rdn; + } + + # print_r($childs_rdn); + return $childs_rdn; +} + + +# Attribute eines Knotens (Vorsicht Array enthält noch DN und COUNT) +# in einem Array wie er z.B. von ldap_add verwendet wird +function get_node_attributes($nodeDN){ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $nodeDN, "(objectclass=*)", array(), "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + # print_r($result); + foreach ($result as $item){ + foreach (array_keys($item) as $merkmal) + $attrs[$merkmal] = $item[$merkmal]; + } + return $attrs; +} + +# Rekursives Kopieren +function dive_into_tree_cp($baseDN,$new_baseDN){ + + global $ds, $suffix, $ldapError; + + $expldn = ldap_explode_dn($new_baseDN,0); + $new_node_rdn = $expldn[0]; + $exp = explode('=',$new_node_rdn); + $new_node_rdn_merk = $exp[0]; + $new_node_rdn_val = $exp[1]; + $new_node_rdn_merk = strtolower($new_node_rdn_merk); + + $childs_rdn = get_childs_rdn($baseDN); + + $attrs = get_node_attributes($baseDN); + # print_r($attrs); echo "
"; + unset($attrs['dn']); + unset($attrs['count']); + $attrs["$new_node_rdn_merk"] = $new_node_rdn_val; + # print_r($attrs); echo "
"; + + $result = ldap_add($ds,$new_baseDN,$attrs); + + + //recursivly do dive for each child + foreach($childs_rdn as $rdn){ + dive_into_tree_cp( $rdn.",".$baseDN , $rdn.",".$new_baseDN); + } + return $result; +} + + +# +# Rekursives Loeschen +function dive_into_tree_del($baseDN,$except){ + + global $ds, $suffix, $ldapError; + + $childs_rdn = get_childs_rdn($baseDN); + //recursivly do dive for each child + foreach($childs_rdn as $rdn){ + dive_into_tree_del( $rdn.",".$baseDN , $except); + } + if($baseDN != $except){ + $result = ldap_delete($ds,$baseDN); + } + + return $result; +} + +# Rekursives Verschieben +function move_subtree($oldDN,$newDN){ + + if(dive_into_tree_cp($oldDN,$newDN)) + { + dive_into_tree_del($oldDN,""); + echo "Moved subtree
"; + return 1; + } + else echo "Moving subtree not possible!!!
"; +} + + +function adjust_dn_entries($oldDN,$newDN){ + + global $ds, $suffix, $ldapError; + + # single Attributes: + if(!($result = uniLdapSearch($ds, $newDN, "(objectclass=host)", array("dn","dhcphlpcont"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + foreach ($result as $item){ + if (strpos($item['dhcphlpcont'],$oldDN) != false){ + $newvalue = str_replace($oldDN,$newDN,$item['dhcphlpcont']); + $entry['dhcphlpcont'] = $newvalue; + ldap_mod_replace($ds,$item['dn'],$entry); + } + } + + if(!($result = uniLdapSearch($ds, $newDN, "(objectclass=PXEConfig)", array("dn","rbservicedn"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + foreach ($result as $item2){ + if (strpos($item2['rbservicedn'],$oldDN) != false){ + $newvalue = str_replace($oldDN,$newDN,$item2['rbservicedn']); + $entry2['rbservicedn'] = $newvalue; + ldap_mod_replace($ds,$item2['dn'],$entry2); + } + } + + if(!($result = uniLdapSearch($ds, $newDN, "(objectclass=dhcpService)", array("dn","dhcpprimarydn","dhcpsecondarydn"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + foreach ($result as $item3){ + if (strpos($item3['dhcpprimarydn'],$oldDN) != false){ + $newvalue = str_replace($oldDN,$newDN,$item3['dhcpprimarydn']); + $entry3['dhcpprimarydn'] = $newvalue; + ldap_mod_replace($ds,$item3['dn'],$entry3); + } + if (strpos($item3['dhcpsecondarydn'],$oldDN) != false){ + $newvalue = str_replace($oldDN,$newDN,$item3['dhcpsecondarydn']); + $entry4['dhcpsecondarydn'] = $newvalue; + ldap_mod_replace($ds,$item3['dn'],$entry4); + } + } + + if(!($result = uniLdapSearch($ds, $newDN, "(objectclass=MenuEntry)", array("dn","genericmenuentrydn","ldapuri"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + foreach ($result as $item4){ + if (strpos($item4['genericmenuentrydn'],$oldDN) != false){ + $newvalue = str_replace($oldDN,$newDN,$item4['genericmenuentrydn']); + $entry5['genericmenuentrydn'] = $newvalue; + ldap_mod_replace($ds,$item4['dn'],$entry5); + } + if (strpos($item4['ldapuri'],$oldDN) != false){ + $newvalue = str_replace($oldDN,$newDN,$item4['ldapuri']); + $entry6['ldapuri'] = $newvalue; + ldap_mod_replace($ds,$item4['dn'],$entry6); + } + } + + # Multi-Attribut member + if(!($result = uniLdapSearch($ds, $newDN, "(objectclass=groupOfComputers)", array("dn","member","dhcphlpcont"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + foreach ($result as $item5){ + for ($i=0; $i
"; + foreach ($result as $item6){ + $newvalue = str_replace($oldDN,$newDN,$item6['associatedname']); + $entry9['associatedname'] = $newvalue; + ldap_mod_replace($ds,$item6['dn'],$entry9); + } + + # Attribut RelativeDomainName in DNS Teilbaum ... noch nicht fertig + $hostdnexpold = ldap_explode_dn($oldDN, 0); + $hostdnexpnew = ldap_explode_dn($newDN, 0); + $oldhostname = $hostdnexpold[0]; + $newhostname = $hostdnexpnew[0]; + if(!($result = uniLdapSearch($ds, "ou=DNS,".$suffix , "(relativedomainname=$oldhostname)", array("dn","relativedomainname"), "", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + foreach ($result as $item7){ + $newvalue = str_replace($oldhostname,$newhostname,$item7['relativedomainname']); + $entry10['relativedomainname'] = $newvalue; + ldap_mod_replace($ds,$item7['dn'],$entry10); + } + +} + + + +function check_for_dc($dn, $dc){ + global $ds, $suffix, $ldapError; + if(!($result = uniLdapSearch($ds, $dn, "(dc=$dc)", array("dc"), "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + if (count($result[0]['dc']) == 0 ) {return 0;} + elseif ($result[0]['dc'] == $dc){return 1;} +} + + +function get_dc_childs($baseDN,$attributes) +{ + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $baseDN, "(objectclass=dnsdomain)", $attributes, "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else { + $result = ldapArraySauber($result); + + $childau_array = array(); + foreach ($result as $item){ + foreach ($attributes as $att){ + $atts[$att] = $item[$att]; + } + $childau_array[] = $atts; + } + if($attributes != false ){return $childau_array;} + else{return $result;} + } +} + +# Liefert die RDNs aller dc-Child-Knoten +function get_dc_childs_rdn($baseDN){ + + global $ds, $suffix, $ldapError; + + $childs = get_dc_childs($baseDN,array("dn")); + # print_r($childs); echo "

"; + + $childs_rdn = array(); + foreach ($childs as $item){ + $exp = explode(',',$item['dn']); + $rdn = $exp[0]; + $childs_rdn[] = $rdn; + } + + # print_r($childs_rdn); + return $childs_rdn; +} + +function get_entry_number($entryDN,$entryobjectclass){ + + global $ds, $suffix, $ldapError; + + if(!($result = uniLdapSearch($ds, $entryDN, "(objectclass=machineconfig)", array("count"), "", "one", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + print_r ($result); + +} + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/rbs_management_functions.php b/ldap-site-mngmt/webinterface/lib/rbs_management_functions.php new file mode 100644 index 00000000..6b1f42fd --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/rbs_management_functions.php @@ -0,0 +1,591 @@ +"; + print_r($rbsDN); echo "
"; + + # Standard Fallback Menü anlegen + $pxecn = "PXE_Fallback-No-Config"; + $pxeDN = "cn=".$pxecn.",".$rbsDN; + $filename = array("fallback-nopxe"); + $ldapuri = LDAP_HOST."/dn=cn=computers,".$auDN; # wirklich nötig?? + $mecn = "Fallback-Text"; + $meDN = "cn=".$mecn.",".$pxeDN; + $meattribs = array("label" => "Keine PXE Boot-Konfiguration fuer die aktuelle Zeit definiert", + "kernel" => "menu.c32", + "submenulink" => "fallback-nopxe"); + + if (ldap_add($ds,$rbsDN,$rbsentry)){ + if (add_pxe($pxeDN,$pxecn,$rbsDN,"",array(),$filename,$ldapuri)){ + if (add_me($meDN,$mecn,"","01",$meattribs,$pxeDN)){ + return 1; + } + else{ + return 0; + } + } + else{ + return 0; + } + } + else{ + return 0; + } +} + +# +# "RBS-Angebote" im Verzeichnis suchen, die die AU ($auDN) nutzen darf, +# Suche nach passenden RBS-Offer-DNs +# +function get_rbsoffers($auDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $attribs = array("dn","rbsofferdn"); + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(objectclass=RBService)", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + #print_r($result);echo "

"; + + $rbs_offers = array(); + foreach ($result as $rbs){ + #print_r(strpos($auDN, $rbs['rbsofferdn']));echo "
"; + if ( strpos($auDN, $rbs['rbsofferdn']) !== false ) + $rbs_offers [] = $rbs['dn']; + } + } + #print_r($rbs_offers);echo "

"; + return $rbs_offers; +} + + +# +# Beim Löschen von RBS-Objekten muss dafür gesorgt werden dass keine PXEs mehr auf +# diese zeigen, Ref. Abhängigkeiten +# +function clean_up_del_rbs($rbsDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $attribs = array("dn"); + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=PXEConfig)(rbservicedn=$rbsDN))", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + $delentry ['rbservicedn'] = $rbsDN; + foreach ($result as $item){ + #print_r($item['dn']); echo "
"; + ldap_mod_del($ds, $item['dn'], $delentry); + } + + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=Host)(hlprbservice=$rbsDN))", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + $delentry2 ['hlprbservice'] = $rbsDN; + foreach ($result as $item){ + #print_r($item['dn']); echo "
"; + ldap_mod_del($ds, $item['dn'], $delentry2); + } + +} + +# +# beim ändern des CN (DN) des RBS muss dieses in allen referenzierenden PXEConfig-Objekten +# nachvollzogen werden, Ref. Abhängigkeiten +# +function adjust_rbs_dn($newrbsDN, $rbsDN){ + + global $ds, $suffix, $auDN, $ldapError; + + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=PXEConfig)(rbservicedn=$rbsDN))", array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $modentry ['rbservicedn'] = $newrbsDN; + foreach ($result as $item){ + ldap_mod_replace($ds, $item['dn'], $modentry); + } + + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=Host)(hlprbservice=$rbsDN))", array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $modentry2 ['hlprbservice'] = $newrbsDN; + foreach ($result as $item){ + ldap_mod_replace($ds, $item['dn'], $modentry2); + } +} + +function rbs_adjust_host($hostDN, $rbs){ + + global $ds, $suffix, $ldapError; + + $modentry ['rbservicedn'] = $rbs; + + $pxearray = get_pxeconfigs($hostDN,array("dn")); + if ( count($pxearray) != 0 ){ + foreach ( $pxearray as $item ){ + if ($result = ldap_mod_replace($ds,$item['dn'],$modentry)){ + return 1; + }else{ + return 0; + } + } + } +} + + +# +# Sucht den Hostname zu einer IP im Rechnerteilbaum der AU +# Verwaltung der am RBS beteiligten Server +# +function get_hostname_from_ip($ip,$auDN){ + + global $ds, $suffix, $ldapError; + + $ipp = array($ip,$ip); + $ipaddress = implode('_',$ipp); + + if(!($result = uniLdapSearch($ds, "cn=computers,".$auDN, "(&(objectclass=Host)(ipaddress=$ipaddress))", array("hostname"), "", "list", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + elseif(count($result) == 0){echo "kein Rechner mit dieser IP"; return "";} + else{ + $result = ldapArraySauber($result); + #print_r($result); + $host ['hostname'] = $result[0]['hostname']; + $host ['dn'] = $result[0]['dn']; + return $host; + } +} + + +############################################################################### +# Funktionen zur Verwaltung von PXE Bootmenüs + +# +# Überprüft, ob sich die angegebene Timerange auf einer der 4 Spezifikationsstufen mit anderen +# Timeranges des Objkets überschneidet +# +function check_timerange_pxe($pxeday,$pxebeg,$pxeend,$nodeDN,$excepttimerange){ + + global $ds, $suffix, $auDN, $ldapError; + + $brothers = get_pxeconfigs($nodeDN,array("timerange")); + # keine Überschneidungen pro Spez.Ebene zulassen + # print_r($brothers); echo "

"; + if (count($brothers) != 0){ + + $intersect = 0; + foreach ($brothers as $item){ + + # Fall das Brother mehrere TimeRanges hat + if (count($item['timerange']) > 1){ + foreach ($item['timerange'] as $tr){ + + if($tr != $excepttimerange){ + $exptime = explode('_',$tr); + $bpxeday = $exptime[0]; + $bpxebeg = $exptime[1]; + $bpxeend = $exptime[2]; + #echo "pxeday:"; print_r($pxeday); echo "
"; + #echo "bpxeday:"; print_r($bpxeday); echo "
"; + #echo "pxebeg:"; print_r($pxebeg); echo "
"; + #echo "bpxebeg:"; print_r($bpxebeg); echo "
"; + #echo "pxeend:"; print_r($pxeend); echo "
"; + #echo "bpxeend:"; print_r($bpxeend); echo "
"; + + if ($pxeday == $bpxeday){ + if ( $pxebeg > $bpxeend || $pxeend < $bpxebeg ){ + # keine Ãœberschneidung in der Uhrzeit + }else{ + # Uhrzeit Ãœberschneidung + $intersect = 1; + $intersecttr = $bpxeday."_".$bpxebeg."_".$bpxeend; + break; + } + } + } + + } + } + # Fall das Brother nur eine TimeRange hat + elseif (count($item['timerange']) == 1){ + + if($item['timerange'] != $excepttimerange){ + $exptime = explode('_',$item['timerange']); + $bpxeday = $exptime[0]; + $bpxebeg = $exptime[1]; + $bpxeend = $exptime[2]; + #echo "pxeday:"; print_r($pxeday); echo "
"; + #echo "bpxeday:"; print_r($bpxeday); echo "
"; + #echo "pxebeg:"; print_r($pxebeg); echo "
"; + #echo "bpxebeg:"; print_r($bpxebeg); echo "
"; + #echo "pxeend:"; print_r($pxeend); echo "
"; + #echo "bmcend:"; print_r($bpxeend); echo "
"; + + if ($pxeday == $bpxeday){ + if ( $pxebeg > $bpxeend || $pxeend < $bpxebeg ){ + # keine Ãœberschneidung in der Uhrzeit + }else{ + # Uhrzeit Ãœberschneidung + $intersect = 1; + $intersecttr = $bpxeday."_".$bpxebeg."_".$bpxeend; + break; + } + } + } + } + } + #echo "intersect: "; print_r($intersect); echo "
"; + if ($intersect == 1){ + echo "[".$pxeday."_".$pxebeg."_".$pxeend."] überschneidet sich mit der + bereits existierende Time Range [".$intersecttr."] !

"; + return 0; + }else{ + return 1; + } + }else{ + return 1; + } +} + + +# +# Neues PXE Bootmenü anlegen +# +function add_pxe($pxeDN,$pxecn,$rbsDN,$pxetimerange,$pxeattribs,$filenames,$conffile){ + + global $ds, $suffix, $auDN, $ldapError; + + $pxeentry ['objectclass'][0] = "PXEConfig"; + $pxeentry ['objectclass'][1] = "top"; + $pxeentry ['cn'] = $pxecn; + $pxeentry ['rbservicedn'] = $rbsDN; + #$pxeentry ['ldapuri'] = $ldapuri; + if ($conffile != ""){$pxeentry ['fileuri'] = $conffile;} + if (count($filenames) > 1 ){ + for ($i=0; $i"; + print_r($pxeDN); echo "
"; + if (ldap_add($ds,$pxeDN,$pxeentry)){ + return 1; + } + else{ + return 0; + } +} + + +# +# PXE CN (DN) ändern, Teilbaum verschieben +# +function modify_pxe_dn($pxeDN, $newpxeDN){ + + global $ds, $suffix, $ldapError; + + if (move_subtree($pxeDN,$newpxeDN)){ + return 1; + }else{ + return 0; + } +} + + +# +# Timerange eines PXEConfig-Objekts ändern +# +function change_pxe_timerange($pxeDN,$newpxeDN,$pxetimerange){ + + global $ds, $suffix, $auDN, $ldapError; + + # move tree + if (move_subtree($pxeDN,$newpxeDN)){ + # timerange ändern + $entrypxe ['timerange'] = $pxetimerange; + if (ldap_mod_replace($ds,$newpxeDN,$entrypxe)){ + return 1; + } + else{ + return 0; + } + } + else{ + return 0; + } +} + +# +# nach dem Löschen von PXEConfig Menueinträgen müssen Menüpositionen in der PXEConfig +# angepasst werden (Lücken schließen) +# +function cleanup_menupositions($pxeDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $me = get_menuentries($pxeDN,array("dn","menuposition")); + if (count($me) != 0){ + foreach ($me as $item){ + $pos = $item['menuposition']; + $pos = preg_replace ( '/0([0-9])/', '$1', $pos); + $menpos[$pos] = $item['dn']; + ksort($menpos); + } + $p = 1; + foreach ($menpos as $item){ + if (strlen($p) == 1){ + $p = "0".$p; + } + $entry ['menuposition'] = $p; + ldap_mod_replace($ds,$item,$entry); + $p++; + } + } +} + +# +# Hilfsfunktion zur Verarbeitung von Menüpositionen in PXEConfigs +# +function increment_menupositions($pxeDN,$menpos){ + + global $ds, $suffix, $auDN, $ldapError; + + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + $meDN = get_dn_menuposition($pxeDN,$menpos); + if ($meDN != ""){ + # zur Berechnung erst führende Nullen weg + $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + $newpos = $menpos+1; + increment_menupositions($pxeDN,$newpos); + # zum Eintragen führenden Nullen wieder dazu + if (strlen($newpos) == 1){ + $newpos = "0".$newpos; + } + $entry ['menuposition'] = $newpos; + ldap_mod_replace($ds,$meDN,$entry); + } +} + +# +# Neuen Menüeintrag anlegen +# +function add_me($meDN,$mecn,$gbmDN,$menpos,$meattribs,$pxeDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $mentry ['objectclass'][0] = "MenuEntry"; + $mentry ['objectclass'][1] = "top"; + $mentry ['cn'] = $mecn; + if($gbmDN != ""){$mentry ['genericmenuentrydn'] = $gbmDN;} + $mentry ['menuposition'] = $menpos; + if (count($meattribs) != 0){ + foreach (array_keys($meattribs) as $key){ + if ($meattribs[$key] != ""){ + $mentry[$key] = $meattribs[$key]; + } + } + } + print_r($mentry); echo "
"; + print_r($meDN); echo "
"; + increment_menupositions($pxeDN,$menpos); # andere jeweils um 1 erhöhen + if (ldap_add($ds,$meDN,$mentry)){ + return 1; + } + else{ + return 0; + } +} + + +# +# Menu Entry CN (DN) ändern +# +function modify_me_dn($meDN, $newmeDN){ + + global $ds, $suffix, $ldapError; + + if (move_subtree($meDN,$newmeDN)){ + return 1; + }else{ + return 0; + } +} + + + +##################################################################### +# Verwaltung von GBM +# + +function add_gbm($gbmDN,$gbmcn,$attribs){ + + global $ds, $suffix, $auDN, $ldapError; + + $entry ['objectclass'][0] = "MenuEntry"; + $entry ['objectclass'][1] = "top"; + $entry ['cn'] = $gbmcn; + if (count($attribs) != 0){ + foreach (array_keys($attribs) as $key){ + if ($attribs[$key] != ""){ + $entry[$key] = $attribs[$key]; + } + } + } + print_r($entry); echo "
"; + print_r($gbmDN); echo "
"; + if (ldap_add($ds,$gbmDN,$entry)){ + return 1; + } + else{ + return 0; + } +} + + +# +# beim löschen von GBMs muss dafür gesorgt werden, dass keine MEs mehr auf diese zeigen, +# Ref.Abhängigkeiten (sonst gibts Fehler beim PXE-Perlskript und die Nutzer wissen nicht dass ihr PXE Menü nicht +# mehr funktioniert, so kann man durch Fehlen des gbmDN wissen das es kein GBM mehr zu diesem ME gibt +# +function clean_up_del_gbm($gbmDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $attribs = array("dn","genericmenuentrydn"); + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=MenuEntry)(genericmenuentrydn=$gbmDN))", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + #print_r($result); echo "

"; + $delentry ['genericmenuentrydn'] = $gbmDN; + foreach ($result as $item){ + #print_r($item['dn']); echo "
"; + ldap_mod_del($ds, $item['dn'], $delentry); + } + +} + + +# +# beim ändern des CN (DN) des GBM, Meüeinträge anpassen, Ref. Abhängigkeiten +# +function adjust_gbm_dn($newgbmDN, $gbmDN){ + + global $ds, $suffix, $auDN, $ldapError; + + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=MenuEntry)(genericmenuentrydn=$gbmDN))", array("dn"), "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + $result = ldapArraySauber($result); + $modentry ['genericmenuentrydn'] = $newgbmDN; + foreach ($result as $item){ + ldap_mod_replace($ds, $item['dn'], $modentry); + } +} + + + +function alternative_rbservices($rbsDN){ + + global $ds, $suffix, $auDN, $ldapError; + + $alt_rbs = array(); + + $rbsarray = get_rbsoffers($auDN); + # print_r($rbsarray); echo "
"; + if (count($rbsarray) != 0){ + for ($i=0; $i < count($rbsarray); $i++){ + if ($rbsarray[$i] != $rbsDN){ + $exp = ldap_explode_dn ( $rbsarray[$i], 1 ); + $alt = array ("dn" => $rbsarray[$i], "cn" => $exp[0], "au" => " / ".$exp[2]); + $alt_rbs[] = $alt; + } + } + } + + return $alt_rbs; +} + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/lib/syntax_check.php b/ldap-site-mngmt/webinterface/lib/syntax_check.php new file mode 100644 index 00000000..35924e3c --- /dev/null +++ b/ldap-site-mngmt/webinterface/lib/syntax_check.php @@ -0,0 +1,268 @@ +ERROR = ""; + } + + + + + +# Ist "dotted quad IPAddress" in gueltigem Bereich? true or false +# Ueberprueft Format, fuehrende Nullen, und Werte > 255 +# +# Ueberprueft nicht nach reservierten oder nicht-route-baren IPs. +# +function check_ip_syntax($IP) +{ + if($this->CLEAR) { $this->clear_error();} + + $len = strlen($IP); + if( $len > 15 ){ + $this->ERROR = "check_ip_syntax: too long [$IP][$len]"; + return false; + } + + $badcharacter = eregi_replace("([0-9\.]+)","",$IP); + if(!empty($badcharacter)){ + $this->ERROR = "check_ip_syntax: Bad data in IP address [$badcharacter]"; + return false; + } + + $chunks = explode(".",$IP); + $count = count($chunks); + if ($count != 4){ + $this->ERROR = "check_ip_syntax: not a dotted quad [$IP]"; + return false; + } + + while ( list ($key,$val) = each ($chunks) ){ + if(ereg("^0",$val)){ + $this->ERROR = "check_ip_syntax: Invalid IP segment [$val]"; + return false; + } + $Num = $val; + settype($Num,"integer"); + if($Num > 255){ + $this->ERROR = "check_ip_syntax: Segment out of range [$Num]"; + return false; + } + } + + return true; + +} + +# Netzwerkaddresse +function check_netip_syntax($IP) +{ + if($this->CLEAR) { $this->clear_error();} + + if ( !($this->check_ip_syntax($IP)) ){ + return false; + } + $chunks = explode(".",$IP); + if ( $chunks[3] != "0" ){ + return false; + } + return true; +} + +# MAC Adresse + +# Domainname + +# Hostname +function is_hostname ($hostname = ""){ + + if($this->CLEAR) { $this->clear_error(); } + + $web = false; + + if(empty($hostname)) + { + $this->ERROR = "is_hostname: No hostname submitted"; + return false; + } + + // Only a-z, 0-9, and "-" or "." are permitted in a hostname + + // Patch for POSIX regex lib by Sascha Schumann sas@schell.de + $Bad = eregi_replace("[-A-Z0-9\.]","",$hostname); + + if(!empty($Bad)) + { + $this->ERROR = "is_hostname: invalid chars [$Bad]"; + return false; + } + + // See if we're doing www.hostname.tld or hostname.tld + if(eregi("^www\.",$hostname)) + { + $web = true; + } + + // double "." is a not permitted + if(ereg("\.\.",$hostname)) + { + $this->ERROR = "is_hostname: Double dot in [$hostname]"; + return false; + } + if(ereg("^\.",$hostname)) + { + $this->ERROR = "is_hostname: leading dot in [$hostname]"; + return false; + } + + $chunks = explode(".",$hostname); + + if( (gettype($chunks)) != "array") + { + $this->ERROR = "is_hostname: Invalid hostname, no dot seperator [$hostname]"; + return false; + } + + $count = ( (count($chunks)) - 1); + + if($count < 1) + { + $this->ERROR = "is_hostname: Invalid hostname [$count] [$hostname]\n"; + return false; + } + + // Bug that can't be killed without doing an is_host, + // something.something will return TRUE, even if it's something + // stupid like NS.SOMETHING (with no tld), because SOMETHING is + // construed to BE the tld. The is_bigfour and is_country + // checks should help eliminate this inconsistancy. To really + // be sure you've got a valid hostname, do an is_host() on it. + + if( ($web) and ($count < 2) ) + { + $this->ERROR = "is_hostname: Invalid hostname [$count] [$hostname]\n"; + return false; + } + + $tld = $chunks[$count]; + + if(empty($tld)) + { + $this->ERROR = "is_hostname: No TLD found in [$hostname]"; + return false; + } + + if(!$this->is_bigfour($tld)) + { + if(!$this->is_country($tld)) + { + $this->ERROR = "is_hostname: Unrecognized TLD [$tld]"; + return false; + } + } + + + return true; +} + + +# Syntax Check für die Eingaben: Uhrzeit, Wochentag, Monatstag, Monatstag.Monat +function check_timerange_syntax($mcday,$mcbeg,$mcend){ + + if($this->CLEAR) { $this->clear_error();} + + $badcharacter = eregi_replace("([a-z0-9\.]+)","",$mcday); + if(!empty($badcharacter)){ + $this->ERROR = "check_ip_syntax: Bad data in MC Day [$badcharacter]"; + return false; + } + $badcharacter = eregi_replace("([x0-9]+)","",$mcbeg); + if(!empty($badcharacter)){ + $this->ERROR = "check_ip_syntax: Bad data in MC Begin [$badcharacter]"; + return false; + } + $badcharacter = eregi_replace("([x0-9]+)","",$mcend); + if(!empty($badcharacter)){ + $this->ERROR = "check_ip_syntax: Bad data in MC End [$badcharacter]"; + return false; + } + + $lenmcday = strlen($mcday); + if (eregi("([a-z]+)",$mcday)){ + if ($lenmcday > 2){$this->ERROR = "WOTAG > 2"; return false;} + if (eregi("([0-9\.]+)",$mcday)){$this->ERROR = "WOTAG enthaelt (0-9.)"; return false;} + #if (!(eregi("[mdsfx][aiorx]",$mcday))){return false;} + if (!(eregi("(m[io]|d[io]|s[ao]|fr|x)",$mcday))){$this->ERROR = "WOTAG falscher String"; return false;} + } + if (eregi("([0-9]+)",$mcday)){ + if (eregi("[\.]",$mcday)){ + preg_match("/[\.]/",$mcday,$treffer); + if (count($treffer) > 1){$this->ERROR = "mehr als 2 Punkte"; return false;}; + $exp = explode('.',$mcday); + $day = $exp[0]; + $lenday = strlen($day); + if ($lenday > 2){$this->ERROR = "TAG > 2"; return false;} + if (!(eregi("(0[1-9]|[0-2][0-9]|3[01])",$day))){$this->ERROR = "TAG nicht korrekt"; return false;} + $month = $exp[1]; + $lenmonth = strlen($month); + if ($lenmonth > 2){$this->ERROR = "MONAT > 2"; return false;} + if (!(eregi("(0[0-9]|0[0-9]|1[0-2])",$month))){$this->ERROR = "Monat nicht korrekt"; return false;} + + } + else{ + if ($lenmcday > 2){$this->ERROR = "TAG > 2"; return false;} + if (!(eregi("(0[0-9]|[0-2][0-9]|3[01])",$mcday))){$this->ERROR = "Tag nicht korrekt"; return false;} + } + } + + $lenmcbeg = strlen($mcbeg); + if ($lenmcbeg == 2){ + if (!(eregi("(0[0-9]|1[0-9]|2[0-3]|x)",$mcbeg))){$this->ERROR = "Uhrzeit nicht korrekt"; return false;} + } + if ($lenmcbeg == 1){ + if (!(eregi("([0-9]|x)",$mcbeg))){$this->ERROR = "Uhrzeit nicht korrekt"; return false;} + } + $lenmcend = strlen($mcend); + if ($lenmcend == 2){ + if (!(eregi("(0[0-9]|1[0-9]|2[0-3]|x)",$mcend))){$this->ERROR = "Uhrzeit nicht korrekt"; return false;} + } + if ($lenmcend == 1){ + if (!(eregi("([0-9]|x)",$mcend))){$this->ERROR = "Uhrzeit nicht korrekt"; return false;} + } + + return true; +} + + +# Überprüft ob Menuposition ein Zahl ist +function check_menuposition($menpos){ + + if($this->CLEAR) { $this->clear_error();} + + $badcharacter = eregi_replace("([0-9]+)","",$menpos); + if(!empty($badcharacter)){ + $this->ERROR = "check_menupostion: Bad data in Menu Position [$badcharacter]"; + return false; + } +} + +} +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/login_form.inc.html b/ldap-site-mngmt/webinterface/login_form.inc.html new file mode 100644 index 00000000..13ecd9c7 --- /dev/null +++ b/ldap-site-mngmt/webinterface/login_form.inc.html @@ -0,0 +1,18 @@ + +
+ + + + + + + + + + + + + + +

Benutzerlogin:

User-Id:

 

Passwort:

+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/delete_confirm.php b/ldap-site-mngmt/webinterface/rbs/delete_confirm.php new file mode 100644 index 00000000..11a04dfd --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/delete_confirm.php @@ -0,0 +1,90 @@ + + + AU Management + + + + + + + +
"; + + +if($type == "gbm"){ + $gbmDN = $dn; + $attribs = array("dn"); + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=MenuEntry)(genericmenuentrydn=$gbmDN))", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + if (count($result) > 0){ + echo "Folgende Menü Einträge sind davon betroffen:

"; + foreach ($result as $item){ + $exp = ldap_explode_dn($item['dn'], 1); + echo "Menü Eintrag ".$exp[0]." in PXE Bootmenü ".$exp[1]."   [ Abteilung: ".$exp[4]." ]
"; + } + } + else{ + echo "Keine Menü Einträge davon betroffen!
"; + } + } +} + +if($type == "rbs"){ + $rbsDN = $dn; + $attribs = array("dn"); + if(!($result = uniLdapSearch($ds, "ou=RIPM,".$suffix, "(&(objectclass=PXEConfig)(rbservicedn=$rbsDN))", $attribs, "dn", "sub", 0, 0))) { + # redirect(5, "", $ldapError, FALSE); + echo "no search"; + die; + } + else{ + $result = ldapArraySauber($result); + if (count($result) > 0){ + echo "Folgende PXE Boot Menüs sind davon betroffen:

"; + foreach ($result as $item){ + $exp = ldap_explode_dn($item['dn'], 1); + echo "PXE Boot Menü ".$exp[0]." an Objekt ".$exp[1]."   [ Abteilung: ".$exp[3]." ]
"; + } + } + else{ + echo "Keine PXE Boot Menüs davon betroffen!
"; + } + } +} + + echo "

+ Wollen Sie das Objekt ".$name." wirklich löschen?

+
+ Falls ja:

+ + + + +

+
+
+ Falls, nein:

+ +
+
+ +"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm.dwt b/ldap-site-mngmt/webinterface/rbs/gbm.dwt new file mode 100644 index 00000000..b2f77800 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm.dwt @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Generisches Boot Image   {GBMCN}

+ + + + + + + + + + + + + + +
AttributWert
Eindeutiger Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +   +

KERNEL und APPEND Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributServer PfadWertWert
KERNEL Image: + {TFTP}::{TFTPPATH} + + +
Initialram FS
(APPEND initrd=..):
+ {TFTP}::{TFTPPATH} + + +
Root Filesystem
(APPEND rootfs=..):
+ {SELECTOPTIONS} + + + +
IPAPPEND:    + + +
+

Generisches Boot Image  {GBMCN}  löschen:

+ + + + + + + + + + + + + +
+ Das generische Boot Image wird komplett gelöscht. +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm.php b/ldap-site-mngmt/webinterface/rbs/gbm.php new file mode 100644 index 00000000..59aefc5a --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm.php @@ -0,0 +1,110 @@ +assign(array("RBSCN" => $rbs_data['cn'], + "NFS" => $rbs_data['nfsserverip'], + "NFSPATH" => $rbs_data['exportpath'], + "TFTP" => $rbs_data['tftpserverip'], + "TFTPPATH" => $rbs_data['tftppath'], + "NBD" => $rbs_data['nbdserverip'])); + + +$template->assign(array("GBMDN" => $gbmDN, + "GBMCN" => "", + "LABEL" => "", + "KERNEL" => "", + "INITRD" => "", + "FSTYPE" => "", + "ROOTFS" => "", + "IPAPPEND" => "")); + +# GBM Daten +$attributes = array("dn","cn","label","kernel","initrd","rootfstype","rootfspath","ipappend"); +$gbm = get_node_data($gbmDN, $attributes); + +if ($gbm['rootfstype'] == 'nfs'){ + $options = " + "; +} +if ($gbm['rootfstype'] == 'nbd'){ + $options = " + "; +} +if ($gbm['rootfstype'] == 'dnbd'){ + $options = " + "; +} +if ($gbm['rootfstype'] != 'nfs' && $gbm['rootfstype'] != 'nbd' && $gbm['rootfstype'] != 'dnbd'){ + $options = " + "; +} + + +$template->assign(array("GBMCN" => $gbm['cn'], + "LABEL" => $gbm['label'], + "KERNEL" => $gbm['kernel'], + "INITRD" => $gbm['initrd'], + "SELECTOPTIONS" => $options, + "ROOTFS" => $gbm['rootfspath'], + "IPAPPEND" => $gbm['ipappend'], + "RBSDN" => $rbsDN, + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + + +################################################################################### + +include("rbs_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm_add.php b/ldap-site-mngmt/webinterface/rbs/gbm_add.php new file mode 100644 index 00000000..2202b4fb --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm_add.php @@ -0,0 +1,68 @@ +
"; + +$seconds = 2; +$get_gbmcn = str_replace ( " ", "_", $gbmcn ); +$url = "gbm.php?gbmcn=".$get_gbmcn."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + + +if ( $gbmcn != "" && $gbmcn != "Hier_NAME_eintragen" ){ + + # Formulareingaben anpassen + $expgbm = explode(" ",$gbmcn); + foreach ($expgbm as $word){$expuc[] = ucfirst($word);} + $gbmcn = implode(" ",$expuc); + $gbmcn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $gbmcn); + + $gbmDN = "cn=".$gbmcn.",".$rbsDN; + + if (add_gbm($gbmDN,$gbmcn,$atts)){ + $mesg .= "
Neuen Generischen Menü Eintrag erfolgreich angelegt
"; + $url = "gbm_overview.php"; + } + else{ + $mesg .= "
Fehler beim anlegen des Generischen Menü Eintrags!
"; + } +} + +elseif ( $gbmcn == "" || $gbmcn == "Hier_NAME_eintragen" ){ + + $mesg = "Sie haben den Namen des neuen Generischen Menü Eintrags nicht angegeben. + Dies ist aber ein notwendiges Attribut.
+ Bitte geben Sie sie an.

"; + $url = "new_gbm.php?gbmcn=Hier_NAME_eintragen&mnr=".$mnr."&sbmnr=".$sbmnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm_change.php b/ldap-site-mngmt/webinterface/rbs/gbm_change.php new file mode 100644 index 00000000..86067acd --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm_change.php @@ -0,0 +1,210 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + +$seconds = 2; +$get_mecn = str_replace ( " ", "_", $mecn ); +$url = "gbm.php?dn=".$gbmDN."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# GBM CN (DN) + +if ( $oldgbmcn == $gbmcn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldgbmcn != "" && $gbmcn != "" && $oldgbmcn != $gbmcn ){ + echo "Name Generisches Boot Menü aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $expgbm = explode(" ",$gbmcn); + foreach ($expgbm as $word){$expuc[] = ucfirst($word);} + $gbmcn = implode(" ",$expuc); + $gbmcn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $gbmcn); + + + $newgbmDN = "cn=".$gbmcn.",".$rbsDN; + print_r($newgbmDN); echo "

"; + + if(move_subtree($gbmDN, $newgbmDN)){ + adjust_gbm_dn($newgbmDN, $gbmDN); + $mesg = "Name Generisches Bootmenü erfolgreich geändert

"; + $gbmDN = $newgbmDN; + }else{ + $mesg = "Fehler beim ändern des Namen des Generischen Bootmenüs!

"; + } + + # newsubmenu holen... + $url = "gbm.php?dn=".$newgbmDN."&mnr=".$mnr."&sbmnr=".$sbmnr; +} + +if ( $oldgbmcn != "" && $gbmcn == "" ){ + echo "Name Generisches Bootmenü loeschen!
+ Dieses ist Teil des DN, Sie werden des Generische Boot Menü komplett löschen

"; + echo "Wollen Sie das Generische Boot Menü ".$oldgbmcn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + +################################### +# RootFS Type + +if ( $oldrootfstype == $rootfstype ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldrootfstype == "" && $rootfstype != "" ){ + $entryadd ['rootfstype'] = $rootfstype; + if(ldap_mod_add($ds,$gbmDN,$entryadd)){ + $mesg = "Attribute RootfsType erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute RootfsType

"; + } +} + + +if ( $oldrootfstype != "" && $rootfstype != "" && $oldrootfstype != $rootfstype ){ + echo "Root FS Type ändern
"; + $entrymod ['rootfstype'] = $rootfstype; + if(ldap_mod_replace($ds,$gbmDN,$entrymod)){ + $mesg = "Attribute RootfsType erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute RootfsType

"; + } +} + + +if ( $oldrootfstype != "" && $rootfstype == "" ){ + echo "Root FS Type löschen!
"; + $entrydel ['rootfstype'] = array(); + if(ldap_mod_del($ds,$gbmDN,$entrydel)){ + $mesg = "Attribute RootfsType erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute RootfsType

"; + } +} + + +################################### +# restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + # nix + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$gbmDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$gbmDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$gbmDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm_delete.php b/ldap-site-mngmt/webinterface/rbs/gbm_delete.php new file mode 100644 index 00000000..8777981a --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm_delete.php @@ -0,0 +1,40 @@ + + + Computers Management + + + + +
"; + +if ( $gbmDN != ""){ + + clean_up_del_gbm($gbmDN); + if ( dive_into_tree_del($gbmDN,"") ){ + clean_up_del_gbm($gbmDN); + $mesg = "Generisches Bootmenü ".$gbmcn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des Generischen Bootmenüs ".$gbmcn." !

"; + } + +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm_overview.dwt b/ldap-site-mngmt/webinterface/rbs/gbm_overview.dwt new file mode 100644 index 00000000..794315e6 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm_overview.dwt @@ -0,0 +1,29 @@ + + + + + + + + + + + +

Generische Boot Images

+ Diese Boot Images werden vom Remote Boot Service {RBSCN} + angeboten. Sie können für jedes Image festlegen, wer dieses Angebot in Anspruch nehmen + kann (Spektrum zwischen (a) ihrer Abteilung {AU} und ihrer Unterabteilungen, und (b) organisationsweit)
+ + + + + + + + + + + + + +
Generisches Boot MenüNetzwerk Dateisystem
{GBMCN}  {FS} 
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/gbm_overview.php b/ldap-site-mngmt/webinterface/rbs/gbm_overview.php new file mode 100644 index 00000000..1158a396 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/gbm_overview.php @@ -0,0 +1,56 @@ +assign(array("GBMDN" => "", + "GBMCN" => "Noch keine Generischen Boot Menüs angelegt", + "KERNEL" => "", + "FS" => "")); + +# rbservice und pxe daten (voerst nur ein rbs) +$rbs_array = get_rbservices($auDN,array("dn","cn")); +$rbsDN = $rbs_array[0]['dn']; + +# Generic Bootmenüs +$generic_bms = get_menuentries($rbsDN,array("dn","cn","label","kernel","nfsroot","nbdroot")); + +$template->define_dynamic("Genericbm", "Webseite"); +$template->define_dynamic("Offers", "Webseite"); +foreach ($generic_bms as $gbm){ + if ($gbm['nfsroot'] != ""){$fs = "NFS";} + if ($gbm['nbdroot'] != ""){$fs = "NBD";} + $template->assign(array("GBMDN" => $gbm['dn'], + "GBMCN" => $gbm['cn'], + "KERNEL" => $gbm['kernel'], + "FS" => $fs)); + $template->parse("GENERICBM_LIST", ".Genericbm"); +} + + +################################################################################### + +include("rbs_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/rbs/menu.dwt b/ldap-site-mngmt/webinterface/rbs/menu.dwt new file mode 100644 index 00000000..fe37aeee --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menu.dwt @@ -0,0 +1,31 @@ + + + + + + + + + + + + + + + + + + + + + {SUB} + + + + + + + + +
{ICON}  + {TEXT_M} 
diff --git a/ldap-site-mngmt/webinterface/rbs/menuentry.dwt b/ldap-site-mngmt/webinterface/rbs/menuentry.dwt new file mode 100644 index 00000000..07f71d95 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuentry.dwt @@ -0,0 +1,247 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Zurück zu  {PXECN}

 

Boot Menü Eintrag   {MECN}

 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +   +
Label:   + +   +
Generisches Boot Image:

(Angeboten von)  
+

{GMECN}

Abteilung: {GMEOU} [Remote Boot Dienst: {GMERBS}] +
Menu Label:   + +   +
Menu Default:   + +   +
Menu Passwd:   + +   +
Menu Hide:   + +   +
Localboot:   + +   +

APPEND Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Client Konfiguration via:   + + ( dhcp | file | ldap ) +
vga:   + +   +
splash:   + +   +
vci:   + +   +
no ldsc:   + +   +
elevator:   + +   +
apic:   + +   +
Union FS:   + +   +
cowloop:   + +   +
Debug Level:   + +   +
Menü Position:   + +   +
Submenü Verweis:   + +
+ Dieses Feld sollte nur bei Verweisen auf Submenüs den vollständigen Link zu diesen enthalten +
(d.h. <TFTP-Server-IP>::/<TFTP-PXE-Pfad>/<Timerange>/<PXE-Dateiname>).
+ Bei Textzeilen und Leerzeilen muss hier "self" stehen.
+ Bei normalen Menüeinträgen (inklusive Localboot) muss diese Feld leer sein. +   +
Kernel:   + +
+ Angabe hier nur sinnvoll bei Leer-, Textzeilen oder Submenüverweisen,
+ denn Eingabe wird, wenn der Menüeintrag auf ein generisches Boot Image verweist (siehe oben)
+ bei der PXE Datei Generierung überschrieben. +   +
+

Boot Menü Eintrag  {MECN}  löschen:

+ + + + + + + + + + + + + + +
+ Das generische Boot Image wird komplett gelöscht. +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/menuentry.php b/ldap-site-mngmt/webinterface/rbs/menuentry.php new file mode 100644 index 00000000..83396ec8 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuentry.php @@ -0,0 +1,158 @@ +assign(array("MEDN" => $meDN, + "MECN" => $me['cn'], + "GMECN" => $gmecn, + "GMEOU" => $gmeou, + "GMERBS" => $gmerbs, + "LABEL" => $me['label'], + "MELABEL" => $me['menulabel'], + "MEDEF" => $me['menudefault'], + "MEPASSWD" => $me['menupasswd'], + "MEHIDE" => $me['menuhide'], + "VGA" => $me['vga'], + "SPLASH" => $me['splash'], + "NOLDSC" => $me['noldsc'], + "ELEVATOR" => $me['elevator'], + "VCI" => $me['vci'], + "CCV" => $me['clientconfvia'], + "APIC" => $me['apic'], + "COWLOOP" => $me['cowloop'], + "UNIONFS" => $me['unionfs'], + "DEBUG" => $me['debug'], + "MENPOS" => $me['menuposition'], + "LOCALBOOT" => $me['localboot'], + "KERNEL" => $me['kernel'], + "SUBMENULINK" => $me['submenulink'], + "PXEDN" => $pxeDN, + "PXECN" => $pxecn, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +# Alternative RB Dienste holen +$altrbs = get_rbservices($auDN,array("dn","cn")); +if (count($altrbs) != 0){ + for ($i=0; $i < count($altrbs); $i++){ + if ($rbsDN == $altrbs[$i]['dn']){ + array_splice($altrbs, $i, 1); + } + } +} + + +if (count($altrbs) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($altrbs as $item){ + $altrbsexp = explode(',',$item['dn']); + $altrbsau = explode('=',$altrebsexp[2]); + $template->assign(array("ALTRBSDN" => $item['dn'], + "ALTRBSCN" => $item['cn'], + "ALTRBSAU" => "[ ".$altrbsau[1]." ]")); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +}else{ + $template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); +} + +################################################ +# Bootmenü Einträge + +$menuentries = get_menuentries($pxeDN,array("dn","menuposition","label","menulabel")); +#print_r($menuentries); echo "
"; + +$template->define_dynamic("Bootmenu", "Webseite"); + +foreach ($menuentries as $me){ + $template->assign(array("MENDN" => $me['dn'], + "MENULABEL" => $me['menulabel'], + "POSITION" => $me['menuposition'], + "AUDN" => $auDN)); + $template->parse("BOOTMENU_LIST", ".Bootmenu"); +} + + +################################################ +# PXE kopieren + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + +################################################################################### + +include("rbs_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/rbs/menuentry_add.php b/ldap-site-mngmt/webinterface/rbs/menuentry_add.php new file mode 100644 index 00000000..8b0c4368 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuentry_add.php @@ -0,0 +1,258 @@ +
"; + +$seconds = 2; +$get_mecn = str_replace ( " ", "_", $mecn ); +$url = "pxe.php?dn=".$pxeDN."&mecn=".$get_mecn."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; +# switch wäre besser ... +if ($typ == "newme" && $typ != "local" && $typ != "text" && $typ != "leer" && $typ != "submenu" ){ + + if ( $mecn != "" && $mecn != "Hier_NAME_eintragen" && $gbmDN != "none" ){ + + # Formulareingaben anpassen + $expme = explode(" ",$mecn); + foreach ($expme as $word){$expuc[] = ucfirst($word);} + $mecn = implode(" ",$expuc); + $mecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mecn); + + if ($menpos != ""){ + # Syntaxcheck Menüposition + #$syntax = new Syntaxcheck; + #if (!($syntax->check_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + $meDN = "cn=".$mecn.",".$pxeDN; + + if (add_me($meDN,$mecn,$gbmDN,$menpos,$meatts,$pxeDN)){ + $mesg .= "
Neuen Menü Eintrag erfolgreich angelegt
"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + } + else{ + $mesg .= "
Fehler beim anlegen des Menü Eintrags!
"; + } + } + + elseif ( $mecn == "" || $mecn == "Hier_NAME_eintragen" || $gbmDN == "none" ){ + + $mesg = "Sie haben den Namen des neuen Menü Eintrags nicht angegeben oder kein + Generisches Boot Image ausgewählt. Beide sind aber ein notwendige Attribute.
+ Bitte geben Sie sie an.

"; + $url = "new_menuentry.php?mecn=Hier_NAME_eintragen&mnr=".$mnr."&sbmnr=".$sbmnr; + } +} + +# Localboot Zeile hinzufügen +elseif ($typ == "local" && $typ != "newme" && $typ != "text" && $typ != "leer" && $typ != "submenu" ){ + + # Menu Position + $menpos = $_POST['localpos']; + if ($menpos != ""){ + # Syntaxcheck Menüposition + #$syntax = new Syntaxcheck; + #if (!($syntax->check_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + # CN bilden + $brothers = get_menuentries($pxeDN,array("dn","cn")); + $i=1; + $localcn = "localboot".$i; + if(count($brothers) != 0){ + for ($c=0; $ccheck_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + $text = $_POST['text']; + if($text != "" && $text != "TEXT"){ + $brothers = get_menuentries($pxeDN,array("dn","cn")); + $i=1; + $textcn = "textzeile".$i; + if(count($brothers) != 0){ + for ($c=0; $ccheck_menuposition($menpos))){ + # $menpos = $maxpos; + #} + }else{ + $menpos = $maxpos; + } + if (strlen($menpos) == 1){ + $menpos = "0".$menpos; + } + # nun doch führende Nullen erzwingen + # also obsolet: $menpos = preg_replace ( '/0([0-9])/', '$1', $menpos); + + # CN bilden + $brothers = get_menuentries($pxeDN,array("dn","cn")); + $i=1; + $leercn = "leerzeile".$i; + if(count($brothers) != 0){ + for ($c=0; $cback"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/menuentry_change.php b/ldap-site-mngmt/webinterface/rbs/menuentry_change.php new file mode 100644 index 00000000..40d5d60d --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuentry_change.php @@ -0,0 +1,207 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + + +$seconds = 2; +$get_mecn = str_replace ( " ", "_", $mecn ); +$url = "menuentry.php?dn=".$meDN."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# ME CN (DN) + +if ( $oldmecn == $mecn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldmecn != "" && $mecn != "" && $oldmecn != $mecn ){ + echo "Menü Eintrag Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $expme = explode(" ",$mecn); + foreach ($expme as $word){$expuc[] = ucfirst($word);} + $mecn = implode(" ",$expuc); + $mecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $mecn); + + + $newmeDN = "cn=".$mecn.",".$pxeDN; + print_r($newmeDN); echo "

"; + + if(modify_me_dn($meDN, $newmeDN)){ + $mesg = "Menü Eintrag Name erfolgreich geändert

"; + $meDN = $newmeDN; + }else{ + $mesg = "Fehler beim ändern des PMenü Eintrag Namen!

"; + } + + + # newsubmenu holen... + $url = "menuentry.php?dn=".$newmeDN."&mnr=".$mnr."&sbmnr=".$sbmnr; +} + +if ( $oldmecn != "" && $mecn == "" ){ + echo "Menü Eintrag Name loeschen!
+ Dieses ist Teil des DN, Sie werden den Menü Eintrag komplett löschen

"; + echo "Wollen Sie den Menü Eintrag ".$oldmecn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + +################################### +# Menu Position + +if ( $menpos == $oldmenpos || $menpos == "" ){ + # keine Änderung +} + +if ( $menpos != "" && $oldmenpos != $menpos ){ + echo "Menü Position ändern

"; + # Syntax Check fehlt noch + + # switch partner finden + $secmeDN = get_dn_menuposition($pxeDN,$menpos); + $entrysec ['menuposition'] = $oldmenpos; + if (ldap_mod_replace($ds,$secmeDN,$entrysec)){ + $entry ['menuposition'] = $menpos; + if (ldap_mod_replace($ds,$meDN,$entry)){ + #cleanup_menupositions($pxeDN); + $mesg .= "Menü Position erfolgeich nach ".$menpos." geändert"; + }else{ + $mesg .= "Fehler beim ändern der Menü Position!"; + } + }else{ + $mesg .= "Fehler beim ändern der Menü Position!"; + } +} + +################################### +# restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + # nix + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$meDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$meDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$meDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + +################################### +# Ende, noch Redirect + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/menuentry_delete.php b/ldap-site-mngmt/webinterface/rbs/menuentry_delete.php new file mode 100644 index 00000000..ba06eb55 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuentry_delete.php @@ -0,0 +1,41 @@ + + + Computers Management + + + + +
"; + +if ( $meDN != ""){ + + if ( dive_into_tree_del($meDN,"") ){ + cleanup_menupositions($pxeDN); + $mesg = "Bootmenü Eintrag ".$mecn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des Bootmenü Eintrags ".$mecn." !

"; + } + +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/menuposition_down.php b/ldap-site-mngmt/webinterface/rbs/menuposition_down.php new file mode 100644 index 00000000..d7b235ce --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuposition_down.php @@ -0,0 +1,41 @@ +"; + $entrysec ['menuposition'] = $oldpos; + if ($result = ldap_mod_replace($ds,$secmeDN,$entrysec)){ + $entrymenu ['menuposition'] = $newpos; + $result = ldap_mod_replace($ds,$meDN,$entrymenu); + } + } +} +$seconds = 0; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&#menu"; +$mesg = ""; +#$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+# Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/menuposition_up.php b/ldap-site-mngmt/webinterface/rbs/menuposition_up.php new file mode 100644 index 00000000..c2611651 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/menuposition_up.php @@ -0,0 +1,39 @@ +"; + $entrysec ['menuposition'] = $oldpos; + if ($result = ldap_mod_replace($ds,$secmeDN,$entrysec)){ + $entrymenu ['menuposition'] = $newpos; + $result = ldap_mod_replace($ds,$meDN,$entrymenu); + } + + } +} +$seconds = 0; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&#menu"; +$mesg = ""; +#$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+# Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_gbm.dwt b/ldap-site-mngmt/webinterface/rbs/new_gbm.dwt new file mode 100644 index 00000000..b84cf66d --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_gbm.dwt @@ -0,0 +1,91 @@ + + + + + + + + + + + + + + + + + + + + + + + + +

Generisches Boot Image   {GBMCN}

+ + + + + + + + + + + + + + +
AttributWert
Eindeutiger Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +

KERNEL und APPEND Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributServer PfadWertWert
KERNEL Image:   + {TFTP}::{TFTPPATH} + +
Initrd (APPEND):   + {TFTP}::{TFTPPATH} + + +
Root Filesystem
(APPEND rootfs=..):
+ + +
IPAPPEND:    + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_gbm.php b/ldap-site-mngmt/webinterface/rbs/new_gbm.php new file mode 100644 index 00000000..4ece741c --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_gbm.php @@ -0,0 +1,66 @@ +assign(array("RBSCN" => $rbs_data['cn'], + "TFTP" => $rbs_data['tftpserverip'], + "TFTPPATH" => $rbs_data['tftppath'], + "NFS" => $rbs_data['nfsserverip'], + "NFSPATH" => $rbs_data['exportpath'], + "NBD" => $rbs_data['nbdserverip'])); + + +$options = " + + + "; + +$template->assign(array("GBMCN" => $gbmcn, + "LABEL" => "", + "KERNEL" => "", + "INITRD" => "", + "SELECTOPTIONS" => $options, + "ROOTFS" => "", + "IPAPPEND" => "", + "RBSDN" => $rbsDN, + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + + + +################################################################################### + +include("rbs_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_menuentry.dwt b/ldap-site-mngmt/webinterface/rbs/new_menuentry.dwt new file mode 100644 index 00000000..2b0e7860 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_menuentry.dwt @@ -0,0 +1,188 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Zurück zu  {PXECN}

 

Neuen Boot Menü Eintrag anlegen:

 

Notwendige Attribute:

+ + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ +
Label:   + +
Generische Boot Images:
(Wählen Sie eines aus)  
+ +
Menü Position:
+ (Bitte ohne führende Null) 
+ +
 

Optionale Attribute:

+ + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Menu Label:
(Wird im Bootmenü statt Label angezeigt)  
+ +
Menu Passwd:   + +
Menu Hide:   + +
Localboot:   + +

APPEND Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Client Konfiguration via:   + +
vga:   + +
splash:   + +
vci:   + +
no ldsc:   + +
elevator:   + +
apic:   + +
Union FS:   + +
cowloop:   + +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_menuentry.php b/ldap-site-mngmt/webinterface/rbs/new_menuentry.php new file mode 100644 index 00000000..a6ee6e3e --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_menuentry.php @@ -0,0 +1,166 @@ +assign(array("MECN" => $mecn, + "LABEL" => "", + "MELABEL" => "", + "MEDEF" => "", + "MEPASSWD" => "", + "MEHIDE" => "", + "VGA" => "", + "SPLASH" => "", + "NOLDSC" => "", + "ELEVATOR" => "", + "VCI" => "", + "CCV" => "", + "APIC" => "", + "COWLOOP" => "", + "UNIONFS" => "", + "DEBUG" => "", + "LOCALBOOT" => "", + "SUBMENULINK" => "", + "MENPOS" => "", + "MAXPOS" => $maxpos, + "PXEDN" => $pxeDN, + "PXECN" => $pxecn, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + + +# verwendbare GBMs holen +# eigene AU (andere noch über "offer" Attribut in RBS suchen) +$attributes = array("dn","cn","label","kernel","initrd","nfsroot","nbdroot","ipappend"); +$gbm_array = get_menuentries($rbsDN,$attributes); +if (count($gbm_array) != 0){ +$template->define_dynamic("Gbms", "Webseite"); + foreach ($gbm_array as $item){ + $template->assign(array("GBMDN" => $item['dn'], + "GBMCN" => $item['cn'], + "GBMLABEL" => $item['label'], + "RBSAU" => $rbsau)); + $template->parse("GBMS_LIST", ".Gbms"); + } +}else{ + $template->assign(array("GBMDN" => "", + "GBMCN" => "Keine generischen Boot Images verfügbar", + "GBMLABEL" => "Keine generischen Boot Images verfügbar", + "RBSAU" => "")); +} + + +# Alternative RB Dienste holen +$altrbs = get_rbservices($auDN,array("dn","cn")); +if (count($altrbs) != 0){ + for ($i=0; $i < count($altrbs); $i++){ + if ($rbsDN == $altrbs[$i]['dn']){ + array_splice($altrbs, $i, 1); + } + } +} + + +if (count($altrbs) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($altrbs as $item){ + $altrbsexp = explode(',',$item['dn']); + $altrbsau = explode('=',$altrebsexp[2]); + $template->assign(array("ALTRBSDN" => $item['dn'], + "ALTRBSCN" => $item['cn'], + "ALTRBSAU" => "[ ".$altrbsau[1]." ]")); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +}else{ + $template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); +} + +################################################ +# Bootmenü Einträge + +$menuentries = get_menuentries($pxeDN,array("dn","menuposition","label","menulabel")); +#print_r($menuentries); echo "
"; + +$template->define_dynamic("Bootmenu", "Webseite"); + +foreach ($menuentries as $me){ + $template->assign(array("MENDN" => $me['dn'], + "MENULABEL" => $me['menulabel'], + "POSITION" => $me['menuposition'], + "AUDN" => $auDN)); + $template->parse("BOOTMENU_LIST", ".Bootmenu"); +} + + +################################################ +# PXE kopieren + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + +################################################################################### + +include("rbs_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/rbs/new_pxe.dwt b/ldap-site-mngmt/webinterface/rbs/new_pxe.dwt new file mode 100644 index 00000000..c97324b5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_pxe.dwt @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + +

Neues DEFAULT PXE Boot Menü anlegen:

 

Allgemein:

+ + + + + + + + + + + + + + + + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
+ PXE_ +
Remote Boot Dienst
+ auswählen:
 
+ +
Gültigkeitsdauer
(Time Range):
 
+ +  
+ Eines der folgenden:
+ + - Datum  (Format: dd.mm, z.B. 21.03/01.11)
+ - Monatstag  (Format: dd, z.B. 01 oder 25)
+ - Wochentag  (Format: MO, DI, ... , SO)
+ - X für täglich + +
+ + :00  -   + + :59 Uhr
+ - Uhrzeit  (Format: hh, z.B. 07-19)
+ - X für rund um die Uhr +

Globale PXE Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Default:   + +   +
Menu Title:   + +   +
Menu Master Passwd:   + +   +
Timeout:   + +   +
No Escape:   + +   +
Prompt:   + +   +
Allow Options:   + +   +
On Error:   + +   +
ON Timeout:   + +   +
Client-Conf Dateiname
(File URI):  
+ +   +
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_pxe.php b/ldap-site-mngmt/webinterface/rbs/new_pxe.php new file mode 100644 index 00000000..9a6afba0 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_pxe.php @@ -0,0 +1,95 @@ +assign(array("PXECN" => $pxecn, + "PXEDAY" => $pxeday, + "PXEBEG" => $pxebeg, + "PXEEND" => $pxeend, + "LDAPURI" => "", + "FILEURI" => "", + "RBS" => "", + "RBSAU" => "", + "NFS" => "", + "NFSROOT" => "", + "TFTP" => "", + "TFTPROOT" => "", + "FILE" => "", + "ALLOW" => "", + "CONSOLE" => "", + "DEFAULT" => "menu.c32", + "DISPLAY" => "", + "FONT" => "", + "IMPLICIT" => "", + "KBDMAP" => "", + "MENMPW" => "", + "MENTIT" => "", + "NOESC" => "1", + "ONERR" => "", + "ONTIME" => "", + "PROMPT" => "0", + "SAY" => "", + "SERIAL" => "", + "TIMEOUT" => "600", + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + +############################################# +# RB Dienste holen +$rbsoffers = get_rbsoffers($auDN); + +$template->assign(array("ALTRBSDN" => "", + "ALTRBSCN" => "", + "ALTRBSAU" => "")); + +if (count($rbsoffers) != 0){ +$template->define_dynamic("Altrbs", "Webseite"); + foreach ($rbsoffers as $item){ + $rbsdnexp = ldap_explode_dn($item,1); + $rbsoffcn = $rbsdnexp[0]; + $rbsoffau = $rbsdnexp[2]; + #$auexp = explode(',',$item['auDN']); + #$altrbsau = explode('=',$auexp[0]); + $template->assign(array("ALTRBSDN" => $item, + "ALTRBSCN" => $rbsoffcn, + "ALTRBSAU" => "   [ Abt.: ".$rbsoffau." ]")); + $template->parse("ALTRBS_LIST", ".Altrbs"); + } +} + +################################################################################### + +include("rbs_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_rbservice.dwt b/ldap-site-mngmt/webinterface/rbs/new_rbservice.dwt new file mode 100644 index 00000000..52e693b5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_rbservice.dwt @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + +

Remote Boot Service anlegen

+ + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger RBS Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ RBS_ +
+ Wer soll Dienst nutzen dürfen:
(Wählen Sie eine Abteilung,
+ impliziert alle Unterabteilungen) +
+ +

Boot Server System:

+ + + + + + + + + + + + + + + + + + + + + + + + + + +
ServerIP Adresse eingeben oder
Rechner auswählen
Pfad
(auf dem jeweiligen Server)
TFTP Server:   + + + + Initial Boot File
+ Kernel Path
+ PXE Path
+ Clientconf Path +
NFS Server:   + + + + +
NBD Server:   + + +  
+
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/new_rbservice.php b/ldap-site-mngmt/webinterface/rbs/new_rbservice.php new file mode 100644 index 00000000..020e3254 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/new_rbservice.php @@ -0,0 +1,107 @@ +Sie werden automatisch auf die nächste Seite geleitet.
+ Falls nicht, klicken Sie hier hier"; + redirect($seconds, $url, $mesg, $addSessionId = TRUE); +} + +$rbscn = str_replace ( "_", " ", $_GET['rbscn']); +$template->assign(array("RBSCN" => $rbscn, + "TFTP" => "", + "TFTPIP" => "", + "INITBOOTFILE" => "", + "TFTPKERNEL" => "", + "TFTPPXE" => "", + "TFTPCLIENTCONF" => "", + "NFS" => "", + "NFSIP" => "", + "NFSPATH" => "", + "NBD" => "", + "NBDIP" => "", + "HDN" => "", + "HN" => "", + "IP" => "", + "OFFERSELF" => $auDN, + "SELFOU" => $au_ou, + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + + +# RBS Anbieten (ausser eigene AU) +$expdn = ldap_explode_dn($auDN, 0); # Mit Merkmalen +$expdn = array_slice($expdn, 2); +$expou = ldap_explode_dn($auDN, 1); # nur Werte +$expou = array_slice($expou, 2, -3); +#print_r($expou); echo "
"; +#print_r($expdn); echo "
"; +for ($i=0; $idefine_dynamic("Rbsoffers", "Webseite"); +foreach ($rbsoffers as $offer){ + $template->assign(array("RBSOFFER" => $offer['dn'], + "RBSOFFEROU" => $offer['ou'],)); + $template->parse("RBSOFFERS_LIST", ".Rbsoffers"); +} + +### Rechner +$hostorgroup = $exp[0]; +$hosts_array = get_hosts($auDN,array("dn","hostname","ipaddress")); + +$template->define_dynamic("TftpHosts", "Webseite"); +$template->define_dynamic("NfsHosts", "Webseite"); +$template->define_dynamic("NbdHosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $item['ipaddress'])); + $template->parse("TFTPHOSTS_LIST", ".TftpHosts"); + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $item['ipaddress'])); + $template->parse("NFSHOSTS_LIST", ".NfsHosts"); + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $item['ipaddress'])); + $template->parse("NBDHOSTS_LIST", ".NbdHosts"); +} + + +################################################################################### + +include("rbs_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/no_rbservice.dwt b/ldap-site-mngmt/webinterface/rbs/no_rbservice.dwt new file mode 100644 index 00000000..2d7c1a87 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/no_rbservice.dwt @@ -0,0 +1,22 @@ + + + + + +

Remote Boot Service

+ +

Sie haben noch keinen Remote Boot Service eingerichtet.

+ +

Um

+ +
    +
  • Generische Boot Menüs

  • +
  • Default PXE Bootmenüs

  • +
+ +

anlegen zu können muss erst ein Remote Boot Service eingerichtet werden.

+ +

Verwenden sie dafür den Link "Remote Boot Service" im Navigationsmenü links, um + zur Eingabemaske zu gelangen.

+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/no_rbservice.php b/ldap-site-mngmt/webinterface/rbs/no_rbservice.php new file mode 100644 index 00000000..657e3738 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/no_rbservice.php @@ -0,0 +1,32 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/pxe.dwt b/ldap-site-mngmt/webinterface/rbs/pxe.dwt new file mode 100644 index 00000000..4ce35565 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe.dwt @@ -0,0 +1,453 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

PXE Boot Menü   {PXECN}

Klicken Sie auf einen Menüeintrag um zur Detailansicht zu gelangen und den Eintrag bearbeiten zu können
+ + + + + + + + + + + + + + + + + + + + + +
#FlagsMenu Label   
{POSITION} {MEDEF} {MEPWD} {MEHIDE} {ANZEIGE}  +
+
+ + + + + + + +

Flags:

+
    +
  • D -> Default Menüeintrag
  • +
  • P -> Passwort geschützt
  • +
  • H -> Hidden
  • +
+

Neuen Menüeintrag anlegen:   

+   zur Eingabemaske  

Standard Menüeinträge anlegen:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Typ    Position 
Localboot   + Menu Label
 
+ Passwort (optional)
 
 
Textzeile    
Leerzeile    
Verweis zu Submenü  Submenü Name
+
Remote Boot Service + +  

Allgemeine Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
  + PXE_ +   +
Gültigkeitsdauer
(Time Range(s)):

+ Zum Löschen einer Time Range
Häkchen setzen 
  + Eines der folgenden:
+ + - Datum  (dd.mm, z.B. 21.03/01.11)
+ - Monatstag  (dd, z.B. 01 oder 25)
+ - Wochentag  (MO, DI, ... , SO)
+ - X für täglich + +
+ - Uhrzeit  (Format: hh, z.B. 07-19)
+ - X für rund um die Uhr + +
  + +   + +  
+ + +
+ + :00  -   + + :59 Uhr
+
Neue Time Range hinzufügen   + + + + + :00  -   + + :59 Uhr
+ +

Globale PXE Parameter:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Default:   + +   +
Menu Title:   + +   +
Menu Master Passwd:   + +   +
Timeout:   + +   +
No Escape:   + +   +
Prompt:   + +   +
Allow Options:   + +   +
On Error:   + +   +
ON Timeout:   + +   +
File URI:   + tftp://{TFTP}/{TFTPFILE} + +   +

PXE Dateiname:

+ Achtung: Änderungen hier können zu nicht verwendeten PXE Dateien führen!
+ Sie sollten hier nur Änderungen vornehmen, wenn der PXE Datei offensichtlich ein falscher Name zugewiesen ist.
+ Wird z.B. vom betroffenen Rechner die MAC Adresse geändert, so wird dies vom System automatisch an dieser Stelle nachvollzogen. + Diese Feld dient daher primär der Kontrolle.
+ + + + + + + +
+ PXE Dateiname(n):
+ Bei PXE von Gruppen ist für jeden Mitgliedsrechner
+ der PXE Dateiname aufgelistet. +
+ + +   + + +
+ + + + + + + +

PXE Boot Menü  {PXECN}  kopieren:

+ Beachten Sie, dass die Time Ranges des PXE Boot Menüs nicht kopiert werden. Sie müssen diese anschließend + neu setzen.
+ Geben Sie bitte den eindeutigen Namen des neuen PXE Boot Menüs an.
+ + + + + + + + + + + + + + + + + + + +
Ziel Objekt:
+ (Mehrfachauswahl möglich) 
+ + +
Eindeutiger Name (cn):
(Bitte ohne Leerzeichen eingeben)  
+ PXE_ +   +
+ +

PXE Boot Menü  {PXECN}  löschen:

+ + + + + + + + + + + + + +
+ Die MachineConfig wird komplett gelöscht. +
+ +
diff --git a/ldap-site-mngmt/webinterface/rbs/pxe.php b/ldap-site-mngmt/webinterface/rbs/pxe.php new file mode 100644 index 00000000..85df99ac --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe.php @@ -0,0 +1,221 @@ +define_dynamic("TRanges", "Webseite"); +if (count($pxe['timerange']) > 1){ + foreach($pxe['timerange'] as $tr){ + $exptime = explode('_',$tr); + $template->assign(array("PXEDAY" => $exptime[0], + "PXEBEG" => $exptime[1], + "PXEEND" => $exptime[2])); + $template->parse("TRANGES_LIST", ".TRanges"); + } +}else{ + $exptime = explode('_',$pxe['timerange']); + $template->assign(array("PXEDAY" => $exptime[0], + "PXEBEG" => $exptime[1], + "PXEEND" => $exptime[2])); + $template->parse("TRANGES_LIST", ".TRanges"); +} + +# Filenames +$template->define_dynamic("Filenames", "Webseite"); +if (count($pxe['filename']) > 1){ + foreach($pxe['filename'] as $fi){ + $template->assign(array("FILE" => $fi)); + $template->parse("FILENAMES_LIST", ".Filenames"); + } +}else{ + $exptime = explode('_',$pxe['filename']); + $template->assign(array("FILE" => $pxe['filename'])); + $template->parse("FILENAMES_LIST", ".Filenames"); +} + +$expcn = explode('_',$pxe['cn']); +$name = array_slice($expcn,1); +$pxecn = implode('_',$name); + +# Bootmenü Einträge +$menuentries = get_menuentries($pxeDN,array("dn","menuposition","label","menulabel","menudefault","menupasswd","menuhide")); +#print_r($menuentries); echo "
"; +$maxpos = count($menuentries)+1; + +# Globale Parameter +$template->assign(array("PXEDN" => $pxeDN, + "PXECN" => $pxecn, + "TIMERANGE" => $pxe['timerange'], + "RBS" => $rbsdata['cn'], + "RBSAU" => $rbsau, + "NFS" => $rbsdata['nfsserverip'], + "NFSROOT" => $rbsdata['exportpath'], + "TFTP" => $rbsdata['tftpserverip'], + "TFTPROOT" => $rbsdata['tftppath'], + "TFTPFILE" => $rbsdata['tftpclientconfpath'], + #"LDAP" => LDAP_HOST, + #"LDAPURI" => $pxe['ldapuri'], + "FILEURI" => $pxe['fileuri'], + "FILE" => $pxe['filename'], + "ALLOW" => $pxe['allowoptions'], + "CONSOLE" => $pxe['console'], + "DEFAULT" => $pxe['default'], + "DISPLAY" => $pxe['display'], + "FONT" => $pxe['font'], + "IMPLICIT" => $pxe['implicit'], + "KBDMAP" => $pxe['kbdmap'], + "MENMPW" => $pxe['menumasterpasswd'], + "MENTIT" => $pxe['menutitle'], + "NOESC" => $pxe['noescape'], + "ONERR" => $pxe['onerror'], + "ONTIME" => $pxe['ontimeout'], + "PROMPT" => $pxe['prompt'], + "SAY" => $pxe['say'], + "SERIAL" => $pxe['serial'], + "TIMEOUT" => $pxe['timeout'], + "MAXPOS" => $maxpos, + "NODEDN" => $nodeDN, + "DEFDN" => $rbsDN, + "MNR" => $mnr, + "SBMNR" => $sbmnr, + "MCNR" => $mcnr)); + +# RB Dienste für Submenüeinträge holen +# kommt wohl wieder raus (->Submenüs nur im eigenen RBS Bereich) +$subrbs = get_rbsoffers($auDN); + +# Für Submenü Einträge +$template->assign(array("SUBRBSDN" => "", + "SUBRBSCN" => "", + "SUBRBSAU" => "")); +if (count($subrbs) != 0){ +$template->define_dynamic("Subrbs", "Webseite"); + foreach ($subrbs as $item){ + $rbsdnexp = ldap_explode_dn($item,1); + $subrbscn = $rbsdnexp[0]; + $subrbsau = $rbsdnexp[2]; + #$subrbsexp = explode(',',$item['dn']); + #$subrbsau = explode('=',$subrbsexp[2]); + $template->assign(array("SUBRBSDN" => $item, + "SUBRBSCN" => $subrbscn, + "SUBRBSAU" => "[ ".$subrbsau." ]")); + $template->parse("SUBRBS_LIST", ".Subrbs"); + } +} + + +################################################ +# Bootmenü Einträge + +$template->define_dynamic("Bootmenu", "Webseite"); +$template->assign(array("MENDN" => "", + "MENULABEL" => "", + "ANZEIGE" => "Noch kein Bootmenü Eintrag angelegt", + "MEDEF" => "", + "MEPWD" => "", + "MEHIDE" => "", + "BGCDEF" => "", + "POSITION" => "")); +foreach ($menuentries as $me){ + $anzeige = ""; + if ($me['label'] != "" && $me['menulabel'] == ""){$anzeige .= $me['label'];} + if ($me['menulabel'] != ""){$anzeige .= $me['menulabel'];} + if ($me['menudefault'] == 1){$medef = "D"; $bgcdef = "background-color:#EEDD82;";} + if ($me['menupasswd'] != ""){$mepwd = "P";} + if ($me['menuhide'] == 1){$mehide = "H"; $bgcdef = "background-color:#A0A0A0;";} + $template->assign(array("MENDN" => $me['dn'], + "ANZEIGE" => "".$anzeige."", + "ANZEIGENAME" => $anzeige, + "POSITION" => $me['menuposition'], + "MEDEF" => $medef, + "MEPWD" => $mepwd, + "MEHIDE" => $mehide, + "BGCDEF" => $bgcdef, + "AUDN" => $auDN)); + $template->parse("BOOTMENU_LIST", ".Bootmenu"); + $medef = ""; + $bgcdef = ""; +} + + + +################################################ +# PXE kopieren + +$hostorgroup = $exp[0]; +$hgexp = explode('=',$exp[0]); + +$hosts_array = get_hosts($auDN,array("dn","hostname")); +$groups_array = get_groups($auDN,array("dn","cn")); + +$template->define_dynamic("Hosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'])); + $template->parse("HOSTS_LIST", ".Hosts"); +} +$template->define_dynamic("Groups", "Webseite"); +foreach ($groups_array as $item){ + $template->assign(array("GDN" => $item['dn'], + "GN" => $item['cn'])); + $template->parse("GROUPS_LIST", ".Groups"); +} + + +# falls TR vorhanden dann soll sie gelöscht werden (flag deltr setzen) +if (count($pxe['timerange']) != 0){ + $template->assign(array("DELTR" => "1")); +} +else{ + $template->assign(array("DELTR" => "0")); +} + +################################################################################### + +include("rbs_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/rbs/pxe_add.php b/ldap-site-mngmt/webinterface/rbs/pxe_add.php new file mode 100644 index 00000000..4b314ab1 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe_add.php @@ -0,0 +1,118 @@ +
"; +$mnr = $_POST['mnr']; +$sbmnr = $_POST['sbmnr']; +$mcnr = $_POST['mcnr']; + + +$seconds = 2; +$get_pxecn = str_replace ( " ", "_", $pxecn ); +$get_pxeday = str_replace ( " ", "_", $pxeday ); +$get_pxebeg = str_replace ( " ", "_", $pxebeg ); +$get_pxeend = str_replace ( " ", "_", $pxeend ); +$url = "new_pxe.php?pxecn=".$get_pxecn."&pxeday=".$get_pxeday."&pxebeg=".$get_pxebeg."&pxeend=".$get_pxeend."&mnr=".$mnr."&sbmnr=".$sbmnr; + +echo " + + + Computers Management + + + + +
"; + +if ( $pxecn != "" && $pxecn != "Hier_PXE_NAME_eintragen" && $rbsDN != "none" ){ + + $pxecn = "PXE_".$pxecn; + # Formulareingaben anpassen + $exppxe = explode(" ",$pxecn); + foreach ($exppxe as $word){$expuc[] = ucfirst($word);} + $pxecn = implode(" ",$expuc); + $pxecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $pxecn); + + $pxetimerange = ""; + + if ( $pxeday != "" && $pxebeg != "" && $pxeend != "" && $pxebeg <= $pxeend ){ + + # TimeRange Syntax checken + $syntax = new Syntaxcheck; + if ($syntax->check_timerange_syntax($pxeday,$pxebeg,$pxeend)){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$pxeday)){$pxeday = strtoupper($pxeday);} + if (preg_match("/([a-z]+)/",$pxebeg)){$pxebeg = strtoupper($pxebeg);} + if (preg_match("/([a-z]+)/",$pxeend)){$pxeend = strtoupper($pxeend);} + + # führende Nullen weg + $pxebeg = preg_replace ( '/0([0-9])/', '$1', $pxebeg); + $pxeend = preg_replace ( '/0([0-9])/', '$1', $pxeend); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken + if(check_timerange_pxe($pxeday,$pxebeg,$pxeend,$rbsDN,"")){ + $pxetimerange = $pxeday."_".$pxebeg."_".$pxeend; + } + else{ + $mesg = "Es existiert bereits ein PXE Boot Menü, das sich mit der eingegebenen Time Range + überschneidet!
+ Das neue PXE Boot Menü wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + } + else{ + $mesg = "Falsche Syntax in der Time-Range-Eingabe! Das neue PXE Boot Menü wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + } + else{ + $mesg = "Keine vollständige Time-Range-Eingabe! Das neue PXE Boot Menü wird ohne Time Range angelegt.
+ Bitte geben Sie diese anschließend ein.

"; + } + + $pxeDN = "cn=".$pxecn.",".$rbsDN; + $filename = array("default"); + #$ldapuri = LDAP_HOST."/dn=cn=computers,".$auDN; + + if (add_pxe($pxeDN,$pxecn,$rbsDN,$pxetimerange,$pxeattribs,$filename,$conffile)){ + $mesg .= "
Neues PXE Boot Menü erfolgreich angelegt
"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + } + else{ + $mesg .= "
Fehler beim anlegen des PXE Boot Menüs!
"; + } +} + +elseif ( $pxecn == "" || $pxecn == "Hier_PXE_NAME_eintragen" || $rbsDN == "none" ){ + + $mesg = "Sie haben den Namen des neuen PXE Boot Menüs nicht angegeben oder den + Remote Boot Dienst nicht ausgewählt. Beide sind aber ein notwendige Attribute.
+ Bitte geben Sie sie an.

"; + $url = "new_pxe.php?pxecn=Hier_PXE_NAME_eintragen&pxeday=".$get_pxeday."&pxebeg=".$get_pxebeg."&pxeend=".$get_pxeend."&mnr=".$mnr."&sbmnr=".$sbmnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/pxe_change.php b/ldap-site-mngmt/webinterface/rbs/pxe_change.php new file mode 100644 index 00000000..d122a830 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe_change.php @@ -0,0 +1,434 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + +$seconds = 2; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# PXE CN (DN) + +if ( $oldpxecn == $pxecn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldpxecn != "" && $pxecn != "" && $oldpxecn != $pxecn ){ + echo "PXE Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $exppxe = explode(" ",$pxecn); + foreach ($exppxe as $word){$expuc[] = ucfirst($word);} + $pxecn = implode(" ",$expuc); + $pxecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $pxecn); + + $newpxeDN = "cn=".$pxecn.",".$nodeDN; + print_r($newpxeDN); echo "

"; + + if(modify_pxe_dn($pxeDN, $newpxeDN)){ + $mesg = "PXE Name erfolgreich geändert

"; + $pxeDN = $newpxeDN; + }else{ + $mesg = "Fehler beim ändern des PXE Namen!

"; + } + + + # newsubmenu holen... + $url = "pxe.php?dn=".$newpxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + +if ( $oldpxecn != "" && $pxecn == "" ){ + echo "Gruppenname loeschen!
+ Dieses ist Teil des DN, Sie werden das PXE Boot Menü komplett löschen

"; + echo "Wollen Sie das PXE Boot Menü ".$oldpxecn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + +########################################## +# Remote Boot Dienst + +if ($rbs != "none"){ + $exp = explode(',',$rbs); + $exprbscn = explode('=',$exp[0]); + $rbscn = $exprbscn[1]; + $exprbsau = explode('=',$exp[2]); + $rbsau = $exprbsau[1]; + + $entryrbs ['rbservicedn'] = $rbs; + if ($result = ldap_mod_replace($ds,$pxeDN,$entryrbs)){ + $mesg = "Remote Boot Service erfolgreich zu ".$rbscn."[Abt.: ".$rbsau."] geändert

"; + }else{ + $mesg = "Fehler beim ändern des Remote Boot Services zu ".$rbscn."!

"; + } +} + + +########################################## +# bereits vorhandene TimeRange(s) bearbeiten + +$entrymodtr = array(); +$modtr = 0; +# TimeRanges zusammensetzen +# $t = 0; # Laufvariable für $entrymodtr, da nicht jede Timerange ok sein muss +for ($i=0; $icheck_timerange_syntax($pxeday[$i],$pxebeg[$i],$pxeend[$i])){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$pxeday[$i])){$pxeday[$i] = strtoupper($pxeday[$i]);} + if (preg_match("/([a-z]+)/",$pxebeg[$i])){$pxebeg[$i] = strtoupper($pxebeg[$i]);} + if (preg_match("/([a-z]+)/",$pxeend[$i])){$pxeend[$i] = strtoupper($pxeend[$i]);} + + # führende Nullen weg + $pxebeg[$i] = preg_replace ( '/0([0-9])/', '$1', $pxebeg[$i]); + $pxeend[$i] = preg_replace ( '/0([0-9])/', '$1', $pxeend[$i]); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken außer mit eigener alter TR da diese + # ja geändert werden soll + if(check_timerange_pxe($pxeday[$i],$pxebeg[$i],$pxeend[$i],$nodeDN,$oldpxetimerange)){ + + $pxetimerange = $pxeday[$i]."_".$pxebeg[$i]."_".$pxeend[$i]; + $entrymodtr ['timerange'][$i] = $pxetimerange; + $modtr = 1; + + } + else{ + $mesg = "Es existiert bereits ein PXE Boot Menü, das sich mit der eingegebenen Time Range + überschneidet!
+ Bitte geben Sie eine andere Time Range ein.

"; + $entrymodtr ['timerange'][$i] = $oldpxetimerange; + } + } + else{ + $mesg = "Falsche Syntax in der Timerange-Eingabe!
+ Bitte geben Sie die erneut Time Range ein.

"; + $entrymodtr ['timerange'][$i] = $oldpxetimerange; + } + +} + + +elseif ( $pxeday[$i] == "" || $pxebeg[$i] == "" || $pxeend[$i] == "" || $pxebeg[$i] > $pxeend[$i]){ + + $mesg = "Sie haben die Time Range Nr.".$i." nicht vollständig angegeben. Diese ist aber ein notwendiges Attribut.
+ Diese Time Range wird nicht bearbeitet.

"; + $entrymodtr ['timerange'][$i] = $oldpxetimerange; +} + +else{$entrymodtr ['timerange'][$i] = $oldpxetimerange;} +} # Ende for-Schleife für jede Timerange +# jetzt noch alle gesammelten Änderungen Durchführen ... +if ($modtr == 1){ + # erst ändern + echo "Ändern: "; print_r($entrymodtr); echo "
"; + if($result = ldap_mod_replace($ds,$pxeDN,$entrymodtr)){ + $mesg = "TimeRanges erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern der TimeRanges!

"; + } +} + + +if ( count($deltr) != 0 && $modtr == 0 ){ + # Time Range löschen + $j = 0; + foreach ($deltr as $delrange){ + $entrydeltr ['timerange'][$j] = $delrange; + $j++; + } + # dann löschen + echo "Löschen: "; print_r($entrydeltr); echo "
"; + if($result = ldap_mod_del($ds,$pxeDN,$entrydeltr)){ + $mesg = "TimeRanges erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen der TimeRanges!

"; + } +}elseif(count($deltr) != 0 && $modtr == 1){ + echo "Nur Ändern (gleichzeitig Löschen und Ändern geht nicht)"; +} + +##################################### +# TimeRange hinzufügen + +if ( $newpxeday != "" && $newpxebeg != "" && $newpxeend != "" && $newpxebeg <= $newpxeend ){ + + # TimeRange Syntax checken + $syntax = new Syntaxcheck; + if ($syntax->check_timerange_syntax($newpxeday,$newpxebeg,$newpxeend)){ + + # in Grossbuchstaben + if (preg_match("/([a-z]+)/",$newpxeday)){$newpxeday = strtoupper($newpxeday);} + if (preg_match("/([a-z]+)/",$newpxebeg)){$newpxebeg = strtoupper($newpxebeg);} + if (preg_match("/([a-z]+)/",$newpxeend)){$newpxeend = strtoupper($newpxeend);} + + # führende Nullen weg + $newpxebeg = preg_replace ( '/0([0-9])/', '$1', $newpxebeg); + $newpxeend = preg_replace ( '/0([0-9])/', '$1', $newpxeend); + + # TimeRange auf Ãœberschneidung mit vorhandenen checken + if(check_timerange_pxe($newpxeday,$newpxebeg,$newpxeend,$nodeDN,"")){ + + $newpxetimerange = $newpxeday."_".$newpxebeg."_".$newpxeend; + $entrytr ['timerange'] = $newpxetimerange; + if($result = ldap_mod_add($ds,$pxeDN,$entrytr)){ + $mesg = "Zusätzliche TimeRange erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der zusätzlichen TimeRange!

"; + } + }else{ + $mesg = "Es existiert bereits ein PXE Boot Menü, das sich mit der eingegebenen Time Range + überschneidet!
+ Bitte geben Sie eine andere Time Range ein.

"; + } + }else{ + $mesg = "Falsche Syntax in der Timerange-Eingabe!
+ Bitte geben Sie die erneut Time Range ein.

"; + } +} + + +##################################### +# PXE Filename(s) + +$filemod = array(); +$modfi = 0; +$filedel = array(); +$delfi = 0; +$j = 0; + +if (count($file) != 0){ + +for ($i=0; $i + Vorsicht dies kann eine nicht verwendbare PXE Datei zur Folge haben!

"; + # hier noch Syntaxcheck + $filemod ['filename'][$i] = $file[$i]; + $modfi = 1; + } + + if ( $oldfile[$i] != "" && $file[$i] == "" ){ + echo "PXE Dateinamen loeschen!
+ Achtung: aus ihren PXE Daten wird keine PXE Datei mehr generiert.
+ Sie sind solange nicht mehr für den PXE Bootvorgang verwendbar bis Sie einen neuen Dateinamen anlegen!

"; + $filemod ['filename'][$i] = $oldfile[$i]; + $filedel ['filename'][$j] = $oldfile[$i]; + $j++; + $delfi = 1; + $seconds = 4; + } +} +#erst ändern +if ($modfi == 1){ + echo "Ändern: "; print_r($filemod); echo "
"; + if(ldap_mod_replace($ds,$pxeDN,$filemod)){ + $mesg = "PXE Dateiname(n) erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern des(r) PXE Dateinamens!

"; + } + $modfi = 0; +} +# dann löschen +if ($delfi == 1){ + echo "Löschen: "; print_r($filedel); echo "
"; + if(ldap_mod_del($ds,$pxeDN,$filedel)){ + $mesg = "PXE Dateiname(n) erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen des PXE Dateinamens !

"; + } + $delfi = 0; +} + +} + +# PXE Dateiname neu anlegen +if ($newfilename == ""){ +} +if ($newfilename != ""){ + echo "PXE Dateiname hinzufügen"; + $fileadd ['filename'] = $newfilename; + if(ldap_mod_add($ds,$pxeDN,$fileadd)){ + $mesg = "PXE Dateiname ".$newfilename." erfolgreich angelegt

"; + }else{ + $mesg = "Fehler beim anlegen des PXE Dateinamens ".$newfilename." !

"; + } +} + + +################################################################## +# Restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} + +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$pxeDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$pxeDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$pxeDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/pxe_copy.php b/ldap-site-mngmt/webinterface/rbs/pxe_copy.php new file mode 100644 index 00000000..92e6ba0b --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe_copy.php @@ -0,0 +1,189 @@ +"; +$n = array_keys($copytargets,'none'); +#print_r($n); echo "
"; +for ($i=0; $i"; + + +$seconds = 2; +$url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + +echo " + + + Computers Management + + + + +
"; + +if ( $pxecn != ""){ + + # Formulareingaben anpassen + $exppxe = explode(" ",$pxecn); + foreach ($exppxe as $word){$expuc[] = ucfirst($word);} + $pxecn = implode(" ",$expuc); + $pxecn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $pxecn); + + $nomac = 0; + + if (count($copytargets) != 0){ + foreach ($copytargets as $targetDN){ + + $exptargetdn = ldap_explode_dn($targetDN, 1); + $targetcn = $exptargetdn[0]; + $targettype = $exptargetdn[1]; + + # falls Target keine MAC hat dann kann keine PXE angelegt werden + if ($targettype == "computers"){ + $macdata = get_node_data($targetDN, array("hwaddress")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Ziel-Rechner ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü wird nicht angelegt.
+
+ Tragen Sie zuerst eine MAC ein!

"; + } + } + if ($targettype == "groups"){ + $members = get_node_data($targetDN, array("member")); + if (count($members) > 1){ + foreach ($members['member'] as $hostDN){ + $macdata = get_node_data($hostDN, array("hwaddress","hostname")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Gruppen-Rechner ".$macdata['hostname']." ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü für die Gruppe wird nicht angelegt.
+
+ Tragen Sie zuerst bei Rechner ".$macdata['hostname']." eine MAC ein!

"; + } + } + } + if (count($members) == 1){ + $macdata = get_node_data($members['member'], array("hwaddress")); + if ($macdata['hwaddress'] == ""){ + $nomac = 1; + echo "Für den Gruppen-Rechner ".$macdata['hostname']." ist keine MAC Adresse eingetragen
+ Das PXE Bootmenü für die Gruppe wird nicht angelegt.
+
+ Tragen Sie zuerst bei Rechner ".$macdata['hostname']." eine MAC ein!

"; + } + } + } + + $brothers = get_pxeconfigs($targetDN,array("cn")); + $brother = 0; + foreach ($brothers as $item){ + if( $item['cn'] == $pxecn ){ + $mesg = "Es existiert bereits ein PXE Boot Menü mit dem eingegebenen Namen!
+ Bitte geben Sie einen anderen Namen ein.

"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; + $brother = 1; + break; + } + } + if ($brother == 0 && $nomac == 0){ + + $exptargetdn = ldap_explode_dn($targetDN, 1); + $target = $exptargetdn[0]; + $targettype = $exptargetdn[1]; + + $oldpxetimerange = $oldpxeday."_".$oldpxebeg."_".$oldpxeend; + $newpxeDN = "cn=".$pxecn.",".$targetDN; + print_r($newpxeDN); echo "
"; + + if (dive_into_tree_cp($pxeDN,$newpxeDN)){ + + $delfileuri = 0; + # Filename anpassen + if ($targettype == "rbs"){ + $entrymod ['filename'] = "default"; + } + if ($targettype == "computers"){ + $macdata = get_node_data($targetDN, array("hwaddress")); + $entrymod ['filename'] = "01-".$macdata['hwaddress']; + $delfileuri = 1; + #$entrymod ['fileuri'] = "01-".$macdata['hwaddress'].".tgz"; + } + if ($targettype == "groups"){ + $members = get_node_data($targetDN, array("member")); + if (count($members) != 0){ + foreach ($members['member'] as $hostDN){ + $macdata = get_node_data($hostDN, array("hwaddress")); + $entrymod ['filename'][] = "01-".$macdata['hwaddress']; + $delfileuri = 1; + #$entrymod ['fileuri'] = $target.".tgz"; + } + } + } + if(ldap_mod_replace($ds,$newpxeDN,$entrymod)){ + if($deltr == 1){ + # Timeranges und FileURI im neuen Objekt löschen + $entrydel ['timerange'] = array(); + if ($delfileuri == 1){ + $entrydel ['fileuri'] = array(); + } + if ( ldap_mod_del($ds,$newpxeDN,$entrydel) ){ + $mesg .= "
PXE Boot Menü erfolgreich nach ".$target[1]." kopiert
"; + } + else{ + ldap_delete($ds,$newpxeDN); + $mesg .= "
Fehler beim kopieren des PXE Boot Menüs nach ".$target[1]."
"; + } + } + } + else{ + ldap_delete($ds,$newpxeDN); + $mesg .= "
Fehler beim kopieren des PXE Boot Menüs nach ".$target[1]."
"; + } + } + else{ + $mesg .= "
Fehler beim kopieren des PXE Boot Menüs nach ".$target[1]."
"; + } + } + } + } + else{ + $mesg .= "
Sie haben kein Ziel angegeben!
"; + } +} + +elseif ( $pxecn == ""){ + + $mesg = "Sie haben den Namen des neuen PXE Boot Menüs nicht angegeben. Dieser ist aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "pxe.php?dn=".$pxeDN."&mnr=".$mnr."&sbmnr=".$sbmnr."&mcnr=".$mcnr; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/pxe_delete.php b/ldap-site-mngmt/webinterface/rbs/pxe_delete.php new file mode 100644 index 00000000..a1b7a060 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe_delete.php @@ -0,0 +1,42 @@ + + + Computers Management + + + + +
"; + +if ( $pxeDN != ""){ + + if ( dive_into_tree_del($pxeDN,"") ){ + $mesg = "PXE Boot Menü ".$pxecn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des PXE Boot Menüs ".$pxecn." !

"; + } + +} + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/pxe_wochenplan.php b/ldap-site-mngmt/webinterface/rbs/pxe_wochenplan.php new file mode 100644 index 00000000..7cb4d394 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxe_wochenplan.php @@ -0,0 +1,154 @@ +assign(array("A0" => "","B0" => "","C0" => "","D0" => "","E0" => "","F0" => "","G0" => "", + "A1" => "","B1" => "","C1" => "","D1" => "","E1" => "","F1" => "","G1" => "", + "A2" => "","B2" => "","C2" => "","D2" => "","E2" => "","F2" => "","G2" => "", + "A3" => "","B3" => "","C3" => "","D3" => "","E3" => "","F3" => "","G3" => "", + "A4" => "","B4" => "","C4" => "","D4" => "","E4" => "","F4" => "","G4" => "", + "A5" => "","B5" => "","C5" => "","D5" => "","E5" => "","F5" => "","G5" => "", + "A6" => "","B6" => "","C6" => "","D6" => "","E6" => "","F6" => "","G6" => "", + "A7" => "","B7" => "","C7" => "","D7" => "","E7" => "","F7" => "","G7" => "", + "A8" => "","B8" => "","C8" => "","D8" => "","E8" => "","F8" => "","G8" => "", + "A9" => "","B9" => "","C9" => "","D9" => "","E9" => "","F9" => "","G9" => "", + "A10" => "","B10" => "","C10" => "","D10" => "","E10" => "","F10" => "","G10" => "", + "A11" => "","B11" => "","C11" => "","D11" => "","E11" => "","F11" => "","G11" => "", + "A12" => "","B12" => "","C12" => "","D12" => "","E12" => "","F12" => "","G12" => "", + "A13" => "","B13" => "","C13" => "","D13" => "","E13" => "","F13" => "","G13" => "", + "A14" => "","B14" => "","C14" => "","D14" => "","E14" => "","F14" => "","G14" => "", + "A15" => "","B15" => "","C15" => "","D15" => "","E15" => "","F15" => "","G15" => "", + "A16" => "","B16" => "","C16" => "","D16" => "","E16" => "","F16" => "","G16" => "", + "A17" => "","B17" => "","C17" => "","D17" => "","E17" => "","F17" => "","G17" => "", + "A18" => "","B18" => "","C18" => "","D18" => "","E18" => "","F18" => "","G18" => "", + "A19" => "","B19" => "","C19" => "","D19" => "","E19" => "","F19" => "","G19" => "", + "A20" => "","B20" => "","C20" => "","D20" => "","E20" => "","F20" => "","G20" => "", + "A21" => "","B21" => "","C21" => "","D21" => "","E21" => "","F21" => "","G21" => "", + "A22" => "","B22" => "","C22" => "","D22" => "","E22" => "","F22" => "","G22" => "", + "A23" => "","B23" => "","C23" => "","D23" => "","E23" => "","F23" => "","G23" => "")); + +#print_r($timeranges); echo "
"; + +# vom spezifischsten zum unspezifischsten : +# FR_0_7 -> FR_X_X -> X_0_7 -> X_X_X +$daytime = array(); +$timex = array(); +$dayx = array(); +$allx = array(); +$legend = array(); +if(count($timeranges) != 0){ +foreach ($timeranges as $tr){ + if (count($tr[0]) > 1){ + foreach ($tr as $item){ + if ($item[0] != "X" && $item[1] != "X" && $item[2] != "X" && ($item[0] == "MO" || $item[0] == "DI" || $item[0] == "MI" || $item[0] == "DO" || $item[0] == "FR" || $item[0] == "SA" || $item[0] == "SO")){ + $daytime[] = $item; + } + if ($item[0] != "X" && $item[1] == "X" && $item[2] == "X"){ + $timex[] = $item; + } + if ($item[0] == "X" && $item[1] != "X" && $item[2] != "X"){ + $dayx[] = $item; + } + if ($item[0] == "X" && $item[1] == "X" && $item[2] == "X"){ + $allx[] = $item; + } + } + }else{ + if ($tr[0] != "X" && $tr[1] != "X" && $tr[2] != "X" && ($tr[0] == "MO" || $tr[0] == "DI" || $tr[0] == "MI" || $tr[0] == "DO" || $tr[0] == "FR" || $tr[0] == "SA" || $tr[0] == "SO")){ + $daytime[] = $tr; + } + if ($tr[0] != "X" && $tr[1] == "X" && $tr[2] == "X"){ + $timex[] = $tr; + } + if ($tr[0] == "X" && $tr[1] != "X" && $tr[2] != "X"){ + $dayx[] = $tr; + } + if ($tr[0] == "X" && $tr[1] == "X" && $tr[2] == "X"){ + $allx[] = $tr; + } + } +} + +#print_r($daytime); echo "
"; +#print_r($timex); echo "
"; +#print_r($dayx); echo "
"; +#print_r($allx); echo "
"; + +$daycode = array("MO" => "A", "DI" => "B", "MI" => "C", "DO" => "D", "FR" => "E", "SA" => "F", "SO" => "G"); +$allxcolors = array("#BEBEBE","A0A0A0","#696969","#EEDFCC","#D8BFD8","#505050"); +$dayxcolors = array("#483D8B","#7B68EE","#191970","#8470FF","#708090","#6A5ACD"); +$timexcolors = array("#CDC673","#A2CD5A","#BDB76B","#8B864E","#6B8E23","#CDBE70"); +$daytimecolors = array("880000","#CD6839","#CC3300","#CC6600","#993300","#8B4C39"); + + +if (count($allx) != 0){ + $c = 0; + foreach ($allx as $range){ + foreach ($daycode as $dc){ + for ($i = 0; $i <= 23; $i++){ + $template->assign(array($dc.$i => "background-color:".$allxcolors[$c].";")); + } + } + $legend[] = array($range ,$allxcolors[$c]); + $c++; + } +} + +if (count($dayx) != 0){ + $c = 0; + foreach ($dayx as $range){ + foreach ($daycode as $dc){ + for ($i = $range[1]; $i<= $range[2]; $i++){ + $template->assign(array($dc.$i => "background-color:".$dayxcolors[$c].";")); + } + } + $legend[] = array($range ,$dayxcolors[$c]); + $c++; + } +} + +if (count($timex) != 0){ + $c = 0; + foreach ($timex as $range){ + $dc = $daycode[$range[0]]; + for ($i = 0; $i<= 23; $i++){ + $template->assign(array($dc.$i => "background-color:".$timexcolors[$c].";")); + } + $legend[] = array($range ,$timexcolors[$c]); + $c++; + } +} + +if (count($daytime) != 0){ + $c = 0; + foreach ($daytime as $range){ + $dc = $daycode[$range[0]]; + for ($i = $range[1]; $i<= $range[2]; $i++){ + $template->assign(array($dc.$i => "background-color:".$daytimecolors[$c].";")); + } + $legend[] = array($range ,$daytimecolors[$c]); + $c++; + } +} + +} + +$template->assign(array("DESCRIPTION" => "")); +#print_r($legend); +if (count($legend) != 0){ + $template->define_dynamic("Legende", "Webseite"); + foreach ($legend as $item){ + # Timerange Komponente + $color = $item[1]; + $template->assign(array("TR1" => $item[0][0], + "TR2" => $item[0][1], + "TR3" => $item[0][2], + "CN" => $item[0][3], + "COLOR" => $color)); + $template->parse("LEGENDE_LIST", ".Legende"); + } +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/pxeconfig_default.dwt b/ldap-site-mngmt/webinterface/rbs/pxeconfig_default.dwt new file mode 100644 index 00000000..bb630723 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxeconfig_default.dwt @@ -0,0 +1,323 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Default PXE Boot Menüs   {AU}

+ + + + + + + + + + + + + + + +
PXE Boot MenüGültigkeitsdauer (Time Range)
{PXECN}  {TRANGES}  

Wochen Übersicht:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
UhrzeitMontagDienstagMittwochDonnerstagFreitagSamstagSonntag
0       
        
2       
        
4       
        
6       
        
8       
        
10       
        
12       
        
14       
        
16        
        
18       
        
20       
        
22       
        

Legende:

+ + + + + + + + + + + + + + + + + + + + + +
PXE Boot Menü Farbe
Keine PXE Definition    
{CN}     
diff --git a/ldap-site-mngmt/webinterface/rbs/pxeconfig_default.php b/ldap-site-mngmt/webinterface/rbs/pxeconfig_default.php new file mode 100644 index 00000000..f9a2b7db --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/pxeconfig_default.php @@ -0,0 +1,77 @@ +assign(array("PXEDN" => "", + "PXECN" => "Noch kein Default PXE Boot Menü angelegt", + "TRANGES" => "", + "RBS" => "", + "CN" => "")); + +# rbservice und pxe daten (voerst nur ein rbs) +$rbs_array = get_rbservices($auDN,array("dn","cn")); +$rbsDN = $rbs_array[0]['dn']; +$pxe_array = get_pxeconfigs($rbsDN,array("dn","cn","timerange","rbservicedn")); +# print_r($pxe_array); + +$template->define_dynamic("Pxeconf", "Webseite"); + +for ($i=0; $i 1 ){ + foreach ($pxe_array[$i]['timerange'] as $tr){ + $exptime = array_merge(explode('_',$tr),$pxe_array[$i]['cn']); + $timeranges[$i][] = $exptime; # Für grafische Wo-Ansicht + if ($exptime[0] == "X"){$exptime[0]="täglich";} + # if ($exptime[1] == "X" && $exptime[2] == "X"){$exptime[1] = ""; $exptime[2]= "";} + $trange .= $exptime[0].", von ".$exptime[1].":00 bis ".$exptime[2].":59 / "; + } + }else{ + $exptime = array_merge(explode('_',$pxe_array[$i]['timerange']), $pxe_array[$i]['cn']); + $timeranges[$i] = $exptime; # Für grafische Wo-Ansicht + if ($exptime[0] == "X"){$exptime[0]="täglich";} + # if ($exptime[1] == "X" && $exptime[2] == "X"){$exptime[1] = ""; $exptime[2]= "";} + $trange .= $exptime[0].", von ".$exptime[1].":00 bis ".$exptime[2].":59"; + } + + $template->assign(array("PXEDN" => $pxe_array[$i]['dn'], + "PXECN" => $pxe_array[$i]['cn'], + "TRANGES" => $trange, + "RBS" => $pxe_array[$i]['rbservicedn'], + "AUDN" => $auDN)); + $template->parse("PXECONF_LIST", ".Pxeconf"); +} + +include("pxe_wochenplan.php"); + + +################################################################################### + +include("rbs_footer.inc.php"); + +?> diff --git a/ldap-site-mngmt/webinterface/rbs/rbs.dwt b/ldap-site-mngmt/webinterface/rbs/rbs.dwt new file mode 100644 index 00000000..ec6d0cbc --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbs.dwt @@ -0,0 +1,79 @@ + + + + {SEITENTITEL} + + + + + + + + + + +
+ + + + + +

Rechner und IP Management

+
+ + + + +
+

Startseite +  >>  {AU}  [ {DOMAIN} ]

+
+
+ + + + +
+ {LOGIN} +
+
+ + + + + +
{MAINMENU}
+ +
+ + + + + + + + + + + +
+ + +
+ + {NAVIGATION} + +
+
+ + +
+ + {HAUPTFENSTER} + +
+
+ + + + diff --git a/ldap-site-mngmt/webinterface/rbs/rbs.php b/ldap-site-mngmt/webinterface/rbs/rbs.php new file mode 100644 index 00000000..3460afa0 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbs.php @@ -0,0 +1,30 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbs_footer.inc.php b/ldap-site-mngmt/webinterface/rbs/rbs_footer.inc.php new file mode 100644 index 00000000..311721c5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbs_footer.inc.php @@ -0,0 +1,18 @@ +assign(array("PFAD" => $START_PATH)); + +# Daten in die Vorlage parsen +$template->parse("LOGIN", "Login"); +$template->parse("MAINMENU", "Mmenu"); +$template->parse("NAVIGATION", "Menu"); +$template->parse("HAUPTFENSTER", "Webseite"); +$template->parse("PAGE", "Vorlage"); + +# Fertige Seite an den Browser senden +$template->FastPrint("PAGE"); + +# Abmelden vom LDAP +ldap_unbind($ds); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbs_header.inc.php b/ldap-site-mngmt/webinterface/rbs/rbs_header.inc.php new file mode 100644 index 00000000..fb7e0751 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbs_header.inc.php @@ -0,0 +1,21 @@ + "rbs.dwt", + "Login" => "../logout_form.inc.dwt", + "Mmenu" => "../hauptmenue.dwt", + "Menu" => "menu.dwt", + "Webseite" => $webseite); +if (isset($additionalTemplates)) { + foreach ($additionalTemplates as $templateKey => $templateFile) { + $definedTemplates[$templateKey] = $templateFile; + } +} +$template->define($definedTemplates); + +$template->assign(array("SEITENTITEL" => $titel, "ROLLE" => "mainadmin", "AU" => $au_ou, "DOMAIN" => $assocdom, "USERCN" => $usercn)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbs_menu.php b/ldap-site-mngmt/webinterface/rbs/rbs_menu.php new file mode 100644 index 00000000..76a786c2 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbs_menu.php @@ -0,0 +1,215 @@ + "rbs.php?mnr=0", + "text" => "Übersicht", + "zugriff" => "alle"), + array("link" => $rbslink, + "text" => "Remote Boot Service", + "zugriff" => array("MainAdmin","HostAdmin")), + array("link" => $gbmlink, + "text" => "Generische Bootmenüs", + "zugriff" => array("MainAdmin","HostAdmin")), + array("link" => $pxelink, + "text" => "Default PXE", + "zugriff" => array("MainAdmin","HostAdmin"))); + #print_r($hauptmenu); + + # Generische Bootmenüs + $gbm = array(); + if (count($rbs_array) != 0){ + $generic_bms = get_menuentries($rbsDN, array("dn","cn")); + for ($g=0;$g "gbm.php?dn=".$generic_bms[$g]['dn']."&mnr=2&sbmnr=".$g, + "text" => $generic_bms[$g]['cn'], + "zugriff" => array("MainAdmin","HostAdmin")); + } + $gbm [] = array("link" => "new_gbm.php?mnr=2&sbmnr=".$g, + "text" => "Neues Generisches BM", + "zugriff" => array("MainAdmin","HostAdmin")); + } + + # default pxe-configs + $pxe = array(); + if (count($rbs_array) != 0){ + $pxe_array = get_pxeconfigs($rbsDN,array("dn","cn","timerange")); + for($n=0;$n "pxe.php?dn=".$pxe_array[$n]['dn']."&mnr=3&sbmnr=".$n, + "text" => $pxe_array[$n]['cn'], + "zugriff" => array("MainAdmin","HostAdmin")); + } + $pxe [] = array("link" => "new_pxe.php?mnr=3&sbmnr=".$n, + "text" => "Neues Default PXE", + "zugriff" => array("MainAdmin","HostAdmin")); + } + $submenu = array(array(), + array(), + $gbm, + $pxe); + + #$rollen = array_keys($roles); + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $template->define_dynamic("Submenu", "Menu"); + $i=0; + $maxmenu = count($hauptmenu); + + foreach($hauptmenu as $item) { + $template->clear_parse("SUBMENU_LIST"); + + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + + $subempty = 0; + $j=0; + $maxsub = count($submenu[$mnr]); + if($maxsub > 0){ + foreach($submenu[$mnr] as $item2) { + + if($item2['zugriff'] === "alle" || vergleicheArrays($rollen, $item2['zugriff'])) { + if($i != $mnr){ + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + else{ + if ($j==0) { + if ($sbmnr==0) { + if($maxsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if($maxsub == 1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($sbmnr==$j) { + if($maxsub == $j+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if($maxsub == $j+1){$zwisch="branchbottom2";} + else {$zwisch="branch2";} + # if ($lastaktive) {$zwisch="branch";} + # else {$zwisch="branch";} + $lastaktive=false; + } + } + $htmlcode= " + + + + +   + + + ".$item2['text']." +   + + "; + $template->assign(array("SUB" => $htmlcode)); + $template->assign(array("FARBE_S" => $farb)); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + } + else { + $subempty++; + } + $j=$j+1; + } + } + if($subempty == count($submenu[$mnr])) { + $template->assign(array("SUB" => "")); + # "LINK_S" => "", + # "TEXT_S" => "")); + $template->parse("SUBMENU_LIST", ".Submenu"); + $template->clear_dynamic("Submenu"); + } + if ($i==0) { + if ($mnr==0) { + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch="";} # {$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else{ + if(count($submenu[$i][0]) != 0){ + if($maxmenu == 1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + if(count($submenu[$mnr][0]) != 0){ + if($maxmenu == $i+1){$zwisch="";} + else {$zwisch="";} + }else{$zwisch="";} + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if(count($submenu[$i][0]) != 0){ + if($maxmenu == $i+1){$zwisch=" + ";} + else {$zwisch=" + ";} + }else{$zwisch="";} + #if ($lastaktive) {$zwisch="";} + #else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("ICON" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + $template->clear_dynamic("Hauptmenu"); + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else{ + $template->assign(array("ENDE" => "")); + } + +} + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbs_start.dwt b/ldap-site-mngmt/webinterface/rbs/rbs_start.dwt new file mode 100644 index 00000000..3436b4ee --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbs_start.dwt @@ -0,0 +1,41 @@ + + + + + + + + + + + +

Modul - Remote Boot Services (PXE) Management:

+

Dieses Modul dient der Verwaltung ihres Remote Boot Services (RBS)
+ Benutzen Sie die Navigation links, um die einzelnen Verwaltungsbereiche anzusteuern:

+
    +
  • Remote Boot Service

    + Allgemeine Einstellungen Ihres Remote Boot Service.
    + Falls Sie noch keinen RBS angelegt haben, können Sie dies hier tun.
    + Daneben können Sie hier ihr RBS Bootserver-System (TFTP-, NFS-, NBD-Server) verwalten. +
  • +
  • Generische Boot Menüs

    + Generische Boot Menues die Sie Nutzern ihres RBS anbieten wollen.
    + Hier verwalten Sie Generische Boot Menues (GBM) oder legen neue an.

    + GBMs enthalten alle Komponenten eines PXE Bootmenüs, welche + auf ihrem Bootserver-System gespeichert und von Ihnen verwaltet werden, d.h. + Kernel-Images, Initial-Ramdisks (initrd), usw. Diese sind unabhängig + von den PXE-Parametern, die das eigentliche Aussehen eines PXE Bootmenüs bestimmen, + wie z.B. Menu-Zeilen, oder PXE Parametern welche zur Bootclient Konfiguration verwendet + werden.
    + Nutzer ihres RBS können aus diesen GBMs dann ihre individuellen PXE Boot + Menüs zusammenstellen. + +
  • +
  • Default PXE

    + Default PXE Boot Konfigurationen, fuer die bootende Rechner ohne spezifische + PXEs.
    + Hier können Sie Default PXEs anlegen und verwalten. +
  • +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice.dwt b/ldap-site-mngmt/webinterface/rbs/rbservice.dwt new file mode 100644 index 00000000..c2af43fb --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbservice.dwt @@ -0,0 +1,228 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Remote Boot Service   {RBSCN}

+ + + + + + + + + + + + + + + + + + + + + + +
AttributWert
Eindeutiger RBS Name (cn):
(Teil des dn, ohne Leerzeichen eingeben)  
+ RBS_ +   +
Dienst kann momentan genutzt werden von:
Abteilung {RBSOFFERNOW}  (und allen Unterabteilungen) +
Ändern:
(Wählen Sie eine andere Abteilung)
+ +   +

Boot Server System:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ServerIP Adresse
(Rechner ändern)
Server Pfade
TFTP Server:   + + Init Boot File + +
{TFTP} + PXE Path + +
 Kernel Path + +
 Clientconf Path + +
NFS Server: + + Export Path + +
{NFS}  +   
NBD Server: + +   
{NBD}  +   
+

Config File für PXE Generator Script

Speichern Sie dieses als pxegen.conf.pl im gleichen Verzeichnis wie ihr PXE Generator Skript pxe_generator.pl
+ + + + + + + +
+ $ldaphost= "{PXEGENLDAP}";
+ $basedn= "{PXEGENBASE}";
+ $userdn= "{PXEGENUDN}";
+ $passwd= "{PXEGENPW}";
+ $rbsdn= "{PXEGENRBS}"; +

Remote Boot Service  {RBSCN}  löschen:

+ + + + + + + + + + + + + +
+ Der Remote Boot Dienst wird komplett gelöscht,
+ d.h. inklusive aller angelegten Generischen PXE Bootmenüs und Default PXEs. +
+ +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice.php b/ldap-site-mngmt/webinterface/rbs/rbservice.php new file mode 100644 index 00000000..73dde633 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbservice.php @@ -0,0 +1,148 @@ +assign(array("RBSDN" => "", + "CN" => "", + "TFTP" => "", + "TFTPIP" => "", + "INITBOOTFILE" => "", + "TFTPKERNEL" => "", + "TFTPPXE" => "", + "TFTPCLIENTCONF" => "", + "NFS" => "", + "NFSIP" => "", + "NFSPATH" => "", + "NBD" => "", + "NBDIP" => "", + "RBSOFFERNOWDN" => "", + "RBSOFFERNOW" => "", + "HDN" => "", + "HN" => "", + "IP" => "")); + +# RBS Daten +$rbs_array = get_rbservices($auDN,array("dn","cn")); +$rbsDN = $rbs_array[0]['dn']; +$attributes = array("dn","cn","rbsofferdn","tftpserverip","tftpkernelpath","tftpclientconfpath","tftppxepath", + "nfsserverip","exportpath","nbdserverip","initbootfile"); +$rbs_data = get_node_data($rbsDN, $attributes); + +# RBS Anbieten +# momentanes Offer +$offerexp = ldap_explode_dn($rbs_data['rbsofferdn'], 1); +$rbsoffernow = $offerexp[0]; +# alternative Offers +$expdn = ldap_explode_dn($auDN, 0); # Mit Merkmalen +$expdn = array_slice($expdn, 1); +$expou = ldap_explode_dn($auDN, 1); # nur Werte +$expou = array_slice($expou, 1, -3); +#print_r($expou); echo "
"; +#print_r($expdn); echo "
"; +for ($i=0; $iassign(array("RBSDN" => $rbs_data['dn'], + "RBSCN" => $rbscn, + "TFTP" => $tftpserver['hostname'], + "TFTPDN" => $tftpserver['dn'], + "TFTPIP" => $rbs_data['tftpserverip'], + "INITBOOTFILE" => $rbs_data['initbootfile'], + "TFTPKERNEL" => $rbs_data['tftpkernelpath'], + "TFTPPXE" => $rbs_data['tftppxepath'], + "TFTPCLIENTCONF" => $rbs_data['tftpclientconfpath'], + "NFS" => $nfsserver['hostname'], + "NFSDN" => $nfsserver['dn'], + "NFSIP" => $rbs_data['nfsserverip'], + "NFSPATH" => $rbs_data['exportpath'], + "NBD" => $nbdserver['hostname'], + "NBDDN" => $nbdserver['dn'], + "NBDIP" => $rbs_data['nbdserverip'], + "RBSOFFERNOWDN" => $rbs_data['rbsofferdn'], + "RBSOFFERNOW" => $rbsoffernow, + "MNR" => $mnr, + "SBMNR" => $sbmnr)); + +$template->define_dynamic("Rbsoffers", "Webseite"); +foreach ($rbsoffers as $offer){ + $template->assign(array("RBSOFFER" => $offer['dn'], + "RBSOFFEROU" => $offer['ou'],)); + $template->parse("RBSOFFERS_LIST", ".Rbsoffers"); +} + +### Rechner +$hostorgroup = $exp[0]; +$hosts_array = get_hosts($auDN,array("dn","hostname","ipaddress")); + +$template->define_dynamic("TftpHosts", "Webseite"); +$template->define_dynamic("NfsHosts", "Webseite"); +$template->define_dynamic("NbdHosts", "Webseite"); +foreach ($hosts_array as $item){ + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $item['ipaddress'])); + $template->parse("TFTPHOSTS_LIST", ".TftpHosts"); + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $item['ipaddress'])); + $template->parse("NFSHOSTS_LIST", ".NfsHosts"); + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $item['ipaddress'])); + $template->parse("NBDHOSTS_LIST", ".NbdHosts"); +} + +################################################ +# PXE Generator Skript Config +$pxegen_ldap = "ldap://".LDAP_HOST; +$pxegen_base = "ou=RIPM,".$suffix; +$pxegen_udn = $userDN; +$pxegen_pw = $userPassword; +$pxegen_rbsdn = $rbsDN; +$template->assign(array("PXEGENLDAP" => $pxegen_ldap, + "PXEGENBASE" => $pxegen_base, + "PXEGENUDN" => $pxegen_udn, + "PXEGENPW" => $pxegen_pw, + "PXEGENRBS" => $pxegen_rbsdn)); + + +################################################################################### + +include("rbs_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice_add.php b/ldap-site-mngmt/webinterface/rbs/rbservice_add.php new file mode 100644 index 00000000..54494999 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbservice_add.php @@ -0,0 +1,140 @@ +
"; + + +$get_rbscn = str_replace ( " ", "_", $rbscn ); +$seconds = 300; +$url = "new_rbservice.php?&mnr=1"; + +echo " + + + Computers Management + + + + +
"; + +if ( $rbscn != "" && $rbscn != "Hier_RBS_NAME_eintragen" ){ + + $rbscn = "RBS_".$rbscn; + + # Formulareingaben anpassen + $exprbs = explode(" ",$rbscn); + foreach ($exprbs as $word){$expuc[] = ucfirst($word);} + $rbscn = implode(" ",$expuc); + $rbscn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $rbscn); + + $rbsDN = "cn=".$rbscn.",".$nodeDN; + print_r($rbsDN); echo "

"; + + # Server_array zusammenstellen + $server = array(); + # TFTP Server + if ($tftpserverip != ""){ + if ($syntax->check_ip_syntax($tftpserverip)){ + $tftpserverip = htmlentities($tftpserverip); + $mesg .= "Suche nach dem Rechner mit IP ".$tftpserverip." :
"; + foreach ($host_array as $host){ + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + if ($tftpserverip == $hostip){ + $server ['tftp'] = $tftpserverip; + break; + }else{ + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$tftpserverip."!
"; + } + } + }else{$mesg .= "Falsche IP Syntax!
";} + } + # NFS Server + if ( $nfsserverip != "" ){ + if ($syntax->check_ip_syntax($nfsserverip)){ + $nfsserverip = htmlentities($nfsserverip); + $mesg .= "Suche nach dem Rechner mit IP ".$nfsserverip." :
"; + foreach ($host_array as $host){ + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + if ($nfsserverip == $hostip){ + $server ['nfs'] = $nfsserverip; + break; + }else{ + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$nfsserverip."!
"; + } + } + }else{$mesg .= "Falsche IP Syntax!
";} + } + # NBD Server + if ( $nbdserverip != "" ){ + if ($syntax->check_ip_syntax($nbdserverip)){ + $nbdserverip = htmlentities($nbdserverip); + $mesg .= "Suche nach dem Rechner mit IP ".$nbdserverip." :
"; + foreach ($host_array as $host){ + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + if ($nbdserverip == $hostip){ + $server ['nbd'] = $nbdserverip; + break; + }else{ + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$nbdserverip."!
"; + } + } + }else{$mesg .= "Falsche IP Syntax!
";} + } + echo "Server Array: ";print_r($server); echo "
"; + + if (add_rbs($rbsDN,$rbscn,$rbsoffer,$server,$atts)){ + $mesg .= "
Remote Boot Service erfolgreich angelegt
"; + $url = "rbservice.php?mnr=1"; + }else{ + $mesg .= "
Fehler beim anlegen des Remote Boot Services!
"; + } +} + +elseif ( $rbscn == "" || $rbscn == "Hier_RBS_NAME_eintragen" ){ + + $mesg = "Sie haben den Namen des neuen Remote Boot Service nicht angegeben. Dieser ist + aber ein notwendiges Attribut.
+ Bitte geben Sie ihn an.

"; + $url = "new_rbservice.php?rbscn=Hier_RBS_NAME_eintragen&mnr=1"; +} + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice_change.php b/ldap-site-mngmt/webinterface/rbs/rbservice_change.php new file mode 100644 index 00000000..e5419c36 --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbservice_change.php @@ -0,0 +1,337 @@ +
"; +$oldattribs = $_POST['oldattribs']; +if (count($oldattribs) != 0){ + foreach (array_keys($oldattribs) as $key){ + $oldatts[$key] = htmlentities($oldattribs[$key]); + } +} +#print_r($oldatts); echo "

"; + + +$seconds = 2; +$url = "rbservice.php?&mnr=1"; + +echo " + + + Computers Management + + + + +
"; + +############################################## +# RBS CN (DN) + +if ( $oldrbscn == $rbscn ){ + # $mesg = "keine Aenderung
"; +} + +if ( $oldrbscn != "" && $rbscn != "" && $oldrbscn != $rbscn ){ + echo "RBS Name aendern
"; + # hier noch Syntaxcheck + # Formulareingaben anpassen + $exprbs = explode(" ",$rbscn); + foreach ($exprbs as $word){$expuc[] = ucfirst($word);} + $rbscn = implode(" ",$expuc); + $rbscn = preg_replace ( '/\s+([0-9A-Z])/', '$1', $rbscn); + + $newrbsDN = "cn=".$rbscn.",".$nodeDN; + print_r($newrbsDN); echo "

"; + + if(move_subtree($rbsDN, $newrbsDN)){ + adjust_rbs_dn($newrbsDN, $rbsDN); + $rbsDN = $newrbsDN; + $mesg = "RBS Name erfolgreich geändert

"; + }else{ + $mesg = "Fehler beim ändern des RBS Namen!

"; + } +} + +if ( $oldrbscn != "" && $rbscn == "" ){ + echo "Gruppenname loeschen!
+ Dieses ist Teil des DN, Sie werden den RBS komplett löschen

"; + echo "Wollen Sie den RBS Dienst ".$oldrbscn." wirklich löschen?

+
+ Falls ja:

+ + +

+
+
+ Falls, nein:

+ +
"; + $seconds = 600; +} + + +##################################### +# Offer ändern + +if ( $rbsoffer != "none" && $rbsoffer == $oldrbsoffer ){ + $mesg = "Sie haben die gleiche Abteilung ausgewählt
+ Keine Änderung!"; +} + +if ( $rbsoffer != "none" && $rbsoffer != $oldrbsoffer ){ + $entryoffer ['rbsofferdn'] = $rbsoffer; + if(ldap_mod_replace($ds,$rbsDN,$entryoffer)){ + $mesg = "RBS Offer erfolgreich geändert

"; + } + else{ + $mesg = "Fehler beim ändern des RBS Offers!

"; + } +} + + +##################################### +# Server ändern über IP Feld + +$syntax = new Syntaxcheck; + +if ( $tftpserverip != "" && $tftpserverip != $oldtftpserverip ){ + + if ($syntax->check_ip_syntax($tftpserverip)){ + $tftpserverip = htmlentities($tftpserverip); + + $mesg .= "Suche nach dem Rechner mit IP ".$tftpserverip." :
"; + foreach ($host_array as $host){ + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + if ($tftpserverip == $hostip){ + $entrytftp ['tftpserverip'] = $tftpserverip; + if (ldap_mod_replace($ds,$rbsDN,$entrytftp)){ + $mesg .= "Treffer: Rechner ".$host['hostname']."
TFTP Server erfolgreich geändert
"; + }else{ + $mesg .= "Fehler beim ändern des TFTP Servers!
"; + } + break; + }else{ + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$tftpserverip."!
"; + } + } + } + else{ + $mesg .= "Falsche IP Syntax!
"; + } +} + +if ( $nfsserverip != "" && $nfsserverip != $oldnfsserverip ){ + + if ($syntax->check_ip_syntax($nfsserverip)){ + $nfsserverip = htmlentities($nfsserverip); + + $mesg .= "Suche nach dem Rechner mit IP ".$nfsserverip." :
"; + foreach ($host_array as $host){ + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + if ($nfsserverip == $hostip){ + $entrytnfs ['nfsserverip'] = $nfsserverip; + if (ldap_mod_replace($ds,$rbsDN,$entrytnfs)){ + $mesg .= "Treffer: Rechner ".$host['hostname']."
NFS Server erfolgreich geändert
"; + }else{ + $mesg .= "Fehler beim ändern des NFS Servers!
"; + } + break; + }else{ + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$nfsserverip."!
"; + } + } + } + else{ + $mesg .= "Falsche IP Syntax!
"; + } +} + +if ( $nbdserverip != "" && $nbdserverip != $oldnbdserverip ){ + + if ($syntax->check_ip_syntax($nbdserverip)){ + $nbdserverip = htmlentities($nbdserverip); + + $mesg .= "Suche nach dem Rechner mit IP ".$nbdserverip." :
"; + foreach ($host_array as $host){ + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + if ($nbdserverip == $hostip){ + $entrytnbd ['nbdserverip'] = $nbdserverip; + if (ldap_mod_replace($ds,$rbsDN,$entrytnbd)){ + $mesg .= "Treffer: Rechner ".$host['hostname']."
NBD Server erfolgreich geändert
"; + }else{ + $mesg .= "Fehler beim ändern des NBD Servers!
"; + } + break; + }else{ + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$nbdserverip."!
"; + } + } + } + else{ + $mesg .= "Falsche IP Syntax!
"; + } +} + +##################################### +# Server ändern über Hostname + +if ($tftpserver != "none" && $tftpserver != $oldtftpserverdn){ + + $host = get_host_ip($tftpserver); + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + $entrytftp ['tftpserverip'] = $hostip; + if (ldap_mod_replace($ds,$rbsDN,$entrytftp)){ + $mesg .= "TFTP Server erfolgreich geändert
"; + }else{ + $mesg .= "Fehler beim ändern des TFTP Servers!
"; + } + +} + +if ($nfsserver != "none" && $nfsserver != $oldnfsserverdn){ + + $host = get_host_ip($nfsserver); + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + $entrynfs ['nfsserverip'] = $hostip; + if (ldap_mod_replace($ds,$rbsDN,$entrynfs)){ + $mesg .= "NFS Server erfolgreich geändert
"; + }else{ + $mesg .= "Fehler beim ändern des NFS Servers!
"; + } + +} + +if ($nbdserver != "none" && $nbdserver != $oldnbdserverdn){ + + $host = get_host_ip($nbdserver); + $hostipexp = explode('_',$host['ipaddress']); + $hostip = $hostipexp[0]; + $entrytnbd ['nbdserverip'] = $hostip; + if (ldap_mod_replace($ds,$rbsDN,$entrytnbd)){ + $mesg .= "NBD Server erfolgreich geändert
"; + }else{ + $mesg .= "Fehler beim ändern des NBD Servers!
"; + } + +} + +##################################### +# Restliche Attribute + +$entryadd = array(); +$entrymod = array(); +$entrydel = array(); + +foreach (array_keys($atts) as $key){ + + if ( $oldatts[$key] == $atts[$key] ){ + + } + if ( $oldatts[$key] == "" && $atts[$key] != "" ){ + # hier noch Syntaxcheck + $entryadd[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] != "" && $oldatts[$key] != $atts[$key] ){ + # hier noch Syntaxcheck + $entrymod[$key] = $atts[$key]; + } + if ( $oldatts[$key] != "" && $atts[$key] == "" ){ + # hier noch Syntaxcheck + $entrydel[$key] = $oldatts[$key]; + } +} + +#print_r($entryadd); echo "
"; +#print_r($entrymod); echo "
"; +#print_r($entrydel); echo "
"; + + +if (count($entryadd) != 0 ){ + #print_r($entryadd); echo "
"; + #echo "neu anlegen
"; + foreach (array_keys($entryadd) as $key){ + $addatts .= "".$key.","; + } + if(ldap_mod_add($ds,$rbsDN,$entryadd)){ + $mesg = "Attribute ".$addatts." erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der Attribute ".$addatts."

"; + } +} + +if (count($entrymod) != 0 ){ + #print_r($entrymod); echo "
"; + #echo "ändern
"; + foreach (array_keys($entrymod) as $key){ + $modatts .= "".$key.","; + } + if(ldap_mod_replace($ds,$rbsDN,$entrymod)){ + $mesg = "Attribute ".$modatts." erfolgreich geaendert

"; + }else{ + $mesg = "Fehler beim aendern der Attribute ".$modatts."

"; + } +} + +if (count($entrydel) != 0 ){ + #print_r($entrydel); echo "
"; + #echo "löschen
"; + foreach (array_keys($entrydel) as $key){ + $delatts .= "".$key.","; + } + if(ldap_mod_del($ds,$rbsDN,$entrydel)){ + $mesg = "Attribute ".$delatts." erfolgreich geloescht

"; + }else{ + $mesg = "Fehler beim loeschen der Attribute ".$delatts."

"; + } +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice_delete.php b/ldap-site-mngmt/webinterface/rbs/rbservice_delete.php new file mode 100644 index 00000000..919987bd --- /dev/null +++ b/ldap-site-mngmt/webinterface/rbs/rbservice_delete.php @@ -0,0 +1,41 @@ + + + Computers Management + + + + +
"; + +if ( $rbsDN != ""){ + + if ( dive_into_tree_del($rbsDN,"") ){ + clean_up_del_rbs($rbsDN); + $mesg = "Remote Boot Service ".$rbscn." erfolgreich gelöscht!

"; + } + else{ + $mesg = "Fehler beim löschen des Remote Boot Services ".$rbscn." !

"; + } + +} + + + + +$mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; +redirect($seconds, $url, $mesg, $addSessionId = TRUE); + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/menu.dwt b/ldap-site-mngmt/webinterface/roles/menu.dwt new file mode 100644 index 00000000..9aadc1c5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/menu.dwt @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + +
   + {TEXT_M} 
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/role_add.php b/ldap-site-mngmt/webinterface/roles/role_add.php new file mode 100644 index 00000000..3c628066 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/role_add.php @@ -0,0 +1,53 @@ + + + Roles Management + + + + +
"; + +# print_r($adduser);echo "
"; +# print_r($adduserDN);echo "
"; +# print_r($adduserUID);echo "
"; +# print_r($role);echo "
"; +# print_r($menr);echo "

"; + +$url = 'role_show.php?role='.$role.'&mnr='.$menr; + +if ($adduser != 'none'){ + $res = new_role_member($adduserDN,$role,$auDN,$domDN); + if ($res == 1){ + $mesg = "Der Benutzer ".$adduserUID." wurde erfolgreich als neuer ".$role." aufgenommen.

"; + }else{ + $mesg = "Fehler! Der Benutzer ".$adduserUID." konnte nicht aufgenommen werden

"; + } + $mesg .= "Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(3, $url, $mesg, $addSessionId = TRUE); +} + +else { + $mesg = "Sie haben keinen Benutzer ausgewählt

+ Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(3, $url, $mesg, $addSessionId = TRUE); +} + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/role_delete.php b/ldap-site-mngmt/webinterface/roles/role_delete.php new file mode 100644 index 00000000..297136e0 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/role_delete.php @@ -0,0 +1,57 @@ + + + Roles Management + + + + +
"; + +if (isset($_POST['deluser'])){ + + # print_r($deluser);echo "
"; + # print_r($role);echo "
"; + # print_r($menr);echo "
"; + + $url = 'role_show.php?role='.$role.'&mnr='.$menr; + $mesg = ""; + + foreach ($deluser as $item){ + $exp = explode('_',$item); + $deluserDN = $exp[0]; + $deluserUID = $exp[1]; + # print_r($deluserDN);echo "
"; + # print_r($deluserUID);echo "
"; + $res = delete_role_member($deluserDN,$role,$auDN,$domDN); + if ($res == 1){ + $mesg .= "Der Benutzer ".$deluserUID." wurde erfolgreich aus der Rolle ".$role." entfernt.
"; + }else{ + $mesg .= "Fehler! Der Benutzer ".$deluserUID." konnte nicht entfernt werden
"; + } + } + $mesg .= "
Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back

"; + redirect(3, $url, $mesg, $addSessionId = TRUE); + +} + +else { + $mesg .= "
Sie haben keinen Benutzer ausgewählt

+ Sie werden automatisch auf die vorherige Seite zurückgeleitet.
+ Falls nicht, klicken Sie hier back"; + redirect(3, $url, $mesg, $addSessionId = TRUE); +} + +echo "
+"; +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/role_show.dwt b/ldap-site-mngmt/webinterface/roles/role_show.dwt new file mode 100644 index 00000000..3eb05b79 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/role_show.dwt @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + +

{ROLE_DESC}

+ + + + + + + + + + + + + + + + + + + + + + + + + + + +
 BenutzerUIDEmail
+ {USERNAME}  {UID}  {MAIL}  

Neuen Administrator anlegen:

+ + + + + + + + + + + + +
+ Wählen Sie einen Benutzer aus
+ + + +
\ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/role_show.php b/ldap-site-mngmt/webinterface/roles/role_show.php new file mode 100644 index 00000000..d209d3e9 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/role_show.php @@ -0,0 +1,116 @@ +assign(array("ROLE" => "MainAdmin","ROLE_DESC" => "Haupt Administratoren","MENR" => $mnr)); + $members = $roles_array['MainAdmin']; + break; +case 'HostAdmin': + $template->assign(array("ROLE" => "HostAdmin","ROLE_DESC" => "Administratoren  -  Rechner, Rechnergruppen, Remote Boot Services (PXE)","MENR" => $mnr)); + $members = $roles_array['HostAdmin']; + break; +case 'DhcpAdmin': + $template->assign(array("ROLE" => "DhcpAdmin","ROLE_DESC" => "Administratoren  -  DHCP","MENR" => $mnr)); + $members = $roles_array['DhcpAdmin']; + break; +case 'ZoneAdmin': + $template->assign(array("ROLE" => "ZoneAdmin","ROLE_DESC" => "Administratoren  -  DNS Zone  [ {DOM} ]","MENR" => $mnr,"DOM" => $assocdom)); + $members = $roles_array['ZoneAdmin']; + break; +} + +# print_r($members); echo "

"; + +# für jedes Member Daten holen (Benutzername, UID) +if ( count($members) != 0 ){ + $members_data = array(); + foreach ($members as $item){ + $members_data[] = get_user_data($item,array("dn","cn","uid","mail")); + # print_r(get_user_data($item,array("dn","cn","uid"))); echo "
"; + } +} +# echo "
"; +# print_r($members_data); echo "

"; + +if (count($members_data) != 0){ + $template->define_dynamic("Members", "Webseite"); + foreach ($members_data as $item){ + $template->assign(array("VALUE" => $item['dn'], + "USERNAME" => $item['cn'], + "UID" => $item['uid'], + "MAIL" => $item['mail'])); + $template->parse("MEMBERS_LIST", ".Members"); + } +}else{ + $template->assign(array("VALUE" => "","USERNAME" => "","UID" => "","MAIL" => "")); +} + + +############################################## +# Admin anlegen ... +$users_array = get_users(); +# print_r($users_array); echo "

"; + +if (count($members_data) != 0){ +for ($i=0; $i < count($users_array); $i++){ + foreach ($members_data as $item){ + if ($users_array[$i]['uid'] == $item['uid']){ + array_splice($users_array, $i, 1); + # break; + } + } +} +# print_r($users_array); echo "

"; +} + +# if (count($users_array) != 0){ + $template->define_dynamic("Users", "Webseite"); + foreach ($users_array as $item){ + $template->assign(array("UDN" => $item['dn'], + "USER" => $item['uid'])); + $template->parse("USERS_LIST", ".Users"); + } +#}else{ +# $template->assign(array("UDN" => "","USER" => "")); +# } + + + + + +############################################################################### + +include("roles_footer.inc.php"); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/roles.dwt b/ldap-site-mngmt/webinterface/roles/roles.dwt new file mode 100644 index 00000000..8e775327 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/roles.dwt @@ -0,0 +1,79 @@ + + + + {SEITENTITEL} + + + + + + + + + + +
+ + + + + +

Rechner und IP Management

+
+ + + + +
+

Startseite +  >>  {AU}  [ {DOMAIN} ]

+
+
+ + + + +
+ {LOGIN} +
+
+ + + + +
{MAINMENU}
+ + +
+ + + + + + + + + + + +
+ + +
+ + {NAVIGATION} + +
+
+ + +
+ + {HAUPTFENSTER} + +
+
+ + + + diff --git a/ldap-site-mngmt/webinterface/roles/roles.php b/ldap-site-mngmt/webinterface/roles/roles.php new file mode 100644 index 00000000..0ae79cf9 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/roles.php @@ -0,0 +1,26 @@ + \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/roles_footer.inc.php b/ldap-site-mngmt/webinterface/roles/roles_footer.inc.php new file mode 100644 index 00000000..311721c5 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/roles_footer.inc.php @@ -0,0 +1,18 @@ +assign(array("PFAD" => $START_PATH)); + +# Daten in die Vorlage parsen +$template->parse("LOGIN", "Login"); +$template->parse("MAINMENU", "Mmenu"); +$template->parse("NAVIGATION", "Menu"); +$template->parse("HAUPTFENSTER", "Webseite"); +$template->parse("PAGE", "Vorlage"); + +# Fertige Seite an den Browser senden +$template->FastPrint("PAGE"); + +# Abmelden vom LDAP +ldap_unbind($ds); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/roles_header.inc.php b/ldap-site-mngmt/webinterface/roles/roles_header.inc.php new file mode 100644 index 00000000..74c96f74 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/roles_header.inc.php @@ -0,0 +1,19 @@ + "roles.dwt", + "Login" => "../logout_form.inc.dwt", + "Mmenu" => "../hauptmenue.dwt", + "Menu" => "menu.dwt", + "Webseite" => $webseite); +if (isset($additionalTemplates)) { + foreach ($additionalTemplates as $templateKey => $templateFile) { + $definedTemplates[$templateKey] = $templateFile; + } +} +$template->define($definedTemplates); +$template->assign(array("SEITENTITEL" => $titel, "AU" => $au_ou, "DOMAIN" => $assocdom, "USERCN" => $usercn)); + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/roles_menu.php b/ldap-site-mngmt/webinterface/roles/roles_menu.php new file mode 100644 index 00000000..e389f4e9 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/roles_menu.php @@ -0,0 +1,87 @@ + "roles.php", + "text" => "Übersicht", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=MainAdmin&mnr=1", + "text" => "Main Admins", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=HostAdmin&mnr=2", + "text" => "Host Admins", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=DhcpAdmin&mnr=3", + "text" => "DHCP Admins", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=ZoneAdmin&mnr=4", + "text" => "DNS Admins", + "zugriff" => array("MainAdmin"))); + }else{ + $hauptmenu = array(array("link" => "roles.php", + "text" => "Übersicht", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=MainAdmin&mnr=1", + "text" => "Main Admins", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=HostAdmin&mnr=2", + "text" => "Host Admins", + "zugriff" => array("MainAdmin")), + array("link" => "role_show.php?role=DhcpAdmin&mnr=3", + "text" => "DHCP Admins", + "zugriff" => array("MainAdmin"))); + } + # $rollen = array_keys($roles); + + # Zusammenstellen der Menuleiste + $template->define_dynamic("Hauptmenu", "Menu"); + $i=0; + foreach($hauptmenu as $item) { + if($item['zugriff'] === "alle" || vergleicheArrays($rollen , $item['zugriff'])) { + if ($i==0) { + if ($mnr==0) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $zwisch=""; + $farb="#A0A0A0"; + $lastaktive=false; + } + } + else { + if ($mnr==$i) { + $zwisch=""; + $lastaktive=true; + $farb="#505050"; + } + else { + $farb="#A0A0A0"; + if ($lastaktive) {$zwisch="";} + else {$zwisch="";} + $lastaktive=false; + } + } + $template->assign(array("ZWISCHEN" => $zwisch, + "FARBE" => $farb, + "LINK_M" => $item["link"], + "TEXT_M" => $item["text"])); + $template->parse("HAUPTMENU_LIST", ".Hauptmenu"); + + } + $i=$i+1; + } + if ($lastaktive) {$template->assign(array("ENDE" => ""));} + else { + $template->assign(array("ENDE" => "")); + } + +} + + +?> \ No newline at end of file diff --git a/ldap-site-mngmt/webinterface/roles/roles_start.dwt b/ldap-site-mngmt/webinterface/roles/roles_start.dwt new file mode 100644 index 00000000..22ab0857 --- /dev/null +++ b/ldap-site-mngmt/webinterface/roles/roles_start.dwt @@ -0,0 +1,37 @@ + + + + + + + + + + + +

Modul - Administratoren Rollen Management:

+

Dieses Modul dient der Verwaltung von Administratoren Rollen in ihrer Abteilung. + Benutzen Sie die Navigation links, um die Verwaltungsbereiche der einzelnen Rollen anzusteuern. + Dort koennen Sie dann Benutzer den Rollen zuweisen oder wieder entziehen.

+

Folgende administrative Rollen stehen zur Verfuegung:

+
    +
  • Main Admins

    + Hauptadministratoren, der AU mit uneingeschraenkten Rechten. Sie verwalten: u.a. + untergeordnete AUs (anlegen/loeschen/im DNS anmelden), + Rollen, IP Adressen und deren Delegierung, Rechner (Gruppen), deren Hardware-Profile und + PXE Boot Konfigurationen, sowie die Dienste DHCP und DNS. +
  • +
  • Host Admins

    + Diese verwalten Rechner (Gruppen), deren Hardware-Profile und PXE Boot Konfigurationen, + und koennen diese im DHCP und DNS anmelden (verwalten im DNS nur deren Namenseintraege). +
  • +
  • DHCP Admins

    + Verwalten den DHCP Dienst, d.h. Subnetz-, Pool-, Class-Objekte. +
  • +
  • DNS Admins

    + Sind die Administratoren der mit der AU assozierten DNS Zone. D.h. sie verwalten SOA, + Include Direktiven untergeordneter Include Files, sowie alle Nameneintraege der Zone. +
  • +
+ +
\ No newline at end of file -- cgit v1.2.3-55-g7522