Merge pull request #6593 from sminnee/env-error

Missing .env error detection
This commit is contained in:
Ingo Schommer 2017-02-27 08:38:10 +13:00 committed by GitHub
commit 6641560987
5 changed files with 98 additions and 54 deletions

View File

@ -8,18 +8,12 @@ body{
.info{ .info{
padding:18px; padding:18px;
background-color:#003050;
position:relative; position:relative;
line-height:24px;
background-image:-webkit-gradient(linear,left top,left bottom,from(#002137),color-stop(10%,#003050),color-stop(90%,#003050),color-stop(90%,#002137));
background-image:-webkit-linear-gradient(#002137,#003050 10%,#003050 90%,#002137);
background-image:linear-gradient(#002137,#003050 10%,#003050 90%,#002137);
z-index:9999; z-index:9999;
} }
.info,.info h1{ .info,.info h1{
margin:0 0 6px; margin:0 0 6px;
color:#fff;
} }
.info h1{ .info h1{
@ -31,35 +25,51 @@ body{
} }
.info h3{ .info h3{
color:#7da4be; color:#003050;
font-size:16px; font-size:16px;
line-height:18px; line-height:18px;
font-weight:400;
} }
.info p{ .info p{
margin:0; margin:0;
font-size:14px; font-size:14px;
color:#fff;
} }
.info a{ .info a{
color:#fff;
font-weight:700; font-weight:700;
text-decoration:none; text-decoration:none;
color:#7da4be;
} }
.info a:active,.info a:hover{ .info a:active,.info a:hover{
color:#fff;
text-decoration:underline; text-decoration:underline;
color:#7da4be;
}
.info li{
font-size:14px;
margin:6px 0;
} }
.header{ .header{
margin:0; background-color:#003050;
border-bottom:6px solid #ccdef3; background-image:-webkit-gradient(linear,left top,left bottom,from(#002137),color-stop(10%,#003050),color-stop(90%,#003050),color-stop(90%,#002137));
height:23px; background-image:-webkit-linear-gradient(#002137,#003050 10%,#003050 90%,#002137);
background-color:#666673; background-image:linear-gradient(#002137,#003050 10%,#003050 90%,#002137);
padding:4px 0 2px 6px; color:#fff;
}
.header h1{
background:url() no-repeat right 3px;
}
.header h3{
color:#7da4be;
font-weight:400;
}
.header a,.header a:active,.header a:hover,.header p{
color:#fff;
} }
.build,.options,.trace{ .build,.options,.trace{
@ -69,11 +79,6 @@ body{
z-index:9999; z-index:9999;
} }
.build li,.options li,.trace li{
font-size:14px;
margin:6px 0;
}
a{ a{
color:#666; color:#666;
} }
@ -149,4 +154,4 @@ fieldset{
background:#ffe9e9; background:#ffe9e9;
border:1px solid #c80700; border:1px solid #c80700;
border-radius:4px; border-radius:4px;
} }

View File

@ -6,15 +6,13 @@ body {
font-family: Helvetica, Arial, sans-serif; font-family: Helvetica, Arial, sans-serif;
} }
/**
* Use class="info" for a regular backgroun
*/
.info { .info {
margin: 0 0 6px 0; margin: 0 0 6px 0;
padding: 18px; padding: 18px;
background-color: #003050;
position: relative; position: relative;
line-height: 24px;
color: #fff;
background-image: linear-gradient(darken(#003050, 5%), #003050 10%, #003050 90%, darken(#003050, 5%));
// try to get the info above the template with z-index // try to get the info above the template with z-index
z-index: 9999; z-index: 9999;
@ -22,7 +20,6 @@ body {
h1 { h1 {
margin: 0 0 6px 0; margin: 0 0 6px 0;
padding: 0 32px 0 0; padding: 0 32px 0 0;
color: #fff;
font-size: 24px; font-size: 24px;
text-shadow: 0 1px darken(#003050, 5%); text-shadow: 0 1px darken(#003050, 5%);
line-height: 30px; line-height: 30px;
@ -31,41 +28,66 @@ body {
} }
h3 { h3 {
color: #7da4be; color: #003050;
font-size: 16px; font-size: 16px;
line-height: 18px; line-height: 18px;
font-weight: normal;
} }
p { p {
margin: 0; margin: 0;
font-size: 14px; font-size: 14px;
}
a {
font-weight: bold;
text-decoration: none;
color: #7da4be;
&:hover,
&:active {
text-decoration: underline;
color: #7da4be;
}
}
li {
font-size: 14px;
margin: 6px 0;
}
}
/**
* Use class="info header" to get the dark background
*/
.header {
background-color: #003050;
background-image: linear-gradient(darken(#003050, 5%), #003050 10%, #003050 90%, darken(#003050, 5%));
color: #fff;
h1 {
background: url("../images/logo_small.png") no-repeat right 3px;
}
h3 {
color: #7da4be;
font-weight: normal;
}
p {
color: #fff; color: #fff;
} }
a { a {
color: #fff; color: #fff;
font-weight: bold;
text-decoration: none;
&:hover, &:hover,
&:active { &:active {
color: #fff; color: #fff;
text-decoration: underline;
} }
} }
} }
.header {
margin: 0;
border-bottom: 6px solid #ccdef3;
height: 23px;
background-color: #666673;
padding: 4px 0 2px 6px;
}
.trace, .trace,
.build, .build,
.options { .options {
@ -76,10 +98,6 @@ body {
position: relative; position: relative;
z-index: 9999; z-index: 9999;
li {
font-size: 14px;
margin: 6px 0;
}
} }
a { a {

View File

@ -184,6 +184,26 @@ global $databaseConfig;
// Redirect to the installer if no database is selected // Redirect to the installer if no database is selected
if(!isset($databaseConfig) || !isset($databaseConfig['database']) || !$databaseConfig['database']) { if(!isset($databaseConfig) || !isset($databaseConfig['database']) || !$databaseConfig['database']) {
// Is there an _ss_environment.php file?
if(file_exists(BASE_PATH . '/_ss_environment.php') || file_exists(dirname(BASE_PATH) . '/_ss_environment.php')) {
header($_SERVER['SERVER_PROTOCOL'] . " 500 Server Error");
$dv = new SilverStripe\Dev\DebugView();
echo $dv->renderHeader();
echo $dv->renderInfo(
"Configuraton Error",
Director::absoluteBaseURL()
);
echo $dv->renderParagraph(
'You need to replace your _ss_environment.php file with a .env file, or with environment variables.<br><br>'
. 'See the <a href="https://docs.silverstripe.org/en/4/getting_started/environment_management/">'
. 'Environment Management</a> docs for more information.'
);
echo $dv->renderFooter();
die();
}
if(!file_exists(BASE_PATH . '/install.php')) { if(!file_exists(BASE_PATH . '/install.php')) {
header($_SERVER['SERVER_PROTOCOL'] . " 500 Server Error"); header($_SERVER['SERVER_PROTOCOL'] . " 500 Server Error");
die('SilverStripe Framework requires a $databaseConfig defined.'); die('SilverStripe Framework requires a $databaseConfig defined.');

View File

@ -237,7 +237,7 @@ class DebugView extends Object
*/ */
public function renderInfo($title, $subtitle, $description = false) public function renderInfo($title, $subtitle, $description = false)
{ {
$output = '<div class="info">'; $output = '<div class="info header">';
$output .= "<h1>" . Convert::raw2xml($title) . "</h1>"; $output .= "<h1>" . Convert::raw2xml($title) . "</h1>";
if ($subtitle) { if ($subtitle) {
$output .= "<h3>" . Convert::raw2xml($subtitle) . "</h3>"; $output .= "<h3>" . Convert::raw2xml($subtitle) . "</h3>";
@ -280,7 +280,7 @@ class DebugView extends Object
} else { } else {
$errstr = Convert::raw2xml($errstr); $errstr = Convert::raw2xml($errstr);
} }
$output = '<div class="info ' . $errorType['class'] . '">'; $output = '<div class="header info ' . $errorType['class'] . '">';
$output .= "<h1>[" . $errorType['title'] . '] ' . $errstr . "</h1>"; $output .= "<h1>[" . $errorType['title'] . '] ' . $errstr . "</h1>";
$output .= "<h3>$httpRequestEnt</h3>"; $output .= "<h3>$httpRequestEnt</h3>";
$output .= "<p>Line <strong>$errline</strong> in <strong>$errfile</strong></p>"; $output .= "<p>Line <strong>$errline</strong> in <strong>$errfile</strong></p>";
@ -298,7 +298,7 @@ class DebugView extends Object
*/ */
public function renderSourceFragment($lines, $errline) public function renderSourceFragment($lines, $errline)
{ {
$output = '<div class="trace"><h3>Source</h3>'; $output = '<div class="info"><h3>Source</h3>';
$output .= '<pre>'; $output .= '<pre>';
foreach ($lines as $offset => $line) { foreach ($lines as $offset => $line) {
$line = htmlentities($line, ENT_COMPAT, 'UTF-8'); $line = htmlentities($line, ENT_COMPAT, 'UTF-8');
@ -308,7 +308,7 @@ class DebugView extends Object
$output .= "<span>$offset</span> $line"; $output .= "<span>$offset</span> $line";
} }
} }
$output .= '</pre>'; $output .= '</pre></div>';
return $output; return $output;
} }
@ -321,7 +321,8 @@ class DebugView extends Object
*/ */
public function renderTrace($trace) public function renderTrace($trace)
{ {
$output = '<h3>Trace</h3>'; $output = '<div class="info">';
$output .= '<h3>Trace</h3>';
$output .= Backtrace::get_rendered_backtrace($trace); $output .= Backtrace::get_rendered_backtrace($trace);
$output .= '</div>'; $output .= '</div>';
@ -336,7 +337,7 @@ class DebugView extends Object
*/ */
public function renderParagraph($text) public function renderParagraph($text)
{ {
return '<p class="info">' . $text . '</p>'; return '<div class="info"><p>' . $text . '</p></div>';
} }
/** /**

View File

@ -588,4 +588,4 @@ body #Footer p{
font-size:18px; font-size:18px;
padding:0 2px 2px 0; padding:0 2px 2px 0;
font-weight:700; font-weight:700;
} }