Mediawiki
Enlaces y referencias
Configuración
Aspectos
Imágenes
Las imágenes en el wiki precisan de:
- Un directorio con permisos de escritura
- Acceso al programa de conversión de imágenes
- Un modelo de almacenamiento definido antes de subir la primera imagen.
## Indicadores activos para emplear imágenes en el wiki (incluyendo subir mediante un URL)
$wgEnableUploads = true;
$wgUseImageMagick = true;
$wgImageMagickConvertCommand = "/usr/bin/convert";
$wgAllowCopyUploads = true;
$wgShowExceptionDetails = true;
##
## Parámetros de almacenamiento y acceso a las imágenes
$wgUploadDirectory = "/var/lib/mediawiki/images";
$wgUploadPath = "/w/images";
##
## Almacenar las imágenes linealmente y no dentro de un
## árbol de subdirectorios
$wgHashedUploadDirectory = false;
Logotipo y favicon
Una vez obtenida una imagen para utilizar como logotipo derivamos de ella un favicon y la subimos al directorio de imágenes y anotamos en la configuración cuál utilizar:
$wgLogo = "{$wgUploadPath}/astillas-logo-120.jpg";
$wgFavicon = "{$wgUploadPath}/favicon.ico";
Ajustes concretos de configuración
Derechos de acceso
Ref: Mediawiki: preventing access
Existen varios parámetros que se pueden definir en la configuración local (LocalSettings.php) y que marcan las líneas generales de funcionamiento del wiki:
# Creación de usuarios sólo a administradores
$wgGroupPermissions['sysop']['createaccount'] = true;
# Permite la edición sólo a usuarios registrados
$wgGroupPermissions['*']['edit'] = false;
$wgGroupPermissions['user']['edit'] = true;
Para ello es necesario editar la página MediaWiki:Sidebar y cambiar allí el orden o el contenido mostrado. Éste consiste en una lista de elementos un poco especiales porque aparece un destino y un texto a mostrar separados por una barra vertical (|). El destino puede ser una página del wiki o un URL completo.
Ejemplo:
* navigation
** mainpage|mainpage
** recentchanges-url|recentchanges
** randompage-url|randompage
** sandbox|Zona de pruebas
Acortando URL
- Acortando direcciones en mediawiki (especialmente eliminando la expresión index.php del URL).]
Cuando se pretende que los URL del wiki sean lo más limpio posible tenemos que tocar en varios sitios en la configuración, dependiendo de si tenemos o no acceso como root a la instalación del wiki.
En mi caso he tomado la decisión de usar la forma estándar de URL que se emplea en la Wikipedia como
http://example.com/wiki/Page_title
porque me permite disponer de un espacio de nombres libres en la raíz del servidor
http://example.com/debian http://example.com/webdav http://example.com/cgi-bin/tool.pl http://example.com/victor
para poder emplearlos con otras aplicaciones o páginas especiales.
Según la documentación los pasos a seguir son los siguientes:
- Asegurarse de que el directorio de Mediawiki no está directamente bajo el árbol de archivos del servidor web para no mezclar páginas del wiki y otros contenidos. En Debian se instala bajo
/var/lib/mediawiki
por lo que esta precaución ya está tomada. En mi caso, además, suelo añadir un enlace simbólico de dicho directorio a/var/www/w
de manera que toda la instalación (como los temas) queda al alcance de una única ruta. - Modificar la configuración del wiki en el archivo
LocalSettings.php
para que refleje las rutas de los programas (/w/index.php) y los artículos (/wiki/Page_title). - Cambiar la configuración del servidor web para apuntar a estas nuevas rutas.
- Reiniciar el servidor web
- Probar el acceso a través de http://localhost/wiki
El archivo LocalSettings.php queda así:
$wgScriptPath = "/w"; $wgScript = "$wgScriptPath/index.php"; $wgArticlePath = "/wiki/$1";
mientras que la configuración de Apache queda de esta forma:
Alias /wiki /var/lib/mediawiki/index.php <Directory /var/lib/mediawiki/> Options +FollowSymLinks AllowOverride All order allow,deny allow from all </Directory>
Subpáginas
Además de tener un nombre más largo ya que la jerarquía de páginas se separa con una barra inclinada como en
http://astillas.net/wiki/SandoBox/Tipografia/varios
en cada página se añade automáticamente, al principio de la misma, enlaces hacia las páginas superiores de las que descienden.
Un detalle a tener en cuenta es que el nombre de la subpágina no admite las mismas mejoras estéticas que los nombres de página. Estos, en mediawiki, se normalizan automágicamente cambiando a mayúscula la primera letra de los mismos. En las subpáginas no sucede así por lo que Hardware/impresoras
es diferente de Hardware/Impresoras
.
Wikis múltiples
Dada la extensión del tema he abierto una página nueva para describir la configuración de múltiples wikis en un mismo servidor.
Derechos de acceso
Existen varios parámetros que se pueden definir en la configuración local (LocalSettings.php
) y que marcan las líneas generales de funcionamiento del wiki:
# Creación de usuarios sólo a administradores $wgGroupPermissions['sysop']['createaccount'] = true; # Permite la edición sólo a usuarios registrados $wgGroupPermissions['*']['edit'] = false; $wgGroupPermissions['user']['edit'] = true;
Para ello es necesario editar la página MediaWiki:Sidebar y cambiar allí el orden o el contenido mostrado. Éste consiste en una lista de elementos un poco especiales porque aparece un destino y un texto a mostrar separados por una barra vertical (|
). El destino puede ser una página del wiki o un URL completo.
Ejemplo:
* navigation ** mainpage|mainpage ** recentchanges-url|recentchanges ** randompage-url|randompage ** sandbox|Zona de pruebas
Enlaces entre wikis
Existe un tipo de enlace especial que permite crear direcciones de otros wikis sin necesidad de conocerlas al completo.
Por ejemplo se puede crear un enlace de éste tipo
[[:wp:Agujero Analógico|esto es obligatorio de leer]]
y el programa mediawiki lo convierte a
[http://es.wikipedia.org/wiki/Agujero_Analógico esto es obligatorio de leer]
en el producto final de la página.
El programa emplea una tabla de su base de datos llamada interwiki para conservar una correlacción entre prefijos (como wp) y direcciones web (como http://es.wikipedia.org/wiki/). Alterarla implica tener acceso a bajo nivel al servidor de datos e insertar un registro en dicha tabla o cambiar el contenido de otra puesto que el entorno mediawiki suele incluir una larga lista de ellos.
La estructura de la tabla de enlaces entre wikis tiene una descripción propia aunque existe una extensión preparada para mantener más cómodamente este mapa de correspondencias.
Otra característica de estos enlaces es que para ellos no existe la comprobación habitual de página existente o nueva, por lo que siempre aparecen como enlaces externos (en color azul generalmente).
Si se tiene acceso directo al servidor MySQL se pueden insertar directamente valores en la tabla apropiada:
$ mysql ... Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 181 Server version: 5.0.51a-24+lenny5 (Debian) Type 'help;' or '\h' for help. Type '\c' to clear the buffer. mysql> insert into interwiki set iw_prefix='wp', iw_url='http://es.wikipedia.org/wiki/$1'; Query OK, 1 row affected, 1 warning (0.00 sec) mysql>
Validación de contenidos
- Ref: Mediawiki - Configuring file uploads
- Ref: Mediawiki - MIME type detection
El proceso de aceptación de contenidos en Mediawiki consta de dos fases: la primera consiste en detectar qué se ha subido y la segunda en comprobar si lo detectado, el tipo MIME, coincide con su nomenclatura
Detección MIME
Mediawiki emplea el módulo PHP FileInfo o el antiguo MimeMagic para obtener el tipo MIME del contenido. Como última opción se utilizará la detección que proporciona el módulo PHP GD, que sólo sirve para un grupo pequeño de imágenes.
También se puede usar un programa externo, indicando cómo llamarlo dentro de la variable $wgMimeDetectorCommand
, lo que permite efectuar pruebas sobre lo que va a reconocer Mediawiki -evitando falsos positivios- sin tocar módulos PHP ni activando la depuración.
Si se desea desactivar completamente la detección de contenido se usa lo siguiente en la configuración
$wgVerifyMimeType = false;
Validación MIME
Para emparejar la extensión del nombre del archivo con su tipo MIME Mediawiki emplea un archivo llamado mime.types
cuya estructura es la de un archivo de texto plano con un registro por línea. Este registro contiene campos separados por espacios en blanco: el primero es el tipo formal MIME y los siguientes son las extensiones admisibles de archivos para el tipo dado.
Ejemplo tomado del archivo real:
... application/x-xpinstall xpi application/xhtml+xml xhtml xht application/xslt+xml xslt application/xml xml xsl xsd application/xml-dtd dtd application/zip zip jar xpi sxc stc sxd std sxi sti sxm stm sxw stw application/x-rar rar ...
Una vez que el emparejamiento funciona se procede a comprobar si la extensión es una de las admitidas consultando varias variables:
Variable | Valor | Descripción |
---|---|---|
$wgStrictFileExtensions
|
true | Si está activa indica que no se admita ninguna extensión que no figure en $wgFileExtensions |
$wgFileExtensions
|
Ver manual | Lista de extensiones de archivos que son admisibles vía subida de archivos o simplemente lista de aquellas extensiones preferentes. Depende de la variable $wgStrictFileExtensions. |
$wgCheckFileExtensions
|
true | Activa o no la comprobación de extensiones de archivos en la subida al wiki. |
$wgFileBlackList
|
Ver detalles | Lista de extensiones de archivos que nunca se permite subir al wiki. |
$wgVerifyMimeType
|
true | Activa o no la comprobación de tipos MIME (por contenido) en la subidad de archivos al wiki. |
Alias y clasificación MIME
Mediawiki emplea un mecanismo para clasificar los contenidos según su tipo MIME. Para ello consulta una lista guardada en el archivo mime.info
en la que relaciona, línea por línea, uno o varios tipos MIME con una etiqueta clasificatoria que luego guarda -junto con el tipo MIME resultante- en la tabla de imágenes de la base de datos que contiene el wiki.
Algunos ejemplos son:
image/png image/x-png [BITMAP] image/svg image/svg+xml application/svg+xml application/svg [DRAWING] audio/mp3 audio/mpeg3 audio/mpeg [AUDIO]
Por el momento no tiene utilidad concreta pero se espera que en el futuro sirva para mejorar la presentación de medios.
Configuración para validaciones MIME
Existen algunas variables que definen los recursos de validación:
Variable | Valor | Descripción |
---|---|---|
$wgMimeTypeFile
|
"includes/mime.types" | Contiene la ruta del archivo con la asociación de tipos MIME y extensiones. |
$wgMimeInfoFile
|
"includes/mime.info" | Contiene la ruta del archivo que contiene los alias y las clasificaciones de los tipos MIME. |
$wgMimeDetectorCommand
|
Define la llamada a un programa externo para detectar contenidos. El programa debe enviar únicamente el tipo MIME resultante a su salida estándar. Recibirá como parámetro final el nombre del archivo a comprobar.
Como ejemplo se puede usar $wgMimeDetectorCommand = "file --brief --mime"; |
Crear un usuario
Para poder crear usuarios en Mediawiki se necesita primero que el wiki esté configurado para que alguien tenga permisos suficientes para crear cuentas. En el siguiente ejemplo asignamos estos privilegios a aquellos usuarios del grupo sysop (WikiSysop por ejemplo) pero lo negamos a cualquier otro por lo que en la pantalla de entrada de usuarios no aparecerá el correspondiente enlace para hacerlo.
# Archivo /etc/mediawiki/LocalSettings.php ... $wgGroupPermissions['*']['createaccount'] = false; $wgGroupPermissions['sysop']['createaccount'] = true; ...
Y segundo se debe acceder al lugar adecuado que es la página especial Special:UserLogin
. En este caso necesitamos estar ya registrados con una cuenta privilegiada y podemos ir directamente con una URL tipo http://URL_DEL_WIKI/Special:UserLogin o escribir
Special:UserLogin
en la caja de búsqueda y seleccionar Ir (y no Buscar).
Es entonces cuando aparece la siguiente pantalla:
Palabras mágicas
Se denominan así a todas aquellas que hacen algo diferente cuando Mediawiki muestra la página, bien sea ejecutar código, bien sea mostrar otra página u otro valor.
Existen varios tipos:
- Conmutadores de funcionamiento como __TOC__.
- Pares de etiquetas con estilo XML como <nowiki>.
- Una variable como {{CURRENTDAY}}.
Conmutadores de funcionamiento
Sólo incluyo aquellas que he empleado y quiero tener como referencia.
Palabra | Descripción |
---|---|
__TOC__ | Fuerza la aparición de la tabla de contenidos en ese punto. |
__NOTOC__ | Oculta la tabla de contenidos de la página. |
__NOEDITSECTION__ | Oculta los enlaces de edición de sección que aparece junto a los encabezados. |
Etiquetas especiales
Las etiquetas deben incluirse al estilo XML y el contenido es el texto que encierran.
<etiqueta>Contenido</etiqueta>
Etiqueta | Funcionamiento |
---|---|
nowiki | Inserta su contenido literalmente, sin interpretar ningún carácter ni palabra especial. |
Variables
Todas las variables se escriben entre dos pares de llaves como en
{{CURRENTYEAR}}
Nombre | Contenido |
---|---|
CURRENTYEAR | Año en curso (2022)) |
CURRENTMONTH | Número de mes actual (06) |
CURRENTDAY | Número de día según el mes (6) |
CURRENTTIME | Hora y minutos (15:16) |
---- | |
SITENAME | Nombre del wiki (Astillas.net) |
SERVER | URL del dominio (https://astillas.net) |
SERVERNAME | Nombre del servidor (astillas.net) |
PAGENAME | Título de la página (Mediawiki) |
FULLPAGENAME | Espacio de nombre y título de la página (Mediawiki) |
---- | |
NUMBEROFPAGES | Número de páginas totales incluyendo imágenes y plantillas (482). |
NUMBEROFARTICLES | Número de artículos (205) |
---- | |
CURRENTVERSION | Versión del software Mediawiki (1.31.16) |