Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use exception_page shard #991

Merged
merged 6 commits into from
Dec 13, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 6 additions & 3 deletions src/amber/cli/templates/app/shard.yml.ecr
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,9 @@ dependencies:
version: 0.3.2

development_dependencies:
garnet_spec:
github: amberframework/garnet-spec
version: ~> 0.2.1
exception_page:
github: crystal-loot/exception_page

garnet_spec:
github: amberframework/garnet-spec
version: ~> 0.2.1
50 changes: 24 additions & 26 deletions src/amber/controller/error.cr
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
require "./base"
require "../exceptions/page"

module Amber::Controller
class Error < Base
Expand All @@ -7,49 +8,46 @@ module Amber::Controller
@context.response.content_type = content_type
end

def not_found
response_format(@ex.message)
def bad_request
response_format
end

def internal_server_error
response_format("ERROR: #{internal_server_error_message}")
def forbidden
response_format
end

def forbidden
response_format(@ex.message)
def not_found
response_format
end

def internal_server_error
response_format
end

private def content_type
if context.request.headers["Accept"]?
request.headers["Accept"].split(",").first
else
"text/html"
"text/plain"
end
end

private def internal_server_error_message
# IMPORTANT: #inspect_with_backtrace will fail in some situations which breaks the tests.
# Even if you call @ex.callstack you'll notice that backtrace is nil.
# #backtrace? is supposed to be safe but it exceptions anyway.
# Please don't remove this without verifying that crystal core has been fixed first.
@ex.inspect_with_backtrace
rescue ex : IndexError
@ex.message
rescue ex
<<-ERROR
Original Error: #{@ex.message}
Error during 'inspect_with_backtrace': #{ex.message}
ERROR
end

private def response_format(message)
private def response_format
case content_type
when "application/json"
{"error": message}.to_json
{"error": @ex.message}.to_json
when "text/html"
"<html><body><pre>#{message}</pre></body></html>"
html_response
else
@ex.message
end
end

private def html_response
if Amber.env.development?
Amber::Exceptions::Page.for_runtime_exception(context, @ex).to_s
else
message
"<html><body><pre>#{@ex.message}</pre></body></html>"
end
end
end
Expand Down
16 changes: 16 additions & 0 deletions src/amber/exceptions/page.cr
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
require "exception_page"

module Amber::Exceptions
class Page < ExceptionPage
def styles
ExceptionPage::Styles.new(
accent: "#f4994b",
logo_uri: ""
)
end

def project_url
"https://amberframework.org"
end
end
end