Compare commits

...

5 Commits

Author SHA1 Message Date
Elam Monnot
c6236ad563 fichier de sécurisation 2023-01-09 11:51:56 +01:00
92d62b1cb7 tp ansible 2022-10-13 09:05:35 +02:00
62df029ff7 tp python 2022-09-29 11:52:19 +02:00
root
ba69fb4a2c scripts python 2022-09-28 17:24:40 +02:00
d04439cb70 ldap-tp 2022-09-27 10:56:56 +02:00
22 changed files with 200872 additions and 0 deletions

View File

@ -0,0 +1,131 @@
<?php
/**
* DokuWiki mainscript
*
* @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
* @author Andreas Gohr <andi@splitbrain.org>
*
* @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);

View File

@ -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

View File

@ -0,0 +1,23 @@
<?php
/*
* Dokuwiki's Main Configuration File - Local Settings
* Auto-generated by config plugin
* Run for user: Unknown
* Date: Tue, 27 Sep 2022 10:19:37 +0200
*/
$conf['title'] = 'Test wiki';
$conf['lang'] = 'fr';
$conf['license'] = 'cc-by-sa';
$conf['useacl'] = 1;
$conf['authtype'] = 'authldap';
$conf['superuser'] = '@admin';
$conf['disableactions'] = 'register';
$conf['plugin']['authldap']['server'] = 'ldap://localhost:389';
$conf['plugin']['authldap']['usertree'] = 'ou=people,dc=labo52,dc=lan';
$conf['plugin']['authldap']['grouptree'] = 'ou=groups,dc=labo52,dc=lan';
$conf['plugin']['authldap']['userfilter'] = '(&(uid=%{user})(objectClass=posixAccount))';
$conf['plugin']['authldap']['groupfilter'] = '(objectClass=posixGroup)(|(gidNumber=%{gid})(memberUID=%{user})))';
$conf['plugin']['authldap']['passcrypt'] = 'ssha';
$conf['plugin']['authldap']['version'] = 3;
$conf['plugin']['authldap']['debug'] = 0;

View File

@ -0,0 +1,22 @@
#!/usr/bin/python3
import sys
import re
volip={}
regexp = "^(\S+) (\S+) (\S+) \[([^]]+)\] \"(\w+) (\S+).*\" (\d+) (\S+)"
for line in sys.stdin: # on lit sur lentrée standard
line = line.rstrip () # on enleve le retour ligne
res = re.match (regexp, line)
if res:
(host, rfc931, user, date, request, url, status, byte) = res.groups()
host = res.group (1)
byte = int(res.group (8))
#print ('host : ', host, ' byte : ', byte)
if host not in volip:
volip[host]=byte
else:
volip[host]=volip[host]+byte
for addr in sorted(volip.keys()):
print(addr, "", volip[addr])

13
sio1/sisr1/70-python/analyse.py Executable file
View File

@ -0,0 +1,13 @@
#!/usr/bin/python3
import sys
import re
regexp = "^(\S+) (\S+) (\S+) \[([^]]+)\] \"(\w+) (\S+).*\" (\d+) (\S+)"
for line in sys.stdin: # on lit sur lentrée standard
line = line.rstrip () # on enleve le retour ligne
res = re.match (regexp, line)
if res:
(host, rfc931, user, date, request, url, status, byte) = res.groups()
host = res.group (1)
byte = res.group (8)
print ('host : ', host, ' byte : ', byte)

View File

@ -0,0 +1,34 @@
#!/usr/bin/python3
import sys
if len(sys.argv) != 2:
print("usage: ", sys.argv[0], "<fichier>")
sys.exit(1) # nombre de parametre invalide
filename = sys.argv[1]
try:
file = open(filename , "r")
except:
msg = "erreur ouverture fichier " + filename
print(msg, file=sys.stderr)
else:
line = file.readline()
maligne = line.rstrip()
while maligne:
(login, complet) = maligne.split(":")
print (login)
print (complet)
commande="useradd --create-home --home-dir /home/"+login+ " --shell /bin/bash --comment \"" + complet + "\" " + login
login = []
line = file.readline()
maligne = line.rstrip()
print(line)
file.close()

View File

@ -0,0 +1,2 @@
#!/usr/bin/python3
print ("bonjour");

15
sio1/sisr1/70-python/phrase.py Executable file
View File

@ -0,0 +1,15 @@
#!/usr/bin/python3
phrase = str(input("Entrez une phrase à analyser : "));
tabmots = phrase.split(' ');
cptmots = {}
for mot in tabmots:
if mot not in cptmots:
cptmots[mot]=1
else:
cptmots[mot] = cptmots[mot] + 1
for mot in cptmots:
print(mot, ":", cptmots[mot])

4
sio1/sisr1/70-python/rayon.py Executable file
View File

@ -0,0 +1,4 @@
#!/usr/bin/python3
rayon=float(input("Entrez le rayon du cercle en cm : "));
perimetre=float(2*rayon*3.141592);
print("le perimètre du cercle est :", perimetre, "cm");

File diff suppressed because it is too large Load Diff

189641
sio1/sisr1/70-python/result.txt Normal file

File diff suppressed because it is too large Load Diff

38
sio1/sisr1/70-python/tableau.py Executable file
View File

@ -0,0 +1,38 @@
#!/usr/bin/python3
min=int(0);
max=int(0);
i=int(0);
tableau=[];
moyenne=float(0);
nombre=int(input("Entrez un nombre entier : "));
min=nombre;
if nombre>max:
max=nombre;
tableau.append(nombre);
for i in range(0,4):
nombre=int(input("Entrez un nombre entier : "));
if nombre<min:
min=nombre;
if max<nombre:
max=nombre;
tableau.append(nombre);
for i in range(0,5):
moyenne+=float(tableau[i]);
moyenne=float(moyenne/len(tableau));
for i in range(0,5):
print(tableau[i]);
print("\nLe plus petit nombre est : ", min);
print("Le nombre le plus grand est : ", max);
print("La moyenne est de :", moyenne);

View File

@ -0,0 +1,4 @@
emonnot:Elam Monnot
pdubois:Paul Dubois
blennon:Bob Lennon

View File

@ -0,0 +1,45 @@
---
- hosts: localhost
# become: true
vars_prompt:
- name: username
prompt: Votre nom?
private: false
tasks:
- name: cree utilisateurs...
shell: "curl depl.sio.lan/usr/mkusrlin-2024.sh|bash"
- name: mdp root verrouillage...
# avec mkpasswd -m SHA-512
ansible.builtin.user:
name: root
password: '$6$Ga8KbEYAgCZYGeDB$7zlfBy1j4koFv.NYQEeZa/k7pwjNTEI7hrWUlrHWTwd1YsEqm.Sy2DZ1GAFYe2qe4ZccMQJAt7QxILY1sd9AV0'
- name: enleve sio de sudo...
ansible.builtin.user:
name: sio
groups: ''
- name: met le user "{{ username }}" dans le groupe sudo...
ansible.builtin.user:
name: "{{ username }}"
groups: sudo
append: yes
- name: installe journal-remote...
apt:
name: systemd-journal-remote
state: present
- name: configure journal-remote...
replace:
path: /etc/systemd/journal-upload.conf
regexp: '^# URL='
replace: 'URL=http://192.168.0.1:19532'
- name: active journal-remote au démarrage...
service:
name: systemd-journal-upload
state: started
enabled: yes

View File

@ -0,0 +1,6 @@
[adm]
infra
[web]
web1
web2

View File

@ -0,0 +1,7 @@
[adm]
infra
[web]
web1
web2

View File

@ -0,0 +1 @@
<title>Bonjour</title>

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,32 @@
---
- hosts: adm
vars:
- proxy_port: 8080
- proxy_mem: 256
- proxy_localnet: 192.168.0.0/24
tasks:
- name: Installation de proxy squid...
apt:
name: squid
state: present
- name: generation du fichier de configuration de squid...
template:
src: squid.conf.j2
dest: /etc/squid/squid.conf
mode: 0644
backup: true
notify: restart squid
handlers:
- name: restart squid
service:
name: squid
state: restarted
# - name: Copie de squid.conf...
# fetch:
# src: /etc/squid/squid.conf
# dest: ./squid.conf.j2
# flat: yes

View File

@ -0,0 +1,30 @@
---
- hosts: web
name: syslog-client-configure
tasks:
- name: editing journald.conf...
ansible.builtin.replace:
path: /etc/systemd/journald.conf
regexp: '^#ForwardToSyslog=yes'
replace: 'ForwardToSyslog=yes'
backup: yes
notify: restart journald
- name: editing rsyslog.conf...
ansible.builtin.lineinfile:
path: /etc/rsyslog.conf
line: '*.* @192.168.0.48:514'
create: yes
notify: restart rsyslog
handlers:
- name: restart journald
service:
name: systemd-journald
state: restarted
- name: restart rsyslog
service:
name: rsyslog
state: restarted

View File

@ -0,0 +1,23 @@
---
- hosts: adm
name: rsyslog-server-configure
tasks:
- name: activation du module imudp...
ansible.builtin.replace:
path: /etc/rsyslog.conf
regexp: '^#module\(load="imudp"\)'
replace: 'module(load="imudp")'
- name: ouverture du port 514...
ansible.builtin.replace:
path: /etc/rsyslog.conf
regexp: '^#input\(type="imudp" port="514"\)'
replace: 'input(type="imudp" port="514")'
notify: restart rsyslog
handlers:
- name: restart rsyslog
service:
name: rsyslog
state: restarted

View File

@ -0,0 +1,24 @@
---
- hosts: web
name: web
tasks:
- name: verifying apache installation
apt :
name: apache2
state: present
- name: verifying php installation
apt :
name: php
state: present
- name: verifying php-mbstring installation
apt :
name: php-mbstring
state: present
- name: overwriting index.html...
copy:
src: index.html
dest: /var/www/html/index.html