ajout de la partie slam dans le dossier web
This commit is contained in:
parent
31d3052792
commit
e375c4f088
1
ap23/web/adminer
Symbolic link
1
ap23/web/adminer
Symbolic link
@ -0,0 +1 @@
|
||||
/usr/share/adminer/adminer
|
57
ap23/web/controleurs/c_connexion.php
Normal file
57
ap23/web/controleurs/c_connexion.php
Normal file
@ -0,0 +1,57 @@
|
||||
<?php
|
||||
// ****************************************'
|
||||
// Le CASTEL-BTS SIO/ PROJET GSB PPE2 2020'
|
||||
// Programme: c_connexion.php '
|
||||
// Objet : authentification '
|
||||
// Client : Bts SIO1 '
|
||||
// Version : 22.03 '
|
||||
// Date : 09/03/2022 à 19h07 '
|
||||
// Auteur : pascal.blain@ac-dijon.fr '
|
||||
//*****************************************'
|
||||
|
||||
if(!isset($_REQUEST['action'])){$_REQUEST['action'] = 'demandeConnexion';}
|
||||
|
||||
$action = $_REQUEST['action'];
|
||||
switch($action){
|
||||
case 'demandeConnexion':{
|
||||
session_unset();
|
||||
unset($choix);
|
||||
$formulaire = "frmIdentification";
|
||||
$champ = "login";
|
||||
include("vues/v_entete.php");
|
||||
include("vues/v_connexion.php");
|
||||
break;
|
||||
}
|
||||
case 'valideConnexion':{
|
||||
$login = $_REQUEST['login'];
|
||||
$mdp = $_REQUEST['mdp']; //md5($_REQUEST['mdp']);
|
||||
$utilisateur = $pdo->getInfosUtilisateur($login,$mdp);
|
||||
|
||||
if(!is_array( $utilisateur)){
|
||||
$formulaire ="frmIdentification";
|
||||
$champ ="login";
|
||||
include("vues/v_entete.php");
|
||||
ajouterErreur("Login ou mot de passe incorrect");
|
||||
include("vues/v_erreurs.php");
|
||||
include("vues/v_connexion.php");
|
||||
}
|
||||
else{
|
||||
$id = $utilisateur['uId'];
|
||||
$nom = $utilisateur['uNom'];
|
||||
$prenom = $utilisateur['uPrenom'];
|
||||
$statut = $utilisateur['uStatut'];
|
||||
($statut==0)?$region=0:$region=$utilisateur['uRegion'];
|
||||
connecter($id,$nom,$prenom,$statut,$region);
|
||||
header ('location: index.php?choixTraitement=param&action=voir');
|
||||
}
|
||||
break;
|
||||
}
|
||||
default :{
|
||||
$formulaire ="frmIdentification";
|
||||
$champ ="login";
|
||||
include("vues/v_entete.php");
|
||||
include("vues/v_connexion.php");
|
||||
break;
|
||||
}
|
||||
}
|
||||
?>
|
79
ap23/web/controleurs/c_param.php
Normal file
79
ap23/web/controleurs/c_param.php
Normal file
@ -0,0 +1,79 @@
|
||||
<?php
|
||||
// ****************************************'
|
||||
// Le CASTEL-BTS SIO/ PROJET démonstration'
|
||||
// Programme: c_param.php '
|
||||
// Objet : gestion des parametres '
|
||||
// Client : Bts SIO1 '
|
||||
// Version : 22.03 '
|
||||
// Date : 09 mars 2022 à 19H51 '
|
||||
// Auteur : pascal-blain@wanadoo.fr '
|
||||
//*****************************************'
|
||||
|
||||
$action = $_REQUEST['action'];
|
||||
if (!isset($_REQUEST['type'])) {$type = '*';} else {$type =$_REQUEST['type'];}
|
||||
if (!isset($_REQUEST['valeur'])) {$valeur = '*';} else {$valeur =$_REQUEST['valeur'];}
|
||||
if (!isset($_REQUEST['zPlancher'])) {$plancher = 0;} else {$plancher =intval($_REQUEST['zPlancher']);}
|
||||
if (!isset($_REQUEST['zPlafond'])) {$plafond = 0;} else {$plafond =intval($_REQUEST['zPlafond']);}
|
||||
if (!isset($_REQUEST['zType'])) {$zType = '*';} else {$zType =$_REQUEST['zType'];}
|
||||
if (!isset($_REQUEST['zIndice'])) {$indice = '*';} else {$indice =$_REQUEST['zIndice'];}
|
||||
|
||||
switch($action) {
|
||||
case 'voir':
|
||||
{
|
||||
include("vues/v_entete.php");
|
||||
$lesParametres=$pdo->getLesParametres();
|
||||
include("vues/v_choixParam.php");
|
||||
$enteteParametre=$lesParametres[$noP-1];
|
||||
$lesInfosParametre = $pdo->getParametre($choix);
|
||||
include("vues/v_ficheParametre.php");
|
||||
$stat="2";
|
||||
break;
|
||||
}
|
||||
//-----------------------------------------liste détaillée pour un parametre
|
||||
case 'liste':
|
||||
{
|
||||
include("vues/v_entete.php");
|
||||
$lesParametres=$pdo->getLesParametres();
|
||||
include("vues/v_choixParam.php");
|
||||
$titre2=$lesStatistiques[0]['libelle'];
|
||||
include("vues/v_listeStat.php");
|
||||
break;
|
||||
}
|
||||
//----------------------------------------- AJOUT/MODIFICATION/SUPPRESSION
|
||||
case 'ajouter':
|
||||
case 'modifier':
|
||||
case 'supprimer':
|
||||
{
|
||||
include("vues/v_entete.php");
|
||||
$infosParam = $pdo->getInfosParam($type, $valeur);
|
||||
include("vues/v_unParam.php");
|
||||
break;
|
||||
}
|
||||
//----------------------------------------- VALIDATION AJOUT
|
||||
case 'validerAjouter':
|
||||
{// enregistrement de la ligne et retour
|
||||
if ($_REQUEST['zOk']=="OK") {$pdo->ajoutParametre($type, $valeur, addslashes ($_REQUEST['zLibelle']), $_REQUEST['zTerritoire'], $_REQUEST['zDep'] , $plancher, $plafond);}
|
||||
header ('location: index.php?choixTraitement=param&action=voir&lstParam='.$type);
|
||||
}
|
||||
//----------------------------------------- VALIDATION MODIFICATION
|
||||
case 'validerModifier':
|
||||
{
|
||||
if ($_REQUEST['zOk']=="OK") {$pdo->majParametre($type, $valeur, addslashes ($_REQUEST['zLibelle']), $_REQUEST['zTerritoire'], $_REQUEST['zDep'], $plancher, $plafond);}
|
||||
header ('location: index.php?choixTraitement=param&action=voir&lstParam='.$type);
|
||||
break;
|
||||
}
|
||||
//----------------------------------------- VALIDATION SUPPRESSION
|
||||
case 'validerSupprimer':
|
||||
{
|
||||
if ($_REQUEST['zOk']=="OK") {$pdo->supprimeParametre($type, $valeur);}
|
||||
header ('location: index.php?choixTraitement=param&action=voir&lstParam='.$type);
|
||||
break;
|
||||
}
|
||||
|
||||
default :
|
||||
{
|
||||
echo 'erreur d\'aiguillage !'.$action;
|
||||
break;
|
||||
}
|
||||
}
|
||||
?>
|
210
ap23/web/controleurs/fonctionsProjet.inc
Normal file
210
ap23/web/controleurs/fonctionsProjet.inc
Normal file
@ -0,0 +1,210 @@
|
||||
<?php
|
||||
/**
|
||||
* Fonctions php pour l'application
|
||||
* @version 22.03 version MVC modifiee le 09 mars 2022 par Blain Pascal
|
||||
*/
|
||||
|
||||
/**
|
||||
* Teste si un utilisateur est connecté (retourne vrai ou faux)
|
||||
*/
|
||||
function estConnecte(){
|
||||
return isset($_SESSION['idUtilisateur']);
|
||||
}
|
||||
/**
|
||||
* Enregistre dans des variables de session les informations d'un utilisateur
|
||||
*/
|
||||
function connecter($id, $nom, $prenom, $statut, $region){
|
||||
$_SESSION['idUtilisateur'] = $id;
|
||||
$_SESSION['nom'] = $nom;
|
||||
$_SESSION['prenom'] = $prenom;
|
||||
$_SESSION['statut'] = $statut;
|
||||
$_SESSION['region'] = $region;
|
||||
}
|
||||
/**
|
||||
* Detruit la session active
|
||||
*/
|
||||
function deconnecter(){
|
||||
session_destroy();
|
||||
}
|
||||
/**
|
||||
* envoyer un message electronique
|
||||
*/
|
||||
function envoyerMail($mail, $sujet, $msg, $entete)
|
||||
{
|
||||
if (mail($mail, $sujet, $msg, null)==false)
|
||||
{ echo 'Suite à un problàme technique, votre message n a pas ´t´ envoy´ a '.$mail.' sujet'.$sujet.'message '.$msg.' entete '.$entete;}
|
||||
}
|
||||
/**
|
||||
* Transforme une date au format français jj/mm/aaaa vers le format anglais aaaa-mm-jj
|
||||
* @param $madate au format jj/mm/aaaa
|
||||
* @return la date au format anglais aaaa-mm-jj
|
||||
*/
|
||||
function dateFrancaisVersAnglais($maDate){
|
||||
if(estDateValide($maDate)== true)
|
||||
{
|
||||
@list($jour,$mois,$annee) = explode('/',$maDate);
|
||||
return date('Y-m-d',mktime(0,0,0,$mois,$jour,$annee));
|
||||
}
|
||||
else
|
||||
{
|
||||
return null;
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Transforme une date au format format anglais aaaa-mm-jj vers le format français jj/mm/aaaa
|
||||
* @param $madate au format aaaa-mm-jj
|
||||
* @return la date au format format français jj/mm/aaaa
|
||||
*/
|
||||
function dateAnglaisVersFrancais($maDate)
|
||||
{
|
||||
@list($annee,$mois,$jour)=explode('-',$maDate);
|
||||
$date="$jour"."/".$mois."/".$annee;
|
||||
return $date;
|
||||
}
|
||||
/**
|
||||
* retourne le mois au format aaaamm selon le jour dans le mois
|
||||
* @param $date au format jj/mm/aaaa
|
||||
* @return le mois au format aaaamm
|
||||
*/
|
||||
function getMois($date){
|
||||
@list($jour,$mois,$annee) = explode('/',$date);
|
||||
if(strlen($mois) == 1){
|
||||
$mois = "0".$mois;
|
||||
}
|
||||
return $annee.$mois;
|
||||
}
|
||||
|
||||
/**
|
||||
* retourne la date en texte
|
||||
*/
|
||||
function dateTexte($laDate){
|
||||
$NomDuJour = array ("Dimanche", "Lundi", "Mardi", "Mercredi", "Jeudi", "Vendredi", "Samedi");
|
||||
$NomDuMois = array ("janvier", "février", "mars", "avril", "mai", "juin", "juillet", "août", "septembre", "octobre", "novembre", "décembre");
|
||||
$lejour = date("j",$laDate);
|
||||
$lemois = $NomDuMois[date("n",$laDate)-1];
|
||||
$dateTexte=$NomDuJour[date("w",$laDate)]." ";
|
||||
if($lejour==01){$dateTexte.=' 1er '; }
|
||||
else {$dateTexte.=$lejour.' ';}
|
||||
$dateTexte.=$lemois.' '.date('Y', $laDate);
|
||||
return $dateTexte;
|
||||
}
|
||||
|
||||
/**
|
||||
* retourne le mois en texte
|
||||
*/
|
||||
function moisTexte($mois){
|
||||
$tabMois = array( '01' => "Janvier",
|
||||
'02' => "Février",
|
||||
'03' => "Mars",
|
||||
'04' => "Avril",
|
||||
'05' => "Mai",
|
||||
'06' => "Juin",
|
||||
'07' => "Juillet",
|
||||
'08' => "Août",
|
||||
'09' => "Septembre",
|
||||
'10' => "Octobre",
|
||||
'11' => "Novembre",
|
||||
'12' => "Décembre");
|
||||
return $tabMois[$mois];
|
||||
}
|
||||
|
||||
/* gestion des erreurs*/
|
||||
/**
|
||||
* Indique si une valeur est un entier positif ou nul
|
||||
* @param $valeur
|
||||
* @return vrai ou faux
|
||||
*/
|
||||
function estEntierPositif($valeur)
|
||||
{
|
||||
return preg_match("/[^0-9]/", $valeur) == 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Indique si un tableau de valeurs est constitué d'entiers positifs ou nuls
|
||||
* @param $tabEntiers : le tableau
|
||||
* @return vrai ou faux
|
||||
*/
|
||||
function estTableauEntiers($tabEntiers)
|
||||
{
|
||||
$ok = true;
|
||||
foreach($tabEntiers as $unEntier)
|
||||
{
|
||||
if(!estEntierPositif($unEntier)){$ok=false;}
|
||||
}
|
||||
return $ok;
|
||||
}
|
||||
/**
|
||||
* Vérifie si une date est inférieure d'un an à la date actuelle
|
||||
* @param $dateTestee
|
||||
* @return vrai ou faux
|
||||
*/
|
||||
function estDateDepassee($dateTestee)
|
||||
{
|
||||
$dateActuelle=date("d/m/Y");
|
||||
@list($jour,$mois,$annee) = explode('/',$dateActuelle);
|
||||
$annee--;
|
||||
$AnPasse = $annee.$mois.$jour;
|
||||
@list($jourTeste,$moisTeste,$anneeTeste) = explode('/',$dateTestee);
|
||||
return ($anneeTeste.$moisTeste.$jourTeste < $AnPasse);
|
||||
}
|
||||
/**
|
||||
* Vérifie la validité du format d'une date française jj/mm/aaaa
|
||||
* @param $date
|
||||
* @return vrai ou faux
|
||||
*/
|
||||
function estDateValide($date){
|
||||
$tabDate = explode('/',$date);
|
||||
$dateOK = true;
|
||||
if (count($tabDate) != 3) {
|
||||
$dateOK = false;
|
||||
}
|
||||
else {
|
||||
if (!estTableauEntiers($tabDate)) {
|
||||
$dateOK = false;
|
||||
}
|
||||
else {
|
||||
if (!checkdate($tabDate[1], $tabDate[0], $tabDate[2])) {
|
||||
$dateOK = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
return $dateOK;
|
||||
}
|
||||
|
||||
/**
|
||||
* Ajoute le libelle d'une erreur au tableau des erreurs
|
||||
* @param $msg : le libellé de l'erreur
|
||||
*/
|
||||
function ajouterErreur($msg){
|
||||
if (! isset($_REQUEST['erreurs'])){
|
||||
$_REQUEST['erreurs']=array();
|
||||
}
|
||||
$_REQUEST['erreurs'][]=$msg;
|
||||
}
|
||||
|
||||
/**
|
||||
* Retoune le nombre de lignes du tableau des erreurs
|
||||
* @return le nombre d'erreurs
|
||||
*/
|
||||
function nbErreurs(){
|
||||
if (!isset($_REQUEST['erreurs'])){
|
||||
return 0;
|
||||
}
|
||||
else{
|
||||
return count($_REQUEST['erreurs']);
|
||||
}
|
||||
}
|
||||
|
||||
/** afficherErreurSQL :
|
||||
Affichage de messages lors l'accès à la bdd avec une requete SQL
|
||||
@param $message : message a afficher
|
||||
@param $req : requete executee
|
||||
@param $info : erreur constatee
|
||||
*/
|
||||
function afficherErreurSQL($message, $req, $info) {
|
||||
echo $message . "<br />";
|
||||
echo "Requete : " . $req . "<br />";
|
||||
echo "Code erreur : " . $info[0] . ", Message : " . $info[2];
|
||||
die();
|
||||
}
|
||||
?>
|
339
ap23/web/doku/COPYING
Normal file
339
ap23/web/doku/COPYING
Normal file
@ -0,0 +1,339 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 2, June 1991
|
||||
|
||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your
|
||||
freedom to share and change it. By contrast, the GNU General Public
|
||||
License is intended to guarantee your freedom to share and change free
|
||||
software--to make sure the software is free for all its users. This
|
||||
General Public License applies to most of the Free Software
|
||||
Foundation's software and to any other program whose authors commit to
|
||||
using it. (Some other Free Software Foundation software is covered by
|
||||
the GNU Lesser General Public License instead.) You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
this service if you wish), that you receive source code or can get it
|
||||
if you want it, that you can change the software or use pieces of it
|
||||
in new free programs; and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid
|
||||
anyone to deny you these rights or to ask you to surrender the rights.
|
||||
These restrictions translate to certain responsibilities for you if you
|
||||
distribute copies of the software, or if you modify it.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must give the recipients all the rights that
|
||||
you have. You must make sure that they, too, receive or can get the
|
||||
source code. And you must show them these terms so they know their
|
||||
rights.
|
||||
|
||||
We protect your rights with two steps: (1) copyright the software, and
|
||||
(2) offer you this license which gives you legal permission to copy,
|
||||
distribute and/or modify the software.
|
||||
|
||||
Also, for each author's protection and ours, we want to make certain
|
||||
that everyone understands that there is no warranty for this free
|
||||
software. If the software is modified by someone else and passed on, we
|
||||
want its recipients to know that what they have is not the original, so
|
||||
that any problems introduced by others will not reflect on the original
|
||||
authors' reputations.
|
||||
|
||||
Finally, any free program is threatened constantly by software
|
||||
patents. We wish to avoid the danger that redistributors of a free
|
||||
program will individually obtain patent licenses, in effect making the
|
||||
program proprietary. To prevent this, we have made it clear that any
|
||||
patent must be licensed for everyone's free use or not licensed at all.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains
|
||||
a notice placed by the copyright holder saying it may be distributed
|
||||
under the terms of this General Public License. The "Program", below,
|
||||
refers to any such program or work, and a "work based on the Program"
|
||||
means either the Program or any derivative work under copyright law:
|
||||
that is to say, a work containing the Program or a portion of it,
|
||||
either verbatim or with modifications and/or translated into another
|
||||
language. (Hereinafter, translation is included without limitation in
|
||||
the term "modification".) Each licensee is addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running the Program is not restricted, and the output from the Program
|
||||
is covered only if its contents constitute a work based on the
|
||||
Program (independent of having been made by running the Program).
|
||||
Whether that is true depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's
|
||||
source code as you receive it, in any medium, provided that you
|
||||
conspicuously and appropriately publish on each copy an appropriate
|
||||
copyright notice and disclaimer of warranty; keep intact all the
|
||||
notices that refer to this License and to the absence of any warranty;
|
||||
and give any other recipients of the Program a copy of this License
|
||||
along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and
|
||||
you may at your option offer warranty protection in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion
|
||||
of it, thus forming a work based on the Program, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in
|
||||
whole or in part contains or is derived from the Program or any
|
||||
part thereof, to be licensed as a whole at no charge to all third
|
||||
parties under the terms of this License.
|
||||
|
||||
c) If the modified program normally reads commands interactively
|
||||
when run, you must cause it, when started running for such
|
||||
interactive use in the most ordinary way, to print or display an
|
||||
announcement including an appropriate copyright notice and a
|
||||
notice that there is no warranty (or else, saying that you provide
|
||||
a warranty) and that users may redistribute the program under
|
||||
these conditions, and telling the user how to view a copy of this
|
||||
License. (Exception: if the Program itself is interactive but
|
||||
does not normally print such an announcement, your work based on
|
||||
the Program is not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Program,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program
|
||||
with the Program (or with a work based on the Program) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it,
|
||||
under Section 2) in object code or executable form under the terms of
|
||||
Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable
|
||||
source code, which must be distributed under the terms of Sections
|
||||
1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three
|
||||
years, to give any third party, for a charge no more than your
|
||||
cost of physically performing source distribution, a complete
|
||||
machine-readable copy of the corresponding source code, to be
|
||||
distributed under the terms of Sections 1 and 2 above on a medium
|
||||
customarily used for software interchange; or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer
|
||||
to distribute corresponding source code. (This alternative is
|
||||
allowed only for noncommercial distribution and only if you
|
||||
received the program in object code or executable form with such
|
||||
an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for
|
||||
making modifications to it. For an executable work, complete source
|
||||
code means all the source code for all modules it contains, plus any
|
||||
associated interface definition files, plus the scripts used to
|
||||
control compilation and installation of the executable. However, as a
|
||||
special exception, the source code distributed need not include
|
||||
anything that is normally distributed (in either source or binary
|
||||
form) with the major components (compiler, kernel, and so on) of the
|
||||
operating system on which the executable runs, unless that component
|
||||
itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering
|
||||
access to copy from a designated place, then offering equivalent
|
||||
access to copy the source code from the same place counts as
|
||||
distribution of the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program
|
||||
except as expressly provided under this License. Any attempt
|
||||
otherwise to copy, modify, sublicense or distribute the Program is
|
||||
void, and will automatically terminate your rights under this License.
|
||||
However, parties who have received copies, or rights, from you under
|
||||
this License will not have their licenses terminated so long as such
|
||||
parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Program or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Program (or any work based on the
|
||||
Program), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the
|
||||
Program), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute or modify the Program subject to
|
||||
these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties to
|
||||
this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Program at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Program by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under
|
||||
any particular circumstance, the balance of the section is intended to
|
||||
apply and the section as a whole is intended to apply in other
|
||||
circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system, which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Program under this License
|
||||
may add an explicit geographical distribution limitation excluding
|
||||
those countries, so that distribution is permitted only in or among
|
||||
countries not thus excluded. In such case, this License incorporates
|
||||
the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions
|
||||
of the General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program
|
||||
specifies a version number of this License which applies to it and "any
|
||||
later version", you have the option of following the terms and conditions
|
||||
either of that version or of any later version published by the Free
|
||||
Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software
|
||||
Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free
|
||||
programs whose distribution conditions are different, write to the author
|
||||
to ask for permission. For software which is copyrighted by the Free
|
||||
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||
make exceptions for this. Our decision will be guided by the two goals
|
||||
of preserving the free status of all derivatives of our free software and
|
||||
of promoting the sharing and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||
REPAIR OR CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
convey the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License along
|
||||
with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program is interactive, make it output a short notice like this
|
||||
when it starts in an interactive mode:
|
||||
|
||||
Gnomovision version 69, Copyright (C) year name of author
|
||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, the commands you use may
|
||||
be called something other than `show w' and `show c'; they could even be
|
||||
mouse-clicks or menu items--whatever suits your program.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or your
|
||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||
necessary. Here is a sample; alter the names:
|
||||
|
||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||
|
||||
<signature of Ty Coon>, 1 April 1989
|
||||
Ty Coon, President of Vice
|
||||
|
||||
This General Public License does not permit incorporating your program into
|
||||
proprietary programs. If your program is a subroutine library, you may
|
||||
consider it more useful to permit linking proprietary applications with the
|
||||
library. If this is what you want to do, use the GNU Lesser General
|
||||
Public License instead of this License.
|
10
ap23/web/doku/README
Normal file
10
ap23/web/doku/README
Normal file
@ -0,0 +1,10 @@
|
||||
All documentation for DokuWiki is available online
|
||||
at https://www.dokuwiki.org/
|
||||
|
||||
For Installation Instructions see
|
||||
https://www.dokuwiki.org/install
|
||||
|
||||
DokuWiki - 2004-2020 (c) Andreas Gohr <andi@splitbrain.org>
|
||||
and the DokuWiki Community
|
||||
See COPYING and file headers for license info
|
||||
|
1
ap23/web/doku/VERSION
Normal file
1
ap23/web/doku/VERSION
Normal file
@ -0,0 +1 @@
|
||||
2020-07-29 "Hogfather"
|
7
ap23/web/doku/bin/.htaccess
Normal file
7
ap23/web/doku/bin/.htaccess
Normal file
@ -0,0 +1,7 @@
|
||||
<IfModule mod_authz_core.c>
|
||||
Require all denied
|
||||
</IfModule>
|
||||
<IfModule !mod_authz_core.c>
|
||||
Order allow,deny
|
||||
Deny from all
|
||||
</IfModule>
|
322
ap23/web/doku/bin/dwpage.php
Executable file
322
ap23/web/doku/bin/dwpage.php
Executable file
@ -0,0 +1,322 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
/**
|
||||
* Checkout and commit pages from the command line while maintaining the history
|
||||
*/
|
||||
class PageCLI extends CLI {
|
||||
|
||||
protected $force = false;
|
||||
protected $username = '';
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
/* global */
|
||||
$options->registerOption(
|
||||
'force',
|
||||
'force obtaining a lock for the page (generally bad idea)',
|
||||
'f'
|
||||
);
|
||||
$options->registerOption(
|
||||
'user',
|
||||
'work as this user. defaults to current CLI user',
|
||||
'u',
|
||||
'username'
|
||||
);
|
||||
$options->setHelp(
|
||||
'Utility to help command line Dokuwiki page editing, allow ' .
|
||||
'pages to be checked out for editing then committed after changes'
|
||||
);
|
||||
|
||||
/* checkout command */
|
||||
$options->registerCommand(
|
||||
'checkout',
|
||||
'Checks out a file from the repository, using the wiki id and obtaining ' .
|
||||
'a lock for the page. ' . "\n" .
|
||||
'If a working_file is specified, this is where the page is copied to. ' .
|
||||
'Otherwise defaults to the same as the wiki page in the current ' .
|
||||
'working directory.'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'wikipage',
|
||||
'The wiki page to checkout',
|
||||
true,
|
||||
'checkout'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'workingfile',
|
||||
'How to name the local checkout',
|
||||
false,
|
||||
'checkout'
|
||||
);
|
||||
|
||||
/* commit command */
|
||||
$options->registerCommand(
|
||||
'commit',
|
||||
'Checks in the working_file into the repository using the specified ' .
|
||||
'wiki id, archiving the previous version.'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'workingfile',
|
||||
'The local file to commit',
|
||||
true,
|
||||
'commit'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'wikipage',
|
||||
'The wiki page to create or update',
|
||||
true,
|
||||
'commit'
|
||||
);
|
||||
$options->registerOption(
|
||||
'message',
|
||||
'Summary describing the change (required)',
|
||||
'm',
|
||||
'summary',
|
||||
'commit'
|
||||
);
|
||||
$options->registerOption(
|
||||
'trivial',
|
||||
'minor change',
|
||||
't',
|
||||
false,
|
||||
'commit'
|
||||
);
|
||||
|
||||
/* lock command */
|
||||
$options->registerCommand(
|
||||
'lock',
|
||||
'Obtains or updates a lock for a wiki page'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'wikipage',
|
||||
'The wiki page to lock',
|
||||
true,
|
||||
'lock'
|
||||
);
|
||||
|
||||
/* unlock command */
|
||||
$options->registerCommand(
|
||||
'unlock',
|
||||
'Removes a lock for a wiki page.'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'wikipage',
|
||||
'The wiki page to unlock',
|
||||
true,
|
||||
'unlock'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
$this->force = $options->getOpt('force', false);
|
||||
$this->username = $options->getOpt('user', $this->getUser());
|
||||
|
||||
$command = $options->getCmd();
|
||||
$args = $options->getArgs();
|
||||
switch($command) {
|
||||
case 'checkout':
|
||||
$wiki_id = array_shift($args);
|
||||
$localfile = array_shift($args);
|
||||
$this->commandCheckout($wiki_id, $localfile);
|
||||
break;
|
||||
case 'commit':
|
||||
$localfile = array_shift($args);
|
||||
$wiki_id = array_shift($args);
|
||||
$this->commandCommit(
|
||||
$localfile,
|
||||
$wiki_id,
|
||||
$options->getOpt('message', ''),
|
||||
$options->getOpt('trivial', false)
|
||||
);
|
||||
break;
|
||||
case 'lock':
|
||||
$wiki_id = array_shift($args);
|
||||
$this->obtainLock($wiki_id);
|
||||
$this->success("$wiki_id locked");
|
||||
break;
|
||||
case 'unlock':
|
||||
$wiki_id = array_shift($args);
|
||||
$this->clearLock($wiki_id);
|
||||
$this->success("$wiki_id unlocked");
|
||||
break;
|
||||
default:
|
||||
echo $options->help();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Check out a file
|
||||
*
|
||||
* @param string $wiki_id
|
||||
* @param string $localfile
|
||||
*/
|
||||
protected function commandCheckout($wiki_id, $localfile) {
|
||||
global $conf;
|
||||
|
||||
$wiki_id = cleanID($wiki_id);
|
||||
$wiki_fn = wikiFN($wiki_id);
|
||||
|
||||
if(!file_exists($wiki_fn)) {
|
||||
$this->fatal("$wiki_id does not yet exist");
|
||||
}
|
||||
|
||||
if(empty($localfile)) {
|
||||
$localfile = getcwd() . '/' . \dokuwiki\Utf8\PhpString::basename($wiki_fn);
|
||||
}
|
||||
|
||||
if(!file_exists(dirname($localfile))) {
|
||||
$this->fatal("Directory " . dirname($localfile) . " does not exist");
|
||||
}
|
||||
|
||||
if(stristr(realpath(dirname($localfile)), realpath($conf['datadir'])) !== false) {
|
||||
$this->fatal("Attempt to check out file into data directory - not allowed");
|
||||
}
|
||||
|
||||
$this->obtainLock($wiki_id);
|
||||
|
||||
if(!copy($wiki_fn, $localfile)) {
|
||||
$this->clearLock($wiki_id);
|
||||
$this->fatal("Unable to copy $wiki_fn to $localfile");
|
||||
}
|
||||
|
||||
$this->success("$wiki_id > $localfile");
|
||||
}
|
||||
|
||||
/**
|
||||
* Save a file as a new page revision
|
||||
*
|
||||
* @param string $localfile
|
||||
* @param string $wiki_id
|
||||
* @param string $message
|
||||
* @param bool $minor
|
||||
*/
|
||||
protected function commandCommit($localfile, $wiki_id, $message, $minor) {
|
||||
$wiki_id = cleanID($wiki_id);
|
||||
$message = trim($message);
|
||||
|
||||
if(!file_exists($localfile)) {
|
||||
$this->fatal("$localfile does not exist");
|
||||
}
|
||||
|
||||
if(!is_readable($localfile)) {
|
||||
$this->fatal("Cannot read from $localfile");
|
||||
}
|
||||
|
||||
if(!$message) {
|
||||
$this->fatal("Summary message required");
|
||||
}
|
||||
|
||||
$this->obtainLock($wiki_id);
|
||||
|
||||
saveWikiText($wiki_id, file_get_contents($localfile), $message, $minor);
|
||||
|
||||
$this->clearLock($wiki_id);
|
||||
|
||||
$this->success("$localfile > $wiki_id");
|
||||
}
|
||||
|
||||
/**
|
||||
* Lock the given page or exit
|
||||
*
|
||||
* @param string $wiki_id
|
||||
*/
|
||||
protected function obtainLock($wiki_id) {
|
||||
if($this->force) $this->deleteLock($wiki_id);
|
||||
|
||||
$_SERVER['REMOTE_USER'] = $this->username;
|
||||
|
||||
if(checklock($wiki_id)) {
|
||||
$this->error("Page $wiki_id is already locked by another user");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
lock($wiki_id);
|
||||
|
||||
if(checklock($wiki_id)) {
|
||||
$this->error("Unable to obtain lock for $wiki_id ");
|
||||
var_dump(checklock($wiki_id));
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Clear the lock on the given page
|
||||
*
|
||||
* @param string $wiki_id
|
||||
*/
|
||||
protected function clearLock($wiki_id) {
|
||||
if($this->force) $this->deleteLock($wiki_id);
|
||||
|
||||
$_SERVER['REMOTE_USER'] = $this->username;
|
||||
if(checklock($wiki_id)) {
|
||||
$this->error("Page $wiki_id is locked by another user");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
unlock($wiki_id);
|
||||
|
||||
if(file_exists(wikiLockFN($wiki_id))) {
|
||||
$this->error("Unable to clear lock for $wiki_id");
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Forcefully remove a lock on the page given
|
||||
*
|
||||
* @param string $wiki_id
|
||||
*/
|
||||
protected function deleteLock($wiki_id) {
|
||||
$wikiLockFN = wikiLockFN($wiki_id);
|
||||
|
||||
if(file_exists($wikiLockFN)) {
|
||||
if(!unlink($wikiLockFN)) {
|
||||
$this->error("Unable to delete $wikiLockFN");
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the current user's username from the environment
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
protected function getUser() {
|
||||
$user = getenv('USER');
|
||||
if(empty ($user)) {
|
||||
$user = getenv('USERNAME');
|
||||
} else {
|
||||
return $user;
|
||||
}
|
||||
if(empty ($user)) {
|
||||
$user = 'admin';
|
||||
}
|
||||
return $user;
|
||||
}
|
||||
}
|
||||
|
||||
// Main
|
||||
$cli = new PageCLI();
|
||||
$cli->run();
|
340
ap23/web/doku/bin/gittool.php
Executable file
340
ap23/web/doku/bin/gittool.php
Executable file
@ -0,0 +1,340 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
/**
|
||||
* Easily manage DokuWiki git repositories
|
||||
*
|
||||
* @author Andreas Gohr <andi@splitbrain.org>
|
||||
*/
|
||||
class GitToolCLI extends CLI {
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
$options->setHelp(
|
||||
"Manage git repositories for DokuWiki and its plugins and templates.\n\n" .
|
||||
"$> ./bin/gittool.php clone gallery template:ach\n" .
|
||||
"$> ./bin/gittool.php repos\n" .
|
||||
"$> ./bin/gittool.php origin -v"
|
||||
);
|
||||
|
||||
$options->registerArgument(
|
||||
'command',
|
||||
'Command to execute. See below',
|
||||
true
|
||||
);
|
||||
|
||||
$options->registerCommand(
|
||||
'clone',
|
||||
'Tries to install a known plugin or template (prefix with template:) via git. Uses the DokuWiki.org ' .
|
||||
'plugin repository to find the proper git repository. Multiple extensions can be given as parameters'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'extension',
|
||||
'name of the extension to install, prefix with \'template:\' for templates',
|
||||
true,
|
||||
'clone'
|
||||
);
|
||||
|
||||
$options->registerCommand(
|
||||
'install',
|
||||
'The same as clone, but when no git source repository can be found, the extension is installed via ' .
|
||||
'download'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'extension',
|
||||
'name of the extension to install, prefix with \'template:\' for templates',
|
||||
true,
|
||||
'install'
|
||||
);
|
||||
|
||||
$options->registerCommand(
|
||||
'repos',
|
||||
'Lists all git repositories found in this DokuWiki installation'
|
||||
);
|
||||
|
||||
$options->registerCommand(
|
||||
'*',
|
||||
'Any unknown commands are assumed to be arguments to git and will be executed in all repositories ' .
|
||||
'found within this DokuWiki installation'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
$command = $options->getCmd();
|
||||
$args = $options->getArgs();
|
||||
if(!$command) $command = array_shift($args);
|
||||
|
||||
switch($command) {
|
||||
case '':
|
||||
echo $options->help();
|
||||
break;
|
||||
case 'clone':
|
||||
$this->cmdClone($args);
|
||||
break;
|
||||
case 'install':
|
||||
$this->cmdInstall($args);
|
||||
break;
|
||||
case 'repo':
|
||||
case 'repos':
|
||||
$this->cmdRepos();
|
||||
break;
|
||||
default:
|
||||
$this->cmdGit($command, $args);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Tries to install the given extensions using git clone
|
||||
*
|
||||
* @param array $extensions
|
||||
*/
|
||||
public function cmdClone($extensions) {
|
||||
$errors = array();
|
||||
$succeeded = array();
|
||||
|
||||
foreach($extensions as $ext) {
|
||||
$repo = $this->getSourceRepo($ext);
|
||||
|
||||
if(!$repo) {
|
||||
$this->error("could not find a repository for $ext");
|
||||
$errors[] = $ext;
|
||||
} else {
|
||||
if($this->cloneExtension($ext, $repo)) {
|
||||
$succeeded[] = $ext;
|
||||
} else {
|
||||
$errors[] = $ext;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
echo "\n";
|
||||
if($succeeded) $this->success('successfully cloned the following extensions: ' . join(', ', $succeeded));
|
||||
if($errors) $this->error('failed to clone the following extensions: ' . join(', ', $errors));
|
||||
}
|
||||
|
||||
/**
|
||||
* Tries to install the given extensions using git clone with fallback to install
|
||||
*
|
||||
* @param array $extensions
|
||||
*/
|
||||
public function cmdInstall($extensions) {
|
||||
$errors = array();
|
||||
$succeeded = array();
|
||||
|
||||
foreach($extensions as $ext) {
|
||||
$repo = $this->getSourceRepo($ext);
|
||||
|
||||
if(!$repo) {
|
||||
$this->info("could not find a repository for $ext");
|
||||
if($this->downloadExtension($ext)) {
|
||||
$succeeded[] = $ext;
|
||||
} else {
|
||||
$errors[] = $ext;
|
||||
}
|
||||
} else {
|
||||
if($this->cloneExtension($ext, $repo)) {
|
||||
$succeeded[] = $ext;
|
||||
} else {
|
||||
$errors[] = $ext;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
echo "\n";
|
||||
if($succeeded) $this->success('successfully installed the following extensions: ' . join(', ', $succeeded));
|
||||
if($errors) $this->error('failed to install the following extensions: ' . join(', ', $errors));
|
||||
}
|
||||
|
||||
/**
|
||||
* Executes the given git command in every repository
|
||||
*
|
||||
* @param $cmd
|
||||
* @param $arg
|
||||
*/
|
||||
public function cmdGit($cmd, $arg) {
|
||||
$repos = $this->findRepos();
|
||||
|
||||
$shell = array_merge(array('git', $cmd), $arg);
|
||||
$shell = array_map('escapeshellarg', $shell);
|
||||
$shell = join(' ', $shell);
|
||||
|
||||
foreach($repos as $repo) {
|
||||
if(!@chdir($repo)) {
|
||||
$this->error("Could not change into $repo");
|
||||
continue;
|
||||
}
|
||||
|
||||
$this->info("executing $shell in $repo");
|
||||
$ret = 0;
|
||||
system($shell, $ret);
|
||||
|
||||
if($ret == 0) {
|
||||
$this->success("git succeeded in $repo");
|
||||
} else {
|
||||
$this->error("git failed in $repo");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Simply lists the repositories
|
||||
*/
|
||||
public function cmdRepos() {
|
||||
$repos = $this->findRepos();
|
||||
foreach($repos as $repo) {
|
||||
echo "$repo\n";
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Install extension from the given download URL
|
||||
*
|
||||
* @param string $ext
|
||||
* @return bool|null
|
||||
*/
|
||||
private function downloadExtension($ext) {
|
||||
/** @var helper_plugin_extension_extension $plugin */
|
||||
$plugin = plugin_load('helper', 'extension_extension');
|
||||
if(!$ext) die("extension plugin not available, can't continue");
|
||||
|
||||
$plugin->setExtension($ext);
|
||||
|
||||
$url = $plugin->getDownloadURL();
|
||||
if(!$url) {
|
||||
$this->error("no download URL for $ext");
|
||||
return false;
|
||||
}
|
||||
|
||||
$ok = false;
|
||||
try {
|
||||
$this->info("installing $ext via download from $url");
|
||||
$ok = $plugin->installFromURL($url);
|
||||
} catch(Exception $e) {
|
||||
$this->error($e->getMessage());
|
||||
}
|
||||
|
||||
if($ok) {
|
||||
$this->success("installed $ext via download");
|
||||
return true;
|
||||
} else {
|
||||
$this->success("failed to install $ext via download");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Clones the extension from the given repository
|
||||
*
|
||||
* @param string $ext
|
||||
* @param string $repo
|
||||
* @return bool
|
||||
*/
|
||||
private function cloneExtension($ext, $repo) {
|
||||
if(substr($ext, 0, 9) == 'template:') {
|
||||
$target = fullpath(tpl_incdir() . '../' . substr($ext, 9));
|
||||
} else {
|
||||
$target = DOKU_PLUGIN . $ext;
|
||||
}
|
||||
|
||||
$this->info("cloning $ext from $repo to $target");
|
||||
$ret = 0;
|
||||
system("git clone $repo $target", $ret);
|
||||
if($ret === 0) {
|
||||
$this->success("cloning of $ext succeeded");
|
||||
return true;
|
||||
} else {
|
||||
$this->error("cloning of $ext failed");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns all git repositories in this DokuWiki install
|
||||
*
|
||||
* Looks in root, template and plugin directories only.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
private function findRepos() {
|
||||
$this->info('Looking for .git directories');
|
||||
$data = array_merge(
|
||||
glob(DOKU_INC . '.git', GLOB_ONLYDIR),
|
||||
glob(DOKU_PLUGIN . '*/.git', GLOB_ONLYDIR),
|
||||
glob(fullpath(tpl_incdir() . '../') . '/*/.git', GLOB_ONLYDIR)
|
||||
);
|
||||
|
||||
if(!$data) {
|
||||
$this->error('Found no .git directories');
|
||||
} else {
|
||||
$this->success('Found ' . count($data) . ' .git directories');
|
||||
}
|
||||
$data = array_map('fullpath', array_map('dirname', $data));
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the repository for the given extension
|
||||
*
|
||||
* @param $extension
|
||||
* @return false|string
|
||||
*/
|
||||
private function getSourceRepo($extension) {
|
||||
/** @var helper_plugin_extension_extension $ext */
|
||||
$ext = plugin_load('helper', 'extension_extension');
|
||||
if(!$ext) die("extension plugin not available, can't continue");
|
||||
|
||||
$ext->setExtension($extension);
|
||||
|
||||
$repourl = $ext->getSourcerepoURL();
|
||||
if(!$repourl) return false;
|
||||
|
||||
// match github repos
|
||||
if(preg_match('/github\.com\/([^\/]+)\/([^\/]+)/i', $repourl, $m)) {
|
||||
$user = $m[1];
|
||||
$repo = $m[2];
|
||||
return 'https://github.com/' . $user . '/' . $repo . '.git';
|
||||
}
|
||||
|
||||
// match gitorious repos
|
||||
if(preg_match('/gitorious.org\/([^\/]+)\/([^\/]+)?/i', $repourl, $m)) {
|
||||
$user = $m[1];
|
||||
$repo = $m[2];
|
||||
if(!$repo) $repo = $user;
|
||||
|
||||
return 'https://git.gitorious.org/' . $user . '/' . $repo . '.git';
|
||||
}
|
||||
|
||||
// match bitbucket repos - most people seem to use mercurial there though
|
||||
if(preg_match('/bitbucket\.org\/([^\/]+)\/([^\/]+)/i', $repourl, $m)) {
|
||||
$user = $m[1];
|
||||
$repo = $m[2];
|
||||
return 'https://bitbucket.org/' . $user . '/' . $repo . '.git';
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
// Main
|
||||
$cli = new GitToolCLI();
|
||||
$cli->run();
|
107
ap23/web/doku/bin/indexer.php
Executable file
107
ap23/web/doku/bin/indexer.php
Executable file
@ -0,0 +1,107 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
/**
|
||||
* Update the Search Index from command line
|
||||
*/
|
||||
class IndexerCLI extends CLI {
|
||||
|
||||
private $quiet = false;
|
||||
private $clear = false;
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
$options->setHelp(
|
||||
'Updates the searchindex by indexing all new or changed pages. When the -c option is ' .
|
||||
'given the index is cleared first.'
|
||||
);
|
||||
|
||||
$options->registerOption(
|
||||
'clear',
|
||||
'clear the index before updating',
|
||||
'c'
|
||||
);
|
||||
$options->registerOption(
|
||||
'quiet',
|
||||
'don\'t produce any output',
|
||||
'q'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
$this->clear = $options->getOpt('clear');
|
||||
$this->quiet = $options->getOpt('quiet');
|
||||
|
||||
if($this->clear) $this->clearindex();
|
||||
|
||||
$this->update();
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the index
|
||||
*/
|
||||
protected function update() {
|
||||
global $conf;
|
||||
$data = array();
|
||||
$this->quietecho("Searching pages... ");
|
||||
search($data, $conf['datadir'], 'search_allpages', array('skipacl' => true));
|
||||
$this->quietecho(count($data) . " pages found.\n");
|
||||
|
||||
foreach($data as $val) {
|
||||
$this->index($val['id']);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Index the given page
|
||||
*
|
||||
* @param string $id
|
||||
*/
|
||||
protected function index($id) {
|
||||
$this->quietecho("$id... ");
|
||||
idx_addPage($id, !$this->quiet, $this->clear);
|
||||
$this->quietecho("done.\n");
|
||||
}
|
||||
|
||||
/**
|
||||
* Clear all index files
|
||||
*/
|
||||
protected function clearindex() {
|
||||
$this->quietecho("Clearing index... ");
|
||||
idx_get_indexer()->clear();
|
||||
$this->quietecho("done.\n");
|
||||
}
|
||||
|
||||
/**
|
||||
* Print message if not supressed
|
||||
*
|
||||
* @param string $msg
|
||||
*/
|
||||
protected function quietecho($msg) {
|
||||
if(!$this->quiet) echo $msg;
|
||||
}
|
||||
}
|
||||
|
||||
// Main
|
||||
$cli = new IndexerCLI();
|
||||
$cli->run();
|
103
ap23/web/doku/bin/plugin.php
Executable file
103
ap23/web/doku/bin/plugin.php
Executable file
@ -0,0 +1,103 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use dokuwiki\Extension\PluginController;
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Colors;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
class PluginCLI extends CLI {
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
$options->setHelp('Excecutes Plugin command line tools');
|
||||
$options->registerArgument('plugin', 'The plugin CLI you want to run. Leave off to see list', false);
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
global $argv;
|
||||
$argv = $options->getArgs();
|
||||
|
||||
if($argv) {
|
||||
$plugin = $this->loadPlugin($argv[0]);
|
||||
if($plugin !== null) {
|
||||
$plugin->run();
|
||||
} else {
|
||||
$this->fatal('Command {cmd} not found.', ['cmd' => $argv[0]]);
|
||||
}
|
||||
} else {
|
||||
echo $options->help();
|
||||
$this->listPlugins();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* List available plugins
|
||||
*/
|
||||
protected function listPlugins() {
|
||||
/** @var PluginController $plugin_controller */
|
||||
global $plugin_controller;
|
||||
|
||||
echo "\n";
|
||||
echo "\n";
|
||||
echo $this->colors->wrap('AVAILABLE PLUGINS:', Colors::C_BROWN);
|
||||
echo "\n";
|
||||
|
||||
$list = $plugin_controller->getList('cli');
|
||||
sort($list);
|
||||
if(!count($list)) {
|
||||
echo $this->colors->wrap(" No plugins providing CLI components available\n", Colors::C_RED);
|
||||
} else {
|
||||
$tf = new \splitbrain\phpcli\TableFormatter($this->colors);
|
||||
|
||||
foreach($list as $name) {
|
||||
$plugin = $this->loadPlugin($name);
|
||||
if($plugin === null) continue;
|
||||
$info = $plugin->getInfo();
|
||||
|
||||
echo $tf->format(
|
||||
[2, '30%', '*'],
|
||||
['', $name, $info['desc']],
|
||||
['', Colors::C_CYAN, '']
|
||||
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Instantiate a CLI plugin
|
||||
*
|
||||
* @param string $name
|
||||
* @return \dokuwiki\Extension\CLIPlugin|null
|
||||
*/
|
||||
protected function loadPlugin($name) {
|
||||
// execute the plugin CLI
|
||||
$class = "cli_plugin_$name";
|
||||
if(class_exists($class)) {
|
||||
return new $class();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
// Main
|
||||
$cli = new PluginCLI();
|
||||
$cli->run();
|
64
ap23/web/doku/bin/render.php
Executable file
64
ap23/web/doku/bin/render.php
Executable file
@ -0,0 +1,64 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
/**
|
||||
* A simple commandline tool to render some DokuWiki syntax with a given
|
||||
* renderer.
|
||||
*
|
||||
* This may not work for plugins that expect a certain environment to be
|
||||
* set up before rendering, but should work for most or even all standard
|
||||
* DokuWiki markup
|
||||
*
|
||||
* @license GPL2
|
||||
* @author Andreas Gohr <andi@splitbrain.org>
|
||||
*/
|
||||
class RenderCLI extends CLI {
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
$options->setHelp(
|
||||
'A simple commandline tool to render some DokuWiki syntax with a given renderer.' .
|
||||
"\n\n" .
|
||||
'This may not work for plugins that expect a certain environment to be ' .
|
||||
'set up before rendering, but should work for most or even all standard ' .
|
||||
'DokuWiki markup'
|
||||
);
|
||||
$options->registerOption('renderer', 'The renderer mode to use. Defaults to xhtml', 'r', 'mode');
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @throws DokuCLI_Exception
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
$renderer = $options->getOpt('renderer', 'xhtml');
|
||||
|
||||
// do the action
|
||||
$source = stream_get_contents(STDIN);
|
||||
$info = array();
|
||||
$result = p_render($renderer, p_get_instructions($source), $info);
|
||||
if(is_null($result)) throw new DokuCLI_Exception("No such renderer $renderer");
|
||||
echo $result;
|
||||
}
|
||||
}
|
||||
|
||||
// Main
|
||||
$cli = new RenderCLI();
|
||||
$cli->run();
|
114
ap23/web/doku/bin/striplangs.php
Executable file
114
ap23/web/doku/bin/striplangs.php
Executable file
@ -0,0 +1,114 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
/**
|
||||
* Remove unwanted languages from a DokuWiki install
|
||||
*/
|
||||
class StripLangsCLI extends CLI {
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
|
||||
$options->setHelp(
|
||||
'Remove all languages from the installation, besides the ones specified. English language ' .
|
||||
'is never removed!'
|
||||
);
|
||||
|
||||
$options->registerOption(
|
||||
'keep',
|
||||
'Comma separated list of languages to keep in addition to English.',
|
||||
'k',
|
||||
'langcodes'
|
||||
);
|
||||
$options->registerOption(
|
||||
'english-only',
|
||||
'Remove all languages except English',
|
||||
'e'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
if($options->getOpt('keep')) {
|
||||
$keep = explode(',', $options->getOpt('keep'));
|
||||
if(!in_array('en', $keep)) $keep[] = 'en';
|
||||
} elseif($options->getOpt('english-only')) {
|
||||
$keep = array('en');
|
||||
} else {
|
||||
echo $options->help();
|
||||
exit(0);
|
||||
}
|
||||
|
||||
// Kill all language directories in /inc/lang and /lib/plugins besides those in $langs array
|
||||
$this->stripDirLangs(realpath(dirname(__FILE__) . '/../inc/lang'), $keep);
|
||||
$this->processExtensions(realpath(dirname(__FILE__) . '/../lib/plugins'), $keep);
|
||||
$this->processExtensions(realpath(dirname(__FILE__) . '/../lib/tpl'), $keep);
|
||||
}
|
||||
|
||||
/**
|
||||
* Strip languages from extensions
|
||||
*
|
||||
* @param string $path path to plugin or template dir
|
||||
* @param array $keep_langs languages to keep
|
||||
*/
|
||||
protected function processExtensions($path, $keep_langs) {
|
||||
if(is_dir($path)) {
|
||||
$entries = scandir($path);
|
||||
|
||||
foreach($entries as $entry) {
|
||||
if($entry != "." && $entry != "..") {
|
||||
if(is_dir($path . '/' . $entry)) {
|
||||
|
||||
$plugin_langs = $path . '/' . $entry . '/lang';
|
||||
|
||||
if(is_dir($plugin_langs)) {
|
||||
$this->stripDirLangs($plugin_langs, $keep_langs);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Strip languages from path
|
||||
*
|
||||
* @param string $path path to lang dir
|
||||
* @param array $keep_langs languages to keep
|
||||
*/
|
||||
protected function stripDirLangs($path, $keep_langs) {
|
||||
$dir = dir($path);
|
||||
|
||||
while(($cur_dir = $dir->read()) !== false) {
|
||||
if($cur_dir != '.' and $cur_dir != '..' and is_dir($path . '/' . $cur_dir)) {
|
||||
|
||||
if(!in_array($cur_dir, $keep_langs, true)) {
|
||||
io_rmdir($path . '/' . $cur_dir, true);
|
||||
}
|
||||
}
|
||||
}
|
||||
$dir->close();
|
||||
}
|
||||
}
|
||||
|
||||
$cli = new StripLangsCLI();
|
||||
$cli->run();
|
186
ap23/web/doku/bin/wantedpages.php
Executable file
186
ap23/web/doku/bin/wantedpages.php
Executable file
@ -0,0 +1,186 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use splitbrain\phpcli\CLI;
|
||||
use splitbrain\phpcli\Options;
|
||||
|
||||
if(!defined('DOKU_INC')) define('DOKU_INC', realpath(dirname(__FILE__) . '/../') . '/');
|
||||
define('NOSESSION', 1);
|
||||
require_once(DOKU_INC . 'inc/init.php');
|
||||
|
||||
/**
|
||||
* Find wanted pages
|
||||
*/
|
||||
class WantedPagesCLI extends CLI {
|
||||
|
||||
const DIR_CONTINUE = 1;
|
||||
const DIR_NS = 2;
|
||||
const DIR_PAGE = 3;
|
||||
|
||||
private $skip = false;
|
||||
private $sort = 'wanted';
|
||||
|
||||
private $result = array();
|
||||
|
||||
/**
|
||||
* Register options and arguments on the given $options object
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function setup(Options $options) {
|
||||
$options->setHelp(
|
||||
'Outputs a list of wanted pages (pages that do not exist yet) and their origin pages ' .
|
||||
' (the pages that are linkin to these missing pages).'
|
||||
);
|
||||
$options->registerArgument(
|
||||
'namespace',
|
||||
'The namespace to lookup. Defaults to root namespace',
|
||||
false
|
||||
);
|
||||
|
||||
$options->registerOption(
|
||||
'sort',
|
||||
'Sort by wanted or origin page',
|
||||
's',
|
||||
'(wanted|origin)'
|
||||
);
|
||||
|
||||
$options->registerOption(
|
||||
'skip',
|
||||
'Do not show the second dimension',
|
||||
'k'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Your main program
|
||||
*
|
||||
* Arguments and options have been parsed when this is run
|
||||
*
|
||||
* @param Options $options
|
||||
* @return void
|
||||
*/
|
||||
protected function main(Options $options) {
|
||||
$args = $options->getArgs();
|
||||
if($args) {
|
||||
$startdir = dirname(wikiFN($args[0] . ':xxx'));
|
||||
} else {
|
||||
$startdir = dirname(wikiFN('xxx'));
|
||||
}
|
||||
|
||||
$this->skip = $options->getOpt('skip');
|
||||
$this->sort = $options->getOpt('sort');
|
||||
|
||||
$this->info("searching $startdir");
|
||||
|
||||
foreach($this->getPages($startdir) as $page) {
|
||||
$this->internalLinks($page);
|
||||
}
|
||||
ksort($this->result);
|
||||
foreach($this->result as $main => $subs) {
|
||||
if($this->skip) {
|
||||
print "$main\n";
|
||||
} else {
|
||||
$subs = array_unique($subs);
|
||||
sort($subs);
|
||||
foreach($subs as $sub) {
|
||||
printf("%-40s %s\n", $main, $sub);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine directions of the search loop
|
||||
*
|
||||
* @param string $entry
|
||||
* @param string $basepath
|
||||
* @return int
|
||||
*/
|
||||
protected function dirFilter($entry, $basepath) {
|
||||
if($entry == '.' || $entry == '..') {
|
||||
return WantedPagesCLI::DIR_CONTINUE;
|
||||
}
|
||||
if(is_dir($basepath . '/' . $entry)) {
|
||||
if(strpos($entry, '_') === 0) {
|
||||
return WantedPagesCLI::DIR_CONTINUE;
|
||||
}
|
||||
return WantedPagesCLI::DIR_NS;
|
||||
}
|
||||
if(preg_match('/\.txt$/', $entry)) {
|
||||
return WantedPagesCLI::DIR_PAGE;
|
||||
}
|
||||
return WantedPagesCLI::DIR_CONTINUE;
|
||||
}
|
||||
|
||||
/**
|
||||
* Collects recursively the pages in a namespace
|
||||
*
|
||||
* @param string $dir
|
||||
* @return array
|
||||
* @throws DokuCLI_Exception
|
||||
*/
|
||||
protected function getPages($dir) {
|
||||
static $trunclen = null;
|
||||
if(!$trunclen) {
|
||||
global $conf;
|
||||
$trunclen = strlen($conf['datadir'] . ':');
|
||||
}
|
||||
|
||||
if(!is_dir($dir)) {
|
||||
throw new DokuCLI_Exception("Unable to read directory $dir");
|
||||
}
|
||||
|
||||
$pages = array();
|
||||
$dh = opendir($dir);
|
||||
while(false !== ($entry = readdir($dh))) {
|
||||
$status = $this->dirFilter($entry, $dir);
|
||||
if($status == WantedPagesCLI::DIR_CONTINUE) {
|
||||
continue;
|
||||
} else if($status == WantedPagesCLI::DIR_NS) {
|
||||
$pages = array_merge($pages, $this->getPages($dir . '/' . $entry));
|
||||
} else {
|
||||
$page = array(
|
||||
'id' => pathID(substr($dir . '/' . $entry, $trunclen)),
|
||||
'file' => $dir . '/' . $entry,
|
||||
);
|
||||
$pages[] = $page;
|
||||
}
|
||||
}
|
||||
closedir($dh);
|
||||
return $pages;
|
||||
}
|
||||
|
||||
/**
|
||||
* Parse instructions and add the non-existing links to the result array
|
||||
*
|
||||
* @param array $page array with page id and file path
|
||||
*/
|
||||
protected function internalLinks($page) {
|
||||
global $conf;
|
||||
$instructions = p_get_instructions(file_get_contents($page['file']));
|
||||
$cns = getNS($page['id']);
|
||||
$exists = false;
|
||||
$pid = $page['id'];
|
||||
foreach($instructions as $ins) {
|
||||
if($ins[0] == 'internallink' || ($conf['camelcase'] && $ins[0] == 'camelcaselink')) {
|
||||
$mid = $ins[1][0];
|
||||
resolve_pageid($cns, $mid, $exists);
|
||||
if(!$exists) {
|
||||
list($mid) = explode('#', $mid); //record pages without hashes
|
||||
|
||||
if($this->sort == 'origin') {
|
||||
$this->result[$pid][] = $mid;
|
||||
} else {
|
||||
$this->result[$mid][] = $pid;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Main
|
||||
$cli = new WantedPagesCLI();
|
||||
$cli->run();
|
8
ap23/web/doku/conf/.htaccess
Normal file
8
ap23/web/doku/conf/.htaccess
Normal file
@ -0,0 +1,8 @@
|
||||
## no access to the conf directory
|
||||
<IfModule mod_authz_core.c>
|
||||
Require all denied
|
||||
</IfModule>
|
||||
<IfModule !mod_authz_core.c>
|
||||
Order allow,deny
|
||||
Deny from all
|
||||
</IfModule>
|
9
ap23/web/doku/conf/acl.auth.php
Normal file
9
ap23/web/doku/conf/acl.auth.php
Normal file
@ -0,0 +1,9 @@
|
||||
# acl.auth.php
|
||||
# <?php exit()?>
|
||||
# Don't modify the lines above
|
||||
#
|
||||
# Access Control Lists
|
||||
#
|
||||
# Auto-generated by install script
|
||||
# Date: Thu, 13 Jan 2022 07:45:04 +0000
|
||||
* @ALL 8
|
21
ap23/web/doku/conf/acl.auth.php.dist
Normal file
21
ap23/web/doku/conf/acl.auth.php.dist
Normal file
@ -0,0 +1,21 @@
|
||||
# acl.auth.php
|
||||
# <?php exit()?>
|
||||
# Don't modify the lines above
|
||||
#
|
||||
# Access Control Lists
|
||||
#
|
||||
# Editing this file by hand shouldn't be necessary. Use the ACL
|
||||
# Manager interface instead.
|
||||
#
|
||||
# If your auth backend allows special char like spaces in groups
|
||||
# or user names you need to urlencode them (only chars <128, leave
|
||||
# UTF-8 multibyte chars as is)
|
||||
#
|
||||
# none 0
|
||||
# read 1
|
||||
# edit 2
|
||||
# create 4
|
||||
# upload 8
|
||||
# delete 16
|
||||
|
||||
* @ALL 8
|
62
ap23/web/doku/conf/acronyms.conf
Normal file
62
ap23/web/doku/conf/acronyms.conf
Normal file
@ -0,0 +1,62 @@
|
||||
# Acronyms.
|
||||
|
||||
ACL Access Control List
|
||||
AFAICS As far as I can see
|
||||
AFAIK As far as I know
|
||||
AFAIR As far as I remember
|
||||
API Application Programming Interface
|
||||
ASAP As soon as possible
|
||||
ASCII American Standard Code for Information Interchange
|
||||
BTW By the way
|
||||
CMS Content Management System
|
||||
CSS Cascading Style Sheets
|
||||
DNS Domain Name System
|
||||
EOF End of file
|
||||
EOL End of line
|
||||
EOM End of message
|
||||
EOT End of text
|
||||
FAQ Frequently Asked Questions
|
||||
FTP File Transfer Protocol
|
||||
FOSS Free & Open-Source Software
|
||||
FLOSS Free/Libre and Open Source Software
|
||||
FUD Fear, Uncertainty, and Doubt
|
||||
FYI For your information
|
||||
GB Gigabyte
|
||||
GHz Gigahertz
|
||||
GPL GNU General Public License
|
||||
GUI Graphical User Interface
|
||||
HTML HyperText Markup Language
|
||||
IANAL I am not a lawyer (but)
|
||||
IE Internet Explorer
|
||||
IIRC If I remember correctly
|
||||
IMHO In my humble opinion
|
||||
IMO In my opinion
|
||||
IOW In other words
|
||||
IRC Internet Relay Chat
|
||||
IRL In real life
|
||||
KISS Keep it simple stupid
|
||||
LAN Local Area Network
|
||||
LGPL GNU Lesser General Public License
|
||||
LOL Laughing out loud
|
||||
MathML Mathematical Markup Language
|
||||
MB Megabyte
|
||||
MHz Megahertz
|
||||
MSIE Microsoft Internet Explorer
|
||||
OMG Oh my God
|
||||
OS Operating System
|
||||
OSS Open Source Software
|
||||
OTOH On the other hand
|
||||
PITA Pain in the Ass
|
||||
RFC Request for Comments
|
||||
ROTFL Rolling on the floor laughing
|
||||
RTFM Read The Fine Manual
|
||||
spec specification
|
||||
TIA Thanks in advance
|
||||
TL;DR Too long; didn't read
|
||||
TOC Table of Contents
|
||||
URI Uniform Resource Identifier
|
||||
URL Uniform Resource Locator
|
||||
W3C World Wide Web Consortium
|
||||
WTF? What the f***
|
||||
WYSIWYG What You See Is What You Get
|
||||
YMMV Your mileage may vary
|
178
ap23/web/doku/conf/dokuwiki.php
Normal file
178
ap23/web/doku/conf/dokuwiki.php
Normal file
@ -0,0 +1,178 @@
|
||||
<?php
|
||||
/**
|
||||
* This is DokuWiki's Main Configuration file
|
||||
*
|
||||
* All the default values are kept here, you should not modify it but use
|
||||
* a local.php file instead to override the settings from here.
|
||||
*
|
||||
* This is a piece of PHP code so PHP syntax applies!
|
||||
*
|
||||
* For help with the configuration and a more detailed explanation of the various options
|
||||
* see https://www.dokuwiki.org/config
|
||||
*/
|
||||
|
||||
|
||||
/* Basic Settings */
|
||||
$conf['title'] = 'DokuWiki'; //what to show in the title
|
||||
$conf['start'] = 'start'; //name of start page
|
||||
$conf['lang'] = 'en'; //your language
|
||||
$conf['template'] = 'dokuwiki'; //see lib/tpl directory
|
||||
$conf['tagline'] = ''; //tagline in header (if template supports it)
|
||||
$conf['sidebar'] = 'sidebar'; //name of sidebar in root namespace (if template supports it)
|
||||
$conf['license'] = 'cc-by-nc-sa'; //see conf/license.php
|
||||
$conf['savedir'] = './data'; //where to store all the files
|
||||
$conf['basedir'] = ''; //absolute dir from serveroot - blank for autodetection
|
||||
$conf['baseurl'] = ''; //URL to server including protocol - blank for autodetect
|
||||
$conf['cookiedir'] = ''; //path to use in cookies - blank for basedir
|
||||
$conf['dmode'] = 0755; //set directory creation mode
|
||||
$conf['fmode'] = 0644; //set file creation mode
|
||||
$conf['allowdebug'] = 0; //allow debug output, enable if needed 0|1
|
||||
|
||||
/* Display Settings */
|
||||
$conf['recent'] = 20; //how many entries to show in recent
|
||||
$conf['recent_days'] = 7; //How many days of recent changes to keep. (days)
|
||||
$conf['breadcrumbs'] = 10; //how many recent visited pages to show
|
||||
$conf['youarehere'] = 0; //show "You are here" navigation? 0|1
|
||||
$conf['fullpath'] = 0; //show full path of the document or relative to datadir only? 0|1
|
||||
$conf['typography'] = 1; //smartquote conversion 0=off, 1=doublequotes, 2=all quotes
|
||||
$conf['dformat'] = '%Y/%m/%d %H:%M'; //dateformat accepted by PHPs strftime() function
|
||||
$conf['signature'] = ' --- //[[@MAIL@|@NAME@]] @DATE@//'; //signature see wiki page for details
|
||||
$conf['showuseras'] = 'loginname'; // 'loginname' users login name
|
||||
// 'username' users full name
|
||||
// 'email' e-mail address (will be obfuscated as per mailguard)
|
||||
// 'email_link' e-mail address as a mailto: link (obfuscated)
|
||||
$conf['toptoclevel'] = 1; //Level starting with and below to include in AutoTOC (max. 5)
|
||||
$conf['tocminheads'] = 3; //Minimum amount of headlines that determines if a TOC is built
|
||||
$conf['maxtoclevel'] = 3; //Up to which level include into AutoTOC (max. 5)
|
||||
$conf['maxseclevel'] = 3; //Up to which level create editable sections (max. 5)
|
||||
$conf['camelcase'] = 0; //Use CamelCase for linking? (I don't like it) 0|1
|
||||
$conf['deaccent'] = 1; //deaccented chars in pagenames (1) or romanize (2) or keep (0)?
|
||||
$conf['useheading'] = 0; //use the first heading in a page as its name
|
||||
$conf['sneaky_index']= 0; //check for namespace read permission in index view (0|1) (1 might cause unexpected behavior)
|
||||
$conf['hidepages'] = ''; //Regexp for pages to be skipped from RSS, Search and Recent Changes
|
||||
|
||||
/* Authentication Settings */
|
||||
$conf['useacl'] = 0; //Use Access Control Lists to restrict access?
|
||||
$conf['autopasswd'] = 1; //autogenerate passwords and email them to user
|
||||
$conf['authtype'] = 'authplain'; //which authentication backend should be used
|
||||
$conf['passcrypt'] = 'bcrypt'; //Used crypt method (smd5,md5,sha1,ssha,crypt,mysql,my411,bcrypt)
|
||||
$conf['defaultgroup']= 'user'; //Default groups new Users are added to
|
||||
$conf['superuser'] = '!!not set!!'; //The admin can be user or @group or comma separated list user1,@group1,user2
|
||||
$conf['manager'] = '!!not set!!'; //The manager can be user or @group or comma separated list user1,@group1,user2
|
||||
$conf['profileconfirm'] = 1; //Require current password to confirm changes to user profile
|
||||
$conf['rememberme'] = 1; //Enable/disable remember me on login
|
||||
$conf['disableactions'] = ''; //comma separated list of actions to disable
|
||||
$conf['auth_security_timeout'] = 900; //time (seconds) auth data is considered valid, set to 0 to recheck on every page view
|
||||
$conf['securecookie'] = 1; //never send HTTPS cookies via HTTP
|
||||
$conf['remote'] = 0; //Enable/disable remote interfaces
|
||||
$conf['remoteuser'] = '!!not set!!'; //user/groups that have access to remote interface (comma separated). leave empty to allow all users
|
||||
|
||||
/* Antispam Features */
|
||||
$conf['usewordblock']= 1; //block spam based on words? 0|1
|
||||
$conf['relnofollow'] = 1; //use rel="ugc nofollow" for external links?
|
||||
$conf['indexdelay'] = 60*60*24*5; //allow indexing after this time (seconds) default is 5 days
|
||||
$conf['mailguard'] = 'hex'; //obfuscate email addresses against spam harvesters?
|
||||
//valid entries are:
|
||||
// 'visible' - replace @ with [at], . with [dot] and - with [dash]
|
||||
// 'hex' - use hex entities to encode the mail address
|
||||
// 'none' - do not obfuscate addresses
|
||||
$conf['iexssprotect']= 1; // check for JavaScript and HTML in uploaded files 0|1
|
||||
|
||||
/* Editing Settings */
|
||||
$conf['usedraft'] = 1; //automatically save a draft while editing (0|1)
|
||||
$conf['htmlok'] = 0; //may raw HTML be embedded? This may break layout and XHTML validity 0|1
|
||||
$conf['phpok'] = 0; //may PHP code be embedded? Never do this on the internet! 0|1
|
||||
$conf['locktime'] = 15*60; //maximum age for lockfiles (defaults to 15 minutes)
|
||||
$conf['cachetime'] = 60*60*24; //maximum age for cachefile in seconds (defaults to a day)
|
||||
|
||||
/* Link Settings */
|
||||
// Set target to use when creating links - leave empty for same window
|
||||
$conf['target']['wiki'] = '';
|
||||
$conf['target']['interwiki'] = '';
|
||||
$conf['target']['extern'] = '';
|
||||
$conf['target']['media'] = '';
|
||||
$conf['target']['windows'] = '';
|
||||
|
||||
/* Media Settings */
|
||||
$conf['mediarevisions'] = 1; //enable/disable media revisions
|
||||
$conf['refcheck'] = 1; //check for references before deleting media files
|
||||
$conf['gdlib'] = 2; //the GDlib version (0, 1 or 2) 2 tries to autodetect
|
||||
$conf['im_convert'] = ''; //path to ImageMagicks convert (will be used instead of GD)
|
||||
$conf['jpg_quality'] = '70'; //quality of compression when scaling jpg images (0-100)
|
||||
$conf['fetchsize'] = 0; //maximum size (bytes) fetch.php may download from extern, disabled by default
|
||||
|
||||
/* Notification Settings */
|
||||
$conf['subscribers'] = 0; //enable change notice subscription support
|
||||
$conf['subscribe_time'] = 24*60*60; //Time after which digests / lists are sent (in sec, default 1 day)
|
||||
//Should be smaller than the time specified in recent_days
|
||||
$conf['notify'] = ''; //send change info to this email (leave blank for nobody)
|
||||
$conf['registernotify'] = ''; //send info about newly registered users to this email (leave blank for nobody)
|
||||
$conf['mailfrom'] = ''; //use this email when sending mails
|
||||
$conf['mailreturnpath'] = ''; //use this email as returnpath for bounce mails
|
||||
$conf['mailprefix'] = ''; //use this as prefix of outgoing mails
|
||||
$conf['htmlmail'] = 1; //send HTML multipart mails
|
||||
|
||||
/* Syndication Settings */
|
||||
$conf['sitemap'] = 0; //Create a google sitemap? How often? In days.
|
||||
$conf['rss_type'] = 'rss1'; //type of RSS feed to provide, by default:
|
||||
// 'rss' - RSS 0.91
|
||||
// 'rss1' - RSS 1.0
|
||||
// 'rss2' - RSS 2.0
|
||||
// 'atom' - Atom 0.3
|
||||
// 'atom1' - Atom 1.0
|
||||
$conf['rss_linkto'] = 'diff'; //what page RSS entries link to:
|
||||
// 'diff' - page showing revision differences
|
||||
// 'page' - the revised page itself
|
||||
// 'rev' - page showing all revisions
|
||||
// 'current' - most recent revision of page
|
||||
$conf['rss_content'] = 'abstract'; //what to put in the items by default?
|
||||
// 'abstract' - plain text, first paragraph or so
|
||||
// 'diff' - plain text unified diff wrapped in <pre> tags
|
||||
// 'htmldiff' - diff as HTML table
|
||||
// 'html' - the full page rendered in XHTML
|
||||
$conf['rss_media'] = 'both'; //what should be listed?
|
||||
// 'both' - page and media changes
|
||||
// 'pages' - page changes only
|
||||
// 'media' - media changes only
|
||||
$conf['rss_update'] = 5*60; //Update the RSS feed every n seconds (defaults to 5 minutes)
|
||||
$conf['rss_show_summary'] = 1; //Add revision summary to title? 0|1
|
||||
$conf['rss_show_deleted'] = 1; //Show deleted items 0|1
|
||||
|
||||
/* Advanced Settings */
|
||||
$conf['updatecheck'] = 1; //automatically check for new releases?
|
||||
$conf['userewrite'] = 0; //this makes nice URLs: 0: off 1: .htaccess 2: internal
|
||||
$conf['useslash'] = 0; //use slash instead of colon? only when rewrite is on
|
||||
$conf['sepchar'] = '_'; //word separator character in page names; may be a
|
||||
// letter, a digit, '_', '-', or '.'.
|
||||
$conf['canonical'] = 0; //Should all URLs use full canonical http://... style?
|
||||
$conf['fnencode'] = 'url'; //encode filenames (url|safe|utf-8)
|
||||
$conf['autoplural'] = 0; //try (non)plural form of nonexisting files?
|
||||
$conf['compression'] = 'gz'; //compress old revisions: (0: off) ('gz': gnuzip) ('bz2': bzip)
|
||||
// bz2 generates smaller files, but needs more cpu-power
|
||||
$conf['gzip_output'] = 0; //use gzip content encodeing for the output xhtml (if allowed by browser)
|
||||
$conf['compress'] = 1; //Strip whitespaces and comments from Styles and JavaScript? 1|0
|
||||
$conf['cssdatauri'] = 512; //Maximum byte size of small images to embed into CSS, won't work on IE<8
|
||||
$conf['send404'] = 0; //Send a HTTP 404 status for non existing pages?
|
||||
$conf['broken_iua'] = 0; //Platform with broken ignore_user_abort (IIS+CGI) 0|1
|
||||
$conf['xsendfile'] = 0; //Use X-Sendfile (1 = lighttpd, 2 = standard)
|
||||
$conf['renderer_xhtml'] = 'xhtml'; //renderer to use for main page generation
|
||||
$conf['readdircache'] = 0; //time cache in second for the readdir operation, 0 to deactivate.
|
||||
$conf['search_nslimit'] = 0; //limit the search to the current X namespaces
|
||||
$conf['search_fragment'] = 'exact'; //specify the default fragment search behavior
|
||||
$conf['trustedproxy'] = '^(::1|[fF][eE]80:|127\.|10\.|192\.168\.|172\.((1[6-9])|(2[0-9])|(3[0-1]))\.)';
|
||||
//Regexp of trusted proxy address when reading IP using HTTP header
|
||||
// if blank, do not trust any proxy (including local IP)
|
||||
|
||||
/* Feature Flags */
|
||||
$conf['defer_js'] = 1; // Defer javascript to be executed after the page's HTML has been parsed. Setting will be removed in the next release.
|
||||
|
||||
/* Network Settings */
|
||||
$conf['dnslookups'] = 1; //disable to disallow IP to hostname lookups
|
||||
$conf['jquerycdn'] = 0; //use a CDN for delivering jQuery?
|
||||
// Proxy setup - if your Server needs a proxy to access the web set these
|
||||
$conf['proxy']['host'] = '';
|
||||
$conf['proxy']['port'] = '';
|
||||
$conf['proxy']['user'] = '';
|
||||
$conf['proxy']['pass'] = '';
|
||||
$conf['proxy']['ssl'] = 0;
|
||||
$conf['proxy']['except'] = '';
|
22
ap23/web/doku/conf/entities.conf
Normal file
22
ap23/web/doku/conf/entities.conf
Normal file
@ -0,0 +1,22 @@
|
||||
# Typography replacements
|
||||
#
|
||||
# Order does matter!
|
||||
#
|
||||
# You can use HTML entities here, but it is not recommended because it may break
|
||||
# non-HTML renderers. Use UTF-8 chars directly instead.
|
||||
|
||||
<-> ↔
|
||||
-> →
|
||||
<- ←
|
||||
<=> ⇔
|
||||
=> ⇒
|
||||
<= ⇐
|
||||
>> »
|
||||
<< «
|
||||
--- —
|
||||
-- –
|
||||
(c) ©
|
||||
(tm) ™
|
||||
(r) ®
|
||||
... …
|
||||
|
42
ap23/web/doku/conf/interwiki.conf
Normal file
42
ap23/web/doku/conf/interwiki.conf
Normal file
@ -0,0 +1,42 @@
|
||||
# Each URL may contain one of these placeholders
|
||||
# {URL} is replaced by the URL encoded representation of the wikiname
|
||||
# this is the right thing to do in most cases
|
||||
# {NAME} this is replaced by the wikiname as given in the document
|
||||
# only mandatory encoded is done, urlencoding if the link
|
||||
# is an external URL, or encoding as a wikiname if it is an
|
||||
# internal link (begins with a colon)
|
||||
# {SCHEME}
|
||||
# {HOST}
|
||||
# {PORT}
|
||||
# {PATH}
|
||||
# {QUERY} these placeholders will be replaced with the appropriate part
|
||||
# of the link when parsed as a URL
|
||||
# If no placeholder is defined the urlencoded name is appended to the URL
|
||||
|
||||
# To prevent losing your added InterWiki shortcuts after an upgrade,
|
||||
# you should add new ones to interwiki.local.conf
|
||||
|
||||
wp https://en.wikipedia.org/wiki/{NAME}
|
||||
wpfr https://fr.wikipedia.org/wiki/{NAME}
|
||||
wpde https://de.wikipedia.org/wiki/{NAME}
|
||||
wpes https://es.wikipedia.org/wiki/{NAME}
|
||||
wppl https://pl.wikipedia.org/wiki/{NAME}
|
||||
wpjp https://ja.wikipedia.org/wiki/{NAME}
|
||||
wpru https://ru.wikipedia.org/wiki/{NAME}
|
||||
wpmeta https://meta.wikipedia.org/wiki/{NAME}
|
||||
doku https://www.dokuwiki.org/
|
||||
rfc https://tools.ietf.org/html/rfc
|
||||
man http://man.cx/
|
||||
amazon https://www.amazon.com/dp/{URL}?tag=splitbrain-20
|
||||
amazon.de https://www.amazon.de/dp/{URL}?tag=splitbrain-21
|
||||
amazon.uk https://www.amazon.co.uk/dp/{URL}
|
||||
paypal https://www.paypal.com/cgi-bin/webscr?cmd=_xclick&business=
|
||||
phpfn https://secure.php.net/{NAME}
|
||||
skype skype:{NAME}
|
||||
google.de https://www.google.de/search?q=
|
||||
go https://www.google.com/search?q={URL}&btnI=lucky
|
||||
user :user:{NAME}
|
||||
|
||||
# To support VoIP/SIP/TEL links
|
||||
callto callto://{NAME}
|
||||
tel tel:{NAME}
|
38
ap23/web/doku/conf/license.php
Normal file
38
ap23/web/doku/conf/license.php
Normal file
@ -0,0 +1,38 @@
|
||||
<?php
|
||||
/**
|
||||
* This file defines multiple available licenses you can license your
|
||||
* wiki contents under. Do not change this file, but create a
|
||||
* license.local.php instead.
|
||||
*/
|
||||
|
||||
if(empty($LC)) $LC = empty($conf['lang']) ? 'en' : $conf['lang'];
|
||||
|
||||
$license['cc-zero'] = array(
|
||||
'name' => 'CC0 1.0 Universal',
|
||||
'url' => 'https://creativecommons.org/publicdomain/zero/1.0/deed.'.$LC,
|
||||
);
|
||||
$license['publicdomain'] = array(
|
||||
'name' => 'Public Domain',
|
||||
'url' => 'https://creativecommons.org/licenses/publicdomain/deed.'.$LC,
|
||||
);
|
||||
$license['cc-by'] = array(
|
||||
'name' => 'CC Attribution 4.0 International',
|
||||
'url' => 'https://creativecommons.org/licenses/by/4.0/deed.'.$LC,
|
||||
);
|
||||
$license['cc-by-sa'] = array(
|
||||
'name' => 'CC Attribution-Share Alike 4.0 International',
|
||||
'url' => 'https://creativecommons.org/licenses/by-sa/4.0/deed.'.$LC,
|
||||
);
|
||||
$license['gnufdl'] = array(
|
||||
'name' => 'GNU Free Documentation License 1.3',
|
||||
'url' => 'https://www.gnu.org/licenses/fdl-1.3.html',
|
||||
);
|
||||
$license['cc-by-nc'] = array(
|
||||
'name' => 'CC Attribution-Noncommercial 4.0 International',
|
||||
'url' => 'https://creativecommons.org/licenses/by-nc/4.0/deed.'.$LC,
|
||||
);
|
||||
$license['cc-by-nc-sa'] = array(
|
||||
'name' => 'CC Attribution-Noncommercial-Share Alike 4.0 International',
|
||||
'url' => 'https://creativecommons.org/licenses/by-nc-sa/4.0/deed.'.$LC,
|
||||
);
|
||||
|
12
ap23/web/doku/conf/local.php
Normal file
12
ap23/web/doku/conf/local.php
Normal file
@ -0,0 +1,12 @@
|
||||
<?php
|
||||
/**
|
||||
* Dokuwiki's Main Configuration File - Local Settings
|
||||
* Auto-generated by install script
|
||||
* Date: Thu, 13 Jan 2022 07:45:04 +0000
|
||||
*/
|
||||
$conf['title'] = 'GSB';
|
||||
$conf['lang'] = 'fr';
|
||||
$conf['license'] = 'cc-by-sa';
|
||||
$conf['useacl'] = 1;
|
||||
$conf['superuser'] = '@admin';
|
||||
$conf['disableactions'] = 'register';
|
16
ap23/web/doku/conf/local.php.dist
Normal file
16
ap23/web/doku/conf/local.php.dist
Normal file
@ -0,0 +1,16 @@
|
||||
<?php
|
||||
/**
|
||||
* This is an example of how a local.php could look like.
|
||||
* Simply copy the options you want to change from dokuwiki.php
|
||||
* to this file and change them.
|
||||
*
|
||||
* When using the installer, a correct local.php file be generated for
|
||||
* you automatically.
|
||||
*/
|
||||
|
||||
|
||||
//$conf['title'] = 'My Wiki'; //what to show in the title
|
||||
|
||||
//$conf['useacl'] = 1; //Use Access Control Lists to restrict access?
|
||||
//$conf['superuser'] = 'joe';
|
||||
|
3
ap23/web/doku/conf/manifest.json
Normal file
3
ap23/web/doku/conf/manifest.json
Normal file
@ -0,0 +1,3 @@
|
||||
{
|
||||
"display": "standalone"
|
||||
}
|
91
ap23/web/doku/conf/mediameta.php
Normal file
91
ap23/web/doku/conf/mediameta.php
Normal file
@ -0,0 +1,91 @@
|
||||
<?php
|
||||
/**
|
||||
* This configures which meta data will be editable through
|
||||
* the media manager. Each field of the array is an array with the
|
||||
* following contents:
|
||||
* fieldname - Where data will be saved (EXIF or IPTC field)
|
||||
* label - key to lookup in the $lang var, if not found printed as is
|
||||
* htmltype - 'text', 'textarea' or 'date'
|
||||
* lookups - array additional fields to lookup the data (EXIF or IPTC fields)
|
||||
*
|
||||
* The fields are not ordered continously to make inserting additional items
|
||||
* in between simpler.
|
||||
*
|
||||
* This is a PHP snippet, so PHP syntax applies.
|
||||
*
|
||||
* Note: $fields is not a global variable and will not be available to any
|
||||
* other functions or templates later
|
||||
*
|
||||
* You may extend or overwrite this variable in a optional
|
||||
* conf/mediameta.local.php file
|
||||
*
|
||||
* For a list of available EXIF/IPTC fields refer to
|
||||
* http://www.dokuwiki.org/devel:templates:detail.php
|
||||
*/
|
||||
|
||||
|
||||
$fields = array(
|
||||
10 => array('Iptc.Headline',
|
||||
'img_title',
|
||||
'text'),
|
||||
|
||||
20 => array('',
|
||||
'img_date',
|
||||
'date',
|
||||
array('Date.EarliestTime')),
|
||||
|
||||
30 => array('',
|
||||
'img_fname',
|
||||
'text',
|
||||
array('File.Name')),
|
||||
|
||||
40 => array('Iptc.Caption',
|
||||
'img_caption',
|
||||
'textarea',
|
||||
array('Exif.UserComment',
|
||||
'Exif.TIFFImageDescription',
|
||||
'Exif.TIFFUserComment')),
|
||||
|
||||
50 => array('Iptc.Byline',
|
||||
'img_artist',
|
||||
'text',
|
||||
array('Exif.TIFFArtist',
|
||||
'Exif.Artist',
|
||||
'Iptc.Credit')),
|
||||
|
||||
60 => array('Iptc.CopyrightNotice',
|
||||
'img_copyr',
|
||||
'text',
|
||||
array('Exif.TIFFCopyright',
|
||||
'Exif.Copyright')),
|
||||
|
||||
70 => array('',
|
||||
'img_format',
|
||||
'text',
|
||||
array('File.Format')),
|
||||
|
||||
80 => array('',
|
||||
'img_fsize',
|
||||
'text',
|
||||
array('File.NiceSize')),
|
||||
|
||||
90 => array('',
|
||||
'img_width',
|
||||
'text',
|
||||
array('File.Width')),
|
||||
|
||||
100 => array('',
|
||||
'img_height',
|
||||
'text',
|
||||
array('File.Height')),
|
||||
|
||||
110 => array('',
|
||||
'img_camera',
|
||||
'text',
|
||||
array('Simple.Camera')),
|
||||
|
||||
120 => array('Iptc.Keywords',
|
||||
'img_keywords',
|
||||
'text',
|
||||
array('Exif.Category')),
|
||||
);
|
72
ap23/web/doku/conf/mime.conf
Normal file
72
ap23/web/doku/conf/mime.conf
Normal file
@ -0,0 +1,72 @@
|
||||
# Allowed uploadable file extensions and mimetypes are defined here.
|
||||
# To extend this file it is recommended to create a mime.local.conf
|
||||
# file. Mimetypes that should be downloadable and not be opened in the
|
||||
# should be prefixed with a !
|
||||
|
||||
jpg image/jpeg
|
||||
jpeg image/jpeg
|
||||
gif image/gif
|
||||
png image/png
|
||||
ico image/vnd.microsoft.icon
|
||||
|
||||
mp3 audio/mpeg
|
||||
ogg audio/ogg
|
||||
wav audio/wav
|
||||
webm video/webm
|
||||
ogv video/ogg
|
||||
mp4 video/mp4
|
||||
vtt text/vtt
|
||||
|
||||
tgz !application/octet-stream
|
||||
tar !application/x-gtar
|
||||
gz !application/octet-stream
|
||||
bz2 !application/octet-stream
|
||||
zip !application/zip
|
||||
rar !application/rar
|
||||
7z !application/x-7z-compressed
|
||||
|
||||
pdf application/pdf
|
||||
ps !application/postscript
|
||||
|
||||
rpm !application/octet-stream
|
||||
deb !application/octet-stream
|
||||
|
||||
doc !application/msword
|
||||
xls !application/msexcel
|
||||
ppt !application/mspowerpoint
|
||||
rtf !application/msword
|
||||
|
||||
docx !application/vnd.openxmlformats-officedocument.wordprocessingml.document
|
||||
xlsx !application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
|
||||
pptx !application/vnd.openxmlformats-officedocument.presentationml.presentation
|
||||
|
||||
sxw !application/soffice
|
||||
sxc !application/soffice
|
||||
sxi !application/soffice
|
||||
sxd !application/soffice
|
||||
|
||||
odc !application/vnd.oasis.opendocument.chart
|
||||
odf !application/vnd.oasis.opendocument.formula
|
||||
odg !application/vnd.oasis.opendocument.graphics
|
||||
odi !application/vnd.oasis.opendocument.image
|
||||
odp !application/vnd.oasis.opendocument.presentation
|
||||
ods !application/vnd.oasis.opendocument.spreadsheet
|
||||
odt !application/vnd.oasis.opendocument.text
|
||||
|
||||
# You should enable HTML and Text uploads only for restricted Wikis.
|
||||
# Spammers are known to upload spam pages through unprotected Wikis.
|
||||
# Note: Enabling HTML opens Cross Site Scripting vulnerabilities
|
||||
# through JavaScript. Only enable this with trusted users. You
|
||||
# need to disable the iexssprotect option additionally to
|
||||
# adding the mime type here
|
||||
#html text/html
|
||||
#htm text/html
|
||||
#txt text/plain
|
||||
#conf text/plain
|
||||
#xml text/xml
|
||||
#csv text/csv
|
||||
|
||||
# Also flash may be able to execute arbitrary scripts in the website's
|
||||
# context
|
||||
#swf application/x-shockwave-flash
|
||||
|
253
ap23/web/doku/conf/mysql.conf.php.example
Normal file
253
ap23/web/doku/conf/mysql.conf.php.example
Normal file
@ -0,0 +1,253 @@
|
||||
<?php
|
||||
/*
|
||||
* This is an example configuration for the mysql auth plugin.
|
||||
*
|
||||
* This SQL statements are optimized for following table structure.
|
||||
* If you use a different one you have to change them accordingly.
|
||||
* See comments of every statement for details.
|
||||
*
|
||||
* TABLE users
|
||||
* uid login pass firstname lastname email
|
||||
*
|
||||
* TABLE groups
|
||||
* gid name
|
||||
*
|
||||
* TABLE usergroup
|
||||
* uid gid
|
||||
*
|
||||
* To use this configuration you have to copy them to local.protected.php
|
||||
* or at least include this file in local.protected.php.
|
||||
*/
|
||||
|
||||
/* Options to configure database access. You need to set up this
|
||||
* options carefully, otherwise you won't be able to access you
|
||||
* database.
|
||||
*/
|
||||
$conf['plugin']['authmysql']['server'] = '';
|
||||
$conf['plugin']['authmysql']['user'] = '';
|
||||
$conf['plugin']['authmysql']['password'] = '';
|
||||
$conf['plugin']['authmysql']['database'] = '';
|
||||
|
||||
/* This option enables debug messages in the mysql plugin. It is
|
||||
* mostly useful for system admins.
|
||||
*/
|
||||
$conf['plugin']['authmysql']['debug'] = 0;
|
||||
|
||||
/* Normally password encryption is done by DokuWiki (recommended) but for
|
||||
* some reasons it might be usefull to let the database do the encryption.
|
||||
* Set 'forwardClearPass' to '1' and the cleartext password is forwarded to
|
||||
* the database, otherwise the encrypted one.
|
||||
*/
|
||||
$conf['plugin']['authmysql']['forwardClearPass'] = 0;
|
||||
|
||||
/* Multiple table operations will be protected by locks. This array tolds
|
||||
* the plugin which tables to lock. If you use any aliases for table names
|
||||
* these array must also contain these aliases. Any unamed alias will cause
|
||||
* a warning during operation. See the example below.
|
||||
*/
|
||||
$conf['plugin']['authmysql']['TablesToLock']= array("users", "users AS u","groups", "groups AS g", "usergroup", "usergroup AS ug");
|
||||
|
||||
/***********************************************************************/
|
||||
/* Basic SQL statements for user authentication (required) */
|
||||
/***********************************************************************/
|
||||
|
||||
/* This statement is used to grant or deny access to the wiki. The result
|
||||
* should be a table with exact one line containing at least the password
|
||||
* of the user. If the result table is empty or contains more than one
|
||||
* row, access will be denied.
|
||||
*
|
||||
* The plugin accesses the password as 'pass' so an alias might be necessary.
|
||||
*
|
||||
* Following patters will be replaced:
|
||||
* %{user} user name
|
||||
* %{pass} encrypted or clear text password (depends on 'encryptPass')
|
||||
* %{dgroup} default group name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['checkPass'] = "SELECT pass
|
||||
FROM usergroup AS ug
|
||||
JOIN users AS u ON u.uid=ug.uid
|
||||
JOIN groups AS g ON g.gid=ug.gid
|
||||
WHERE login='%{user}'
|
||||
AND name='%{dgroup}'";
|
||||
|
||||
/* This statement should return a table with exact one row containing
|
||||
* information about one user. The field needed are:
|
||||
* 'pass' containing the encrypted or clear text password
|
||||
* 'name' the user's full name
|
||||
* 'mail' the user's email address
|
||||
*
|
||||
* Keep in mind that Dokuwiki will access thise information through the
|
||||
* names listed above so aliasses might be neseccary.
|
||||
*
|
||||
* Following patters will be replaced:
|
||||
* %{user} user name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['getUserInfo'] = "SELECT pass, CONCAT(firstname,' ',lastname) AS name, email AS mail
|
||||
FROM users
|
||||
WHERE login='%{user}'";
|
||||
|
||||
/* This statement is used to get all groups a user is member of. The
|
||||
* result should be a table containing all groups the given user is
|
||||
* member of. The plugin accesses the group name as 'group' so an alias
|
||||
* might be nessecary.
|
||||
*
|
||||
* Following patters will be replaced:
|
||||
* %{user} user name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['getGroups'] = "SELECT name as `group`
|
||||
FROM groups g, users u, usergroup ug
|
||||
WHERE u.uid = ug.uid
|
||||
AND g.gid = ug.gid
|
||||
AND u.login='%{user}'";
|
||||
|
||||
/***********************************************************************/
|
||||
/* Additional minimum SQL statements to use the user manager */
|
||||
/***********************************************************************/
|
||||
|
||||
/* This statement should return a table containing all user login names
|
||||
* that meet certain filter criteria. The filter expressions will be added
|
||||
* case dependend by the plugin. At the end a sort expression will be added.
|
||||
* Important is that this list contains no double entries for a user. Each
|
||||
* user name is only allowed once in the table.
|
||||
*
|
||||
* The login name will be accessed as 'user' to an alias might be neseccary.
|
||||
* No patterns will be replaced in this statement but following patters
|
||||
* will be replaced in the filter expressions:
|
||||
* %{user} in FilterLogin user's login name
|
||||
* %{name} in FilterName user's full name
|
||||
* %{email} in FilterEmail user's email address
|
||||
* %{group} in FilterGroup group name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['getUsers'] = "SELECT DISTINCT login AS user
|
||||
FROM users AS u
|
||||
LEFT JOIN usergroup AS ug ON u.uid=ug.uid
|
||||
LEFT JOIN groups AS g ON ug.gid=g.gid";
|
||||
$conf['plugin']['authmysql']['FilterLogin'] = "login LIKE '%{user}'";
|
||||
$conf['plugin']['authmysql']['FilterName'] = "CONCAT(firstname,' ',lastname) LIKE '%{name}'";
|
||||
$conf['plugin']['authmysql']['FilterEmail'] = "email LIKE '%{email}'";
|
||||
$conf['plugin']['authmysql']['FilterGroup'] = "name LIKE '%{group}'";
|
||||
$conf['plugin']['authmysql']['SortOrder'] = "ORDER BY login";
|
||||
|
||||
/***********************************************************************/
|
||||
/* Additional SQL statements to add new users with the user manager */
|
||||
/***********************************************************************/
|
||||
|
||||
/* This statement should add a user to the database. Minimum information
|
||||
* to store are: login name, password, email address and full name.
|
||||
*
|
||||
* Following patterns will be replaced:
|
||||
* %{user} user's login name
|
||||
* %{pass} password (encrypted or clear text, depends on 'encryptPass')
|
||||
* %{email} email address
|
||||
* %{name} user's full name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['addUser'] = "INSERT INTO users
|
||||
(login, pass, email, firstname, lastname)
|
||||
VALUES ('%{user}', '%{pass}', '%{email}',
|
||||
SUBSTRING_INDEX('%{name}',' ', 1),
|
||||
SUBSTRING_INDEX('%{name}',' ', -1))";
|
||||
|
||||
/* This statement should add a group to the database.
|
||||
* Following patterns will be replaced:
|
||||
* %{group} group name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['addGroup'] = "INSERT INTO groups (name)
|
||||
VALUES ('%{group}')";
|
||||
|
||||
/* This statement should connect a user to a group (a user become member
|
||||
* of that group).
|
||||
* Following patterns will be replaced:
|
||||
* %{user} user's login name
|
||||
* %{uid} id of a user dataset
|
||||
* %{group} group name
|
||||
* %{gid} id of a group dataset
|
||||
*/
|
||||
$conf['plugin']['authmysql']['addUserGroup']= "INSERT INTO usergroup (uid, gid)
|
||||
VALUES ('%{uid}', '%{gid}')";
|
||||
|
||||
/* This statement should remove a group fom the database.
|
||||
* Following patterns will be replaced:
|
||||
* %{group} group name
|
||||
* %{gid} id of a group dataset
|
||||
*/
|
||||
$conf['plugin']['authmysql']['delGroup'] = "DELETE FROM groups
|
||||
WHERE gid='%{gid}'";
|
||||
|
||||
/* This statement should return the database index of a given user name.
|
||||
* The plugin will access the index with the name 'id' so an alias might be
|
||||
* necessary.
|
||||
* following patters will be replaced:
|
||||
* %{user} user name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['getUserID'] = "SELECT uid AS id
|
||||
FROM users
|
||||
WHERE login='%{user}'";
|
||||
|
||||
/***********************************************************************/
|
||||
/* Additional SQL statements to delete users with the user manager */
|
||||
/***********************************************************************/
|
||||
|
||||
/* This statement should remove a user fom the database.
|
||||
* Following patterns will be replaced:
|
||||
* %{user} user's login name
|
||||
* %{uid} id of a user dataset
|
||||
*/
|
||||
$conf['plugin']['authmysql']['delUser'] = "DELETE FROM users
|
||||
WHERE uid='%{uid}'";
|
||||
|
||||
/* This statement should remove all connections from a user to any group
|
||||
* (a user quits membership of all groups).
|
||||
* Following patterns will be replaced:
|
||||
* %{uid} id of a user dataset
|
||||
*/
|
||||
$conf['plugin']['authmysql']['delUserRefs'] = "DELETE FROM usergroup
|
||||
WHERE uid='%{uid}'";
|
||||
|
||||
/***********************************************************************/
|
||||
/* Additional SQL statements to modify users with the user manager */
|
||||
/***********************************************************************/
|
||||
|
||||
/* This statements should modify a user entry in the database. The
|
||||
* statements UpdateLogin, UpdatePass, UpdateEmail and UpdateName will be
|
||||
* added to updateUser on demand. Only changed parameters will be used.
|
||||
*
|
||||
* Following patterns will be replaced:
|
||||
* %{user} user's login name
|
||||
* %{pass} password (encrypted or clear text, depends on 'encryptPass')
|
||||
* %{email} email address
|
||||
* %{name} user's full name
|
||||
* %{uid} user id that should be updated
|
||||
*/
|
||||
$conf['plugin']['authmysql']['updateUser'] = "UPDATE users SET";
|
||||
$conf['plugin']['authmysql']['UpdateLogin'] = "login='%{user}'";
|
||||
$conf['plugin']['authmysql']['UpdatePass'] = "pass='%{pass}'";
|
||||
$conf['plugin']['authmysql']['UpdateEmail'] = "email='%{email}'";
|
||||
$conf['plugin']['authmysql']['UpdateName'] = "firstname=SUBSTRING_INDEX('%{name}',' ', 1),
|
||||
lastname=SUBSTRING_INDEX('%{name}',' ', -1)";
|
||||
$conf['plugin']['authmysql']['UpdateTarget']= "WHERE uid=%{uid}";
|
||||
|
||||
/* This statement should remove a single connection from a user to a
|
||||
* group (a user quits membership of that group).
|
||||
*
|
||||
* Following patterns will be replaced:
|
||||
* %{user} user's login name
|
||||
* %{uid} id of a user dataset
|
||||
* %{group} group name
|
||||
* %{gid} id of a group dataset
|
||||
*/
|
||||
$conf['plugin']['authmysql']['delUserGroup']= "DELETE FROM usergroup
|
||||
WHERE uid='%{uid}'
|
||||
AND gid='%{gid}'";
|
||||
|
||||
/* This statement should return the database index of a given group name.
|
||||
* The plugin will access the index with the name 'id' so an alias might
|
||||
* be necessary.
|
||||
*
|
||||
* Following patters will be replaced:
|
||||
* %{group} group name
|
||||
*/
|
||||
$conf['plugin']['authmysql']['getGroupID'] = "SELECT gid AS id
|
||||
FROM groups
|
||||
WHERE name='%{group}'";
|
||||
|
||||
|
12
ap23/web/doku/conf/plugins.local.php
Normal file
12
ap23/web/doku/conf/plugins.local.php
Normal file
@ -0,0 +1,12 @@
|
||||
<?php
|
||||
/*
|
||||
* Local plugin enable/disable settings
|
||||
*
|
||||
* Auto-generated by install script
|
||||
* Date: Thu, 13 Jan 2022 07:45:04 +0000
|
||||
*/
|
||||
|
||||
$plugins['authad'] = 0;
|
||||
$plugins['authldap'] = 0;
|
||||
$plugins['authmysql'] = 0;
|
||||
$plugins['authpgsql'] = 0;
|
6
ap23/web/doku/conf/plugins.php
Normal file
6
ap23/web/doku/conf/plugins.php
Normal file
@ -0,0 +1,6 @@
|
||||
<?php
|
||||
/**
|
||||
* This file configures the default states of available plugins. All settings in
|
||||
* the plugins.*.php files will override those here.
|
||||
*/
|
||||
$plugins['testing'] = 0;
|
12
ap23/web/doku/conf/plugins.required.php
Normal file
12
ap23/web/doku/conf/plugins.required.php
Normal file
@ -0,0 +1,12 @@
|
||||
<?php
|
||||
/**
|
||||
* This file configures the enabled/disabled status of plugins, which are also protected
|
||||
* from changes by the extention manager. These settings will override any local settings.
|
||||
* It is not recommended to change this file, as it is overwritten on DokuWiki upgrades.
|
||||
*/
|
||||
$plugins['acl'] = 1;
|
||||
$plugins['authplain'] = 1;
|
||||
$plugins['extension'] = 1;
|
||||
$plugins['config'] = 1;
|
||||
$plugins['usermanager'] = 1;
|
||||
$plugins['template:dokuwiki'] = 1; // not a plugin, but this should not be uninstalled either
|
11
ap23/web/doku/conf/scheme.conf
Normal file
11
ap23/web/doku/conf/scheme.conf
Normal file
@ -0,0 +1,11 @@
|
||||
#Add URL schemes you want to be recognized as links here
|
||||
|
||||
http
|
||||
https
|
||||
telnet
|
||||
gopher
|
||||
wais
|
||||
ftp
|
||||
ed2k
|
||||
irc
|
||||
ldap
|
28
ap23/web/doku/conf/smileys.conf
Normal file
28
ap23/web/doku/conf/smileys.conf
Normal file
@ -0,0 +1,28 @@
|
||||
# Smileys configured here will be replaced by the
|
||||
# configured images in the smiley directory
|
||||
|
||||
8-) icon_cool.gif
|
||||
8-O icon_eek.gif
|
||||
8-o icon_eek.gif
|
||||
:-( icon_sad.gif
|
||||
:-) icon_smile.gif
|
||||
=) icon_smile2.gif
|
||||
:-/ icon_doubt.gif
|
||||
:-\ icon_doubt2.gif
|
||||
:-? icon_confused.gif
|
||||
:-D icon_biggrin.gif
|
||||
:-P icon_razz.gif
|
||||
:-o icon_surprised.gif
|
||||
:-O icon_surprised.gif
|
||||
:-x icon_silenced.gif
|
||||
:-X icon_silenced.gif
|
||||
:-| icon_neutral.gif
|
||||
;-) icon_wink.gif
|
||||
m( facepalm.gif
|
||||
^_^ icon_fun.gif
|
||||
:?: icon_question.gif
|
||||
:!: icon_exclaim.gif
|
||||
LOL icon_lol.gif
|
||||
FIXME fixme.gif
|
||||
DELETEME delete.gif
|
||||
|
13
ap23/web/doku/conf/users.auth.php
Normal file
13
ap23/web/doku/conf/users.auth.php
Normal file
@ -0,0 +1,13 @@
|
||||
# users.auth.php
|
||||
# <?php exit()?>
|
||||
# Don't modify the lines above
|
||||
#
|
||||
# Userfile
|
||||
#
|
||||
# Auto-generated by install script
|
||||
# Date: Thu, 13 Jan 2022 07:45:04 +0000
|
||||
#
|
||||
# Format:
|
||||
# login:passwordhash:Real Name:email:groups,comma,separated
|
||||
|
||||
superadmin:$2y$10$6Rgguf9Ve4uCQ6mpCRLXR.zumeZSCVW6JzV4xMXuQmJrdUC1NSeim:admin:rayankecole@gmail.com:admin,user
|
10
ap23/web/doku/conf/users.auth.php.dist
Normal file
10
ap23/web/doku/conf/users.auth.php.dist
Normal file
@ -0,0 +1,10 @@
|
||||
# users.auth.php
|
||||
# <?php exit()?>
|
||||
# Don't modify the lines above
|
||||
#
|
||||
# Userfile
|
||||
#
|
||||
# Format:
|
||||
#
|
||||
# login:passwordhash:Real Name:email:groups,comma,separated
|
||||
|
29
ap23/web/doku/conf/wordblock.conf
Normal file
29
ap23/web/doku/conf/wordblock.conf
Normal file
@ -0,0 +1,29 @@
|
||||
# This blacklist is maintained by the DokuWiki community
|
||||
# patches welcome
|
||||
#
|
||||
https?:\/\/(\S*?)(-side-effects|top|pharm|pill|discount|discount-|deal|price|order|now|best|cheap|cheap-|online|buy|buy-|sale|sell)(\S*?)(cialis|viagra|prazolam|xanax|zanax|soma|vicodin|zenical|xenical|meridia|paxil|prozac|claritin|allegra|lexapro|wellbutrin|zoloft|retin|valium|levitra|phentermine)
|
||||
https?:\/\/(\S*?)(bi\s*sex|gay\s*sex|fetish|incest|penis|\brape\b)
|
||||
zoosex
|
||||
gang\s*bang
|
||||
facials
|
||||
ladyboy
|
||||
\btits\b
|
||||
bolea\.com
|
||||
52crystal
|
||||
baida\.org
|
||||
web-directory\.awardspace\.us
|
||||
korsan-team\.com
|
||||
BUDA TAMAMDIR
|
||||
wow-powerleveling-wow\.com
|
||||
wow gold
|
||||
wow-gold\.dinmo\.cn
|
||||
downgrade-vista\.com
|
||||
downgradetowindowsxp\.com
|
||||
elegantugg\.com
|
||||
classicedhardy\.com
|
||||
research-service\.com
|
||||
https?:\/\/(\S*?)(2-pay-secure|911essay|academia-research|anypapers|applicationessay|bestbuyessay|bestdissertation|bestessay|bestresume|besttermpaper|businessessay|college-paper|customessay|custom-made-paper|custom-writing|degree-?result|dissertationblog|dissertation-service|dissertations?expert|essaybank|essay-?blog|essaycapital|essaylogic|essaymill|essayontime|essaypaper|essays?land|essaytownsucks|essay-?writ|fastessays|freelancercareers|genuinecontent|genuineessay|genuinepaper|goessay|grandresume|killer-content|ma-dissertation|managementessay|masterpaper|mightystudent|needessay|researchedge|researchpaper-blog|resumecvservice|resumesexperts|resumesplanet|rushessay|samedayessay|superiorcontent|superiorpaper|superiorthesis|term-paper|termpaper-blog|term-paper-research|thesisblog|universalresearch|valwriting|vdwriters|wisetranslation|writersassembly|writers\.com\.ph|writers\.ph)
|
||||
flatsinmumbai\.co\.in
|
||||
https?:\/\/(\S*?)penny-?stock
|
||||
mattressreview\.biz
|
||||
(just|simply) (my|a) profile (site|webpage|page)
|
7
ap23/web/doku/data/.htaccess
Normal file
7
ap23/web/doku/data/.htaccess
Normal file
@ -0,0 +1,7 @@
|
||||
<IfModule mod_authz_core.c>
|
||||
Require all denied
|
||||
</IfModule>
|
||||
<IfModule !mod_authz_core.c>
|
||||
Order allow,deny
|
||||
Deny from all
|
||||
</IfModule>
|
1
ap23/web/doku/data/_dummy
Normal file
1
ap23/web/doku/data/_dummy
Normal file
@ -0,0 +1 @@
|
||||
You can safely delete this file.
|
1
ap23/web/doku/data/attic/_dummy
Normal file
1
ap23/web/doku/data/attic/_dummy
Normal file
@ -0,0 +1 @@
|
||||
You can safely delete this file.
|
BIN
ap23/web/doku/data/attic/start.1642060092.txt.gz
Normal file
BIN
ap23/web/doku/data/attic/start.1642060092.txt.gz
Normal file
Binary file not shown.
BIN
ap23/web/doku/data/attic/start.1642060225.txt.gz
Normal file
BIN
ap23/web/doku/data/attic/start.1642060225.txt.gz
Normal file
Binary file not shown.
BIN
ap23/web/doku/data/attic/start.1643875683.txt.gz
Normal file
BIN
ap23/web/doku/data/attic/start.1643875683.txt.gz
Normal file
Binary file not shown.
1
ap23/web/doku/data/cache/0/09a9c377a9ef68ba60aa17a44728196a.i
vendored
Normal file
1
ap23/web/doku/data/cache/0/09a9c377a9ef68ba60aa17a44728196a.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:35:"Pages pointant sur la page en cours";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:70:"Ceci est la liste des pages qui semblent pointer sur la page actuelle.";}i:2;i:52;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:122;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:123;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:123;}}
|
9
ap23/web/doku/data/cache/0/09a9c377a9ef68ba60aa17a44728196a.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/0/09a9c377a9ef68ba60aa17a44728196a.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="pages_pointant_sur_la_page_en_cours">Pages pointant sur la page en cours</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Ceci est la liste des pages qui semblent pointer sur la page actuelle.
|
||||
</p>
|
||||
|
||||
</div>
|
1
ap23/web/doku/data/cache/0/0d6bcd66738a9962365a36ce0615323e.pwauth
vendored
Normal file
1
ap23/web/doku/data/cache/0/0d6bcd66738a9962365a36ce0615323e.pwauth
vendored
Normal file
@ -0,0 +1 @@
|
||||
superadmin
|
1
ap23/web/doku/data/cache/0/0e77045d6a395df933da94eac23b575f.i
vendored
Normal file
1
ap23/web/doku/data/cache/0/0e77045d6a395df933da94eac23b575f.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:14:"Wiki groupe 23";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:3:"oui";}i:2;i:32;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:35;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:35;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:35;}}
|
1
ap23/web/doku/data/cache/0/0e77045d6a395df933da94eac23b575f.metadata
vendored
Normal file
1
ap23/web/doku/data/cache/0/0e77045d6a395df933da94eac23b575f.metadata
vendored
Normal file
@ -0,0 +1 @@
|
||||
1646899200
|
9
ap23/web/doku/data/cache/0/0e77045d6a395df933da94eac23b575f.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/0/0e77045d6a395df933da94eac23b575f.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="wiki_groupe_23">Wiki groupe 23</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
oui
|
||||
</p>
|
||||
|
||||
</div>
|
1
ap23/web/doku/data/cache/1/195dc2ba5acca5865d245ae8ee875785.i
vendored
Normal file
1
ap23/web/doku/data/cache/1/195dc2ba5acca5865d245ae8ee875785.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:14:"Wiki groupe 23";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:3:"oui";}i:2;i:32;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:35;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:35;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:35;}}
|
1
ap23/web/doku/data/cache/1/195dc2ba5acca5865d245ae8ee875785.metadata
vendored
Normal file
1
ap23/web/doku/data/cache/1/195dc2ba5acca5865d245ae8ee875785.metadata
vendored
Normal file
@ -0,0 +1 @@
|
||||
1646899315
|
9
ap23/web/doku/data/cache/1/195dc2ba5acca5865d245ae8ee875785.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/1/195dc2ba5acca5865d245ae8ee875785.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="wiki_groupe_23">Wiki groupe 23</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
oui
|
||||
</p>
|
||||
|
||||
</div>
|
BIN
ap23/web/doku/data/cache/1/1a3ec2df3cfffe4d44058616997c1393.media.128x32.crop.png
vendored
Normal file
BIN
ap23/web/doku/data/cache/1/1a3ec2df3cfffe4d44058616997c1393.media.128x32.crop.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 6.8 KiB |
BIN
ap23/web/doku/data/cache/1/1a3ec2df3cfffe4d44058616997c1393.media.50x50.png
vendored
Normal file
BIN
ap23/web/doku/data/cache/1/1a3ec2df3cfffe4d44058616997c1393.media.50x50.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 6.3 KiB |
BIN
ap23/web/doku/data/cache/1/1a3ec2df3cfffe4d44058616997c1393.media.90x90.png
vendored
Normal file
BIN
ap23/web/doku/data/cache/1/1a3ec2df3cfffe4d44058616997c1393.media.90x90.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 17 KiB |
1
ap23/web/doku/data/cache/3/34d7ff31c58ad0d3817d2a90dbfaaf0f.i
vendored
Normal file
1
ap23/web/doku/data/cache/3/34d7ff31c58ad0d3817d2a90dbfaaf0f.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:12:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:7:"Aperçu";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:60:"Ceci est un aperçu de votre document. Attention : il n'est ";}i:2;i:24;}i:5;a:3:{i:0;s:11:"strong_open";i:1;a:0:{}i:2;i:84;}i:6;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:22:"pas encore enregistré";}i:2;i:86;}i:7;a:3:{i:0;s:12:"strong_close";i:1;a:0:{}i:2;i:108;}i:8;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:2:" !";}i:2;i:110;}i:9;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:112;}i:10;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:114;}i:11;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:114;}}
|
9
ap23/web/doku/data/cache/3/34d7ff31c58ad0d3817d2a90dbfaaf0f.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/3/34d7ff31c58ad0d3817d2a90dbfaaf0f.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="apercu">Aperçu</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Ceci est un aperçu de votre document. Attention : il n'est <strong>pas encore enregistré</strong> !
|
||||
</p>
|
||||
|
||||
</div>
|
3
ap23/web/doku/data/cache/3/3c9e188c526aba70c30c6ea8de3009f4.code
vendored
Normal file
3
ap23/web/doku/data/cache/3/3c9e188c526aba70c30c6ea8de3009f4.code
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<span class="kw1">echo</span> <span class="st_h">'The PHP version: '</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <a href="http://www.php.net/phpversion"><span class="kw3">phpversion</span></a><span class="br0">(</span><span class="br0">)</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <span class="st_h">' (inline HTML)'</span><span class="sy0">;</span>
|
1
ap23/web/doku/data/cache/4/49640f95c2ec64e9a971355914a38867.i
vendored
Normal file
1
ap23/web/doku/data/cache/4/49640f95c2ec64e9a971355914a38867.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:13:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:0;}i:2;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:65:"Modifiez cette page et cliquez sur « Enregistrer ». Voyez le ";}i:2;i:1;}i:3;a:3:{i:0;s:12:"internallink";i:1;a:2:{i:0;s:12:":wiki:syntax";i:1;s:21:"guide de mise en page";}i:2;i:66;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:92:" pour une aide à propos du formatage. Veuillez ne modifier cette page que si vous pouvez l'";}i:2;i:104;}i:5;a:3:{i:0;s:11:"strong_open";i:1;a:0:{}i:2;i:196;}i:6;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:10:"améliorer";}i:2;i:198;}i:7;a:3:{i:0;s:12:"strong_close";i:1;a:0:{}i:2;i:208;}i:8;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:69:". Si vous souhaitez faire des tests, faites vos premiers pas dans le ";}i:2;i:210;}i:9;a:3:{i:0;s:12:"internallink";i:1;a:2:{i:0;s:22:":playground:playground";i:1;s:12:"bac à sable";}i:2;i:279;}i:10;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:1:".";}i:2;i:318;}i:11;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:319;}i:12;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:319;}}
|
4
ap23/web/doku/data/cache/4/49640f95c2ec64e9a971355914a38867.xhtml
vendored
Normal file
4
ap23/web/doku/data/cache/4/49640f95c2ec64e9a971355914a38867.xhtml
vendored
Normal file
@ -0,0 +1,4 @@
|
||||
|
||||
<p>
|
||||
Modifiez cette page et cliquez sur « Enregistrer ». Voyez le <a href="/doku/doku.php?id=wiki:syntax" class="wikilink1" title="wiki:syntax" data-wiki-id="wiki:syntax">guide de mise en page</a> pour une aide à propos du formatage. Veuillez ne modifier cette page que si vous pouvez l'<strong>améliorer</strong>. Si vous souhaitez faire des tests, faites vos premiers pas dans le <a href="/doku/doku.php?id=playground:playground" class="wikilink1" title="playground:playground" data-wiki-id="playground:playground">bac à sable</a>.
|
||||
</p>
|
1
ap23/web/doku/data/cache/5/54f73be88eb86109ec13c3959a29b54e.code
vendored
Normal file
1
ap23/web/doku/data/cache/5/54f73be88eb86109ec13c3959a29b54e.code
vendored
Normal file
@ -0,0 +1 @@
|
||||
<span class="sc2"><<a href="http://december.com/html/4/element/p.html"><span class="kw2">p</span></a> <span class="kw3">style</span><span class="sy0">=</span><span class="st0">"border:2px dashed red;"</span>></span>And this is some block HTML<span class="sc2"><<span class="sy0">/</span><a href="http://december.com/html/4/element/p.html"><span class="kw2">p</span></a>></span>
|
1
ap23/web/doku/data/cache/5/55ea3d10b7dbc0f95433d5a02826fb7f.pwauth
vendored
Normal file
1
ap23/web/doku/data/cache/5/55ea3d10b7dbc0f95433d5a02826fb7f.pwauth
vendored
Normal file
@ -0,0 +1 @@
|
||||
superadmin
|
1
ap23/web/doku/data/cache/5/57e08330ffad3d0f3654b827a1182e1f.i
vendored
Normal file
1
ap23/web/doku/data/cache/5/57e08330ffad3d0f3654b827a1182e1f.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:20:"Derniers changements";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:48:"Voici la liste des pages modifiées récemment :";}i:2;i:37;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:85;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:86;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:86;}}
|
9
ap23/web/doku/data/cache/5/57e08330ffad3d0f3654b827a1182e1f.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/5/57e08330ffad3d0f3654b827a1182e1f.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="derniers_changements">Derniers changements</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Voici la liste des pages modifiées récemment :
|
||||
</p>
|
||||
|
||||
</div>
|
1
ap23/web/doku/data/cache/6/65330cf069cbc11061bf95019a710ebe.code
vendored
Normal file
1
ap23/web/doku/data/cache/6/65330cf069cbc11061bf95019a710ebe.code
vendored
Normal file
@ -0,0 +1 @@
|
||||
This is some <span class="sc2"><<a href="http://december.com/html/4/element/span.html"><span class="kw2">span</span></a> <span class="kw3">style</span><span class="sy0">=</span><span class="st0">"color:red;font-size:150%;"</span>></span>inline HTML<span class="sc2"><<span class="sy0">/</span><a href="http://december.com/html/4/element/span.html"><span class="kw2">span</span></a>></span>
|
1
ap23/web/doku/data/cache/6/676154311e289fe00b8de424b69022ac.i
vendored
Normal file
1
ap23/web/doku/data/cache/6/676154311e289fe00b8de424b69022ac.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:30:"Cette page n'existe pas encore";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:164:"Vous avez suivi un lien vers une page qui n'existe pas encore. Si vos permissions sont suffisantes, vous pouvez la créer en cliquant sur « Créer cette page ».";}i:2;i:47;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:211;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:212;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:212;}}
|
9
ap23/web/doku/data/cache/6/676154311e289fe00b8de424b69022ac.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/6/676154311e289fe00b8de424b69022ac.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="cette_page_n_existe_pas_encore">Cette page n'existe pas encore</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Vous avez suivi un lien vers une page qui n'existe pas encore. Si vos permissions sont suffisantes, vous pouvez la créer en cliquant sur « Créer cette page ».
|
||||
</p>
|
||||
|
||||
</div>
|
9
ap23/web/doku/data/cache/6/6d079fddabcf4cf2934c3775101efc7d.code
vendored
Normal file
9
ap23/web/doku/data/cache/6/6d079fddabcf4cf2934c3775101efc7d.code
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
<span class="co3">/**
|
||||
* The HelloWorldApp class implements an application that
|
||||
* simply displays "Hello World!" to the standard output.
|
||||
*/</span>
|
||||
<span class="kw1">class</span> HelloWorldApp <span class="br0">{</span>
|
||||
<span class="kw1">public</span> <span class="kw1">static</span> <span class="kw4">void</span> main<span class="br0">(</span><a href="http://www.google.com/search?hl=en&q=allinurl%3Adocs.oracle.com+javase+docs+api+string"><span class="kw3">String</span></a><span class="br0">[</span><span class="br0">]</span> args<span class="br0">)</span> <span class="br0">{</span>
|
||||
<a href="http://www.google.com/search?hl=en&q=allinurl%3Adocs.oracle.com+javase+docs+api+system"><span class="kw3">System</span></a>.<span class="me1">out</span>.<span class="me1">println</span><span class="br0">(</span><span class="st0">"Hello World!"</span><span class="br0">)</span><span class="sy0">;</span> <span class="co1">//Display the string.</span>
|
||||
<span class="br0">}</span>
|
||||
<span class="br0">}</span>
|
1
ap23/web/doku/data/cache/6/6e386b79a4a123e61a1f56564e12245c.i
vendored
Normal file
1
ap23/web/doku/data/cache/6/6e386b79a4a123e61a1f56564e12245c.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:20:"Anciennes révisions";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:266:"Voici les anciennes révisions de la page en cours. Pour les comparer, sélectionnez-les avec les cases à options. Pour revenir à une ancienne révision, affichez-la en cliquant sur son nom, puis cliquez sur le bouton « Modifier cette page » et enregistrez-la.";}i:2;i:37;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:303;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:303;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:303;}}
|
9
ap23/web/doku/data/cache/6/6e386b79a4a123e61a1f56564e12245c.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/6/6e386b79a4a123e61a1f56564e12245c.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="anciennes_revisions">Anciennes révisions</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Voici les anciennes révisions de la page en cours. Pour les comparer, sélectionnez-les avec les cases à options. Pour revenir à une ancienne révision, affichez-la en cliquant sur son nom, puis cliquez sur le bouton « Modifier cette page » et enregistrez-la.
|
||||
</p>
|
||||
|
||||
</div>
|
1
ap23/web/doku/data/cache/7/778603d587a51d5ba845256d00ae20eb.i
vendored
Normal file
1
ap23/web/doku/data/cache/7/778603d587a51d5ba845256d00ae20eb.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:12:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:29:"This topic does not exist yet";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:113:"You've followed a link to a topic that doesn't exist yet. If permissions allow, you may create it by clicking on ";}i:2;i:46;}i:5;a:3:{i:0;s:11:"strong_open";i:1;a:0:{}i:2;i:159;}i:6;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:16:"Create this page";}i:2;i:161;}i:7;a:3:{i:0;s:12:"strong_close";i:1;a:0:{}i:2;i:177;}i:8;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:1:".";}i:2;i:179;}i:9;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:180;}i:10;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:181;}i:11;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:181;}}
|
9
ap23/web/doku/data/cache/7/778603d587a51d5ba845256d00ae20eb.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/7/778603d587a51d5ba845256d00ae20eb.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="this_topic_does_not_exist_yet">This topic does not exist yet</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
You've followed a link to a topic that doesn't exist yet. If permissions allow, you may create it by clicking on <strong>Create this page</strong>.
|
||||
</p>
|
||||
|
||||
</div>
|
123
ap23/web/doku/data/cache/7/7fe3eba67a51654e766567e44758ab72.i
vendored
Normal file
123
ap23/web/doku/data/cache/7/7fe3eba67a51654e766567e44758ab72.i
vendored
Normal file
File diff suppressed because one or more lines are too long
1
ap23/web/doku/data/cache/7/7fe3eba67a51654e766567e44758ab72.metadata
vendored
Normal file
1
ap23/web/doku/data/cache/7/7fe3eba67a51654e766567e44758ab72.metadata
vendored
Normal file
@ -0,0 +1 @@
|
||||
1642059961
|
862
ap23/web/doku/data/cache/7/7fe3eba67a51654e766567e44758ab72.xhtml
vendored
Normal file
862
ap23/web/doku/data/cache/7/7fe3eba67a51654e766567e44758ab72.xhtml
vendored
Normal file
@ -0,0 +1,862 @@
|
||||
|
||||
<h1 class="sectionedit1" id="formatting_syntax">Formatting Syntax</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
<a href="https://www.dokuwiki.org/DokuWiki" class="interwiki iw_doku" title="https://www.dokuwiki.org/DokuWiki">DokuWiki</a> supports some simple markup language, which tries to make the datafiles to be as readable as possible. This page contains all possible syntax you may use when editing the pages. Simply have a look at the source of this page by pressing “Edit this page”. If you want to try something, just use the <a href="/doku/doku.php?id=playground:playground" class="wikilink1" title="playground:playground" data-wiki-id="playground:playground">playground</a> page. The simpler markup is easily accessible via <a href="https://www.dokuwiki.org/toolbar" class="interwiki iw_doku" title="https://www.dokuwiki.org/toolbar">quickbuttons</a>, too.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Formatting Syntax","hid":"formatting_syntax","codeblockOffset":0,"secid":1,"range":"1-472"} -->
|
||||
<h2 class="sectionedit2" id="basic_text_formatting">Basic Text Formatting</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
DokuWiki supports <strong>bold</strong>, <em>italic</em>, <em class="u">underlined</em> and <code>monospaced</code> texts. Of course you can <strong><em class="u"><em><code>combine</code></em></em></strong> all these.
|
||||
</p>
|
||||
<pre class="code">DokuWiki supports **bold**, //italic//, __underlined__ and ''monospaced'' texts.
|
||||
Of course you can **__//''combine''//__** all these.</pre>
|
||||
|
||||
<p>
|
||||
You can use <sub>subscript</sub> and <sup>superscript</sup>, too.
|
||||
</p>
|
||||
<pre class="code">You can use <sub>subscript</sub> and <sup>superscript</sup>, too.</pre>
|
||||
|
||||
<p>
|
||||
You can mark something as <del>deleted</del> as well.
|
||||
</p>
|
||||
<pre class="code">You can mark something as <del>deleted</del> as well.</pre>
|
||||
|
||||
<p>
|
||||
<strong>Paragraphs</strong> are created from blank lines. If you want to <strong>force a newline</strong> without a paragraph, you can use two backslashes followed by a whitespace or the end of line.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
This is some text with some linebreaks<br/>
|
||||
Note that the
|
||||
two backslashes are only recognized at the end of a line<br/>
|
||||
|
||||
or followed by<br/>
|
||||
a whitespace \\this happens without it.
|
||||
</p>
|
||||
<pre class="code">This is some text with some linebreaks\\ Note that the
|
||||
two backslashes are only recognized at the end of a line\\
|
||||
or followed by\\ a whitespace \\this happens without it.</pre>
|
||||
|
||||
<p>
|
||||
You should use forced newlines only if really needed.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Basic Text Formatting","hid":"basic_text_formatting","codeblockOffset":0,"secid":2,"range":"473-1609"} -->
|
||||
<h2 class="sectionedit3" id="links">Links</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
DokuWiki supports multiple ways of creating links.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Links","hid":"links","codeblockOffset":0,"secid":3,"range":"1610-1680"} -->
|
||||
<h3 class="sectionedit4" id="external">External</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
External links are recognized automagically: <a href="http://www.google.com" class="urlextern" title="http://www.google.com" rel="ugc nofollow">http://www.google.com</a> or simply <a href="http://www.google.com" class="urlextern" title="http://www.google.com" rel="ugc nofollow">www.google.com</a> - You can set the link text as well: <a href="http://www.google.com" class="urlextern" title="http://www.google.com" rel="ugc nofollow">This Link points to google</a>. Email addresses like this one: <a href="mailto:andi@splitbrain.org" class="mail" title="andi@splitbrain.org">andi@splitbrain.org</a> are recognized, too.
|
||||
</p>
|
||||
<pre class="code">DokuWiki supports multiple ways of creating links. External links are recognized
|
||||
automagically: http://www.google.com or simply www.google.com - You can set
|
||||
link text as well: [[http://www.google.com|This Link points to google]]. Email
|
||||
addresses like this one: <andi@splitbrain.org> are recognized, too.</pre>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"External","hid":"external","codeblockOffset":0,"secid":4,"range":"1681-2271"} -->
|
||||
<h3 class="sectionedit5" id="internal">Internal</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
Internal links are created by using square brackets. You can either just give a <a href="/doku/doku.php?id=wiki:pagename" class="wikilink2" title="wiki:pagename" rel="nofollow" data-wiki-id="wiki:pagename">pagename</a> or use an additional <a href="/doku/doku.php?id=wiki:pagename" class="wikilink2" title="wiki:pagename" rel="nofollow" data-wiki-id="wiki:pagename">link text</a>.
|
||||
</p>
|
||||
<pre class="code">Internal links are created by using square brackets. You can either just give
|
||||
a [[pagename]] or use an additional [[pagename|link text]].</pre>
|
||||
|
||||
<p>
|
||||
<a href="https://www.dokuwiki.org/pagename" class="interwiki iw_doku" title="https://www.dokuwiki.org/pagename">Wiki pagenames</a> are converted to lowercase automatically, special characters are not allowed.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
You can use <a href="/doku/doku.php?id=some:namespaces" class="wikilink2" title="some:namespaces" rel="nofollow" data-wiki-id="some:namespaces">namespaces</a> by using a colon in the pagename.
|
||||
</p>
|
||||
<pre class="code">You can use [[some:namespaces]] by using a colon in the pagename.</pre>
|
||||
|
||||
<p>
|
||||
For details about namespaces see <a href="https://www.dokuwiki.org/namespaces" class="interwiki iw_doku" title="https://www.dokuwiki.org/namespaces">namespaces</a>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Linking to a specific section is possible, too. Just add the section name behind a hash character as known from <abbr title="HyperText Markup Language">HTML</abbr>. This links to <a href="/doku/doku.php?id=wiki:syntax#internal" class="wikilink1" title="wiki:syntax" data-wiki-id="wiki:syntax">this Section</a>.
|
||||
</p>
|
||||
<pre class="code">This links to [[syntax#internal|this Section]].</pre>
|
||||
|
||||
<p>
|
||||
Notes:
|
||||
</p>
|
||||
<ul>
|
||||
<li class="level1"><div class="li"> Links to <a href="/doku/doku.php?id=wiki:syntax" class="wikilink1" title="wiki:syntax" data-wiki-id="wiki:syntax">existing pages</a> are shown in a different style from <a href="/doku/doku.php?id=wiki:nonexisting" class="wikilink2" title="wiki:nonexisting" rel="nofollow" data-wiki-id="wiki:nonexisting">nonexisting</a> ones.</div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> DokuWiki does not use <a href="https://en.wikipedia.org/wiki/CamelCase" class="interwiki iw_wp" title="https://en.wikipedia.org/wiki/CamelCase">CamelCase</a> to automatically create links by default, but this behavior can be enabled in the <a href="https://www.dokuwiki.org/config" class="interwiki iw_doku" title="https://www.dokuwiki.org/config">config</a> file. Hint: If DokuWiki is a link, then it's enabled.</div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> When a section's heading is changed, its bookmark changes, too. So don't rely on section linking too much.</div>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Internal","hid":"internal","codeblockOffset":0,"secid":5,"range":"2272-3506"} -->
|
||||
<h3 class="sectionedit6" id="interwiki">Interwiki</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
DokuWiki supports <a href="https://www.dokuwiki.org/Interwiki" class="interwiki iw_doku" title="https://www.dokuwiki.org/Interwiki">Interwiki</a> links. These are quick links to other Wikis. For example this is a link to Wikipedia's page about Wikis: <a href="https://en.wikipedia.org/wiki/Wiki" class="interwiki iw_wp" title="https://en.wikipedia.org/wiki/Wiki">Wiki</a>.
|
||||
</p>
|
||||
<pre class="code">DokuWiki supports [[doku>Interwiki]] links. These are quick links to other Wikis.
|
||||
For example this is a link to Wikipedia's page about Wikis: [[wp>Wiki]].</pre>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Interwiki","hid":"interwiki","codeblockOffset":0,"secid":6,"range":"3507-3843"} -->
|
||||
<h3 class="sectionedit7" id="windows_shares">Windows Shares</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
Windows shares like <a href="file://///server/share" class="windows" title="\\server\share">this</a> are recognized, too. Please note that these only make sense in a homogeneous user group like a corporate <a href="https://en.wikipedia.org/wiki/Intranet" class="interwiki iw_wp" title="https://en.wikipedia.org/wiki/Intranet">Intranet</a>.
|
||||
</p>
|
||||
<pre class="code">Windows Shares like [[\\server\share|this]] are recognized, too.</pre>
|
||||
|
||||
<p>
|
||||
Notes:
|
||||
</p>
|
||||
<ul>
|
||||
<li class="level1"><div class="li"> For security reasons direct browsing of windows shares only works in Microsoft Internet Explorer per default (and only in the “local zone”).</div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> For Mozilla and Firefox it can be enabled through different workaround mentioned in the <a href="http://kb.mozillazine.org/Links_to_local_pages_do_not_work" class="urlextern" title="http://kb.mozillazine.org/Links_to_local_pages_do_not_work" rel="ugc nofollow">Mozilla Knowledge Base</a>. However, there will still be a JavaScript warning about trying to open a Windows Share. To remove this warning (for all users), put the following line in <code>conf/lang/en/lang.php</code> (more details at <a href="https://www.dokuwiki.org/localization#changing_some_localized_texts_and_strings_in_your_installation" class="interwiki iw_doku" title="https://www.dokuwiki.org/localization#changing_some_localized_texts_and_strings_in_your_installation">localization</a>): <dl class="code">
|
||||
<dt><a href="/doku/doku.php?do=export_code&id=wiki:syntax&codeblock=0" title="Télécharger cet extrait" class="mediafile mf_php">conf/lang/en/lang.php</a></dt>
|
||||
<dd><pre class="code"><?php
|
||||
/**
|
||||
* Customization of the english language file
|
||||
* Copy only the strings that needs to be modified
|
||||
*/
|
||||
$lang['js']['nosmblinks'] = '';</pre>
|
||||
</dd></dl>
|
||||
</div>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Windows Shares","hid":"windows_shares","codeblockOffset":0,"secid":7,"range":"3844-4916"} -->
|
||||
<h3 class="sectionedit8" id="image_links">Image Links</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
You can also use an image to link to another internal or external page by combining the syntax for links and <a href="#images_and_other_files" title="wiki:syntax ↵" class="wikilink1">images</a> (see below) like this:
|
||||
</p>
|
||||
<pre class="code">[[http://php.net|{{wiki:dokuwiki-128.png}}]]</pre>
|
||||
|
||||
<p>
|
||||
<a href="http://php.net" class="media" title="http://php.net" rel="ugc nofollow"><img src="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="media" alt="" /></a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Please note: The image formatting is the only formatting syntax accepted in link names.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
The whole <a href="#images_and_other_files" title="wiki:syntax ↵" class="wikilink1">image</a> and <a href="#links" title="wiki:syntax ↵" class="wikilink1">link</a> syntax is supported (including image resizing, internal and external images and URLs and interwiki links).
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Image Links","hid":"image_links","codeblockOffset":1,"secid":8,"range":"4917-5462"} -->
|
||||
<h2 class="sectionedit9" id="footnotes">Footnotes</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
You can add footnotes <sup><a href="#fn__1" id="fnt__1" class="fn_top">1)</a></sup> by using double parentheses.
|
||||
</p>
|
||||
<pre class="code">You can add footnotes ((This is a footnote)) by using double parentheses.</pre>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Footnotes","hid":"footnotes","codeblockOffset":1,"secid":9,"range":"5463-5637"} -->
|
||||
<h2 class="sectionedit10" id="sectioning">Sectioning</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
You can use up to five different levels of headlines to structure your content. If you have more than three headlines, a table of contents is generated automatically – this can be disabled by including the string <code>~~NOTOC~~</code> in the document.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Sectioning","hid":"sectioning","codeblockOffset":1,"secid":10,"range":"5638-5924"} -->
|
||||
<h3 class="sectionedit11" id="headline_level_3">Headline Level 3</h3>
|
||||
<div class="level3">
|
||||
|
||||
</div>
|
||||
|
||||
<h4 id="headline_level_4">Headline Level 4</h4>
|
||||
<div class="level4">
|
||||
|
||||
</div>
|
||||
|
||||
<h5 id="headline_level_5">Headline Level 5</h5>
|
||||
<div class="level5">
|
||||
<pre class="code">==== Headline Level 3 ====
|
||||
=== Headline Level 4 ===
|
||||
== Headline Level 5 ==</pre>
|
||||
|
||||
<p>
|
||||
By using four or more dashes, you can make a horizontal line:
|
||||
</p>
|
||||
<hr />
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Headline Level 3","hid":"headline_level_3","codeblockOffset":1,"secid":11,"range":"5925-6151"} -->
|
||||
<h2 class="sectionedit12" id="media_files">Media Files</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
You can include external and internal <a href="https://www.dokuwiki.org/images" class="interwiki iw_doku" title="https://www.dokuwiki.org/images">images, videos and audio files</a> with curly brackets. Optionally you can specify the size of them.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Real size: <a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="media" alt="" /></a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Resize to given width: <a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?w=50&tok=f9f615&media=wiki:dokuwiki-128.png" class="media" alt="" width="50" /></a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Resize to given width and height<sup><a href="#fn__2" id="fnt__2" class="fn_top">2)</a></sup>: <a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?w=200&h=50&tok=d56d51&media=wiki:dokuwiki-128.png" class="media" alt="" width="200" height="50" /></a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Resized external image: <a href="/doku/lib/exe/fetch.php?tok=1a9cc5&media=https%3A%2F%2Fsecure.php.net%2Fimages%2Fphp.gif" class="media" title="https://secure.php.net/images/php.gif"><img src="/doku/lib/exe/fetch.php?w=200&h=50&tok=d0456a&media=https%3A%2F%2Fsecure.php.net%2Fimages%2Fphp.gif" class="media" alt="" width="200" height="50" /></a>
|
||||
</p>
|
||||
<pre class="code">Real size: {{wiki:dokuwiki-128.png}}
|
||||
Resize to given width: {{wiki:dokuwiki-128.png?50}}
|
||||
Resize to given width and height: {{wiki:dokuwiki-128.png?200x50}}
|
||||
Resized external image: {{https://secure.php.net/images/php.gif?200x50}}</pre>
|
||||
|
||||
<p>
|
||||
By using left or right whitespaces you can choose the alignment.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
<a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="mediaright" alt="" /></a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
<a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="medialeft" alt="" /></a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
<a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="mediacenter" alt="" /></a>
|
||||
</p>
|
||||
<pre class="code">{{ wiki:dokuwiki-128.png}}
|
||||
{{wiki:dokuwiki-128.png }}
|
||||
{{ wiki:dokuwiki-128.png }}</pre>
|
||||
|
||||
<p>
|
||||
Of course, you can add a title (displayed as a tooltip by most browsers), too.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
<a href="/doku/lib/exe/detail.php?id=wiki%3Asyntax&media=wiki:dokuwiki-128.png" class="media" title="wiki:dokuwiki-128.png"><img src="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="mediacenter" title="This is the caption" alt="This is the caption" /></a>
|
||||
</p>
|
||||
<pre class="code">{{ wiki:dokuwiki-128.png |This is the caption}}</pre>
|
||||
|
||||
<p>
|
||||
For linking an image to another page see <a href="#image_links" title="wiki:syntax ↵" class="wikilink1">Image Links</a> above.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Media Files","hid":"media_files","codeblockOffset":1,"secid":12,"range":"6152-7524"} -->
|
||||
<h3 class="sectionedit13" id="supported_media_formats">Supported Media Formats</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
DokuWiki can embed the following media formats directly.
|
||||
</p>
|
||||
<div class="table sectionedit14"><table class="inline">
|
||||
<tr class="row0">
|
||||
<td class="col0"> Image </td><td class="col1 leftalign"> <code>gif</code>, <code>jpg</code>, <code>png</code> </td>
|
||||
</tr>
|
||||
<tr class="row1">
|
||||
<td class="col0"> Video </td><td class="col1"> <code>webm</code>, <code>ogv</code>, <code>mp4</code> </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<td class="col0"> Audio </td><td class="col1 leftalign"> <code>ogg</code>, <code>mp3</code>, <code>wav</code> </td>
|
||||
</tr>
|
||||
<tr class="row3">
|
||||
<td class="col0"> Flash </td><td class="col1 leftalign"> <code>swf</code> </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table","secid":14,"range":"7618-7773"} -->
|
||||
<p>
|
||||
If you specify a filename that is not a supported media format, then it will be displayed as a link instead.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
By adding <code>?linkonly</code> you provide a link to the media without displaying it inline
|
||||
</p>
|
||||
<pre class="code">{{wiki:dokuwiki-128.png?linkonly}}</pre>
|
||||
|
||||
<p>
|
||||
<a href="/doku/lib/exe/fetch.php?media=wiki:dokuwiki-128.png" class="media mediafile mf_png" title="wiki:dokuwiki-128.png (27.2 KB)">dokuwiki-128.png</a> This is just a link to the image.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Supported Media Formats","hid":"supported_media_formats","codeblockOffset":1,"secid":13,"range":"7525-8078"} -->
|
||||
<h3 class="sectionedit15" id="fallback_formats">Fallback Formats</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
Unfortunately not all browsers understand all video and audio formats. To mitigate the problem, you can upload your file in different formats for maximum browser compatibility.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
For example consider this embedded mp4 video:
|
||||
</p>
|
||||
<pre class="code">{{video.mp4|A funny video}}</pre>
|
||||
|
||||
<p>
|
||||
When you upload a <code>video.webm</code> and <code>video.ogv</code> next to the referenced <code>video.mp4</code>, DokuWiki will automatically add them as alternatives so that one of the three files is understood by your browser.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Additionally DokuWiki supports a “poster” image which will be shown before the video has started. That image needs to have the same filename as the video and be either a jpg or png file. In the example above a <code>video.jpg</code> file would work.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Fallback Formats","hid":"fallback_formats","codeblockOffset":1,"secid":15,"range":"8079-8809"} -->
|
||||
<h2 class="sectionedit16" id="lists">Lists</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
Dokuwiki supports ordered and unordered lists. To create a list item, indent your text by two spaces and use a <code>*</code> for unordered lists or a <code>-</code> for ordered ones.
|
||||
</p>
|
||||
<ul>
|
||||
<li class="level1"><div class="li"> This is a list</div>
|
||||
</li>
|
||||
<li class="level1 node"><div class="li"> The second item</div>
|
||||
<ul>
|
||||
<li class="level2"><div class="li"> You may have different levels</div>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> Another item</div>
|
||||
</li>
|
||||
</ul>
|
||||
<ol>
|
||||
<li class="level1"><div class="li"> The same list but ordered</div>
|
||||
</li>
|
||||
<li class="level1 node"><div class="li"> Another item</div>
|
||||
<ol>
|
||||
<li class="level2"><div class="li"> Just use indention for deeper levels</div>
|
||||
</li>
|
||||
</ol>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> That's it</div>
|
||||
</li>
|
||||
</ol>
|
||||
<pre class="code"> * This is a list
|
||||
* The second item
|
||||
* You may have different levels
|
||||
* Another item
|
||||
|
||||
- The same list but ordered
|
||||
- Another item
|
||||
- Just use indention for deeper levels
|
||||
- That's it</pre>
|
||||
|
||||
<p>
|
||||
Also take a look at the <a href="https://www.dokuwiki.org/faq%3Alists" class="interwiki iw_doku" title="https://www.dokuwiki.org/faq%3Alists">FAQ on list items</a>.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Lists","hid":"lists","codeblockOffset":1,"secid":16,"range":"8810-9469"} -->
|
||||
<h2 class="sectionedit17" id="text_conversions">Text Conversions</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
DokuWiki can convert certain pre-defined characters or strings into images or other text or <abbr title="HyperText Markup Language">HTML</abbr>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
The text to image conversion is mainly done for smileys. And the text to <abbr title="HyperText Markup Language">HTML</abbr> conversion is used for typography replacements, but can be configured to use other <abbr title="HyperText Markup Language">HTML</abbr> as well.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Text Conversions","hid":"text_conversions","codeblockOffset":2,"secid":17,"range":"9470-9774"} -->
|
||||
<h3 class="sectionedit18" id="text_to_image_conversions">Text to Image Conversions</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
DokuWiki converts commonly used <a href="https://en.wikipedia.org/wiki/emoticon" class="interwiki iw_wp" title="https://en.wikipedia.org/wiki/emoticon">emoticon</a>s to their graphical equivalents. Those <a href="https://www.dokuwiki.org/Smileys" class="interwiki iw_doku" title="https://www.dokuwiki.org/Smileys">Smileys</a> and other images can be configured and extended. Here is an overview of Smileys included in DokuWiki:
|
||||
</p>
|
||||
<ul>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_cool.gif" class="icon" alt="8-)" /> 8-) </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_eek.gif" class="icon" alt="8-O" /> 8-O </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_sad.gif" class="icon" alt=":-(" /> :-( </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_smile.gif" class="icon" alt=":-)" /> :-) </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_smile2.gif" class="icon" alt="=)" /> =) </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_doubt.gif" class="icon" alt=":-/" /> :-/ </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_doubt2.gif" class="icon" alt=":-\" /> :-\ </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_confused.gif" class="icon" alt=":-?" /> :-? </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_biggrin.gif" class="icon" alt=":-D" /> :-D </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_razz.gif" class="icon" alt=":-P" /> :-P </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_surprised.gif" class="icon" alt=":-O" /> :-O </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_silenced.gif" class="icon" alt=":-X" /> :-X </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_neutral.gif" class="icon" alt=":-|" /> :-| </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_wink.gif" class="icon" alt=";-)" /> ;-) </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_fun.gif" class="icon" alt="^_^" /> ^_^ </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_question.gif" class="icon" alt=":?:" /> :?: </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_exclaim.gif" class="icon" alt=":!:" /> :!: </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/icon_lol.gif" class="icon" alt="LOL" /> LOL </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/fixme.gif" class="icon" alt="FIXME" /> FIXME </div>
|
||||
</li>
|
||||
<li class="level1"><div class="li"> <img src="/doku/lib/images/smileys/delete.gif" class="icon" alt="DELETEME" /> DELETEME </div>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Text to Image Conversions","hid":"text_to_image_conversions","codeblockOffset":2,"secid":18,"range":"9775-10430"} -->
|
||||
<h3 class="sectionedit19" id="text_to_html_conversions">Text to HTML Conversions</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
Typography: <a href="/doku/doku.php?id=wiki:dokuwiki" class="wikilink1" title="wiki:dokuwiki" data-wiki-id="wiki:dokuwiki">DokuWiki</a> can convert simple text characters to their typographically correct entities. Here is an example of recognized characters.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
→ ← ↔ ⇒ ⇐ ⇔ » « – — 640×480 © ™ ®
|
||||
“He thought 'It's a man's world'…”
|
||||
</p>
|
||||
<pre class="code">-> <- <-> => <= <=> >> << -- --- 640x480 (c) (tm) (r)
|
||||
"He thought 'It's a man's world'..."</pre>
|
||||
|
||||
<p>
|
||||
The same can be done to produce any kind of <abbr title="HyperText Markup Language">HTML</abbr>, it just needs to be added to the <a href="https://www.dokuwiki.org/entities" class="interwiki iw_doku" title="https://www.dokuwiki.org/entities">pattern file</a>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
There are three exceptions which do not come from that pattern file: multiplication entity (640×480), 'single' and “double quotes”. They can be turned off through a <a href="https://www.dokuwiki.org/config%3Atypography" class="interwiki iw_doku" title="https://www.dokuwiki.org/config%3Atypography">config option</a>.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Text to HTML Conversions","hid":"text_to_html_conversions","codeblockOffset":2,"secid":19,"range":"10431-11138"} -->
|
||||
<h2 class="sectionedit20" id="quoting">Quoting</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
Some times you want to mark some text to show it's a reply or comment. You can use the following syntax:
|
||||
</p>
|
||||
<pre class="code">I think we should do it
|
||||
|
||||
> No we shouldn't
|
||||
|
||||
>> Well, I say we should
|
||||
|
||||
> Really?
|
||||
|
||||
>> Yes!
|
||||
|
||||
>>> Then lets do it!</pre>
|
||||
|
||||
<p>
|
||||
I think we should do it
|
||||
</p>
|
||||
<blockquote><div class="no">
|
||||
No we shouldn't</div></blockquote>
|
||||
<blockquote><div class="no">
|
||||
<blockquote><div class="no">
|
||||
Well, I say we should</div></blockquote>
|
||||
</div></blockquote>
|
||||
<blockquote><div class="no">
|
||||
Really?</div></blockquote>
|
||||
<blockquote><div class="no">
|
||||
<blockquote><div class="no">
|
||||
Yes!</div></blockquote>
|
||||
</div></blockquote>
|
||||
<blockquote><div class="no">
|
||||
<blockquote><div class="no">
|
||||
<blockquote><div class="no">
|
||||
Then lets do it!</div></blockquote>
|
||||
</div></blockquote>
|
||||
</div></blockquote>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Quoting","hid":"quoting","codeblockOffset":3,"secid":20,"range":"11139-11504"} -->
|
||||
<h2 class="sectionedit21" id="tables">Tables</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
DokuWiki supports a simple syntax to create tables.
|
||||
</p>
|
||||
<div class="table sectionedit22"><table class="inline">
|
||||
<thead>
|
||||
<tr class="row0">
|
||||
<th class="col0 leftalign"> Heading 1 </th><th class="col1 leftalign"> Heading 2 </th><th class="col2 leftalign"> Heading 3 </th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tr class="row1">
|
||||
<td class="col0 leftalign"> Row 1 Col 1 </td><td class="col1 leftalign"> Row 1 Col 2 </td><td class="col2 leftalign"> Row 1 Col 3 </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<td class="col0 leftalign"> Row 2 Col 1 </td><td class="col1" colspan="2"> some colspan (note the double pipe) </td>
|
||||
</tr>
|
||||
<tr class="row3">
|
||||
<td class="col0 leftalign"> Row 3 Col 1 </td><td class="col1 leftalign"> Row 3 Col 2 </td><td class="col2 leftalign"> Row 3 Col 3 </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table1","secid":22,"range":"11578-11809"} -->
|
||||
<p>
|
||||
Table rows have to start and end with a <code>|</code> for normal rows or a <code>^</code> for headers.
|
||||
</p>
|
||||
<pre class="code">^ Heading 1 ^ Heading 2 ^ Heading 3 ^
|
||||
| Row 1 Col 1 | Row 1 Col 2 | Row 1 Col 3 |
|
||||
| Row 2 Col 1 | some colspan (note the double pipe) ||
|
||||
| Row 3 Col 1 | Row 3 Col 2 | Row 3 Col 3 |</pre>
|
||||
|
||||
<p>
|
||||
To connect cells horizontally, just make the next cell completely empty as shown above. Be sure to have always the same amount of cell separators!
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Vertical tableheaders are possible, too.
|
||||
</p>
|
||||
<div class="table sectionedit23"><table class="inline">
|
||||
<thead>
|
||||
<tr class="row0">
|
||||
<td class="col0 leftalign"> </td><th class="col1 leftalign"> Heading 1 </th><th class="col2 leftalign"> Heading 2 </th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tr class="row1">
|
||||
<th class="col0 leftalign"> Heading 3 </th><td class="col1 leftalign"> Row 1 Col 2 </td><td class="col2 leftalign"> Row 1 Col 3 </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<th class="col0 leftalign"> Heading 4 </th><td class="col1"> no colspan this time </td><td class="col2 leftalign"> </td>
|
||||
</tr>
|
||||
<tr class="row3">
|
||||
<th class="col0 leftalign"> Heading 5 </th><td class="col1 leftalign"> Row 2 Col 2 </td><td class="col2 leftalign"> Row 2 Col 3 </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table2","secid":23,"range":"12329-12572"} -->
|
||||
<p>
|
||||
As you can see, it's the cell separator before a cell which decides about the formatting:
|
||||
</p>
|
||||
<pre class="code">| ^ Heading 1 ^ Heading 2 ^
|
||||
^ Heading 3 | Row 1 Col 2 | Row 1 Col 3 |
|
||||
^ Heading 4 | no colspan this time | |
|
||||
^ Heading 5 | Row 2 Col 2 | Row 2 Col 3 |</pre>
|
||||
|
||||
<p>
|
||||
You can have rowspans (vertically connected cells) by adding <code>:::</code> into the cells below the one to which they should connect.
|
||||
</p>
|
||||
<div class="table sectionedit24"><table class="inline">
|
||||
<thead>
|
||||
<tr class="row0">
|
||||
<th class="col0 leftalign"> Heading 1 </th><th class="col1 leftalign"> Heading 2 </th><th class="col2 leftalign"> Heading 3 </th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tr class="row1">
|
||||
<td class="col0 leftalign"> Row 1 Col 1 </td><td class="col1" rowspan="3"> this cell spans vertically </td><td class="col2 leftalign"> Row 1 Col 3 </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<td class="col0 leftalign"> Row 2 Col 1 </td><td class="col1 leftalign"> Row 2 Col 3 </td>
|
||||
</tr>
|
||||
<tr class="row3">
|
||||
<td class="col0 leftalign"> Row 3 Col 1 </td><td class="col1 leftalign"> Row 2 Col 3 </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table3","secid":24,"range":"13051-13326"} -->
|
||||
<p>
|
||||
Apart from the rowspan syntax those cells should not contain anything else.
|
||||
</p>
|
||||
<pre class="code">^ Heading 1 ^ Heading 2 ^ Heading 3 ^
|
||||
| Row 1 Col 1 | this cell spans vertically | Row 1 Col 3 |
|
||||
| Row 2 Col 1 | ::: | Row 2 Col 3 |
|
||||
| Row 3 Col 1 | ::: | Row 2 Col 3 |</pre>
|
||||
|
||||
<p>
|
||||
You can align the table contents, too. Just add at least two whitespaces at the opposite end of your text: Add two spaces on the left to align right, two spaces on the right to align left and two spaces at least at both ends for centered text.
|
||||
</p>
|
||||
<div class="table sectionedit25"><table class="inline">
|
||||
<thead>
|
||||
<tr class="row0">
|
||||
<th class="col0 centeralign" colspan="3"> Table with alignment </th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tr class="row1">
|
||||
<td class="col0 rightalign"> right</td><td class="col1 centeralign"> center </td><td class="col2 leftalign">left </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<td class="col0 leftalign">left </td><td class="col1 rightalign"> right</td><td class="col2 centeralign"> center </td>
|
||||
</tr>
|
||||
<tr class="row3">
|
||||
<td class="col0"> xxxxxxxxxxxx </td><td class="col1"> xxxxxxxxxxxx </td><td class="col2"> xxxxxxxxxxxx </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table4","secid":25,"range":"13935-14122"} -->
|
||||
<p>
|
||||
This is how it looks in the source:
|
||||
</p>
|
||||
<pre class="code">^ Table with alignment ^^^
|
||||
| right| center |left |
|
||||
|left | right| center |
|
||||
| xxxxxxxxxxxx | xxxxxxxxxxxx | xxxxxxxxxxxx |</pre>
|
||||
|
||||
<p>
|
||||
Note: Vertical alignment is not supported.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Tables","hid":"tables","codeblockOffset":4,"secid":21,"range":"11505-14401"} -->
|
||||
<h2 class="sectionedit26" id="no_formatting">No Formatting</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
If you need to display text exactly like it is typed (without any formatting), enclose the area either with <code><nowiki></code> tags or even simpler, with double percent signs <code>%%</code>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
|
||||
This is some text which contains addresses like this: http://www.splitbrain.org and **formatting**, but nothing is done with it.
|
||||
|
||||
The same is true for //__this__ text// with a smiley ;-).
|
||||
</p>
|
||||
<pre class="code"><nowiki>
|
||||
This is some text which contains addresses like this: http://www.splitbrain.org and **formatting**, but nothing is done with it.
|
||||
</nowiki>
|
||||
The same is true for %%//__this__ text// with a smiley ;-)%%.</pre>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"No Formatting","hid":"no_formatting","codeblockOffset":4,"secid":26,"range":"14402-15057"} -->
|
||||
<h2 class="sectionedit27" id="code_blocks">Code Blocks</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
You can include code blocks into your documents by either indenting them by at least two spaces (like used for the previous examples) or by using the tags <code><code></code> or <code><file></code>.
|
||||
</p>
|
||||
<pre class="code">This is text is indented by two spaces.</pre>
|
||||
<pre class="code">This is preformatted code all spaces are preserved: like <-this</pre>
|
||||
<pre class="file">This is pretty much the same, but you could use it to show that you quoted a file.</pre>
|
||||
|
||||
<p>
|
||||
Those blocks were created by this source:
|
||||
</p>
|
||||
<pre class="code"> This is text is indented by two spaces.</pre>
|
||||
<pre class="code"><code>
|
||||
This is preformatted code all spaces are preserved: like <-this
|
||||
</code></pre>
|
||||
<pre class="code"><file>
|
||||
This is pretty much the same, but you could use it to show that you quoted a file.
|
||||
</file></pre>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Code Blocks","hid":"code_blocks","codeblockOffset":4,"secid":27,"range":"15058-15799"} -->
|
||||
<h3 class="sectionedit28" id="syntax_highlighting">Syntax Highlighting</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
<a href="/doku/doku.php?id=wiki:dokuwiki" class="wikilink1" title="wiki:dokuwiki" data-wiki-id="wiki:dokuwiki">DokuWiki</a> can highlight sourcecode, which makes it easier to read. It uses the <a href="http://qbnz.com/highlighter/" class="urlextern" title="http://qbnz.com/highlighter/" rel="ugc nofollow">GeSHi</a> Generic Syntax Highlighter – so any language supported by GeSHi is supported. The syntax uses the same code and file blocks described in the previous section, but this time the name of the language syntax to be highlighted is included inside the tag, e.g. <code><code java></code> or <code><file java></code>.
|
||||
</p>
|
||||
<pre class="code java"><span class="co3">/**
|
||||
* The HelloWorldApp class implements an application that
|
||||
* simply displays "Hello World!" to the standard output.
|
||||
*/</span>
|
||||
<span class="kw1">class</span> HelloWorldApp <span class="br0">{</span>
|
||||
<span class="kw1">public</span> <span class="kw1">static</span> <span class="kw4">void</span> main<span class="br0">(</span><a href="http://www.google.com/search?hl=en&q=allinurl%3Adocs.oracle.com+javase+docs+api+string"><span class="kw3">String</span></a><span class="br0">[</span><span class="br0">]</span> args<span class="br0">)</span> <span class="br0">{</span>
|
||||
<a href="http://www.google.com/search?hl=en&q=allinurl%3Adocs.oracle.com+javase+docs+api+system"><span class="kw3">System</span></a>.<span class="me1">out</span>.<span class="me1">println</span><span class="br0">(</span><span class="st0">"Hello World!"</span><span class="br0">)</span><span class="sy0">;</span> <span class="co1">//Display the string.</span>
|
||||
<span class="br0">}</span>
|
||||
<span class="br0">}</span></pre>
|
||||
|
||||
<p>
|
||||
The following language strings are currently recognized: <em>4cs 6502acme 6502kickass 6502tasm 68000devpac abap actionscript3 actionscript ada aimms algol68 apache applescript apt_sources arm asm asp asymptote autoconf autohotkey autoit avisynth awk bascomavr bash basic4gl batch bf biblatex bibtex blitzbasic bnf boo caddcl cadlisp ceylon cfdg cfm chaiscript chapel cil c_loadrunner clojure c_mac cmake cobol coffeescript c cpp cpp-qt cpp-winapi csharp css cuesheet c_winapi dart dcl dcpu16 dcs delphi diff div dos dot d ecmascript eiffel email epc e erlang euphoria ezt f1 falcon fo fortran freebasic freeswitch fsharp gambas gdb genero genie gettext glsl gml gnuplot go groovy gwbasic haskell haxe hicest hq9plus html html4strict html5 icon idl ini inno intercal io ispfpanel java5 java javascript jcl j jquery julia kixtart klonec klonecpp kotlin latex lb ldif lisp llvm locobasic logtalk lolcode lotusformulas lotusscript lscript lsl2 lua m68k magiksf make mapbasic mathematica matlab mercury metapost mirc mk-61 mmix modula2 modula3 mpasm mxml mysql nagios netrexx newlisp nginx nimrod nsis oberon2 objc objeck ocaml-brief ocaml octave oobas oorexx oracle11 oracle8 oxygene oz parasail parigp pascal pcre perl6 perl per pf phix php-brief php pic16 pike pixelbender pli plsql postgresql postscript povray powerbuilder powershell proftpd progress prolog properties providex purebasic pycon pys60 python qbasic qml q racket rails rbs rebol reg rexx robots roff rpmspec rsplus ruby rust sas sass scala scheme scilab scl sdlbasic smalltalk smarty spark sparql sql sshconfig standardml stonescript swift systemverilog tclegg tcl teraterm texgraph text thinbasic tsql twig typoscript unicon upc urbi uscript vala vbnet vb vbscript vedit verilog vhdl vim visualfoxpro visualprolog whitespace whois winbatch wolfram xbasic xml xojo xorg_conf xpp yaml z80 zxbasic</em>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
There are additional <a href="https://www.dokuwiki.org/syntax_highlighting" class="interwiki iw_doku" title="https://www.dokuwiki.org/syntax_highlighting">advanced options</a> available for syntax highlighting, such as highlighting lines or adding line numbers.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Syntax Highlighting","hid":"syntax_highlighting","codeblockOffset":6,"secid":28,"range":"15800-18585"} -->
|
||||
<h3 class="sectionedit29" id="downloadable_code_blocks">Downloadable Code Blocks</h3>
|
||||
<div class="level3">
|
||||
|
||||
<p>
|
||||
When you use the <code><code></code> or <code><file></code> syntax as above, you might want to make the shown code available for download as well. You can do this by specifying a file name after language code like this:
|
||||
</p>
|
||||
<pre class="code"><file php myexample.php>
|
||||
<?php echo "hello world!"; ?>
|
||||
</file></pre>
|
||||
<dl class="file">
|
||||
<dt><a href="/doku/doku.php?do=export_code&id=wiki:syntax&codeblock=8" title="Télécharger cet extrait" class="mediafile mf_php">myexample.php</a></dt>
|
||||
<dd><pre class="code file php"><span class="kw2"><?php</span> <span class="kw1">echo</span> <span class="st0">"hello world!"</span><span class="sy0">;</span> <span class="sy1">?></span></pre>
|
||||
</dd></dl>
|
||||
|
||||
<p>
|
||||
If you don't want any highlighting but want a downloadable file, specify a dash (<code>-</code>) as the language code: <code><code - myfile.foo></code>.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Downloadable Code Blocks","hid":"downloadable_code_blocks","codeblockOffset":7,"secid":29,"range":"18586-19116"} -->
|
||||
<h2 class="sectionedit30" id="embedding_html_and_php">Embedding HTML and PHP</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
You can embed raw <abbr title="HyperText Markup Language">HTML</abbr> or PHP code into your documents by using the <code><html></code> or <code><php></code> tags. (Use uppercase tags if you need to enclose block level elements.)
|
||||
</p>
|
||||
|
||||
<p>
|
||||
<abbr title="HyperText Markup Language">HTML</abbr> example:
|
||||
</p>
|
||||
<pre class="code"><html>
|
||||
This is some <span style="color:red;font-size:150%;">inline HTML</span>
|
||||
</html>
|
||||
<HTML>
|
||||
<p style="border:2px dashed red;">And this is some block HTML</p>
|
||||
</HTML></pre>
|
||||
|
||||
<p>
|
||||
<code class="code html4strict">This is some <span class="sc2"><<a href="http://december.com/html/4/element/span.html"><span class="kw2">span</span></a> <span class="kw3">style</span><span class="sy0">=</span><span class="st0">"color:red;font-size:150%;"</span>></span>inline HTML<span class="sc2"><<span class="sy0">/</span><a href="http://december.com/html/4/element/span.html"><span class="kw2">span</span></a>></span></code>
|
||||
</p>
|
||||
<pre class="code html4strict"><span class="sc2"><<a href="http://december.com/html/4/element/p.html"><span class="kw2">p</span></a> <span class="kw3">style</span><span class="sy0">=</span><span class="st0">"border:2px dashed red;"</span>></span>And this is some block HTML<span class="sc2"><<span class="sy0">/</span><a href="http://december.com/html/4/element/p.html"><span class="kw2">p</span></a>></span></pre>
|
||||
<p>
|
||||
PHP example:
|
||||
</p>
|
||||
<pre class="code"><php>
|
||||
echo 'The PHP version: ';
|
||||
echo phpversion();
|
||||
echo ' (generated inline HTML)';
|
||||
</php>
|
||||
<PHP>
|
||||
echo '<table class="inline"><tr><td>The same, but inside a block level element:</td>';
|
||||
echo '<td>'.phpversion().'</td>';
|
||||
echo '</tr></table>';
|
||||
</PHP></pre>
|
||||
|
||||
<p>
|
||||
<code class="code php"><span class="kw1">echo</span> <span class="st_h">'The PHP version: '</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <a href="http://www.php.net/phpversion"><span class="kw3">phpversion</span></a><span class="br0">(</span><span class="br0">)</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <span class="st_h">' (inline HTML)'</span><span class="sy0">;</span></code>
|
||||
</p>
|
||||
<pre class="code php"><span class="kw1">echo</span> <span class="st_h">'<table class="inline"><tr><td>The same, but inside a block level element:</td>'</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <span class="st_h">'<td>'</span><span class="sy0">.</span><a href="http://www.php.net/phpversion"><span class="kw3">phpversion</span></a><span class="br0">(</span><span class="br0">)</span><span class="sy0">.</span><span class="st_h">'</td>'</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <span class="st_h">'</tr></table>'</span><span class="sy0">;</span></pre>
|
||||
<p>
|
||||
<strong>Please Note</strong>: <abbr title="HyperText Markup Language">HTML</abbr> and PHP embedding is disabled by default in the configuration. If disabled, the code is displayed instead of executed.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Embedding HTML and PHP","hid":"embedding_html_and_php","codeblockOffset":9,"secid":30,"range":"19117-20350"} -->
|
||||
<h2 class="sectionedit31" id="rss_atom_feed_aggregation">RSS/ATOM Feed Aggregation</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
<a href="/doku/doku.php?id=wiki:dokuwiki" class="wikilink1" title="wiki:dokuwiki" data-wiki-id="wiki:dokuwiki">DokuWiki</a> can integrate data from external XML feeds. For parsing the XML feeds, <a href="http://simplepie.org/" class="urlextern" title="http://simplepie.org/" rel="ugc nofollow">SimplePie</a> is used. All formats understood by SimplePie can be used in DokuWiki as well. You can influence the rendering by multiple additional space separated parameters:
|
||||
</p>
|
||||
<div class="table sectionedit32"><table class="inline">
|
||||
<thead>
|
||||
<tr class="row0">
|
||||
<th class="col0 leftalign"> Parameter </th><th class="col1"> Description </th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tr class="row1">
|
||||
<td class="col0"> any number </td><td class="col1"> will be used as maximum number items to show, defaults to 8 </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<td class="col0 leftalign"> reverse </td><td class="col1"> display the last items in the feed first </td>
|
||||
</tr>
|
||||
<tr class="row3">
|
||||
<td class="col0 leftalign"> author </td><td class="col1"> show item authors names </td>
|
||||
</tr>
|
||||
<tr class="row4">
|
||||
<td class="col0 leftalign"> date </td><td class="col1"> show item dates </td>
|
||||
</tr>
|
||||
<tr class="row5">
|
||||
<td class="col0"> description</td><td class="col1"> show the item description. If <a href="https://www.dokuwiki.org/config%3Ahtmlok" class="interwiki iw_doku" title="https://www.dokuwiki.org/config%3Ahtmlok">HTML</a> is disabled all tags will be stripped </td>
|
||||
</tr>
|
||||
<tr class="row6">
|
||||
<td class="col0 leftalign"> nosort </td><td class="col1"> do not sort the items in the feed </td>
|
||||
</tr>
|
||||
<tr class="row7">
|
||||
<td class="col0"> <em>n</em>[dhm] </td><td class="col1"> refresh period, where d=days, h=hours, m=minutes. (e.g. 12h = 12 hours). </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table5","secid":32,"range":"20671-21162"} -->
|
||||
<p>
|
||||
The refresh period defaults to 4 hours. Any value below 10 minutes will be treated as 10 minutes. <a href="/doku/doku.php?id=wiki:dokuwiki" class="wikilink1" title="wiki:dokuwiki" data-wiki-id="wiki:dokuwiki">DokuWiki</a> will generally try to supply a cached version of a page, obviously this is inappropriate when the page contains dynamic external content. The parameter tells <a href="/doku/doku.php?id=wiki:dokuwiki" class="wikilink1" title="wiki:dokuwiki" data-wiki-id="wiki:dokuwiki">DokuWiki</a> to re-render the page if it is more than <em>refresh period</em> since the page was last rendered.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
By default the feed will be sorted by date, newest items first. You can sort it by oldest first using the <code>reverse</code> parameter, or display the feed as is with <code>nosort</code>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
<strong>Example:</strong>
|
||||
</p>
|
||||
<pre class="code">{{rss>http://slashdot.org/index.rss 5 author date 1h }}</pre>
|
||||
<ul class="rss"><li><div class="li"><a href="https://news.slashdot.org/story/22/01/12/2234245/scammers-put-fake-qr-codes-on-parking-meters-to-intercept-parkers-payments?utm_source=rss1.0mainlinkanon&utm_medium=feed" class="urlextern" title="https://news.slashdot.org/story/22/01/12/2234245/scammers-put-fake-qr-codes-on-parking-meters-to-intercept-parkers-payments?utm_source=rss1.0mainlinkanon&utm_medium=feed" rel="ugc nofollow">Scammers Put Fake QR Codes On Parking Meters To Intercept Parkers' Payments</a> de BeauHD (2022/01/13 04:30)</div></li><li><div class="li"><a href="https://news.slashdot.org/story/22/01/12/2229203/us-to-hold-largest-ever-offshore-wind-farm-auction-next-month?utm_source=rss1.0mainlinkanon&utm_medium=feed" class="urlextern" title="https://news.slashdot.org/story/22/01/12/2229203/us-to-hold-largest-ever-offshore-wind-farm-auction-next-month?utm_source=rss1.0mainlinkanon&utm_medium=feed" rel="ugc nofollow">US To Hold Largest-Ever Offshore Wind Farm Auction Next Month</a> de BeauHD (2022/01/13 03:02)</div></li><li><div class="li"><a href="https://tech.slashdot.org/story/22/01/12/2225227/germany-raises-prospect-of-shutting-telegram-over-hate-threats?utm_source=rss1.0mainlinkanon&utm_medium=feed" class="urlextern" title="https://tech.slashdot.org/story/22/01/12/2225227/germany-raises-prospect-of-shutting-telegram-over-hate-threats?utm_source=rss1.0mainlinkanon&utm_medium=feed" rel="ugc nofollow">Germany Raises Prospect of Shutting Telegram Over Hate Threats</a> de BeauHD (2022/01/13 02:25)</div></li><li><div class="li"><a href="https://hardware.slashdot.org/story/22/01/12/2222247/taiwan-will-soon-have-more-electric-scooter-battery-swap-stations-than-gas-stations?utm_source=rss1.0mainlinkanon&utm_medium=feed" class="urlextern" title="https://hardware.slashdot.org/story/22/01/12/2222247/taiwan-will-soon-have-more-electric-scooter-battery-swap-stations-than-gas-stations?utm_source=rss1.0mainlinkanon&utm_medium=feed" rel="ugc nofollow">Taiwan Will Soon Have More Electric Scooter Battery Swap Stations Than Gas Stations</a> de BeauHD (2022/01/13 01:57)</div></li><li><div class="li"><a href="https://hardware.slashdot.org/story/22/01/12/2214257/raspberry-pi-can-detect-malware-by-scanning-for-electromagnetic-waves?utm_source=rss1.0mainlinkanon&utm_medium=feed" class="urlextern" title="https://hardware.slashdot.org/story/22/01/12/2214257/raspberry-pi-can-detect-malware-by-scanning-for-electromagnetic-waves?utm_source=rss1.0mainlinkanon&utm_medium=feed" rel="ugc nofollow">Raspberry Pi Can Detect Malware By Scanning For Electromagnetic Waves</a> de BeauHD (2022/01/13 01:45)</div></li></ul>
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"RSS\/ATOM Feed Aggregation","hid":"rss_atom_feed_aggregation","codeblockOffset":11,"secid":31,"range":"20351-21854"} -->
|
||||
<h2 class="sectionedit33" id="control_macros">Control Macros</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
Some syntax influences how DokuWiki renders a page without creating any output it self. The following control macros are availble:
|
||||
</p>
|
||||
<div class="table sectionedit34"><table class="inline">
|
||||
<thead>
|
||||
<tr class="row0">
|
||||
<th class="col0 leftalign"> Macro </th><th class="col1"> Description </th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tr class="row1">
|
||||
<td class="col0 leftalign"> ~~NOTOC~~ </td><td class="col1"> If this macro is found on the page, no table of contents will be created </td>
|
||||
</tr>
|
||||
<tr class="row2">
|
||||
<td class="col0"> ~~NOCACHE~~ </td><td class="col1"> DokuWiki caches all output by default. Sometimes this might not be wanted (eg. when the <php> syntax above is used), adding this macro will force DokuWiki to rerender a page on every call </td>
|
||||
</tr>
|
||||
</table></div>
|
||||
<!-- EDIT{"target":"table","name":"","hid":"table6","secid":34,"range":"22015-22357"} -->
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Control Macros","hid":"control_macros","codeblockOffset":11,"secid":33,"range":"21855-22358"} -->
|
||||
<h2 class="sectionedit35" id="syntax_plugins">Syntax Plugins</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
DokuWiki's syntax can be extended by <a href="https://www.dokuwiki.org/plugins" class="interwiki iw_doku" title="https://www.dokuwiki.org/plugins">Plugins</a>. How the installed plugins are used is described on their appropriate description pages. The following syntax plugins are available in this particular DokuWiki installation:
|
||||
</p>
|
||||
<ul><li><div class="li"><a href="http://dokuwiki.org/plugin:info" class="urlextern" title="http://dokuwiki.org/plugin:info" rel="ugc nofollow">Info Plugin</a> <em>2020-06-04</em> de <a href="mailto:andi@splitbrain.org" class="mail" title="andi@splitbrain.org">Andreas Gohr</a><br />Displays information about various DokuWiki internals</div></li></ul>
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Syntax Plugins","hid":"syntax_plugins","codeblockOffset":11,"secid":35,"range":"22359-"} --><div class="footnotes">
|
||||
<div class="fn"><sup><a href="#fnt__1" id="fn__1" class="fn_bot">1)</a></sup>
|
||||
<div class="content">This is a footnote</div></div>
|
||||
<div class="fn"><sup><a href="#fnt__2" id="fn__2" class="fn_bot">2)</a></sup>
|
||||
<div class="content">when the aspect ratio of the given width and height doesn't match that of the image, it will be cropped to the new ratio before resizing</div></div>
|
||||
</div>
|
1
ap23/web/doku/data/cache/9/90a2ba64915062a5e0695a2488ed27c3.js
vendored
Normal file
1
ap23/web/doku/data/cache/9/90a2ba64915062a5e0695a2488ed27c3.js
vendored
Normal file
File diff suppressed because one or more lines are too long
BIN
ap23/web/doku/data/cache/9/90a2ba64915062a5e0695a2488ed27c3.js.gz
vendored
Normal file
BIN
ap23/web/doku/data/cache/9/90a2ba64915062a5e0695a2488ed27c3.js.gz
vendored
Normal file
Binary file not shown.
BIN
ap23/web/doku/data/cache/9/971959c86e9eb592b52429de7f63393b.media.200x50.png
vendored
Normal file
BIN
ap23/web/doku/data/cache/9/971959c86e9eb592b52429de7f63393b.media.200x50.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 15 KiB |
1
ap23/web/doku/data/cache/_dummy
vendored
Normal file
1
ap23/web/doku/data/cache/_dummy
vendored
Normal file
@ -0,0 +1 @@
|
||||
You can safely delete this file.
|
1
ap23/web/doku/data/cache/a/a5125c2035a7b6ffff11998ec30181ec.i
vendored
Normal file
1
ap23/web/doku/data/cache/a/a5125c2035a7b6ffff11998ec30181ec.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:9:"Connexion";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:156:"Vous n'êtes pas connecté ! Entrez vos identifiants ci-dessous pour vous connecter. Votre navigateur doit accepter les cookies pour pouvoir vous connecter.";}i:2;i:26;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:182;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:183;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:183;}}
|
9
ap23/web/doku/data/cache/a/a5125c2035a7b6ffff11998ec30181ec.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/a/a5125c2035a7b6ffff11998ec30181ec.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="connexion">Connexion</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Vous n'êtes pas connecté ! Entrez vos identifiants ci-dessous pour vous connecter. Votre navigateur doit accepter les cookies pour pouvoir vous connecter.
|
||||
</p>
|
||||
|
||||
</div>
|
1
ap23/web/doku/data/cache/a/a57cce7e119d40799fb2ecb4b3caab13.i
vendored
Normal file
1
ap23/web/doku/data/cache/a/a57cce7e119d40799fb2ecb4b3caab13.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:8:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:31:"Envoyer un nouveau mot de passe";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:219:"Veuillez compléter les champs ci-dessous pour obtenir un nouveau mot de passe pour votre compte dans ce wiki. Un lien de confirmation vous sera expédié à l'adresse de courriel utilisée lors de votre enregistrement.";}i:2;i:48;}i:5;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:267;}i:6;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:268;}i:7;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:268;}}
|
9
ap23/web/doku/data/cache/a/a57cce7e119d40799fb2ecb4b3caab13.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/a/a57cce7e119d40799fb2ecb4b3caab13.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="envoyer_un_nouveau_mot_de_passe">Envoyer un nouveau mot de passe</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Veuillez compléter les champs ci-dessous pour obtenir un nouveau mot de passe pour votre compte dans ce wiki. Un lien de confirmation vous sera expédié à l'adresse de courriel utilisée lors de votre enregistrement.
|
||||
</p>
|
||||
|
||||
</div>
|
0
ap23/web/doku/data/cache/autosubmit.txt
vendored
Normal file
0
ap23/web/doku/data/cache/autosubmit.txt
vendored
Normal file
2
ap23/web/doku/data/cache/c/c42432c368af21787d8084605705213c.i
vendored
Normal file
2
ap23/web/doku/data/cache/c/c42432c368af21787d8084605705213c.i
vendored
Normal file
File diff suppressed because one or more lines are too long
1
ap23/web/doku/data/cache/c/c42432c368af21787d8084605705213c.metadata
vendored
Normal file
1
ap23/web/doku/data/cache/c/c42432c368af21787d8084605705213c.metadata
vendored
Normal file
@ -0,0 +1 @@
|
||||
1642067122
|
67
ap23/web/doku/data/cache/c/c42432c368af21787d8084605705213c.xhtml
vendored
Normal file
67
ap23/web/doku/data/cache/c/c42432c368af21787d8084605705213c.xhtml
vendored
Normal file
@ -0,0 +1,67 @@
|
||||
|
||||
<h1 class="sectionedit1" id="welcome_to_your_new_dokuwiki">Welcome to your new DokuWiki</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Congratulations, your wiki is now up and running. Here are a few more tips to get you started.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Enjoy your work with DokuWiki,<br/>
|
||||
|
||||
– the developers
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Welcome to your new DokuWiki","hid":"welcome_to_your_new_dokuwiki","codeblockOffset":0,"secid":1,"range":"1-192"} -->
|
||||
<h2 class="sectionedit2" id="create_your_first_pages">Create your first pages</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
Your wiki needs to have a start page. As long as it doesn't exist, this link will be red: <a href="/doku/doku.php?id=start" class="wikilink1" title="start" data-wiki-id="start">start</a>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Go on, follow that link and create the page. If you need help with using the syntax you can always refer to the <a href="/doku/doku.php?id=wiki:syntax" class="wikilink1" title="wiki:syntax" data-wiki-id="wiki:syntax">syntax page</a>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
You might also want to use a sidebar. To create it, just edit the <a href="/doku/doku.php?id=sidebar" class="wikilink2" title="sidebar" rel="nofollow" data-wiki-id="sidebar">sidebar</a> page. Everything in that page will be shown in a margin column on the side. Read our <a href="https://www.dokuwiki.org/faq%3Asidebar" class="interwiki iw_doku" title="https://www.dokuwiki.org/faq%3Asidebar">FAQ on sidebars</a> to learn more.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Please be aware that not all templates support sidebars.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Create your first pages","hid":"create_your_first_pages","codeblockOffset":0,"secid":2,"range":"193-749"} -->
|
||||
<h2 class="sectionedit3" id="customize_your_wiki">Customize your Wiki</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
Once you're comfortable with creating and editing pages you might want to have a look at the <a href="http://ap23/doku/doku.php?do=admin&page=config" class="interwiki iw_this" title="http://ap23/doku/doku.php?do=admin&page=config">configuration settings</a> (be sure to login as superuser first).
|
||||
</p>
|
||||
|
||||
<p>
|
||||
You may also want to see what <a href="https://www.dokuwiki.org/plugins" class="interwiki iw_doku" title="https://www.dokuwiki.org/plugins">plugins</a> and <a href="https://www.dokuwiki.org/templates" class="interwiki iw_doku" title="https://www.dokuwiki.org/templates">templates</a> are available at DokuWiki.org to extend the functionality and looks of your DokuWiki installation.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Customize your Wiki","hid":"customize_your_wiki","codeblockOffset":0,"secid":3,"range":"750-1165"} -->
|
||||
<h2 class="sectionedit4" id="join_the_community">Join the Community</h2>
|
||||
<div class="level2">
|
||||
|
||||
<p>
|
||||
DokuWiki is an Open Source project that thrives through user contributions. A good way to stay informed on what's going on and to get useful tips in using DokuWiki is subscribing to the <a href="https://www.dokuwiki.org/newsletter" class="interwiki iw_doku" title="https://www.dokuwiki.org/newsletter">newsletter</a>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
The <a href="https://forum.dokuwiki.org" class="urlextern" title="https://forum.dokuwiki.org" rel="ugc nofollow">DokuWiki User Forum</a> is an excellent way to get in contact with other DokuWiki users and is just one of the many ways to get <a href="https://www.dokuwiki.org/faq%3Asupport" class="interwiki iw_doku" title="https://www.dokuwiki.org/faq%3Asupport">support</a>.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
Of course we'd be more than happy to have you <a href="https://www.dokuwiki.org/teams%3Agetting_involved" class="interwiki iw_doku" title="https://www.dokuwiki.org/teams%3Agetting_involved">getting involved</a> with DokuWiki.
|
||||
</p>
|
||||
|
||||
</div>
|
||||
<!-- EDIT{"target":"section","name":"Join the Community","hid":"join_the_community","codeblockOffset":0,"secid":4,"range":"1166-"} -->
|
3
ap23/web/doku/data/cache/c/c768e64cf6b3cd83f316600743dc59b8.code
vendored
Normal file
3
ap23/web/doku/data/cache/c/c768e64cf6b3cd83f316600743dc59b8.code
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<span class="kw1">echo</span> <span class="st_h">'<table class="inline"><tr><td>The same, but inside a block level element:</td>'</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <span class="st_h">'<td>'</span><span class="sy0">.</span><a href="http://www.php.net/phpversion"><span class="kw3">phpversion</span></a><span class="br0">(</span><span class="br0">)</span><span class="sy0">.</span><span class="st_h">'</td>'</span><span class="sy0">;</span>
|
||||
<span class="kw1">echo</span> <span class="st_h">'</tr></table>'</span><span class="sy0">;</span>
|
1
ap23/web/doku/data/cache/c/ca51ac4fe3cc3ef2a8352aa03d0d0519.css
vendored
Normal file
1
ap23/web/doku/data/cache/c/ca51ac4fe3cc3ef2a8352aa03d0d0519.css
vendored
Normal file
File diff suppressed because one or more lines are too long
BIN
ap23/web/doku/data/cache/c/ca51ac4fe3cc3ef2a8352aa03d0d0519.css.gz
vendored
Normal file
BIN
ap23/web/doku/data/cache/c/ca51ac4fe3cc3ef2a8352aa03d0d0519.css.gz
vendored
Normal file
Binary file not shown.
1
ap23/web/doku/data/cache/c/cb68741488368edf01be033a7c681628.code
vendored
Normal file
1
ap23/web/doku/data/cache/c/cb68741488368edf01be033a7c681628.code
vendored
Normal file
@ -0,0 +1 @@
|
||||
<span class="kw2"><?php</span> <span class="kw1">echo</span> <span class="st0">"hello world!"</span><span class="sy0">;</span> <span class="sy1">?></span>
|
16
ap23/web/doku/data/cache/d/d223e1439188e478349d52476506c22e.js
vendored
Normal file
16
ap23/web/doku/data/cache/d/d223e1439188e478349d52476506c22e.js
vendored
Normal file
File diff suppressed because one or more lines are too long
BIN
ap23/web/doku/data/cache/d/d223e1439188e478349d52476506c22e.js.gz
vendored
Normal file
BIN
ap23/web/doku/data/cache/d/d223e1439188e478349d52476506c22e.js.gz
vendored
Normal file
Binary file not shown.
0
ap23/web/doku/data/cache/d/df10cbe878cdbaf697704a7e04354267.updmsg
vendored
Normal file
0
ap23/web/doku/data/cache/d/df10cbe878cdbaf697704a7e04354267.updmsg
vendored
Normal file
1
ap23/web/doku/data/cache/e/e2dcffe9cef137dbb8712c206589404c.js
vendored
Normal file
1
ap23/web/doku/data/cache/e/e2dcffe9cef137dbb8712c206589404c.js
vendored
Normal file
File diff suppressed because one or more lines are too long
BIN
ap23/web/doku/data/cache/e/e2dcffe9cef137dbb8712c206589404c.js.gz
vendored
Normal file
BIN
ap23/web/doku/data/cache/e/e2dcffe9cef137dbb8712c206589404c.js.gz
vendored
Normal file
Binary file not shown.
1
ap23/web/doku/data/cache/f/f551a13bee4201d11e2c43b6300340fb.pwauth
vendored
Normal file
1
ap23/web/doku/data/cache/f/f551a13bee4201d11e2c43b6300340fb.pwauth
vendored
Normal file
@ -0,0 +1 @@
|
||||
superadmin
|
1
ap23/web/doku/data/cache/f/fa1b0d8de3e6de0ed6ca248949d6bbfa.i
vendored
Normal file
1
ap23/web/doku/data/cache/f/fa1b0d8de3e6de0ed6ca248949d6bbfa.i
vendored
Normal file
@ -0,0 +1 @@
|
||||
a:10:{i:0;a:3:{i:0;s:14:"document_start";i:1;a:0:{}i:2;i:0;}i:1;a:3:{i:0;s:6:"header";i:1;a:3:{i:0;s:12:"Plan du site";i:1;i:1;i:2;i:1;}i:2;i:1;}i:2;a:3:{i:0;s:12:"section_open";i:1;a:1:{i:0;i:1;}i:2;i:1;}i:3;a:3:{i:0;s:6:"p_open";i:1;a:0:{}i:2;i:1;}i:4;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:67:"Voici un plan du site de toutes les pages disponibles, triées par ";}i:2;i:29;}i:5;a:3:{i:0;s:13:"interwikilink";i:1;a:4:{i:0;s:18:"doku>fr:namespaces";i:1;s:11:"catégories";i:2;s:4:"doku";i:3;s:13:"fr:namespaces";}i:2;i:96;}i:6;a:3:{i:0;s:5:"cdata";i:1;a:1:{i:0;s:1:".";}i:2;i:130;}i:7;a:3:{i:0;s:7:"p_close";i:1;a:0:{}i:2;i:131;}i:8;a:3:{i:0;s:13:"section_close";i:1;a:0:{}i:2;i:132;}i:9;a:3:{i:0;s:12:"document_end";i:1;a:0:{}i:2;i:132;}}
|
9
ap23/web/doku/data/cache/f/fa1b0d8de3e6de0ed6ca248949d6bbfa.xhtml
vendored
Normal file
9
ap23/web/doku/data/cache/f/fa1b0d8de3e6de0ed6ca248949d6bbfa.xhtml
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
<h1 class="sectionedit1" id="plan_du_site">Plan du site</h1>
|
||||
<div class="level1">
|
||||
|
||||
<p>
|
||||
Voici un plan du site de toutes les pages disponibles, triées par <a href="https://www.dokuwiki.org/fr%3Anamespaces" class="interwiki iw_doku" title="https://www.dokuwiki.org/fr%3Anamespaces">catégories</a>.
|
||||
</p>
|
||||
|
||||
</div>
|
1
ap23/web/doku/data/cache/purgefile
vendored
Normal file
1
ap23/web/doku/data/cache/purgefile
vendored
Normal file
@ -0,0 +1 @@
|
||||
1643875683
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user