From 6fc556cf8cd1931a81ff5fcee369410fd6e25621 Mon Sep 17 00:00:00 2001 From: "Brian J. Cardiff" Date: Tue, 30 Jul 2019 09:52:29 -0300 Subject: [PATCH 1/9] Annotate return types of, and implement abstract methods --- src/amber/controller/filters.cr | 6 ++++++ src/amber/exceptions/page.cr | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/src/amber/controller/filters.cr b/src/amber/controller/filters.cr index fe6a8287a..5c20aec33 100644 --- a/src/amber/controller/filters.cr +++ b/src/amber/controller/filters.cr @@ -80,6 +80,12 @@ module Amber::Controller filters[filter.precedence] << filter end + def each(&block : {Symbol, Array(Filter)} -> _) + filters.each do |key, filter| + yield({key, filter}) + end + end + def run(precedence : Symbol, action : Symbol, except_action : Symbol | Nil = nil) filters[precedence].each do |filter| next if except_filter_and_has_action?(filter, except_action) diff --git a/src/amber/exceptions/page.cr b/src/amber/exceptions/page.cr index 4005d619b..afd237769 100644 --- a/src/amber/exceptions/page.cr +++ b/src/amber/exceptions/page.cr @@ -2,7 +2,7 @@ require "exception_page" module Amber::Exceptions class Page < ExceptionPage - def styles + def styles : ExceptionPage::Styles ExceptionPage::Styles.new( accent: "#f4994b", logo_uri: "" From 9c5e6e30ea709b55c9a318eedc8d578845a25f05 Mon Sep 17 00:00:00 2001 From: "Brian J. Cardiff" Date: Tue, 30 Jul 2019 19:24:23 -0300 Subject: [PATCH 2/9] Upgrade to Crystal v0.30.0 --- src/amber/pipes/static.cr | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/amber/pipes/static.cr b/src/amber/pipes/static.cr index e6e052e8b..827d0b7a6 100644 --- a/src/amber/pipes/static.cr +++ b/src/amber/pipes/static.cr @@ -11,7 +11,7 @@ module Amber return allow_get_or_head(context) unless method_get_or_head?(context.request.method) 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 f0a50ccc5a68c29ec5d8db8d9f1abbfa34320cbc Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Tue, 6 Aug 2019 21:56:01 -0700 Subject: [PATCH 3/9] shard updates --- shard.yml | 10 +++++----- src/amber/cli/templates/app/shard.yml.ecr | 8 ++++---- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/shard.yml b/shard.yml index c3b72f83a..adcf7def7 100644 --- a/shard.yml +++ b/shard.yml @@ -32,7 +32,7 @@ dependencies: liquid: github: TechMagister/liquid.cr - version: ~> 0.3.0 + #version: ~> 0.3.0 micrate: github: amberframework/micrate @@ -40,15 +40,15 @@ dependencies: pg: github: will/crystal-pg - version: ~> 0.16.1 + version: ~> 0.18.0 mysql: github: crystal-lang/crystal-mysql - version: ~> 0.6.0 + version: ~> 0.8.0 sqlite3: github: crystal-lang/crystal-sqlite3 - version: ~> 0.12.0 + version: ~> 0.13.0 redis: github: stefanwille/crystal-redis @@ -68,7 +68,7 @@ dependencies: teeplate: github: mosop/teeplate - version: ~> 0.7.0 + version: ~> 0.8.0 exception_page: github: crystal-loot/exception_page diff --git a/src/amber/cli/templates/app/shard.yml.ecr b/src/amber/cli/templates/app/shard.yml.ecr index c23555bcf..a18820c72 100644 --- a/src/amber/cli/templates/app/shard.yml.ecr +++ b/src/amber/cli/templates/app/shard.yml.ecr @@ -36,20 +36,20 @@ dependencies: <% case @database when "pg" -%> pg: github: will/crystal-pg - version: ~> 0.16.1 + version: ~> 0.18.0 <% when "mysql" -%> mysql: github: crystal-lang/crystal-mysql - version: ~> 0.6.0 + version: ~> 0.8.0 <% when "sqlite" -%> sqlite3: github: crystal-lang/crystal-sqlite3 - version: ~> 0.12.0 + version: ~> 0.13.0 <% end -%> citrine-i18n: github: amberframework/citrine-i18n - version: 0.3.2 + version: 0.4.0 development_dependencies: garnet_spec: From 11d48fd20702d0fda706d11e7e86a00438f29f99 Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Wed, 7 Aug 2019 05:43:53 -0700 Subject: [PATCH 4/9] Update granite to latest DSL --- shard.yml | 4 ++-- src/amber/cli/templates/app/config/database.cr.ecr | 2 +- src/amber/cli/templates/app/shard.yml.ecr | 2 +- src/amber/cli/templates/model/src/models/{{name}}.cr.ecr | 8 ++++---- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/shard.yml b/shard.yml index adcf7def7..ccb5f861a 100644 --- a/shard.yml +++ b/shard.yml @@ -19,8 +19,8 @@ dependencies: version: ~> 0.3.0 cli: - github: mosop/cli - version: ~> 0.7.0 + github: drujensen/cli + version: ~> 0.8.0 compiled_license: github: elorest/compiled_license diff --git a/src/amber/cli/templates/app/config/database.cr.ecr b/src/amber/cli/templates/app/config/database.cr.ecr index c1d93bd46..3dc4c80b0 100644 --- a/src/amber/cli/templates/app/config/database.cr.ecr +++ b/src/amber/cli/templates/app/config/database.cr.ecr @@ -1,5 +1,5 @@ require "granite/adapter/<%= @database %>" -Granite::Adapters << Granite::Adapter::<%= @database.capitalize %>.new({name: "<%= @database %>", url: Amber.settings.database_url}) +Granite::Connections << Granite::Adapter::<%= @database.capitalize %>.new({name: "<%= @database %>", url: Amber.settings.database_url}) Granite.settings.logger = Amber.settings.logger.dup Granite.settings.logger.not_nil!.progname = "Granite" diff --git a/src/amber/cli/templates/app/shard.yml.ecr b/src/amber/cli/templates/app/shard.yml.ecr index a18820c72..664690b5d 100644 --- a/src/amber/cli/templates/app/shard.yml.ecr +++ b/src/amber/cli/templates/app/shard.yml.ecr @@ -23,7 +23,7 @@ dependencies: granite: github: amberframework/granite - version: ~> 0.16.0 + version: ~> 0.17.0 quartz_mailer: github: amberframework/quartz-mailer diff --git a/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr b/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr index 92a8c8ce1..73111e541 100644 --- a/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr +++ b/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr @@ -1,13 +1,13 @@ class <%= class_name %> < Granite::Base - adapter <%= config.database %> - <%= "table_name #{table_name}" %> + connection <%= config.database %> + <%= "table #{table_name}" %> <% @fields.select{|f| f.reference? }.each do |field| %> belongs_to :<%= field.name %> <% end -%> - primary id : Int64 + column id : Int64, primary: true <% @fields.reject{|f| f.hidden || f.reference? }.each do |field| -%> - field <%= field.name %> : <%= field.cr_type %> + column <%= field.name %> : <%= field.cr_type %> <% end -%> <% if config.database != "sqlite" -%> timestamps From 23b78d61a216a2667fe875609872edfe2fdb226d Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Wed, 7 Aug 2019 05:49:45 -0700 Subject: [PATCH 5/9] update specs and fix auth generator --- spec/amber/cli/commands/init_spec.cr | 2 +- spec/support/fixtures/cli_fixtures.cr | 14 +++++++------- .../cli/templates/auth/src/models/{{name}}.cr.ecr | 8 ++++---- 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/spec/amber/cli/commands/init_spec.cr b/spec/amber/cli/commands/init_spec.cr index dc9ac0912..f4b23e97f 100644 --- a/spec/amber/cli/commands/init_spec.cr +++ b/spec/amber/cli/commands/init_spec.cr @@ -22,7 +22,7 @@ module Amber::CLI [camel_case, snake_case].each do |arg| MainCommand.run ["generate", "model", "-y", arg] filename = snake_case - granite_table_name = "table_name #{snake_case}s" + granite_table_name = "table #{snake_case}s" src_filepath = "./src/models/#{filename}.cr" spec_filepath = "./spec/models/#{filename}_spec.cr" File.exists?(src_filepath).should be_true diff --git a/spec/support/fixtures/cli_fixtures.cr b/spec/support/fixtures/cli_fixtures.cr index f42b918d6..7d84fe2c9 100644 --- a/spec/support/fixtures/cli_fixtures.cr +++ b/spec/support/fixtures/cli_fixtures.cr @@ -56,16 +56,16 @@ module CLIFixtures def expected_post_model <<-MODEL class Post < Granite::Base - adapter pg - table_name posts + connection pg + table posts belongs_to :user - primary id : Int64 - field title : String - field body : String - field published : Bool - field likes : Int32 + column id : Int64, primary: true + column title : String + column body : String + column published : Bool + column likes : Int32 timestamps end diff --git a/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr b/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr index d36a48606..478afd39f 100644 --- a/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr +++ b/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr @@ -2,12 +2,12 @@ require "crypto/bcrypt/password" class <%= class_name %> < Granite::Base include Crypto - adapter <%= config.database %> - <%= "table_name #{table_name}" %> + connection <%= config.database %> + <%= "table #{table_name}" %> - primary id : Int64 + column id : Int64, primary: true <% @fields.reject{|f| f.hidden }.each do |field| -%> - field <%= field.name %> : <%= field.cr_type %> + column <%= field.name %> : <%= field.cr_type %> <% end -%> <% if config.database != "sqlite" -%> timestamps From 7f92a477360bc3ba2515cd5faa763cb796956b7d Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Wed, 7 Aug 2019 06:37:02 -0700 Subject: [PATCH 6/9] template fixes --- src/amber/cli/templates/app/config/database.cr.ecr | 2 +- src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr | 2 +- src/amber/cli/templates/model/src/models/{{name}}.cr.ecr | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/amber/cli/templates/app/config/database.cr.ecr b/src/amber/cli/templates/app/config/database.cr.ecr index 3dc4c80b0..690947757 100644 --- a/src/amber/cli/templates/app/config/database.cr.ecr +++ b/src/amber/cli/templates/app/config/database.cr.ecr @@ -1,5 +1,5 @@ require "granite/adapter/<%= @database %>" -Granite::Connections << Granite::Adapter::<%= @database.capitalize %>.new({name: "<%= @database %>", url: Amber.settings.database_url}) +Granite::Connections << Granite::Adapter::<%= @database.capitalize %>.new(name: "<%= @database %>", url: Amber.settings.database_url) Granite.settings.logger = Amber.settings.logger.dup Granite.settings.logger.not_nil!.progname = "Granite" diff --git a/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr b/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr index 478afd39f..889eba557 100644 --- a/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr +++ b/src/amber/cli/templates/auth/src/models/{{name}}.cr.ecr @@ -7,7 +7,7 @@ class <%= class_name %> < Granite::Base column id : Int64, primary: true <% @fields.reject{|f| f.hidden }.each do |field| -%> - column <%= field.name %> : <%= field.cr_type %> + column <%= field.name %> : <%= field.cr_type %>? <% end -%> <% if config.database != "sqlite" -%> timestamps diff --git a/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr b/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr index 73111e541..4390a9946 100644 --- a/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr +++ b/src/amber/cli/templates/model/src/models/{{name}}.cr.ecr @@ -7,7 +7,7 @@ class <%= class_name %> < Granite::Base column id : Int64, primary: true <% @fields.reject{|f| f.hidden || f.reference? }.each do |field| -%> - column <%= field.name %> : <%= field.cr_type %> + column <%= field.name %> : <%= field.cr_type %>? <% end -%> <% if config.database != "sqlite" -%> timestamps From 7501dadf8a4e83c0639b5135770fdb2f20298ec4 Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Wed, 7 Aug 2019 07:48:44 -0700 Subject: [PATCH 7/9] use compatible garnet-spec --- src/amber/cli/templates/app/shard.yml.ecr | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/amber/cli/templates/app/shard.yml.ecr b/src/amber/cli/templates/app/shard.yml.ecr index 664690b5d..ab38f1343 100644 --- a/src/amber/cli/templates/app/shard.yml.ecr +++ b/src/amber/cli/templates/app/shard.yml.ecr @@ -54,4 +54,4 @@ dependencies: development_dependencies: garnet_spec: github: amberframework/garnet-spec - version: ~> 0.2.1 + version: 0.2.1 From aa4504798cf04a38b8cfc0ed4458fae8aa207afd Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Wed, 7 Aug 2019 11:06:35 -0700 Subject: [PATCH 8/9] fix specs --- spec/amber/router/cookies_spec.cr | 2 +- spec/support/fixtures/cli_fixtures.cr | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/spec/amber/router/cookies_spec.cr b/spec/amber/router/cookies_spec.cr index 31a3b7bad..9ceb5437f 100644 --- a/spec/amber/router/cookies_spec.cr +++ b/spec/amber/router/cookies_spec.cr @@ -40,7 +40,7 @@ module Amber::Router cookies.set "that & guy", "foo & bar => baz" - cookie_header(cookies).should eq "that%20%26%20guy=foo%20%26%20bar%20%3D%3E%20baz; path=/" + cookie_header(cookies).should eq "that+%26+guy=foo+%26+bar+%3D%3E+baz; path=/" end it "sets the cookie with expiration" do diff --git a/spec/support/fixtures/cli_fixtures.cr b/spec/support/fixtures/cli_fixtures.cr index 7d84fe2c9..dbf61cfc9 100644 --- a/spec/support/fixtures/cli_fixtures.cr +++ b/spec/support/fixtures/cli_fixtures.cr @@ -62,10 +62,10 @@ module CLIFixtures belongs_to :user column id : Int64, primary: true - column title : String - column body : String - column published : Bool - column likes : Int32 + column title : String? + column body : String? + column published : Bool? + column likes : Int32? timestamps end From 0d1f4fad7656e9c4718973849f6a50201d1d1a13 Mon Sep 17 00:00:00 2001 From: Dru Jensen Date: Wed, 7 Aug 2019 11:08:27 -0700 Subject: [PATCH 9/9] update version in docker file --- Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Dockerfile b/Dockerfile index b0367a689..72c5c2523 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM crystallang/crystal:0.29.0 +FROM crystallang/crystal:0.30.0 # Install Dependencies ARG DEBIAN_FRONTEND=noninteractive