mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #6593 from sminnee/env-error
Missing .env error detection
This commit is contained in:
commit
6641560987
49
client/dist/styles/debug.css
vendored
49
client/dist/styles/debug.css
vendored
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
20
main.php
20
main.php
@ -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.');
|
||||||
|
@ -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>';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user