Code

- Forgot to include modified helpviewer ;-(
[gosa.git] / doc / guide / admin / es / manual_gosa_es_apache.tex
1 \chapter{Apache y PHP}\r
2 \section{Introducción a Apache}\r
3 \r
4 GOsa es una aplicación escrita en el lenguaje de programación PHP y pensada para uso a través de páginas web.\r
5 \r
6 Aunque todo el mundo conoce lo que es una página web, no viene de menos repasar algunos puntos:\r
7 \r
8 \begin{description}\r
9 \item[WWW]\r
10 La World Wide Web (Red alrededor del mundo) es el motor de lo que conocemos como internet, es un espacio de información donde cada recurso está identificado por su URI (Identificador de Recurso Universal /  Universal Resource Identifier), este define el protocolo necesario para acceder a la información, el equipo que la posee y donde está colocada.\r
11 \r
12 La WWW es la gran revolución de nuestra época, es una fuente enorme de información. Y como tal todas las aplicaciones están siendo orientadas a ella. GOsa usa WWW por una sencilla razón, distribuye el programa, una aplicación orientada a internet es capaz de ser usada desde cualquier lugar y prácticamente en cualquier momento. GOsa no necesita estar siendo ejecutado en la misma máquina que lo tiene, mas \r
13 aun cada uno de los servidores que controla pueden estar en máquinas diferentes y en remotos lugares.\r
14 \r
15 \item[HTTP]\r
16 \htmladdnormallink{HTTP}{http://www.w3.org/Protocols/}\cite{2616} es el acrónimo de Protocolo de Transferencia de Texto / HyperText Transfer Protocol, cuyo propósito mas importante es la publicación y recepción de "páginas Web".\r
17 \r
18 Es un protocolo de nivel de aplicación ideado para sistemas distribuidos de información hipermedia. Ha estado siendo usada para la WWW desde 1990, la versión actual es HTTP/1.1.\r
19 \r
20 El funcionamiento práctico se puede reducir a un cliente que realiza una petición y a un servidor que gestiona esa petición y realiza una respuesta.\r
21 \r
22 \item[HTML]\r
23 Si la petición del cliente y la respuesta del servidor son correctas, la respuesta del servidor contendrá algún tipo de hipermedia, el mas habitual es \htmladdnormallink{HTML}{http://www.w3.org/TR/1998/REC-html40-19980424/} (Lenguaje de marcas de hipertexto /  HyperText Markup Language), un lenguaje pensado para la publicación con contenidos y para una fácil navegación por ellos. Es un protocolo en constante desarrollo, la versión actual es HTML4.01 y en publicación XHTML2.0\r
24 \end{description}\r
25 \r
26 \htmladdnormallink{APACHE}{http://httpd.apache.org/} es el servidor HTTP mas utilizado que \htmladdnormallink{ existe }{http://news.netcraft.com/archives/web_server_survey.html}, seguro, eficiente y extensible.\r
27 \r
28 En este manual nos centraremos en este servidor, ya que es el mas usado y tiene una licencia calificada de opensource.\r
29 \r
30 Mas información sobre este servidor en \htmladdnormallink{http://httpd.apache.org/docs-2.0/}{http://httpd.apache.org/docs-2.0/}\r
31  \r
32 \section{Introducción a PHP}\r
33 \r
34 PHP (PHP: Hypertext Preprocessor), es un lenguaje de interpretado alto nivel, especialmente pensado para el diseño de páginas webs. Su sintaxis es una mezcla de C, Perl y Java. Es embebido en las páginas HTML y es ejecutado por el servidor HTTP.\r
35 \r
36 PHP está ampliamente extendido y tiene un numeroso grupo de desarrolladores, una \htmladdnormallink{ extensa documentación }{http://www.php.net/docs.php} y numerosos sitios webs con documentación y ejemplos.\r
37 \r
38 \newpage\r
39 \r
40 \section{Instalación }\r
41 \subsection{Descargando e Instalando Apache}\r
42 \label{down_apache}\r
43 Al igual que en el capítulo anterior, Apache está en prácticamente todas las distribuciones, aunque veremos su instalación desde las fuentes. Nos vamos a centrar por ahora en las versiones mas avanzadas de apache, la serie 2.0.XX considerada estable.\r
44 \r
45 Se recomienda instalar los mismos paquetes que se necesitan para openLDAP\ref{down_ldap}.\r
46 \r
47 Se puede descargar de: \htmladdnormallink{http://httpd.apache.org/download.cgi}{http://httpd.apache.org/download.cgi}, la versión que vamos a descargar en /usr/src es la httpd-2.0.XX.tar.gz\r
48 \r
49 Ejecutamos \htmladdnormallink{./configure}{http://warping.sourceforge.net/gosa/contrib/es/configure-apache.sh} con las siguientes opciones.\r
50 \r
51 \begin{itemize}\r
52 \item[]Generales\\\r
53 \begin{tabular}{|ll|}\hline \r
54 --enable-so & $\rightarrow$ Soporte de Objetos Dinámicos Compartidos (DSO)\\\r
55 --with-program-name=apache2 & \\\r
56 --with-dbm=db42 & $\rightarrow$ Versión de la Berkeley DB que vamos a usar\\\r
57 --with-external-pcre=/usr & \\\r
58 --enable-logio & $\rightarrow$ Registro de entrada y salida\\\r
59 --with-ldap=yes & \\\r
60 --with-ldap-include=/usr/include & \\\r
61 --with-ldap-lib=/usr/lib & \\\r
62 \hline \end{tabular}\r
63  \r
64 \item[]Soporte suexec\\\r
65 \begin{tabular}{|ll|}\hline\r
66 --with-suexec-caller=www-data & \\\r
67 --with-suexec-bin=/usr/lib/apache2/suexec2 & \\\r
68 --with-suexec-docroot=/var/www & \\\r
69 --with-suexec-userdir=public\_html & \\\r
70 --with-suexec-logfile=/var/log/apache2/suexec.log & \\\r
71 \hline \end{tabular}\r
72 \r
73 \item[]\r
74 \begin{longtable}{|ll|}\r
75 \hline\r
76 \multicolumn{2}{|c|}{\textbf{Módulos}}\\\r
77 \hline\r
78 \endfirsthead\r
79 \hline\r
80 \endhead\r
81 \hline\r
82 \multicolumn{2}{|c|}{Continue $\ldots$}\\\r
83 \hline\r
84 \endfoot\r
85 \hline\r
86 \multicolumn{2}{|c|}{\textbf{End}}\\\r
87 \hline\r
88 \endlastfoot\r
89 --enable-userdir=shared & $\rightarrow$ mod\_userdir, módulo para directorios de usuario\\\r
90 --enable-ssl=shared & $\rightarrow$ mod\_ssl, módulo de conectividad segura SSL\\\r
91 --enable-deflate=shared & $\rightarrow$ mod\_deflate, módulo para comprimir la información enviada\\\r
92 --enable-ldap=shared & $\rightarrow$ mod\_ldap\_userdir, módulo para caché y conexiones ldap\\\r
93 --enable-auth-ldap=shared & $\rightarrow$ mod\_ldap, módulo de autentificación en ldap\\\r
94 --enable-speling=shared & $\rightarrow$ mod\_speling, módulo para la corrección de fallos en URL\\\r
95 --enable-include=shared & $\rightarrow$ mod\_include, módulo para la inclusión de otras configuraciones\\\r
96 --enable-rewrite=shared & $\rightarrow$ mod\_rewrite, permite la manipulación de URL\\\r
97 --enable-cgid=shared & $\rightarrow$ CGI script\\\r
98 --enable-vhost-alias=shared & $\rightarrow$ módulo de alias de dominios virtuales\\\r
99 --enable-info=shared & $\rightarrow$ Información del servidor\\\r
100 --enable-suexec=shared & $\rightarrow$ Cambia el usuario y el grupo de los procesos\\\r
101 --enable-unique-id=shared & $\rightarrow$ Identificador único por petición\\\r
102 --enable-usertrack=shared & $\rightarrow$ Seguimiento de la sesión de usuario\\\r
103 --enable-expires=shared & $\rightarrow$ Módulo para el envío de la cabecera de expiración\\\r
104 --enable-cern-meta=shared & $\rightarrow$ Ficheros meta tipo CERN\\\r
105 --enable-mime-magic=shared & $\rightarrow$ Determina automáticamente el tipo MIME\\\r
106 --enable-headers=shared & $\rightarrow$ Control cabeceras HTTP\\\r
107 --enable-auth-anon=shared & $\rightarrow$ Acceso a usuarios anónimos\\\r
108 --enable-proxy=shared & $\rightarrow$ Permite el uso de Apache como proxy\\\r
109 --enable-dav=shared & $\rightarrow$ Capaz de manejar el protocolo WebDav\\\r
110 --enable-dav-fs=shared & $\rightarrow$ Proveedor DAV para el sistema de archivos\\\r
111 --enable-auth-dbm=shared & $\rightarrow$ Autentificación basada en base de datos DBM\\\r
112 --enable-cgi=shared & $\rightarrow$ Permite CGI scripts\\\r
113 --enable-asis=shared & $\rightarrow$ Tipos de archivos como son\\\r
114 --enable-imap=shared & $\rightarrow$ Mapas de imágenes en el lado de servidor\\\r
115 --enable-ext-filter=shared & $\rightarrow$ Módulo para filtros externos\\\r
116 --enable-authn-dbm=shared & \\\r
117 --enable-authn-anon=shared & \\\r
118 --enable-authz-dbm=shared & \\\r
119 --enable-auth-digest=shared & $\rightarrow$ Colección de autentificaciones según RFC2617\\\r
120 --enable-actions=shared & $\rightarrow$ Activa acciones según peticiones\\\r
121 --enable-file-cache=shared & $\rightarrow$ Cache de archivos\\\r
122 --enable-cache=shared & $\rightarrow$ Cache dinámico de archivos\\\r
123 --enable-disk-cache=shared & $\rightarrow$ Cache de disco\\\r
124 --enable-mem-cache=shared & $\rightarrow$ Cache de memoria\\\r
125 \hline \end{longtable}\r
126 \end{itemize}\r
127 \r
128 Una vez configurado, hacemos:\\\r
129 \\\r
130 \begin{tabular}{|l|}\hline \r
131 \#make \&\& make install\\\r
132 \hline \end{tabular}\r
133 \newpage\r
134 \r
135 \r
136 \subsection{ Instalando PHP sobre Apache}\r
137 \r
138 Se puede descargar de \htmladdnormallink{http://www.php.net/downloads.php}{http://www.php.net/downloads.php} siendo la versión necesaria a la fecha de este manual para utilizar GOsa la 4.3.XX, ya que las versiones 5.0.XX aún no están soportadas. Las descargaremos en /usr/src.\r
139 \r
140 Para poder compilar los módulos necesarios además de necesitar las librerías de desarrollo de la seccion Servidores \ref{servidores}, además de las mismas que para openLDAP\ref{down_ldap} y Apache\ref{down_apache} necesitaremos alguna librería mas:\r
141 \r
142 \begin{itemize}\r
143 \item[libbz2]\r
144 La podemos descargar de \htmladdnormallink{http://sources.redhat.com/bzip2/}{http://sources.redhat.com/bzip2/} para módulo de compresión BZ2.\r
145 \item[e2fsprogs]\r
146 Se puede descargar de \htmladdnormallink{http://e2fsprogs.sourceforge.net}{http://e2fsprogs.sourceforge.net} para acceso al sistema de archivos.\r
147 \item[expat]\r
148 Se descarga de \htmladdnormallink{http://expat.sourceforge.net/}{http://expat.sourceforge.net/}, es un parser XML.\r
149 \item[zziplib]\r
150 Bajarla de \htmladdnormallink{http://zziplib.sourceforge.net/}{http://zziplib.sourceforge.net/}, acceso a archivos ZIP.\r
151 \item[zlib]\r
152 Desde \htmladdnormallink{http://www.gzip.org/zlib/}{http://www.gzip.org/zlib/} para compresión GZ.\r
153 \item[file]\r
154 Desde \htmladdnormallink{http://www.darwinsys.com/freeware/file.html}{http://www.darwinsys.com/freeware/file.html} control de archivos.\r
155 \item[sed]\r
156 De \htmladdnormallink{http://www.gnu.org/software/sed/sed.html}{http://www.gnu.org/software/sed/sed.html}, una de las herramientas mas potentes para manipulación de texto.\r
157 \item[libcurl]\r
158 Potente herramienta para manejar archivos remotos, la bajaremos de \htmladdnormallink{http://curl.haxx.se/}{http://curl.haxx.se/} .\r
159 \item[gettext]\r
160 Herramienta GNU para soporte de varios idiomas, la descargamos de \htmladdnormallink{http://www.gnu.org/software/gettext/gettext.html}{http://www.gnu.org/software/gettext/gettext.html} .\r
161 \item[libgd]\r
162 Para la manipulación y creación de imágenes desde: \htmladdnormallink{http://www.boutell.com/gd/}{http://www.boutell.com/gd/} .\r
163 \item[libjpeg]\r
164 Manipulación de imágenes JPEG de \htmladdnormallink{http://www.ijg.org/}{http://www.ijg.org/} .\r
165 \item[libpng]\r
166 Manipulación imágenes PNG de \htmladdnormallink{http://www.libpng.org/pub/png/libpng.html}{http://www.libpng.org/pub/png/libpng.html} .\r
167 \item[mcal]\r
168 Librería para el acceso a Calendarios remotos, se baja de \htmladdnormallink{http://mcal.chek.com/}{http://mcal.chek.com/} .\r
169 \item[libmysql]\r
170 Soporte para la famosísima base de datos, es imprescindible para php, se baja de \htmladdnormallink{http://www.mysql.com/}{http://www.mysql.com/}\r
171 \end{itemize}\r
172 \r
173 Una configuración recomendada será:\r
174 \r
175 \r
176 \begin{itemize}\r
177 \item[]Apache2\\\r
178 \begin{tabular}{|ll|}\hline \r
179 --prefix=/usr --with-apxs2=/usr/bin/apxs2 & \\\r
180 --with-config-file-path=/etc/php4/apache2 & \\\r
181 \hline \end{tabular}\r
182 \r
183 \r
184  \r
185 \item[]Opciones de compilación\\\r
186 \begin{tabular}{|ll|}\hline\r
187 --enable-memory-limit & \# Compilado con límite de memoria\\\r
188 --disable-debug & \# Compilar sin símbolos de depuración\\\r
189 --disable-static & \# Sin librerías estáticas\\\r
190 --with-pic & \# Usar objetos PIC y no PIC\\\r
191 --with-layout=GNU & \\\r
192 --enable-sysvsem & \# Soporte sysvmsg \\\r
193 --enable-sysvshm & \# Soporte semáforos System V \\\r
194 --enable-sysvmsg & \# Soporte memoria compartida System V \\\r
195 --disable-rpath & \# Desactiva poder pasar rutas a librerías adiciones al binario\\\r
196 --without-mm & \# Desactivar el soporte de sesiones por memoria\\\r
197 \hline \end{tabular}\r
198 \r
199 \item[]De sesión\\\r
200 \begin{tabular}{|ll|}\hline\r
201 --enable-track-vars & \\\r
202 --enable-trans-sid & \\\r
203 \hline \end{tabular}\r
204 \r
205 \item[]Soporte\\\r
206 \begin{tabular}{|ll|}\hline\r
207 --enable-sockets & \# Soporte de sockets\\\r
208 --with-mime-magic=/usr/share/misc/file/magic.mime & \\\r
209 --with-exec-dir=/usr/lib/php4/libexec & \\\r
210 \hline \end{tabular}\r
211 \r
212 \item[]pear\\\r
213 \begin{tabular}{|ll|}\hline\r
214 --with-pear=/usr/share/php & Donde vamos a instalar PEAR\\\r
215 \hline \end{tabular}\r
216   \r
217 \item[]Funciones\\\r
218 \begin{tabular}{|ll|}\hline\r
219 --enable-ctype & Soporte funciones de control de caracteres \\\r
220 --with-iconv & Soporte funciones iconv\\\r
221 --with-bz2 & Soporte Compresión BZ2\\\r
222 --with-regex=php & Tipo de librería de expresiones regulares\\\r
223 --enable-calendar & Funciones para conversión de calendario\\\r
224 --enable-bcmath & Soporte de matemáticas de precisión arbitraria\\\r
225 --with-db4 & DBA: Soporte Berkeley DB versión 4\\\r
226 --enable-exif & Soporte funciones exif, para lectura metadata JPG y TIFF\\\r
227 --enable-ftp & Soporte funciones FTP \\\r
228 --with-gettext & Soporte Localización\\\r
229 --enable-mbstring & \\\r
230 --with-pcre-regex=/usr & \\\r
231 --enable-shmop & Funciones de memoria compartida\\\r
232 --disable-xml --with-expat-dir=/usr & Usa el xml de expat en vez del que viene con php\\\r
233 --with-xmlrpc & \\\r
234 --with-zlib & \\\r
235 --with-zlib-dir=/usr & \\\r
236 --with-imap=shared,/usr & Soporte imap genérico\\\r
237 --with-kerberos=/usr & Imap con autentificación kerberos\\\r
238 --with-imap-ssl & Imap con acceso seguro SSL\\\r
239 --with-openssl=/usr & \\\r
240 --with-zip=/usr & \\\r
241 --enable-dbx & Capa de abstracción a base de datos\\\r
242 \hline \end{tabular}\r
243 \r
244 \item[]Módulos externos\\\r
245 \begin{tabular}{|ll|}\hline\r
246 --with-curl=shared,/usr & Manejo remoto de archivos\\\r
247 --with-dom=shared,/usr --with-dom-xslt=shared,/usr --with-dom-exslt=shared,/usr & Con xmlrpc ya integrado\\\r
248 --with-gd=shared,/usr --enable-gd-native-ttf & Soporte de manejo de gráficos\\\r
249 --with-jpeg-dir=shared,/usr & Soporte GD para jpeg\\\r
250 --with-png-dir=shared,/usr & Soporte GD para png\\\r
251 --with-ldap=shared,/usr & Soporte para ldap\\\r
252 --with-mcal=shared,/usr & Soporte de calendarios\\\r
253 --with-mhash=shared,/usr & Módulo para varios algoritmos de generación de claves\\\r
254 --with-mysql=shared,/usr & Soporte de base de datos Mysql\\    \r
255 \hline \end{tabular}\r
256 \end{itemize}\r
257 Posteriormente hacemos:\\\r
258 \\\r
259 \begin{tabular}{|l|}\hline \r
260 \#make \&\& make install\\\r
261 \hline \end{tabular}\r
262 \newpage\r
263 \section{ Configuración Apache2}\r
264 \r
265 La configuración de apache se guardara en el directorio /etc/apache2 en los siguientes ficheros y directorios:\r
266 \begin{itemize}\r
267 \item[]Archivo apache2.conf:\\\r
268 COnfiguración principal de apache2, tiene la configuración necesaria para arrancar apache.\\\r
269 No necesitamos editar este archivo.\r
270 \item[]Archivo ports.conf\\\r
271 Que puertos escucha apache, necesitamos dos, el puerto 80 para HTTP y el 443 para HTTPS, editaremos el ficheros, dejandolo como esto:\r
272 \begin{tabular}{|l|}\hline\r
273 Listen 80,443\\\r
274 \hline \end{tabular}\r
275 \item[]Directorio conf.d:\\\r
276 Directorio para configuraciones especiales, no lo necesitamos.\r
277 \item[]Directorios mods-available y mods-enabled:\\\r
278 Este directorio tiene todos los módulos que podemos usar de apache2, para poder usar un módulo es necesario enlazar este al directorio mods-enabled.\r
279 \item[]Directorios sites-available y sites-enabled:\\\r
280 En sites-available debemos configurar los sitios que vamos a usar.\\\r
281 Por ejemplo vamos a crear el sitio no seguro gosa, que vamos a usar para redirigir las peticiones a un servidor seguro.\r
282 \r
283 La configuración de GOsa (sites-available/gosa) puede ser parecida a esta::\\\r
284 \begin{tabular}{|l|}\hline\r
285 \noindent NameVirtual *\\\r
286 <VirtualHost *>\\\r
287 \verb|    |ServerName gosa.chaosdimension.org\\\r
288 \\\r
289 \verb|    |Redirect /gosa https://gosa.chaosdimension.org/gosa\\\r
290 \\\r
291 \verb|    |CustomLog /var/log/apache/gosa.log combined\\\r
292 \verb|    |ErrorLog /var/log/apache/gosa.log\\\r
293 \\\r
294 </VirtualHost>\\\r
295 \hline \end{tabular}\r
296 \r
297 Una vez sea guardada, podemos activarla haciendo esto:\\\r
298 \\\r
299 \begin{tabular}{|l|}\hline \r
300 \#>ln -s /etc/apache2/mods-available/suphp.conf /etc/apache2/mods-enabled/suphp.conf\\\r
301 \hline \end{tabular}\r
302 \\\r
303 \item[]Directorio ssl:\\\r
304 Directorio de configuración de Secure Socket Layer, esto lo veremos en la siguiente sección.\r
305 \end{itemize}\r
306 \newpage\r
307 \subsection{ Seguridad}\r
308 \r
309 La seguridad es uno de los puntos mas importantes al configurar un servidor apache, necesitaremos un entorno seguro donde no permitir que los usuarios manipulen y accedan a codigo o programas.\r
310 \r
311 La formas de conseguir esto es usando encriptación, con lo que buscamos que los usuarios y el servidor se comuniquen de forma que nadie mas pueda acceder a los datos. Esto se consigue con encriptación.\r
312 \r
313 La otra manera de asegurar el sistema es que si existe algún fallo en el sistema o en el código, y un intruso intenta ejecutar codigo, este se vea incapacitado, ya que existen poderosas limitaciones, como no permitir que ejecute comandos, lea el codigo de otros script, no pueda modificar nada y tenga un usuario con muy limitados recursos.\r
314 \subsubsection{ Certificados SSL}\r
315 \r
316 \noindent Existe amplia documentación sobre encriptación y concretamente sobre SSL, un sistema de encriptación con clave publica y privada.\\\r
317 \\\r
318 \noindent Como el paquete openSSL ya lo tenemos instalado a partir de los pasos anteriores, debemos crear los certificados que usaremos en nuestro servidor web.\\\r
319 \\\r
320 \noindent Supongamos que guardamos el certificado en /etc/apache2/ssl/gosa.pem\\\r
321 \\\r
322 \begin{tabular}{|l|}\hline \r
323 \#>FILE=/ect/apache2/ssl/gosa.pem\\\r
324 \#>export RANDFILE=/dev/random\\\r
325 \#>openssl req -new -x509 -nodes -out \$FILE -keyout /etc/apache2/ssl/apache.pem\\\r
326 \#>chmod 600 \$FILE\\\r
327 \#>ln -sf \$FILE /etc/apache2/ssl/`/usr/bin/openssl x509 -noout -hash < \$FILE`.0\\\r
328 \hline \end{tabular}\r
329 \\\r
330 \noindent Con esto hemos creado un certificado que nos permite el acceso SSL a nuestras páginas.\\\r
331 \\\r
332 \noindent Si lo que queremos es una configuración que nos permita no solo que el tráfico esté encriptado, sino que además el cliente garantice que es un usuario válido, debemos provocar que el servidor pida una certificación de cliente. \\\r
333 \\\r
334 \noindent En este caso seguiremos un procedimiento mas largo, primero la creación de una certificación de CA:\\\r
335 \\\r
336 \begin{tabular}{|l|}\hline \r
337 \#>CAFILE=/ect/apache2/ssl/gosa.ca\\\r
338 \#>KEY=/etc/apache2/ssl/gosa.key\\\r
339 \#>REQFILE=/etc/apache2/ssl/gosa.req\\\r
340 \#>CERTFILE=/ect/apache2/ssl/gosa.cert\\\r
341 \#>DAYS=365\\\r
342 \#>export RANDFILE=/dev/random\\\r
343 \#>openssl req -x509 -keyout \$CAKEY -out \$CAFILE \$DAYS\\\r
344 \hline \end{tabular}\r
345 \\\r
346 \noindent Después de varias cuestiones tendremos una CA, ahora hacemos un requerimiento a la CA creada:\\\r
347 \\\r
348 \begin{tabular}{|l|}\hline \r
349 \#>openssl req -new -keyout \$REQFILE -out \$REQFILE \$DAYS\\\r
350 \hline \end{tabular}\r
351 \\\r
352 \noindent Firmamos el nuevo certificado:\\\r
353 \\\r
354 \begin{tabular}{|l|}\hline \r
355 \#>openssl ca -policy policy\_anything -out \$CERFILE -infiles \$REQFILE\\\r
356 \hline \end{tabular}\r
357 \\\r
358 \noindent Y creamos un pkcs12 para configurar la certificación en los clientes:\\\r
359 \\\r
360 \begin{tabular}{|l|}\hline \r
361 \#>openssl pkcs12 -export -inkey \$KEY -in \$CERTFILE -out certificado\_cliente.pkcs12\\\r
362 \hline \end{tabular}\r
363 \\\r
364 \noindent Este certificado se puede instalar en el cliente, y en el servidor web mediante la configuración explicada en el siguiente punto, nos dará la seguridad de que solo accederán aquellos clientes que nosotros deseamos y que su comunicación será estrictamente confidencial.\\\r
365 \r
366 \r
367 \r
368 \subsubsection{ Configurando mod-SSL}\r
369 \r
370 \r
371 \noindent El módulo SSL viene de serie con apache2, esto simplificara nuestro trabajo. Para saber si está ya configurado:\\\r
372 \\\r
373 \begin{tabular}{|l|}\hline \r
374 \#> if [ -h /etc/apache2/mods-enabled/ssl.load ]; then echo "módulo instalado";else echo "módulo no instalado"; fi\\\r
375 \hline \end{tabular}\r
376 \\\r
377 \noindent Para activarlo haremos lo siguiente:\\\r
378 \\\r
379 \begin{tabular}{|l|}\hline \r
380 \#>ln -s /etc/apache2/mods-available/ssl.conf /etc/apache2/mods-enabled/ssl.conf\\\r
381 \#>ln -s /etc/apache2/mods-available/ssl.load /etc/apache2/mods-enabled/ssl.load\\\r
382 \hline \end{tabular}\r
383 \\\r
384 \noindent Esto configurará el módulo en apache2 y se podrá utilizar después de recargar el servidor con:\\\r
385 \\\r
386 \begin{tabular}{|l|}\hline \r
387 \#>/etc/init.d/apache2 restart\\\r
388 \hline \end{tabular}\r
389 \\\r
390 \\\r
391 \noindent Para el caso de querer solo una configuración para comunicación encriptada, crearemos en /etc/apache2/sites-available, gosa-ssl:\\\r
392 \\\r
393 \begin{tabular}{|l|}\hline \r
394 \noindent NameVirtual *:443\\\r
395 <VirtualHost *:443>\\\r
396 \verb|    |ServerName gosa.chaosdimension.org\\\r
397 \\\r
398 \verb|    |alias /gosa /usr/share/gosa/html\\\r
399 \\\r
400 \verb|    |DocumentRoot /var/www/gosa.chaosdimension.org\\\r
401 \verb|    |CustomLog /var/log/apache/gosa.log combined\\\r
402 \verb|    |ErrorLog /var/log/apache/gosa.log\\\r
403 \\\r
404 \verb|    |SSLEngine On\\\r
405 \verb|    |SSLCertificateFile    /etc/apache2/ssl/gosa.cert\\\r
406 \verb|    |SSLCertificateKeyFile /etc/apache2/ssl/gosa.key\\\r
407 \verb|    |SSLCertificateChainFile /etc/apache2/ssl/gosa.cert\\\r
408 \verb|    |SSLCertificateKeyFile /etc/apache2/ssl/gosa.key\\\r
409 \verb|    |SSLCACertificateFile /etc/apache2/ssl/gosa.ca\\\r
410 \verb|    |SSLCACertificatePath /etc/apache2/ssl/\\\r
411 \verb|    |SSLLogLevel error\\\r
412 \verb|    |SSLLog /var/log/apache2/ssl-gosa.log\\\r
413 \\\r
414 </VirtualHost>\\\r
415 \hline \end{tabular}\r
416 \\\r
417 \noindent Para una comunicación encriptada en la cual verificamos el certificado del cliente:\r
418 \\\r
419 \begin{tabular}{|l|}\hline \r
420 \noindent NameVirtual *:443\\\r
421 <VirtualHost *:443>\\\r
422 \verb|    |ServerName gosa.chaosdimension.org\\\r
423 \\\r
424 \verb|    |alias /gosa /usr/share/gosa/html\\\r
425 \\\r
426 \verb|    |DocumentRoot /var/www/gosa.chaosdimension.org\\\r
427 \verb|    |CustomLog /var/log/apache/gosa.log combined\\\r
428 \verb|    |ErrorLog /var/log/apache/gosa.log\\\r
429 \\\r
430 \verb|    |SSLEngine On\\\r
431 \verb|    |SSLCertificateFile    /etc/apache2/ssl/gosa.cert\\\r
432 \verb|    |SSLCertificateKeyFile /etc/apache2/ssl/gosa.key\\\r
433 \verb|    |SSLCertificateChainFile /etc/apache2/ssl/gosa.cert\\\r
434 \verb|    |SSLCertificateKeyFile /etc/apache2/ssl/gosa.key\\\r
435 \verb|    |SSLCACertificateFile /etc/apache2/ssl/gosa.ca\\\r
436 \verb|    |SSLCACertificatePath /etc/apache2/ssl/\\\r
437 \verb|    |SSLLogLevel error\\\r
438 \verb|    |SSLLog /var/log/apache2/ssl-gosa.log\\\r
439 \\      \r
440 \verb|    |<Directory /usr/share/gosa >\\\r
441 \verb|    |\verb|    |SSLVerifyClient require\\\r
442 \verb|    |\verb|    |SSLVerifyDepth 1\\\r
443 \verb|    |</Directory>\\\r
444 </VirtualHost>\\\r
445 \hline \end{tabular}\r
446 \r
447 \subsubsection{ Configurando suphp}\r
448 \noindent\r
449 Suphp es un módulo para apache y php que permite ejecutar procesos de php con un usuario diferente del que usa apache para ejecutar las páginas html y php.\r
450 \r
451 Consta de dos partes, una es un modulo para apache que "captura" las peticiones de páginas php, comprueba el usuario del archivo, su grupo, y envía la información a la otra parte, que es un ejecutable suid-root que lanza php4-cgi con el usuario que le ha sido indicado, este devuelve el resultado al módulo del apache.\r
452 \r
453 La idea es minimizar el daño que se provocaría al ser explotado un posible fallo del sistema, de esta manera el usuario entraría en el sistema con una cuenta no habilitada, sin permisos de ejecución y sin posibilidad de acceso a otro código o sitios web.\r
454 \r
455 Suphp se puede descargar de \htmladdnormallink{http://www.suphp.org/Home.html}{http://www.suphp.org/Home.html}, descomprimiendo el paquete en /usr/src y compilando con las siguientes opciones:\r
456 \\\r
457 \begin{tabular}{|l|}\hline \r
458 \#>./configure --prefix=/usr \textbackslash \\\r
459 \verb|    |--with-apxs=/usr/bin/apxs2 \textbackslash \\\r
460 \verb|    |--with-apache-user=www-data \textbackslash \\\r
461 \verb|    |--with-php=/usr/lib/cgi-bin/php4 \textbackslash \\\r
462 \verb|    |--sbindir=/usr/lib/suphp \textbackslash \\\r
463 \verb|    |--with-logfile=/var/log/suphp/suphp.log \textbackslash \\\r
464 \verb|    |-with-setid-mode \textbackslash \\\r
465 \verb|    |--disable-checkpath \\\r
466 \hline \end{tabular}\r
467 \\\r
468 \noindent Por supuesto necesitaremos tener compilado php para cgi, esto significa volver a compilar php, pero quitando la configuración para apache2 y añadiendo:\\\r
469 \\\r
470 \begin{tabular}{|l|}\hline \r
471 \verb|    |--prefix=/usr --enable-force-cgi-redirect --enable-fastcgi \textbackslash\\\r
472 \verb|    |--with-config-file-path=/etc/php4/cgi\\\r
473 \hline \end{tabular}\r
474 \r
475 \noindent Para configurarlo en apache haremos igual que para ssl, primero comprobamos si está configurado:\\\r
476 \\\r
477 \begin{tabular}{|l|}\hline \r
478 \#> if [ -h /etc/apache2/mods-enabled/suphp.load ]; then echo "módulo instalado";else echo "módulo no instalado"; fi\\\r
479 \hline \end{tabular}\r
480 \\\r
481 \noindent Para activarlo haremos lo siguiente:\\\r
482 \\\r
483 \begin{tabular}{|l|}\hline \r
484 \#>ln -s /etc/apache2/mods-available/suphp.conf /etc/apache2/mods-enabled/suphp.conf\\\r
485 \#>ln -s /etc/apache2/mods-available/suphp.load /etc/apache2/mods-enabled/suphp.load\\\r
486 \hline \end{tabular}\r
487 \\\r
488 \noindent Esto configurará el módulo en apache2 y se podrá utilizar después de recargar el servidor con:\\\r
489 \\\r
490 \begin{tabular}{|l|}\hline \r
491 \#>/etc/init.d/apache2 restart\\\r
492 \hline \end{tabular}\r
493 \\\r
494 \r
495 \noindent La configuración del sitio seguro con suphp incluido quedaría así:\\\r
496 \\\r
497 \begin{tabular}{|l|}\hline \r
498 \noindent NameVirtual *:443\\\r
499 <VirtualHost *:443>\\\r
500 \verb|    |ServerName gosa.chaosdimension.org\\\r
501 \\\r
502 \verb|    |DocumentRoot /usr/share/gosa/html\\\r
503 \verb|    |alias /gosa /usr/share/gosa/html\\\r
504 \verb|    |CustomLog /var/log/apache/gosa.log combined\\\r
505 \verb|    |ErrorLog /var/log/apache/gosa.log\\\r
506 \\\r
507 \verb|    |suPHP\_Engine on\\\r
508 \\\r
509 \verb|    |SSLEngine On\\\r
510 \verb|    |SSLCertificateFile    /etc/apache2/ssl/gosa.cert\\\r
511 \verb|    |SSLCertificateKeyFile /etc/apache2/ssl/gosa.key\\\r
512 \verb|    |SSLCertificateChainFile /etc/apache2/ssl/gosa.cert\\\r
513 \verb|    |SSLCertificateKeyFile /etc/apache2/ssl/gosa.key\\\r
514 \verb|    |SSLCACertificateFile /etc/apache2/ssl/gosa.ca\\\r
515 \verb|    |SSLCACertificatePath /etc/apache2/ssl/\\\r
516 \verb|    |SSLLogLevel error\\\r
517 \verb|    |SSLLog /var/log/apache2/ssl-gosa.log\\\r
518 \\      \r
519 \verb|    |<Directory /usr/share/gosa >\\\r
520 \verb|    |\verb|    |SSLVerifyClient require\\\r
521 \verb|    |\verb|    |SSLVerifyDepth 1\\\r
522 \verb|    |</Directory>\\\r
523 </VirtualHost>\\\r
524 \hline \end{tabular}\r
525 \r
526 \noindent Debemos decidir que usuario vamos a usar, en este caso voy a crear uno llamado gosa, que me sirva para el fin indicado anteriormente:\\\r
527 \\\r
528 \begin{tabular}{|l|}\hline \r
529 \verb|    |\#useradd -d /usr/share/gosa/html gosa\\\r
530 \verb|    |\#passwd -l gosa\\\r
531 \verb|    |\#cd /usr/share/gosa\\\r
532 \verb|    |\#find /usr/share/gosa -name "*.php" -exec chown gosa {} ";"\\\r
533 \verb|    |\#find /usr/share/gosa -name "*.php" -exec chmod 600 {} ";"\\\r
534 \hline \end{tabular}\r
535 \r
536 \r
537 \r
538 \section{Configuración Php4}\r
539 \r
540 La configuración para mod\_php se guardará en el sitio que hallamos puesto en la partes anteriores. En nuestro caso es /etc/php4/apache2.\r
541 \r
542 El archivo de configuración siempre es php.ini y en el configuramos los módulos.\r
543 \r
544 Una configuración básica será como esta:\r
545 \begin{center}\r
546 \begin{longtable}{|l|}\r
547 \caption{PHP4 Configuration}\\\r
548 \hline\r
549 \multicolumn{1}{|c|}{\textbf{PHP4 Configuration}}\\\r
550 \hline\r
551 \endfirsthead\r
552 \hline\r
553 \endhead\r
554 \hline\r
555 \multicolumn{1}{|c|}{Continue $\ldots$}\\\r
556 \hline\r
557 \endfoot\r
558 \hline\r
559 \multicolumn{1}{|c|}{\textbf{End}}\\\r
560 \hline\r
561 \endlastfoot\r
562 ; Engine\\\r
563 \verb|    |engine   = On ; Activa PHP\\\r
564 \verb|    |short\_open\_tag = On ; Permite usar <? para simplificar <?php\\\r
565 \verb|    |asp\_tags  = Off ; No permitimos etiquetas estilo ASP: <\% \%>\\\r
566 \verb|    |precision  = 14 ; Número de dígitos significantes mostrados en números en coma flotante\\\r
567 \verb|    |output\_buffering = Off ; Solo permitimos que envie cabecera antes de enviar el contenido.\\\r
568 \verb|    |implicit\_flush  = Off ; No forzamos a php a que limpie el buffer de salida después de cada bloque.\\\r
569 \\\r
570 ; Safe Mode\\\r
571 \verb|    |\label{sm} safe\_mode  = Off ; No queremos el modo seguro\\\r
572 \verb|    |\label{smed} safe\_mode\_exec\_dir = ; Directorio donde se ejecutara PHP\\\r
573 \verb|    |\label{smid} safe\_mode\_include\_dir = Directorios donde hará la busqueda PHP de librerías\\\r
574 \verb|    |\label{smaev} safe\_mode\_allowed\_env\_vars = PHP\_     ; Solo se permite a los usuarios\\\r
575 \verb|    |\verb|    |\verb|    |;a crear variables del sistema que empiecen por PHP\_\\\r
576 \verb|    |\label{smpev} safe\_mode\_protected\_env\_vars = LD\_LIBRARY\_PATH  ; Lista de variables del sistema que\\\r
577 \verb|    |\verb|    |\verb|    |; no pueden ser cambiadas por razones de seguridad\\\r
578 \verb|    |\label{df} disable\_functions =        ; Funciones que serán desactivadas por razones de seguridad\\\r
579 \verb|    |\label{auf} allow\_url\_fopen = Yes ; Permitimos que se abran archivos desde PHP\\\r
580 \verb|    |\label{ob} open\_basedir = ;\\\r
581 \\\r
582 ; Colores para el modo de síntasis coloreada.\\\r
583 \verb|    |highlight.string = \#DD0000\\\r
584 \verb|    |highlight.comment = \#FF8000\\\r
585 \verb|    |highlight.keyword = \#007700\\\r
586 \verb|    |highlight.bg  = \#FFFFFF\\\r
587 \verb|    |highlight.default = \#0000BB\\\r
588 \verb|    |highlight.html  = \#000000\\\r
589 \\\r
590 ; Misc\\\r
591 \verb|    |\label{ep}expose\_php = On  ; Indica en el mensaje del servidor web si está instalado o no.\\\r
592 \\\r
593 ; Resource Limits ;\\\r
594 \verb|    |max\_execution\_time = 30     ; Tiempo máximo de ejecución del script.\\\r
595 \verb|    |memory\_limit = 16M   ; La cantidad máxima permitida de memoria que puede consumir un script.\\\r
596 \\\r
597 ; Error handling and logging ;\\\r
598 \verb|    |error\_reporting = E\_ALL; Indicamos que muestre todos los errores y avisos.\\\r
599 \verb|    |display\_errors = Off ; Que no los imprima en pantalla.\\\r
600 \verb|    |display\_startup\_errors = Off  ; Que no muestre los errores de arranque de PHP.\\\r
601 \verb|    |log\_errors  = On ; Que envíe los errores a un fichero.\\\r
602 \verb|    |track\_errors = On ; Que guarde el último error / aviso para \$php\_errormsg (boolean)\\\r
603 \verb|    |error\_log = /var/log/php/php4.log ; Fichero que guardará los errores\\\r
604 \verb|    |warn\_plus\_overloading = Off  ; No avisamos si se usa el operador + con cadenas de texto\\\r
605 \\\r
606 ; Data Handling ;\\\r
607 \verb|    |variables\_order  = "EGPCS" ; Esta directiva describe el orden en el cual\\\r
608 \verb|    |;se registrarán las variables de PHP (Siendo G=GET, P=POST, C=Cookie,\\\r
609 \verb|    |; E= Sistema, S= Propias de PHP, todas es indicado como EGPCS)\\\r
610 \verb|    |\label{rg} register\_globals = Off  ; No queremos que se registren las EGPCS como globales.\\\r
611 \verb|    |register\_argc\_argv = Off  ; No declaramos ARGV y ARGC para su uso en scripts.\\\r
612 \verb|    |post\_max\_size  = 8M  ; Tamaño máximo de un envío POST que aceptará PHP.\\\r
613 \r
614 ; Magic quotes\\\r
615 \verb|    |\label{mqq}magic\_quotes\_gpc = On  ; Comillas añadidas para gpc(información GET/POST/Cookie)\\\r
616 \verb|    |magic\_quotes\_runtime= Off  ; Comillas añadidas para información generada por el sistema, \\\r
617 \verb|    |;por ejemplo desde SQL, exec(), etc.\\\r
618 \verb|    |magic\_quotes\_sybase = Off  ; Usar comillas añadidas al estilo de Sybase \\\r
619 \verb|    |;(escapa ' con '' en lugar de \textbackslash ')\\\r
620 \\\r
621 ; Tipo de archivo por defecto de PHP y codificación por defecto.\\\r
622 \verb|    |default\_mimetype = "text/html"\\\r
623 \verb|    |default\_charset = "iso-8859-1"\\\r
624 \\\r
625 ; Rutas y directorios ;\\\r
626 \verb|    |\label{ip} include\_path = . ;\\\r
627 \verb|    |doc\_root  =     ; Raíz de las páginas php, mejor dejarlo en blanco.\\\r
628 \verb|    |user\_dir  =     ; Donde php ejecuta el script, tambien mejor en blanco.\\\r
629 \verb|    |;extension\_dir = /usr/lib/php4/apache   ; ¿Donde estan los módulos?\\\r
630 \verb|    |enable\_dl  = Off    ; Permitir o no la carga dinámica de módulos con la función dl().\\\r
631 \\\r
632 ; Subir ficheros al servidor;\\\r
633 \verb|    |file\_uploads = On    ; Permitir el subir archivos al servidor.\\\r
634 \verb|    |upload\_max\_filesize = 2M      ; Tamaño máximo de los archivos que vamos a subir.\\\r
635 \\\r
636 ; Extensiones dinámicas ;\\\r
637 \verb|    |extension=gd.so              ; Graficos\\\r
638 \verb|    |extension=mysql.so   ; Mysql\\\r
639 \verb|    |extension=ldap.so    ; Ldap\\\r
640 \verb|    |extension=mhash.so   ; Mhash\\\r
641 \verb|    |extension=imap.so    ; Imap\\\r
642 \verb|    |extension=kadm5.so   ; Kerberos\\\r
643 \verb|    |extension=cups.so    ; Cupsys\\\r
644 \\\r
645 ; Log del sistema\\\r
646 \verb|[Syslog]|\\\r
647 \verb|    |define\_syslog\_variables = Off ; Desactivamos la definición de variables de syslog.\\\r
648 \\\r
649 ; funciones de correo\\\r
650 \verb|[mail function]|\\\r
651 \verb|    |;sendmail\_path =      ;En sistemas Unix, donde esta hubicado sendmail (por defecto es 'sendmail -t -i')\\\r
652 \\\r
653 ; depuración\\\r
654 \verb|[Debugger]|\\\r
655 \verb|    |debugger.host = localhost ; Donde está el depurador.\\\r
656 \verb|    |debugger.port = 7869 ; En que puerto escucha.\\\r
657 \verb|    |debugger.enabled = False ; En principio suponemos que no hay depurados.\\\r
658 \\\r
659 ; Opciones SQL\\\r
660 \verb|[SQL]|\\\r
661 \verb|    |sql.safe\_mode = Off ; Modo seguro de sql, en principio estará desactivado.\\\r
662 \\\r
663 ; Opciones Mysql\\\r
664 \verb|[MySQL]|\\\r
665 \verb|    |mysql.allow\_persistent = Off ; Desactivaremos los enlaces persistentes por razones de seguridad.\\\r
666 \verb|    |mysql.max\_persistent = -1 ; Numero de conexiones persistentes, no se usa por haberlas desactivado.\\\r
667 \verb|    |mysql.max\_links   = -1 ; Numero máximo de conexiones, -1 es sin limite.\\\r
668 \verb|    |mysql.default\_port  =  3306; Puerto por defecto del mysql.\\\r
669 \verb|    |mysql.default\_socket =  ; Nombre de socket que se usaran para conexiones locales MySQL.\\\r
670 \verb|    |;Si está vacio se usara el que tengamos en la configuración de la compilación del PHP.\\\r
671 \verb|    |mysql.default\_host  =  ; No configuramos host por defecto.\\\r
672 \verb|    |mysql.default\_user  =  ; No configuramos usuario por defecto.\\\r
673 \verb|    |mysql.default\_password =  ; No configuramos una contraseña por defecto.\\\r
674 \\\r
675 ; Control de sesiones\\\r
676 \verb|[Session]|\\\r
677 \verb|    |session.save\_handler      = files   ; Guardamos la información de sesión en ficheros.\\\r
678 \verb|    |\label{ss} session.save\_path         = /var/lib/php4    ; Donde se van ha guardar los ficheros de sesión.\\\r
679 \verb|    |session.use\_cookies       = 1       ; Usaremos cookies para el seguimiento de sesión.\\\r
680 \verb|    |session.name              = PHPSESSID   ; Nombre de la sesión que será usado en el nombre de la cookie.\\\r
681 \verb|    |session.auto\_start        = 0       ; No iniciamos sesión automáticamente.\\\r
682 \verb|    |session.cookie\_lifetime   = 0       ; Tiempo de vida de una cookie de sesión o 0 si esperamos a que cierre el navegador.\\\r
683 \verb|    |session.cookie\_path       = /       ; La ruta para que es válida la cookie.\\\r
684 \verb|    |session.cookie\_domain     =         ; El dominio para el cual es válida la cookie.\\\r
685 \verb|    |session.serialize\_handler = php     ; Manipulador usado para serializar los datos.\\\r
686 \verb|    |session.gc\_probability    = 1       ; Probabilidad en porcentaje de que el recolector de basura se active en cada sesión.\\\r
687 \verb|    |session.gc\_maxlifetime    = 1440    ; Después de este tiempo en segundos, la información guardada\\\r
688 \verb|    |; será vista como basura para el recolector de basura.\\\r
689 \verb|    |session.referer\_check     =         ; Comprueba los Referer HTTP para invalidar URLs externas conteniendo ids\\\r
690 \verb|    |session.entropy\_length    = 0       ; Número de bytes a leer del fichero de entropía.\\\r
691 \verb|    |session.entropy\_file      =         ; El fichero que generará la entropía.\\\r
692 \verb|    |session.cache\_limiter     = nocache ; Sin cache de sessiones.\\\r
693 \verb|    |session.cache\_expire      = 180     ; Tiempo de expiración del documento.\\\r
694 \verb|    |session.use\_trans\_sid     = 0       ; Usar sid transportable si está activado en la compilación\\\r
695 \\\r
696 \end{longtable}\r
697 \end{center}\r
698 \r
699 \r
700 \subsection{Seguridad}\r
701 \r
702 Php es un poderoso lenguaje de script, permite a su usuario tener bastante control sobre el sistema y a atacantes maliciosos muchas opciones de alcanzar su objetivo.\r
703 \r
704 Un administrador de sistemas no debe suponer que un sistema es completamente seguro con solo tener las actualizaciones de seguridad instaladas, un sistema que muestra código al exterior no es seguro, aunque el resultado sea HTML, se expone a ataques de formas muy diversas y a fallos de seguridad desconocidos.\r
705 \r
706 Limitar al máximo el acceso que permite php es entonces una necesidad.\r
707 \r
708 \subsection{Configurando safe php}\r
709 \r
710 PHP tiene un modo llamado \htmladdnormallink{safe-mode}{http://www.php.net/manual/en/features.safe-mode.php} que permite una mayor seguridad, una configuración para Safe mode recomendada es:\\\r
711 \\\r
712 \noindent \begin{tabular}{|l|}\hline\r
713 \verb|    |\ref{mqq} magic\_quotes\_qpc = On\\\r
714 \verb|    |\ref{auf} allow\_url\_fopen = No\\\r
715 \verb|    |\ref{rg} register\_globals = Off\\\r
716 \verb|    |\ref{sm} safe\_mode = On\\\r
717 \verb|    |\ref{smid} safe\_mode\_include\_dir = "/usr/share/gosa:/var/spool/gosa"\\\r
718 \verb|    |\ref{smed} safe\_mode\_exec\_dir = "/usr/lib/gosa"\\\r
719 \verb|    |\ref{smaev} safe\_mode\_allowed\_env\_vars = PHP\_,LANG\\\r
720 \verb|    |\ref{ob} open\_basedir = "/etc/gosa:/var/spool/gosa:/var/cache/gosa:/usr/share/gosa:/tmp"\\\r
721 \verb|    |\ref{ip} include\_path = ".:/usr/share/php:/usr/share/gosa:/var/spool/gosa:/usr/share/gosa/safe\_bin"\\\r
722 \verb|    |\ref{df} disable\_functions = system, shell\_exec, passthru, phpinfo, show\_source\\\r
723 \hline \end{tabular}\r
724 \\\r
725 En el caso de que vayamos a usar SuPHP, debemos dar los siguientes permisos al directorio /var/lib/php4:\\\r
726 \begin{tabular}{|l|}\hline \r
727 \#chmod 1777 /var/lib/php4\\\r
728 \hline \end{tabular}\r
729 \r
730 Ya que cada usuario que ejecute PHP guardara la sesión con ese usuario.\r
731 \r
732 \r
733 \section{ Módulos de PHP necesarios}\r
734 \r
735 En esta sección se explicaran los pasos para conseguir compilar y usar los módulos necesarios o importantes para GOsa, se recomienda instalar todos los módulos, incluso los que no son necesarios.\r
736 \r
737 \subsection{ ldap.so}\r
738 \r
739 MÓDULO NECESARIO\r
740 \r
741 \indent Este módulo no necesita ninguna configuración especial para funcionar.\r
742 \r
743 \indent Solo se conoce un problema: No puede conectarse PHP+Apache con un servidor LDAP que pida Certificado válido. Con lo cual la comunicación será segura, ya que se puede usar SSL, pero no estará garantizada.\r
744 \r
745 \subsection{ mysql.so}\r
746 \r
747 MÓDULO OPCIONAL\r
748 \r
749 \indent Este módulo no necesita ninguna configuración especial para funcionar.\r
750 \r
751 \indent Sirve para albergar configuraciones del plugin imap - sieve.\r
752 \r
753 \subsection{ imap.so}\r
754 \r
755 MÓDULO OPCIONAL\r
756 \r
757 \indent El módulo instalado al compilar PHP funcionara, pero tendrá una importante carencia, la función getacl que da control sobre las carpetas, así que necesitaremos un parche y una serie de pasos para compilar el módulo para su uso en GOsa.\r
758 \r
759 Nos bajamos el parche de \htmladdnormallink{php4-imap-getacl.patch}{ftp://oss.gonicus.de/pub/gosa/patches/php4-imap-getacl.patch} y lo ponemos en /usr/src, como tenemos las fuentes de PHP en /usr/src, ejecutamos los siguientes comandos:\\\r
760 \\\r
761 \noindent \begin{tabular}{|l|}\hline\r
762 \#cd /usr/src/php4.3-XXX/extensions/imap\\\r
763 \#make clear\\\r
764 \#patch -p1 </usr/src/patch/php4-imap-getacl.patch\\\r
765 \#phpize\\\r
766 \#./configure\\\r
767 \#make\\\r
768 \#make install\\\r
769 \hline \end{tabular}\r
770 \r
771 \r
772 Esto configurara e instalara correctamente el módulo.\r
773 \r
774 \subsection{ gd.so}\r
775 \r
776 MÓDULO OPCIONAL\r
777 \r
778 \indent Este módulo no necesita ninguna configuración especial para funcionar.\r
779 \r
780 \indent El módulo es usado para el manejo de gráficos, tambien usado por el sistema de plantillas smarty.\r
781 \r
782 \subsection{cups}\r
783 \r
784 MÓDULO OPCIONAL\r
785 \r
786 \indent Para utilizar el módulo Cups para la selección de la impresora en Posix, primero debemos descargar las fuentes de cups de \htmladdnormallink{http://www.cups.org/software.php}{http://www.cups.org/software.php} y descomprimirlas en /usr/src, ejecutamos entonces los siguientes comandos:\\\r
787 \\\r
788 \noindent \begin{tabular}{|l|}\hline\r
789 \#cd /usr/src/cups-1.1.XX/scripting/php\\\r
790 \#phpize\\\r
791 \#./configure\\\r
792 \#make\\\r
793 \#make install\\\r
794 \#echo \verb|"extension=cups.so" >>| /etc/php4/apache2/php.init\\\r
795 \#/etc/init.d/apache2 reload\\\r
796 \hline \end{tabular}\r
797 \r
798 \r
799 \subsection{krb}\r
800 \r
801 MÓDULO OPCIONAL\r
802 \r
803 \indent Este módulo necesita tener instaladas las fuentes de kerberos del MIT, ya que no se puede compilar con las fuentes de kerberos de Heimdal.\r
804 \r
805 \indent El módulo interactuará con los servidores Kerberos para actualizar las claves de los usuarios creados.\r
806 \r
807 Se descargara de \htmladdnormallink{PECL}{http://pecl.php.net/kadm5}, y lo descomprimiremos en /usr/src, debemos tener tambien las fuentes del kerberos del MIT, las cuales descomprimiremos en /usr/src, con ello hacemos (sustituimos X.X por las respectivas versiones de los programas):\\\r
808 \\\r
809 \noindent \begin{tabular}{|l|}\hline\r
810 \#cd /usr/src/kadm5-0.X.X/scripting/php\\\r
811 \#cp config.m4 config.m4.2\\\r
812 \#sed \verb|s/krb5-1\.2\.4\/src\/include/krb5-1\.X\.X\/src\/lib/| config.m4.2 >config.m4\\\r
813 \#rm -f config.m4.2\\\r
814 \#phpize\\\r
815 \#./configure\\\r
816 \#make\\\r
817 \#make install\\\r
818 \#echo \verb|"extension=kadm5.so" >>| /etc/php4/apache2/php.ini\\\r
819 \#/etc/init.d/apache2 reload\\\r
820 \hline \end{tabular}\r
821 \r
822 \r