From 06665e81bcb84b1c3f88ba4968f13f3bf9aa2b31 Mon Sep 17 00:00:00 2001 From: Sijawusz Pur Rahnama Date: Thu, 13 Jun 2019 13:31:45 +0200 Subject: [PATCH 1/8] Use Ameba on Travis CI (#520) --- .travis.yml | 1 + shard.yml | 5 +++++ src/kemal/exception_handler.cr | 2 +- src/kemal/ext/response.cr | 2 +- src/kemal/static_file_handler.cr | 2 +- 5 files changed, 9 insertions(+), 3 deletions(-) diff --git a/.travis.yml b/.travis.yml index 11e436b..9883f5e 100644 --- a/.travis.yml +++ b/.travis.yml @@ -7,6 +7,7 @@ script: - crystal spec - crystal spec --release --no-debug - crystal tool format --check + - bin/ameba src matrix: allow_failures: diff --git a/shard.yml b/shard.yml index 69ec827..6700d8a 100644 --- a/shard.yml +++ b/shard.yml @@ -15,6 +15,11 @@ dependencies: github: crystal-loot/exception_page version: ~> 0.1.1 +development_dependencies: + ameba: + github: veelenga/ameba + version: ~> 0.9.0 + crystal: 0.27.2 license: MIT diff --git a/src/kemal/exception_handler.cr b/src/kemal/exception_handler.cr index 1462832..eee6eec 100644 --- a/src/kemal/exception_handler.cr +++ b/src/kemal/exception_handler.cr @@ -14,7 +14,7 @@ module Kemal log("Exception: #{ex.inspect_with_backtrace}") return call_exception_with_status_code(context, ex, 500) if Kemal.config.error_handlers.has_key?(500) verbosity = Kemal.config.env == "production" ? false : true - return render_500(context, ex, verbosity) + render_500(context, ex, verbosity) end private def call_exception_with_status_code(context : HTTP::Server::Context, exception : Exception, status_code : Int32) diff --git a/src/kemal/ext/response.cr b/src/kemal/ext/response.cr index 1f0a8fd..233bdee 100644 --- a/src/kemal/ext/response.cr +++ b/src/kemal/ext/response.cr @@ -1,7 +1,7 @@ class HTTP::Server::Response class Output def close - unless response.wrote_headers? && !response.headers.has_key?("Content-Range") + if !response.wrote_headers? && response.headers.has_key?("Content-Range") response.content_length = @out_count end diff --git a/src/kemal/static_file_handler.cr b/src/kemal/static_file_handler.cr index 50d1574..11ae98e 100644 --- a/src/kemal/static_file_handler.cr +++ b/src/kemal/static_file_handler.cr @@ -52,7 +52,7 @@ module Kemal context.response.content_type = "text/html" directory_listing(context.response, request_path, file_path) else - return call_next(context) + call_next(context) end elsif File.exists?(file_path) last_modified = modification_time(file_path) From ecaa4237749fabfd0616616711ac8e744d4a54c4 Mon Sep 17 00:00:00 2001 From: sdogruyol Date: Thu, 13 Jun 2019 14:38:41 +0300 Subject: [PATCH 2/8] Bump ameba to 0.10.0 --- shard.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/shard.yml b/shard.yml index 6700d8a..025971a 100644 --- a/shard.yml +++ b/shard.yml @@ -18,7 +18,7 @@ dependencies: development_dependencies: ameba: github: veelenga/ameba - version: ~> 0.9.0 + version: ~> 0.10.0 crystal: 0.27.2 From fc8ac1160cba24714f6a6ceb0ef53af98ed059fb Mon Sep 17 00:00:00 2001 From: sdogruyol Date: Thu, 13 Jun 2019 15:33:11 +0300 Subject: [PATCH 3/8] Add /bin to .gitignore --- .gitignore | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index 5a0d7aa..6c364e4 100644 --- a/.gitignore +++ b/.gitignore @@ -2,7 +2,7 @@ /.crystal/ /.shards/ *.log - +/bin/ # Libraries don't need dependency lock # Dependencies will be locked in application that uses them -/shard.lock +/shard.lock \ No newline at end of file From f3d02e60af2687580425f526ff8adfc579f73efc Mon Sep 17 00:00:00 2001 From: sdogruyol Date: Thu, 13 Jun 2019 15:42:21 +0300 Subject: [PATCH 4/8] Add auto-generated .ameba.yml --- .ameba.yml | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 .ameba.yml diff --git a/.ameba.yml b/.ameba.yml new file mode 100644 index 0000000..bf117f0 --- /dev/null +++ b/.ameba.yml @@ -0,0 +1,33 @@ +# This configuration file was generated by `ameba --gen-config` +# on 2019-06-13 12:39:59 UTC using Ameba version 0.10.0. +# The point is for the user to remove these configuration records +# one by one as the reported problems are removed from the code base. + +# Problems found: 1 +# Run `ameba --only Lint/ShadowingOuterLocalVar` for details +Lint/ShadowingOuterLocalVar: + Description: Disallows the usage of the same name as outer local variables for block + or proc arguments. + Enabled: true + Severity: Warning + Excluded: + - spec/run_spec.cr + +# Problems found: 7 +# Run `ameba --only Lint/UselessAssign` for details +Lint/UselessAssign: + Description: Disallows useless variable assignments + Enabled: true + Severity: Warning + Excluded: + - spec/view_spec.cr + +# Problems found: 1 +# Run `ameba --only Metrics/CyclomaticComplexity` for details +Metrics/CyclomaticComplexity: + Description: Disallows methods with a cyclomatic complexity higher than `MaxComplexity` + MaxComplexity: 10 + Enabled: true + Severity: Convention + Excluded: + - src/kemal/static_file_handler.cr From e3544a86bf002f75d2b341c5343e9ebdbf839f80 Mon Sep 17 00:00:00 2001 From: Anton Maminov Date: Tue, 18 Jun 2019 18:03:32 +0300 Subject: [PATCH 5/8] Do not early return from HTTP::Server::Response::Output.close. Revert what Ameba broke --- .ameba.yml | 31 ++++++++++++++++++++----------- src/kemal/ext/response.cr | 2 +- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/.ameba.yml b/.ameba.yml index bf117f0..cf5dbb2 100644 --- a/.ameba.yml +++ b/.ameba.yml @@ -1,18 +1,8 @@ # This configuration file was generated by `ameba --gen-config` -# on 2019-06-13 12:39:59 UTC using Ameba version 0.10.0. +# on 2019-06-14 15:05:57 UTC using Ameba version 0.10.0. # The point is for the user to remove these configuration records # one by one as the reported problems are removed from the code base. -# Problems found: 1 -# Run `ameba --only Lint/ShadowingOuterLocalVar` for details -Lint/ShadowingOuterLocalVar: - Description: Disallows the usage of the same name as outer local variables for block - or proc arguments. - Enabled: true - Severity: Warning - Excluded: - - spec/run_spec.cr - # Problems found: 7 # Run `ameba --only Lint/UselessAssign` for details Lint/UselessAssign: @@ -22,6 +12,25 @@ Lint/UselessAssign: Excluded: - spec/view_spec.cr +# Problems found: 1 +# Run `ameba --only Lint/ShadowingOuterLocalVar` for details +Lint/ShadowingOuterLocalVar: + Description: Disallows the usage of the same name as outer local variables for block + or proc arguments. + Enabled: true + Severity: Warning + Excluded: + - spec/run_spec.cr + +# Problems found: 1 +# Run `ameba --only Style/NegatedConditionsInUnless` for details +Style/NegatedConditionsInUnless: + Description: Disallows negated conditions in unless + Enabled: true + Severity: Convention + Excluded: + - src/kemal/ext/response.cr + # Problems found: 1 # Run `ameba --only Metrics/CyclomaticComplexity` for details Metrics/CyclomaticComplexity: diff --git a/src/kemal/ext/response.cr b/src/kemal/ext/response.cr index 233bdee..1f0a8fd 100644 --- a/src/kemal/ext/response.cr +++ b/src/kemal/ext/response.cr @@ -1,7 +1,7 @@ class HTTP::Server::Response class Output def close - if !response.wrote_headers? && response.headers.has_key?("Content-Range") + unless response.wrote_headers? && !response.headers.has_key?("Content-Range") response.content_length = @out_count end From 6e2714404d9aa5cc327b960e8647832a5f2c9089 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20M=C3=BCller?= Date: Fri, 26 Jul 2019 10:48:14 +0200 Subject: [PATCH 6/8] Add missing return types to overrides of abstract methods (#544) --- src/kemal/helpers/exception_page.cr | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/kemal/helpers/exception_page.cr b/src/kemal/helpers/exception_page.cr index cf812cd..4ec180c 100644 --- a/src/kemal/helpers/exception_page.cr +++ b/src/kemal/helpers/exception_page.cr @@ -2,7 +2,7 @@ require "exception_page" module Kemal class ExceptionPage < ExceptionPage - def styles + def styles : ExceptionPage::Styles ExceptionPage::Styles.new( accent: "red", logo_uri: "" From 17bf1c7709b6c4e3570ce9ef65c814c529e83ea3 Mon Sep 17 00:00:00 2001 From: "Brian J. Cardiff" Date: Sat, 3 Aug 2019 13:35:40 -0300 Subject: [PATCH 7/8] Upgrade to Crystal v0.30.0 (#548) --- src/kemal/param_parser.cr | 2 +- src/kemal/static_file_handler.cr | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/kemal/param_parser.cr b/src/kemal/param_parser.cr index 7dfb52b..92c3112 100644 --- a/src/kemal/param_parser.cr +++ b/src/kemal/param_parser.cr @@ -24,7 +24,7 @@ module Kemal end private def unescape_url_param(value : String) - value.empty? ? value : URI.unescape(value) + value.empty? ? value : URI.decode(value) rescue value end diff --git a/src/kemal/static_file_handler.cr b/src/kemal/static_file_handler.cr index 11ae98e..cd83749 100644 --- a/src/kemal/static_file_handler.cr +++ b/src/kemal/static_file_handler.cr @@ -21,7 +21,7 @@ module Kemal config = Kemal.config.serve_static original_path = context.request.path.not_nil! - request_path = URI.unescape(original_path) + request_path = URI.decode(original_path) # File path cannot contains '\0' (NUL) because all filesystem I know # don't accept '\0' character as file name. From 18ddc3b4e6232ad7674d756c3d507da94398c7d6 Mon Sep 17 00:00:00 2001 From: Omar Roth Date: Sat, 3 Aug 2019 11:37:23 -0500 Subject: [PATCH 8/8] Fix static file handler for files > 2^31 bytes (#546) --- src/kemal/helpers/helpers.cr | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/kemal/helpers/helpers.cr b/src/kemal/helpers/helpers.cr index 821d47e..7baf851 100644 --- a/src/kemal/helpers/helpers.cr +++ b/src/kemal/helpers/helpers.cr @@ -184,26 +184,26 @@ end private def multipart(file, env : HTTP::Server::Context) # See http://httpwg.org/specs/rfc7233.html fileb = file.size - startb = endb = 0 + startb = endb = 0_i64 if match = env.request.headers["Range"].match /bytes=(\d{1,})-(\d{0,})/ - startb = match[1].to_i { 0 } if match.size >= 2 - endb = match[2].to_i { 0 } if match.size >= 3 + startb = match[1].to_i64 { 0_i64 } if match.size >= 2 + endb = match[2].to_i64 { 0_i64 } if match.size >= 3 end endb = fileb - 1 if endb == 0 if startb < endb < fileb - content_length = 1 + endb - startb + content_length = 1_i64 + endb - startb env.response.status_code = 206 env.response.content_length = content_length env.response.headers["Accept-Ranges"] = "bytes" env.response.headers["Content-Range"] = "bytes #{startb}-#{endb}/#{fileb}" # MUST if startb > 1024 - skipped = 0 + skipped = 0_i64 # file.skip only accepts values less or equal to 1024 (buffer size, undocumented) - until (increase_skipped = skipped + 1024) > startb + until (increase_skipped = skipped + 1024_i64) > startb file.skip(1024) skipped = increase_skipped end