Overview
SHA1:eaeee5f5c5cacb01b7b533a05c473a981e202c4e
Date: 2013-09-02 10:48:58
User: bohwaz
Comment:Arrêtons d'essayer d'être intelligents, dans 90% des cas ça merde
Timelines: family | ancestors | descendants | both | trunk
Downloads: Tarball | ZIP archive
Other Links: files | file ages | folders | manifest
Tags And Properties
Context
2013-09-10
11:35
[583fa92c76] Le graphique des dépenses et recettes était inversé + Fix bug dans la gestion du cache statique (user: bohwaz, tags: trunk)
2013-09-02
10:48
[eaeee5f5c5] Arrêtons d'essayer d'être intelligents, dans 90% des cas ça merde (user: bohwaz, tags: trunk)
2013-08-05
14:33
[5d50b2a2e9] Vérifications plus poussées à l'installation (user: bohwaz, tags: trunk)
Changes

Modified src/index.php from [285e299a05] to [c36e7f7e8f].

1
2





3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
<?php






if (!version_compare(phpversion(), '5.3.0', '>='))
{
	die('PHP 5.3.0 ou supérieur est nécessaire au fonctionnement de Garradin.');
}

define('GARRADIN_INSTALL_PROCESS', true);
require __DIR__ . '/include/init.php';

if (!defined('PHP_SAPI') || file_exists(GARRADIN_ROOT . '/.garradinRootProcessed'))
{
	header('Location: '.WWW_URL);
	exit;
}

if (preg_match('/^apache/', PHP_SAPI))
{
	// On tente de faire un .htaccess qui redirige la racine vers /www/
	// de manière transparente si Garradin n'est pas configuré
	// pour que la racine soit déjà dans www/
	if (!file_exists(__DIR__ . '/.htaccess'))
	{
		file_put_contents(__DIR__ . '/.htaccess',
			"RewriteEngine On\n" .
			"RewriteCond %{REQUEST_URI} !^".WWW_URI."\n" .
			"RewriteRule ^(.*)$ ".WWW_URI."$1 [QSA,L]\n");
	}

	$uri = dirname(WWW_URI);

	if (substr($uri, -1) != '/')
	{
		$uri .= '/';
	}

	$url = 'http' . (!empty($_SERVER['HTTPS']) ? 's' : '') . '://' . $_SERVER['HTTP_HOST'] . $uri;

	$headers = get_headers($url . 'admin/install.php');

	// On regarde si ça redirige bien
	if (!preg_match('!^HTTP/[0-9.]+ 200!', $headers[0]))
	{
		// Sinon on tente de faire une simple redirection
		file_put_contents(__DIR__ . '/.htaccess',
			"RedirectMatch ".dirname(WWW_URI)."/((?!www).*) ".WWW_URI."$1\n");

		$headers = get_headers($url . 'admin/install.php');

		// Si ça ne marche toujours pas tant pis
		if (!preg_match('!^HTTP/[0-9.]+ 302!', $headers[0]))
		{
			unlink(__DIR__ . '/.htaccess');
		}
		else
		{
			// On vérifie quand même que ça ne part pas en redirection infinie
			// normalement c'est impossible mais on sait jamais
			$headers = get_headers($url . 'www/admin/install.php');

			// Redirection infinie ou erreur 500 sur /www/ -> abandon
			if (!preg_match('!^HTTP/[0-9.]+ 404!', $headers[0]))
			{
				unlink(__DIR__ . '/.htaccess');
			}
			else
			{
				// C'est bon pour la redir !
				touch(GARRADIN_ROOT . '/.garradinRootProcessed');
				header('Location: '.WWW_URL);
				exit;
			}
		}
	}
	else
	{
		// C'est bon pour le rewrite !
		touch(GARRADIN_ROOT . '/.garradinRootProcessed');
		file_put_contents(GARRADIN_ROOT . '/config.local.php', '<?php define(\'WWW_URI\', \''.$uri.'\'); ?>');
		header('Location: '.$url);
		exit;
	}
}

// Si serveur non Apache, ou ni RewriteRule ni RedirectMatch ne fonctionnent,
// on empêche quand même de lister les répertoires qui ne sont pas censés être publics
$dir = dir(GARRADIN_ROOT);

while ($file = $dir->read())
{
	if ($file[0] == '.')
	{
		continue;
	}

	if (!is_dir(GARRADIN_ROOT . '/' . $file) || $file == 'www')
	{
		continue;
	}

	file_put_contents(GARRADIN_ROOT . '/' . $file . '/index.html',
		'<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">' .
		'<html><head><title>404 Not Found</title></head><body>' .
		'<h1>Not Found</h1><p>The requested URL was not found on this server.</p>' .
		'</body></html>');
}

$dir->close();

touch(GARRADIN_ROOT . '/.garradinRootProcessed');
header('Location: '.WWW_URL);

?>


>
>
>
>
>
|

|


<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
|
<
<
<
<
<
<
|
<
<
<
|
|
|
|
<
<
|
|








|




|









|


1
2
3
4
5
6
7
8
9
10
11
12





























































13






14



15
16
17
18


19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<?php

// Ce fichier n'est pas censé être appelé sauf si l'installation de Garradin
// n'est pas effectuée correctement avec le vhost pointant sur le répertoire www/
// auquel cas on limite les dégâts

// Juste une vérification avant de continuer
if (!version_compare(phpversion(), '5.4.0', '>='))
{
	die('PHP 5.4.0 ou supérieur est nécessaire au fonctionnement de Garradin.');
}






























































if (file_exists(__DIR__ . '/.garradinRootProcessed'))






{



	header('Location: www/');
	exit;
}



// on empêche de lister les répertoires qui ne sont pas censés être publics
$dir = dir(__DIR__);

while ($file = $dir->read())
{
	if ($file[0] == '.')
	{
		continue;
	}

	if (!is_dir(__DIR__ . '/' . $file) || $file == 'www')
	{
		continue;
	}

	file_put_contents(__DIR__ . '/' . $file . '/index.html',
		'<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">' .
		'<html><head><title>404 Not Found</title></head><body>' .
		'<h1>Not Found</h1><p>The requested URL was not found on this server.</p>' .
		'</body></html>');
}

$dir->close();

touch(GARRADIN_ROOT . '/.garradinRootProcessed');
header('Location: www/');

?>