Skip to content

Commit 2cf39e7

Browse files
dwightwatsondrujensen
authored andcommitted
Use exception_page shard (#991)
* Use exception_page shard * Restore existing error controller * Restore Error page * Attempt to restore suite * Only return exception page in development * Move exception_page dependency to app template
1 parent 38f01f1 commit 2cf39e7

File tree

3 files changed

+46
-29
lines changed

3 files changed

+46
-29
lines changed

src/amber/cli/templates/app/shard.yml.ecr

+6-3
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,9 @@ dependencies:
5858
version: 0.3.2
5959

6060
development_dependencies:
61-
garnet_spec:
62-
github: amberframework/garnet-spec
63-
version: ~> 0.2.1
61+
exception_page:
62+
github: crystal-loot/exception_page
63+
64+
garnet_spec:
65+
github: amberframework/garnet-spec
66+
version: ~> 0.2.1

src/amber/controller/error.cr

+24-26
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
require "./base"
2+
require "../exceptions/page"
23

34
module Amber::Controller
45
class Error < Base
@@ -7,49 +8,46 @@ module Amber::Controller
78
@context.response.content_type = content_type
89
end
910

10-
def not_found
11-
response_format(@ex.message)
11+
def bad_request
12+
response_format
1213
end
1314

14-
def internal_server_error
15-
response_format("ERROR: #{internal_server_error_message}")
15+
def forbidden
16+
response_format
1617
end
1718

18-
def forbidden
19-
response_format(@ex.message)
19+
def not_found
20+
response_format
21+
end
22+
23+
def internal_server_error
24+
response_format
2025
end
2126

2227
private def content_type
2328
if context.request.headers["Accept"]?
2429
request.headers["Accept"].split(",").first
2530
else
26-
"text/html"
31+
"text/plain"
2732
end
2833
end
2934

30-
private def internal_server_error_message
31-
# IMPORTANT: #inspect_with_backtrace will fail in some situations which breaks the tests.
32-
# Even if you call @ex.callstack you'll notice that backtrace is nil.
33-
# #backtrace? is supposed to be safe but it exceptions anyway.
34-
# Please don't remove this without verifying that crystal core has been fixed first.
35-
@ex.inspect_with_backtrace
36-
rescue ex : IndexError
37-
@ex.message
38-
rescue ex
39-
<<-ERROR
40-
Original Error: #{@ex.message}
41-
Error during 'inspect_with_backtrace': #{ex.message}
42-
ERROR
43-
end
44-
45-
private def response_format(message)
35+
private def response_format
4636
case content_type
4737
when "application/json"
48-
{"error": message}.to_json
38+
{"error": @ex.message}.to_json
4939
when "text/html"
50-
"<html><body><pre>#{message}</pre></body></html>"
40+
html_response
41+
else
42+
@ex.message
43+
end
44+
end
45+
46+
private def html_response
47+
if Amber.env.development?
48+
Amber::Exceptions::Page.for_runtime_exception(context, @ex).to_s
5149
else
52-
message
50+
"<html><body><pre>#{@ex.message}</pre></body></html>"
5351
end
5452
end
5553
end

src/amber/exceptions/page.cr

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
require "exception_page"
2+
3+
module Amber::Exceptions
4+
class Page < ExceptionPage
5+
def styles
6+
ExceptionPage::Styles.new(
7+
accent: "#f4994b",
8+
logo_uri: ""
9+
)
10+
end
11+
12+
def project_url
13+
"https://amberframework.org"
14+
end
15+
end
16+
end

0 commit comments

Comments
 (0)