From d04439cb704b1e1322bf4ecdd8f8cfa7a198dc1a Mon Sep 17 00:00:00 2001 From: elam monnot Date: Tue, 27 Sep 2022 10:56:56 +0200 Subject: [PATCH] ldap-tp --- sio1/sisr1/30-config/ldap-tp/doku.php | 131 +++++++ sio1/sisr1/30-config/ldap-tp/labo52.lan.ldif | 393 +++++++++++++++++++ sio1/sisr1/30-config/ldap-tp/local.php | 23 ++ 3 files changed, 547 insertions(+) create mode 100644 sio1/sisr1/30-config/ldap-tp/doku.php create mode 100644 sio1/sisr1/30-config/ldap-tp/labo52.lan.ldif create mode 100644 sio1/sisr1/30-config/ldap-tp/local.php diff --git a/sio1/sisr1/30-config/ldap-tp/doku.php b/sio1/sisr1/30-config/ldap-tp/doku.php new file mode 100644 index 0000000..50e3726 --- /dev/null +++ b/sio1/sisr1/30-config/ldap-tp/doku.php @@ -0,0 +1,131 @@ + + * + * @global Input $INPUT + */ + +// update message version - always use a string to avoid localized floats! +use dokuwiki\Extension\Event; + +$updateVersion = "53"; + +// xdebug_start_profiling(); + +if(!defined('DOKU_INC')) define('DOKU_INC', dirname(__FILE__).'/'); + +// define all DokuWiki globals here (needed within test requests but also helps to keep track) +global $ACT, $INPUT, $QUERY, $ID, $REV, $DATE_AT, $IDX, + $DATE, $RANGE, $HIGH, $TEXT, $PRE, $SUF, $SUM, $INFO, $JSINFO; + + +if(isset($_SERVER['HTTP_X_DOKUWIKI_DO'])) { + $ACT = trim(strtolower($_SERVER['HTTP_X_DOKUWIKI_DO'])); +} elseif(!empty($_REQUEST['idx'])) { + $ACT = 'index'; +} elseif(isset($_REQUEST['do'])) { + $ACT = $_REQUEST['do']; +} else { + $ACT = 'show'; +} + +// load and initialize the core system +require_once(DOKU_INC.'inc/init.php'); + +//import variables +$INPUT->set('id', str_replace("\xC2\xAD", '', $INPUT->str('id'))); //soft-hyphen +$QUERY = trim($INPUT->str('q')); +$ID = getID(); + +$REV = $INPUT->int('rev'); +$DATE_AT = $INPUT->str('at'); +$IDX = $INPUT->str('idx'); +$DATE = $INPUT->int('date'); +$RANGE = $INPUT->str('range'); +$HIGH = $INPUT->param('s'); +if(empty($HIGH)) $HIGH = getGoogleQuery(); + +if($INPUT->post->has('wikitext')) { + $TEXT = cleanText($INPUT->post->str('wikitext')); +} +$PRE = cleanText(substr($INPUT->post->str('prefix'), 0, -1)); +$SUF = cleanText($INPUT->post->str('suffix')); +$SUM = $INPUT->post->str('summary'); + + +//parse DATE_AT +if($DATE_AT) { + $date_parse = strtotime($DATE_AT); + if($date_parse) { + $DATE_AT = $date_parse; + } else { // check for UNIX Timestamp + $date_parse = @date('Ymd',$DATE_AT); + if(!$date_parse || $date_parse === '19700101') { + msg(sprintf($lang['unable_to_parse_date'], hsc($DATE_AT))); + $DATE_AT = null; + } + } +} + +//check for existing $REV related to $DATE_AT +if($DATE_AT) { + $pagelog = new \dokuwiki\ChangeLog\PageChangeLog($ID); + $rev_t = $pagelog->getLastRevisionAt($DATE_AT); + if($rev_t === '') { //current revision + $REV = null; + $DATE_AT = null; + } else if ($rev_t === false) { //page did not exist + $rev_n = $pagelog->getRelativeRevision($DATE_AT,+1); + msg( + sprintf( + $lang['page_nonexist_rev'], + dformat($DATE_AT), + wl($ID, array('rev' => $rev_n)), + dformat($rev_n) + ) + ); + $REV = $DATE_AT; //will result in a page not exists message + } else { + $REV = $rev_t; + } +} + +//make infos about the selected page available +$INFO = pageinfo(); + +// handle debugging +if($conf['allowdebug'] && $ACT == 'debug') { + html_debug(); + exit; +} + +//send 404 for missing pages if configured or ID has special meaning to bots +if(!$INFO['exists'] && + ($conf['send404'] || preg_match('/^(robots\.txt|sitemap\.xml(\.gz)?|favicon\.ico|crossdomain\.xml)$/', $ID)) && + ($ACT == 'show' || (!is_array($ACT) && substr($ACT, 0, 7) == 'export_')) +) { + header('HTTP/1.0 404 Not Found'); +} + +//prepare breadcrumbs (initialize a static var) +if($conf['breadcrumbs']) breadcrumbs(); + +// check upstream +checkUpdateMessages(); + +$tmp = array(); // No event data +Event::createAndTrigger('DOKUWIKI_STARTED', $tmp); + +//close session +session_write_close(); + +//do the work (picks up what to do from global env) +act_dispatch(); + +$tmp = array(); // No event data +Event::createAndTrigger('DOKUWIKI_DONE', $tmp); + +// xdebug_dump_function_profile(1); diff --git a/sio1/sisr1/30-config/ldap-tp/labo52.lan.ldif b/sio1/sisr1/30-config/ldap-tp/labo52.lan.ldif new file mode 100644 index 0000000..933d587 --- /dev/null +++ b/sio1/sisr1/30-config/ldap-tp/labo52.lan.ldif @@ -0,0 +1,393 @@ +dn: dc=labo52,dc=lan +o: labo52 +dc: labo52 +structuralObjectClass: organization +entryUUID: 8cea1486-cf8c-103c-84fc-fb9fff7ed8be +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923130824Z +ou: labo52 +description: labo52 +objectClass: top +objectClass: dcObject +objectClass: organization +objectClass: gosaDepartment +objectClass: gosaAcl +gosaAclEntry: 0:subtree:Y249YWRtaW4sb3U9YWNscm9sZXMsZGM9bGFibzUyLGRjPWxhbg== + :dWlkPWZkLWFkbWluLG91PXBlb3BsZSxkYz1sYWJvNTIsZGM9bGFu +entryCSN: 20220923131630.253993Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131630Z + +dn: cn=admin,dc=labo52,dc=lan +objectClass: simpleSecurityObject +objectClass: organizationalRole +cn: admin +description: LDAP administrator +userPassword:: e1NTSEF9ZHdmWGZTTkpzOENzZTU4VmlEZmZTb2hXUHlVM0tyVjI= +structuralObjectClass: organizationalRole +entryUUID: 8cea6936-cf8c-103c-84fd-fb9fff7ed8be +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923130824Z +entryCSN: 20220923130824.418299Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923130824Z + +dn: ou=fusiondirectory,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: fusiondirectory +structuralObjectClass: organizationalUnit +entryUUID: 7a531cd6-cf8d-103c-9474-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131502Z +entryCSN: 20220923131502.724490Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131502Z + +dn: cn=config,ou=fusiondirectory,dc=labo52,dc=lan +fdLanguage: fr_FR +fdTheme: breezy +fdTimezone: America/New_York +fusionConfigMd5: 8781d81883d1a89872fc104c4eddcfb4 +fdLdapSizeLimit: 200 +fdModificationDetectionAttribute: entryCSN +fdLogging: TRUE +fdSchemaCheck: TRUE +fdEnableSnapshots: TRUE +fdSnapshotBase: ou=snapshots,dc=labo52,dc=lan +fdPasswordDefaultHash: ssha +fdForcePasswordDefaultHash: FALSE +fdHandleExpiredAccounts: FALSE +fdLoginAttribute: uid +fdForceSSL: FALSE +fdWarnSSL: TRUE +fdSessionLifeTime: 1800 +fdHttpAuthActivated: FALSE +fdHttpHeaderAuthActivated: FALSE +fdHttpHeaderAuthHeaderName: AUTH_USER +fdSslKeyPath: /etc/ssl/private/fd.key +fdSslCertPath: /etc/ssl/certs/fd.cert +fdSslCaCertPath: /etc/ssl/certs/ca.cert +fdCasActivated: FALSE +fdCasServerCaCertPath: /etc/ssl/certs/ca.cert +fdCasHost: localhost +fdCasPort: 443 +fdCasContext: /cas +fdAccountPrimaryAttribute: uid +fdCnPattern: %givenName% %sn% +fdStrictNamingRules: TRUE +fdUserRDN: ou=people +fdAclRoleRDN: ou=aclroles +fdRestrictRoleMembers: FALSE +fdSplitPostalAddress: FALSE +fdDisplayErrors: FALSE +fdLdapStats: FALSE +fdDebugLevel: 0 +fdListSummary: TRUE +fdAclTabOnObjects: FALSE +fdDisplayHookOutput: FALSE +structuralObjectClass: fusionDirectoryConf +cn: config +entryUUID: 7a5393dc-cf8d-103c-9475-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131502Z +fdDashboardNumberOfDigit: 3 +fdDashboardPrefix: PC +fdDashboardExpiredAccountsDays: 15 +fdOGroupRDN: ou=groups +fdForceSaslPasswordAsk: FALSE +fdGroupRDN: ou=groups +fdMinId: 100 +fdUidNumberBase: 1100 +fdGidNumberBase: 1100 +fdIdAllocationMethod: traditional +fdShells: /bin/ash +fdShells: /bin/bash +fdShells: /bin/csh +fdShells: /bin/sh +fdShells: /bin/ksh +fdShells: /bin/tcsh +fdShells: /bin/dash +fdShells: /bin/zsh +fdShells: /sbin/nologin +fdShells: /bin/false +fdShells: /usr/bin/git-shell +fdDefaultShell: /bin/ash +objectClass: fusionDirectoryConf +objectClass: fdDashboardPluginConf +objectClass: fusionDirectoryPluginsConf +objectClass: fdPasswordRecoveryConf +fdPasswordRecoveryActivated: FALSE +fdPasswordRecoveryEmail: to.be@chang.ed +fdPasswordRecoveryValidity: 10 +fdPasswordRecoverySalt: SomethingSecretAndVeryLong +fdPasswordRecoveryUseAlternate: FALSE +fdPasswordRecoveryLoginAttribute: uid +fdPasswordRecoveryMailSubject:: W0Z1c2lvbkRpcmVjdG9yeV0gTGllbiBkZSByw6lpbml0 + aWFsaXNhdGlvbiBkdSBtb3QgZGUgcGFzc2U= +fdPasswordRecoveryMailBody:: Qm9uam91ciwKClZvaWNpIHZvcyBpbmZvcm1hdGlvbnMgOgo + tIElkZW50aWZpYW504oCvOiAlcwotIExpZW7igK86ICVzCgpDZSBsaWVuIGVzdCBzZXVsZW1lbn + QgdmFsaWRlIHBlbmRhbnQgMTAgbWludXRlcw== +fdPasswordRecoveryMail2Subject:: W0Z1c2lvbkRpcmVjdG9yeV0gUsOpaW5pdGlhbGlzYXR + pb24gZHUgbW90IGRlIHBhc3NlIHLDqXVzc2ll4oCvIQ== +fdPasswordRecoveryMail2Body:: Qm9uam91ciwKClZvdHJlIG1vdCBkZSBwYXNzZSBhIMOpdM + OpIGNoYW5nw6kuIApWb3RyZSBpZGVudGlmaWFudCBkZSBjb25uZXhpb24gZXN0IHRvdWpvdXJzI + CVzLg== +entryCSN: 20220923132212.156185Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923132212Z + +dn: ou=aclroles,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: aclroles +structuralObjectClass: organizationalUnit +entryUUID: ae7b94c0-cf8d-103c-9477-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131630Z +entryCSN: 20220923131630.231223Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131630Z + +dn: cn=admin,ou=aclroles,dc=labo52,dc=lan +objectClass: top +objectClass: gosaRole +cn: admin +description: Donne tous les droits sur tous les objets +gosaAclTemplate: 0:all;cmdrw +structuralObjectClass: gosaRole +entryUUID: ae7bf064-cf8d-103c-9478-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131630Z +entryCSN: 20220923131630.233570Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131630Z + +dn: ou=people,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: people +structuralObjectClass: organizationalUnit +entryUUID: ae7dd7ee-cf8d-103c-9479-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131630Z +entryCSN: 20220923131630.246051Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131630Z + +dn: uid=fd-admin,ou=people,dc=labo52,dc=lan +cn: System Administrator +sn: Administrator +givenName: System +uid: fd-admin +userPassword:: e1NTSEF9VVRpcWRmRjRYUlN4MEE1aFRYekdYQktWWndGZUhKWG8= +structuralObjectClass: inetOrgPerson +entryUUID: ae7e4954-cf8d-103c-947a-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131630Z +objectClass: inetOrgPerson +objectClass: organizationalPerson +objectClass: person +objectClass: posixAccount +objectClass: shadowAccount +homeDirectory: /home/admin +gecos: System Administrator +loginShell: /bin/bash +uidNumber: 1102 +gidNumber: 1102 +shadowLastChange: 19262 +entryCSN: 20220927070640.394432Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220927070640Z + +dn: cn=manager,ou=aclroles,dc=labo52,dc=lan +cn: manager +description: Donner tous les droits aux utilisateurs sur cette branche +objectClass: top +objectClass: gosaRole +gosaAclTemplate: 0:user/user;cmdrw,user/posixAccount;cmdrw +structuralObjectClass: gosaRole +entryUUID: b08a5c4c-cf8d-103c-947b-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131633Z +entryCSN: 20220923131633.683521Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131633Z + +dn: cn=editowninfos,ou=aclroles,dc=labo52,dc=lan +cn: editowninfos +description:: UGVybWV0IGF1eCB1dGlsaXNhdGV1cnMgZCfDqWRpdGVyIGxldXJzIHByb3ByZX + MgaW5mb3JtYXRpb25zIChvbmdsZXRzIGfDqW7DqXJpcXVlIGV0IHBvc2l4LCDDoCBuJ3V0aWxpc + 2VyIHF1ZSBzdXIgbGEgYmFzZSk= +objectClass: top +objectClass: gosaRole +gosaAclTemplate: 0:user/user;srw,user/posixAccount;srw +structuralObjectClass: gosaRole +entryUUID: b08ad140-cf8d-103c-947c-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131633Z +entryCSN: 20220923131633.686520Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131633Z + +dn: cn=editownpwd,ou=aclroles,dc=labo52,dc=lan +cn: editownpwd +description:: UGVybWV0IGF1eCB1dGlsaXNhdGV1cnMgZGUgY2hhbmdlciBsZXVyIG1vdCBkZS + BwYXNzZSAow6AgbuKAmXV0aWxpc2VyIHF1ZSBzdXIgbGEgYmFzZSk= +objectClass: top +objectClass: gosaRole +gosaAclTemplate: 0:user/user;s#userPassword;rw +structuralObjectClass: gosaRole +entryUUID: b08b3d4c-cf8d-103c-947d-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923131633Z +entryCSN: 20220923131633.689286Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923131633Z + +dn: ou=recovery,ou=fusiondirectory,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: recovery +structuralObjectClass: organizationalUnit +entryUUID: 7a462994-cf8e-103c-9480-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923132212Z +entryCSN: 20220923132212.136345Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923132212Z + +dn: ou=locks,ou=fusiondirectory,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: locks +structuralObjectClass: organizationalUnit +entryUUID: d788d28c-cf8e-103c-9481-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923132448Z +entryCSN: 20220923132448.601281Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923132448Z + +dn: ou=snapshots,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: snapshots +structuralObjectClass: organizationalUnit +entryUUID: dd5c772c-cf8e-103c-9482-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923132458Z +entryCSN: 20220923132458.376943Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923132458Z + +dn: uid=dpaul,ou=people,dc=labo52,dc=lan +cn: Paul Dubois +sn: Dubois +givenName: Paul +uid: dpaul +userPassword:: e1NTSEF9c09STWsySzZ4VmFDdERlYUkxa1BrNTVQQktmTy8vTGU= +structuralObjectClass: inetOrgPerson +entryUUID: 6fd7626a-cf8f-103c-9483-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923132904Z +objectClass: inetOrgPerson +objectClass: organizationalPerson +objectClass: person +objectClass: posixAccount +objectClass: shadowAccount +homeDirectory: /home/paul.dubois +gecos: Paul Dubois +uidNumber: 1101 +gidNumber: 1101 +shadowLastChange: 19258 +loginShell: /bin/bash +entryCSN: 20220923134716.687589Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923134716Z + +dn: ou=groups,dc=labo52,dc=lan +objectClass: organizationalUnit +ou: groups +structuralObjectClass: organizationalUnit +entryUUID: 6fd9f7d2-cf8f-103c-9486-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923132904Z +entryCSN: 20220923132904.146797Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923132904Z + +dn: cn=dpaul,ou=groups,dc=labo52,dc=lan +objectClass: posixGroup +cn: dpaul +description: Groupe de l'utilisateur dpaul +gidNumber: 1101 +structuralObjectClass: posixGroup +entryUUID: 6fda4624-cf8f-103c-9487-ad02623342dd +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220923132904Z +entryCSN: 20220923132904.148802Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220923132904Z + +dn: cn=fd-admin,ou=groups,dc=labo52,dc=lan +objectClass: posixGroup +cn: fd-admin +description: Groupe de l'utilisateur fd-admin +gidNumber: 1102 +structuralObjectClass: posixGroup +entryUUID: adf57b1c-d27e-103c-85f4-9db5680eeb52 +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220927070640Z +entryCSN: 20220927070640.389773Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220927070640Z + +dn: uid=test,ou=people,dc=labo52,dc=lan +cn: test test +sn: test +givenName: test +uid: test +preferredLanguage: en_US +userPassword:: e1NTSEF9NExNdGpBUXpFbnBvcThSM3VQNE93T1hUa01BN1BOSFM= +structuralObjectClass: inetOrgPerson +entryUUID: 14c2ec50-d28c-103c-9e03-077ab6ad89d1 +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220927084236Z +objectClass: inetOrgPerson +objectClass: organizationalPerson +objectClass: person +objectClass: posixAccount +objectClass: shadowAccount +homeDirectory: /home/test +gecos: test test +loginShell: /bin/bash +uidNumber: 1103 +gidNumber: 1103 +shadowLastChange: 19262 +entryCSN: 20220927084236.348813Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220927084236Z + +dn: cn=test,ou=groups,dc=labo52,dc=lan +objectClass: posixGroup +cn: test +description: Groupe de l'utilisateur test +gidNumber: 1103 +structuralObjectClass: posixGroup +entryUUID: 14c698be-d28c-103c-9e06-077ab6ad89d1 +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220927084236Z +entryCSN: 20220927084236.345323Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220927084236Z + +dn: cn=31137f330f0161c6725d7fded31984ef,ou=locks,ou=fusiondirectory,dc=labo5 + 2,dc=lan +objectClass: fdLockEntry +fdUserDn: uid=fd-admin,ou=people,dc=labo52,dc=lan +fdObjectDn: dWlkPWRwYXVsLG91PXBlb3BsZSxkYz1sYWJvNTIsZGM9bGFu +cn: 31137f330f0161c6725d7fded31984ef +fdLockTimestamp: 20220927084756.846245Z +structuralObjectClass: fdLockEntry +entryUUID: d3cf2d0c-d28c-103c-9e07-077ab6ad89d1 +creatorsName: cn=admin,dc=labo52,dc=lan +createTimestamp: 20220927084756Z +entryCSN: 20220927084756.846378Z#000000#000#000000 +modifiersName: cn=admin,dc=labo52,dc=lan +modifyTimestamp: 20220927084756Z + diff --git a/sio1/sisr1/30-config/ldap-tp/local.php b/sio1/sisr1/30-config/ldap-tp/local.php new file mode 100644 index 0000000..425dd03 --- /dev/null +++ b/sio1/sisr1/30-config/ldap-tp/local.php @@ -0,0 +1,23 @@ +