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{
padding:18px;
background-color:#003050;
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;
}
.info,.info h1{
margin:0 0 6px;
color:#fff;
}
.info h1{
@ -31,35 +25,51 @@ body{
}
.info h3{
color:#7da4be;
color:#003050;
font-size:16px;
line-height:18px;
font-weight:400;
}
.info p{
margin:0;
font-size:14px;
color:#fff;
}
.info a{
color:#fff;
font-weight:700;
text-decoration:none;
color:#7da4be;
}
.info a:active,.info a:hover{
color:#fff;
text-decoration:underline;
color:#7da4be;
}
.info li{
font-size:14px;
margin:6px 0;
}
.header{
margin:0;
border-bottom:6px solid #ccdef3;
height:23px;
background-color:#666673;
padding:4px 0 2px 6px;
background-color:#003050;
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);
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{
@ -69,11 +79,6 @@ body{
z-index:9999;
}
.build li,.options li,.trace li{
font-size:14px;
margin:6px 0;
}
a{
color:#666;
}
@ -149,4 +154,4 @@ fieldset{
background:#ffe9e9;
border:1px solid #c80700;
border-radius:4px;
}
}

View File

@ -6,15 +6,13 @@ body {
font-family: Helvetica, Arial, sans-serif;
}
/**
* Use class="info" for a regular backgroun
*/
.info {
margin: 0 0 6px 0;
padding: 18px;
background-color: #003050;
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
z-index: 9999;
@ -22,7 +20,6 @@ body {
h1 {
margin: 0 0 6px 0;
padding: 0 32px 0 0;
color: #fff;
font-size: 24px;
text-shadow: 0 1px darken(#003050, 5%);
line-height: 30px;
@ -31,41 +28,66 @@ body {
}
h3 {
color: #7da4be;
color: #003050;
font-size: 16px;
line-height: 18px;
font-weight: normal;
}
p {
margin: 0;
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;
}
a {
color: #fff;
font-weight: bold;
text-decoration: none;
&:hover,
&:active {
color: #fff;
text-decoration: underline;
}
}
}
.header {
margin: 0;
border-bottom: 6px solid #ccdef3;
height: 23px;
background-color: #666673;
padding: 4px 0 2px 6px;
}
.trace,
.build,
.options {
@ -76,10 +98,6 @@ body {
position: relative;
z-index: 9999;
li {
font-size: 14px;
margin: 6px 0;
}
}
a {

View File

@ -184,6 +184,26 @@ global $databaseConfig;
// Redirect to the installer if no database is selected
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')) {
header($_SERVER['SERVER_PROTOCOL'] . " 500 Server Error");
die('SilverStripe Framework requires a $databaseConfig defined.');

View File

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