hanami 1.3.5 → 2.0.0.alpha4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (172) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +196 -5
  3. data/FEATURES.md +1 -3
  4. data/README.md +4 -4
  5. data/hanami.gemspec +27 -30
  6. data/lib/hanami/application/autoloader/inflector_adapter.rb +22 -0
  7. data/lib/hanami/application/container/boot/inflector.rb +7 -0
  8. data/lib/hanami/application/container/boot/logger.rb +7 -0
  9. data/lib/hanami/application/container/boot/rack_logger.rb +19 -0
  10. data/lib/hanami/application/container/boot/rack_monitor.rb +12 -0
  11. data/lib/hanami/application/container/boot/routes_helper.rb +9 -0
  12. data/lib/hanami/application/container/boot/settings.rb +7 -0
  13. data/lib/hanami/application/router.rb +59 -0
  14. data/lib/hanami/application/routes.rb +55 -0
  15. data/lib/hanami/application/routes_helper.rb +34 -0
  16. data/lib/hanami/application/routing/middleware/stack.rb +89 -0
  17. data/lib/hanami/application/routing/resolver/node.rb +50 -0
  18. data/lib/hanami/application/routing/resolver/trie.rb +59 -0
  19. data/lib/hanami/application/routing/resolver.rb +87 -0
  20. data/lib/hanami/application/settings/dotenv_store.rb +60 -0
  21. data/lib/hanami/application/settings.rb +93 -0
  22. data/lib/hanami/application.rb +349 -174
  23. data/lib/hanami/assets/application_configuration.rb +63 -0
  24. data/lib/hanami/assets/configuration.rb +54 -0
  25. data/lib/hanami/boot.rb +5 -0
  26. data/lib/hanami/cli/application/cli.rb +40 -0
  27. data/lib/hanami/cli/application/command.rb +47 -0
  28. data/lib/hanami/cli/application/commands/console.rb +81 -0
  29. data/lib/hanami/cli/application/commands.rb +16 -0
  30. data/lib/hanami/cli/base_command.rb +48 -0
  31. data/lib/hanami/cli/commands/command.rb +23 -31
  32. data/lib/hanami/cli/commands/server.rb +63 -14
  33. data/lib/hanami/cli/commands.rb +5 -41
  34. data/lib/hanami/configuration/logger.rb +40 -0
  35. data/lib/hanami/configuration/middleware.rb +9 -29
  36. data/lib/hanami/configuration/null_configuration.rb +14 -0
  37. data/lib/hanami/configuration/router.rb +52 -0
  38. data/lib/hanami/configuration/sessions.rb +50 -0
  39. data/lib/hanami/configuration.rb +152 -185
  40. data/lib/hanami/init.rb +5 -0
  41. data/lib/hanami/server.rb +5 -69
  42. data/lib/hanami/setup.rb +8 -2
  43. data/lib/hanami/slice.rb +167 -0
  44. data/lib/hanami/version.rb +3 -1
  45. data/lib/hanami/web/rack_logger.rb +96 -0
  46. data/lib/hanami.rb +42 -241
  47. metadata +88 -222
  48. data/bin/hanami +0 -6
  49. data/lib/hanami/action/csrf_protection.rb +0 -211
  50. data/lib/hanami/action/routing_helpers.rb +0 -40
  51. data/lib/hanami/app.rb +0 -96
  52. data/lib/hanami/application_configuration.rb +0 -1495
  53. data/lib/hanami/application_name.rb +0 -108
  54. data/lib/hanami/application_namespace.rb +0 -14
  55. data/lib/hanami/assets/asset.rb +0 -72
  56. data/lib/hanami/assets/static.rb +0 -102
  57. data/lib/hanami/cli/commands/assets/precompile.rb +0 -42
  58. data/lib/hanami/cli/commands/assets.rb +0 -16
  59. data/lib/hanami/cli/commands/console.rb +0 -95
  60. data/lib/hanami/cli/commands/db/apply.rb +0 -32
  61. data/lib/hanami/cli/commands/db/console.rb +0 -44
  62. data/lib/hanami/cli/commands/db/create.rb +0 -32
  63. data/lib/hanami/cli/commands/db/drop.rb +0 -32
  64. data/lib/hanami/cli/commands/db/migrate.rb +0 -39
  65. data/lib/hanami/cli/commands/db/prepare.rb +0 -32
  66. data/lib/hanami/cli/commands/db/rollback.rb +0 -59
  67. data/lib/hanami/cli/commands/db/version.rb +0 -32
  68. data/lib/hanami/cli/commands/db.rb +0 -32
  69. data/lib/hanami/cli/commands/destroy/action.rb +0 -137
  70. data/lib/hanami/cli/commands/destroy/app.rb +0 -159
  71. data/lib/hanami/cli/commands/destroy/mailer.rb +0 -74
  72. data/lib/hanami/cli/commands/destroy/migration.rb +0 -51
  73. data/lib/hanami/cli/commands/destroy/model.rb +0 -84
  74. data/lib/hanami/cli/commands/destroy.rb +0 -26
  75. data/lib/hanami/cli/commands/generate/action/action.erb +0 -7
  76. data/lib/hanami/cli/commands/generate/action/action_spec.minitest.erb +0 -11
  77. data/lib/hanami/cli/commands/generate/action/action_spec.rspec.erb +0 -9
  78. data/lib/hanami/cli/commands/generate/action/action_without_view.erb +0 -7
  79. data/lib/hanami/cli/commands/generate/action/view.erb +0 -7
  80. data/lib/hanami/cli/commands/generate/action/view_spec.minitest.erb +0 -12
  81. data/lib/hanami/cli/commands/generate/action/view_spec.rspec.erb +0 -10
  82. data/lib/hanami/cli/commands/generate/action.rb +0 -321
  83. data/lib/hanami/cli/commands/generate/app/application.erb +0 -313
  84. data/lib/hanami/cli/commands/generate/app/favicon.ico +0 -0
  85. data/lib/hanami/cli/commands/generate/app/gitkeep.erb +0 -0
  86. data/lib/hanami/cli/commands/generate/app/layout.erb +0 -7
  87. data/lib/hanami/cli/commands/generate/app/layout_spec.minitest.erb +0 -10
  88. data/lib/hanami/cli/commands/generate/app/layout_spec.rspec.erb +0 -10
  89. data/lib/hanami/cli/commands/generate/app/routes.erb +0 -5
  90. data/lib/hanami/cli/commands/generate/app/template.erb.erb +0 -10
  91. data/lib/hanami/cli/commands/generate/app/template.haml.erb +0 -7
  92. data/lib/hanami/cli/commands/generate/app/template.slim.erb +0 -8
  93. data/lib/hanami/cli/commands/generate/app.rb +0 -243
  94. data/lib/hanami/cli/commands/generate/mailer/mailer.erb +0 -9
  95. data/lib/hanami/cli/commands/generate/mailer/mailer_spec.minitest.erb +0 -7
  96. data/lib/hanami/cli/commands/generate/mailer/mailer_spec.rspec.erb +0 -5
  97. data/lib/hanami/cli/commands/generate/mailer.rb +0 -104
  98. data/lib/hanami/cli/commands/generate/migration/migration.erb +0 -4
  99. data/lib/hanami/cli/commands/generate/migration.rb +0 -41
  100. data/lib/hanami/cli/commands/generate/model/entity.erb +0 -2
  101. data/lib/hanami/cli/commands/generate/model/entity_spec.minitest.erb +0 -5
  102. data/lib/hanami/cli/commands/generate/model/entity_spec.rspec.erb +0 -3
  103. data/lib/hanami/cli/commands/generate/model/migration.erb +0 -10
  104. data/lib/hanami/cli/commands/generate/model/repository.erb +0 -5
  105. data/lib/hanami/cli/commands/generate/model/repository_spec.minitest.erb +0 -5
  106. data/lib/hanami/cli/commands/generate/model/repository_spec.rspec.erb +0 -3
  107. data/lib/hanami/cli/commands/generate/model.rb +0 -125
  108. data/lib/hanami/cli/commands/generate/secret.rb +0 -48
  109. data/lib/hanami/cli/commands/generate.rb +0 -28
  110. data/lib/hanami/cli/commands/new/.env.development.erb +0 -3
  111. data/lib/hanami/cli/commands/new/.env.test.erb +0 -3
  112. data/lib/hanami/cli/commands/new/.gitkeep.erb +0 -0
  113. data/lib/hanami/cli/commands/new/Gemfile.erb +0 -57
  114. data/lib/hanami/cli/commands/new/README.md.erb +0 -33
  115. data/lib/hanami/cli/commands/new/config/boot.erb +0 -2
  116. data/lib/hanami/cli/commands/new/config/environment.erb +0 -49
  117. data/lib/hanami/cli/commands/new/config.ru.erb +0 -3
  118. data/lib/hanami/cli/commands/new/gitignore.erb +0 -4
  119. data/lib/hanami/cli/commands/new/gitignore_with_sqlite.erb +0 -5
  120. data/lib/hanami/cli/commands/new/hanamirc.erb +0 -3
  121. data/lib/hanami/cli/commands/new/lib/project.erb +0 -2
  122. data/lib/hanami/cli/commands/new/minitest/Rakefile.erb +0 -12
  123. data/lib/hanami/cli/commands/new/minitest/features_helper.erb +0 -11
  124. data/lib/hanami/cli/commands/new/minitest/spec_helper.erb +0 -7
  125. data/lib/hanami/cli/commands/new/rspec/Rakefile.erb +0 -9
  126. data/lib/hanami/cli/commands/new/rspec/capybara.erb +0 -8
  127. data/lib/hanami/cli/commands/new/rspec/features_helper.erb +0 -12
  128. data/lib/hanami/cli/commands/new/rspec/rspec.erb +0 -2
  129. data/lib/hanami/cli/commands/new/rspec/spec_helper.erb +0 -103
  130. data/lib/hanami/cli/commands/new/schema.sql.erb +0 -0
  131. data/lib/hanami/cli/commands/new.rb +0 -578
  132. data/lib/hanami/cli/commands/project.rb +0 -421
  133. data/lib/hanami/cli/commands/routes.rb +0 -21
  134. data/lib/hanami/cli/commands/templates.rb +0 -31
  135. data/lib/hanami/cli/commands/version.rb +0 -19
  136. data/lib/hanami/common_logger.rb +0 -109
  137. data/lib/hanami/components/app/assets.rb +0 -59
  138. data/lib/hanami/components/app/controller.rb +0 -74
  139. data/lib/hanami/components/app/routes.rb +0 -59
  140. data/lib/hanami/components/app/view.rb +0 -44
  141. data/lib/hanami/components/component.rb +0 -182
  142. data/lib/hanami/components/components.rb +0 -479
  143. data/lib/hanami/components/routes_inspector.rb +0 -72
  144. data/lib/hanami/components.rb +0 -156
  145. data/lib/hanami/config/cookies.rb +0 -69
  146. data/lib/hanami/config/framework_configuration.rb +0 -43
  147. data/lib/hanami/config/load_paths.rb +0 -46
  148. data/lib/hanami/config/mapper.rb +0 -47
  149. data/lib/hanami/config/routes.rb +0 -20
  150. data/lib/hanami/config/security.rb +0 -110
  151. data/lib/hanami/config/sessions.rb +0 -119
  152. data/lib/hanami/configuration/app.rb +0 -21
  153. data/lib/hanami/early_hints.rb +0 -129
  154. data/lib/hanami/env.rb +0 -69
  155. data/lib/hanami/environment.rb +0 -541
  156. data/lib/hanami/environment_application_configurations.rb +0 -37
  157. data/lib/hanami/frameworks.rb +0 -22
  158. data/lib/hanami/hanamirc.rb +0 -169
  159. data/lib/hanami/mailer/glue.rb +0 -27
  160. data/lib/hanami/middleware_stack.rb +0 -172
  161. data/lib/hanami/rake_helper.rb +0 -78
  162. data/lib/hanami/rake_tasks.rb +0 -3
  163. data/lib/hanami/rendering_policy.rb +0 -94
  164. data/lib/hanami/routes.rb +0 -219
  165. data/lib/hanami/routing/default.rb +0 -32
  166. data/lib/hanami/static.rb +0 -63
  167. data/lib/hanami/templates/default.html.erb +0 -30
  168. data/lib/hanami/templates/welcome.html.erb +0 -52
  169. data/lib/hanami/views/default.rb +0 -37
  170. data/lib/hanami/views/default_template_finder.rb +0 -22
  171. data/lib/hanami/views/null_view.rb +0 -15
  172. data/lib/hanami/welcome.rb +0 -41
@@ -1,211 +0,0 @@
1
- require 'securerandom'
2
-
3
- module Hanami
4
- # @api private
5
- module Action
6
- # Invalid CSRF Token
7
- #
8
- # @since 0.4.0
9
- class InvalidCSRFTokenError < ::StandardError
10
- end
11
-
12
- # CSRF Protection
13
- #
14
- # This security mechanism is enabled automatically if sessions are turned on.
15
- #
16
- # It stores a "challenge" token in session. For each "state changing request"
17
- # (eg. <tt>POST</tt>, <tt>PATCH</tt> etc..), we should send a special param:
18
- # <tt>_csrf_token</tt>.
19
- #
20
- # If the param matches with the challenge token, the flow can continue.
21
- # Otherwise the application detects an attack attempt, it reset the session
22
- # and <tt>Hanami::Action::InvalidCSRFTokenError</tt> is raised.
23
- #
24
- # We can specify a custom handling strategy, by overriding <tt>#handle_invalid_csrf_token</tt>.
25
- #
26
- # Form helper (<tt>#form_for</tt>) automatically sets a hidden field with the
27
- # correct token. A special view method (<tt>#csrf_token</tt>) is available in
28
- # case the form markup is manually crafted.
29
- #
30
- # We can disable this check on action basis, by overriding <tt>#verify_csrf_token?</tt>.
31
- #
32
- # @since 0.4.0
33
- #
34
- # @see https://www.owasp.org/index.php/Cross-Site_Request_Forgery_%28CSRF%29
35
- # @see https://www.owasp.org/index.php/Cross-Site_Request_Forgery_(CSRF)_Prevention_Cheat_Sheet
36
- #
37
- # @example Custom Handling
38
- # module Web::Controllers::Books
39
- # class Create
40
- # include Web::Action
41
- #
42
- # def call(params)
43
- # # ...
44
- # end
45
- #
46
- # private
47
- #
48
- # def handle_invalid_csrf_token
49
- # Web::Logger.warn "CSRF attack: expected #{ session[:_csrf_token] }, was #{ params[:_csrf_token] }"
50
- # # manual handling
51
- # end
52
- # end
53
- # end
54
- #
55
- # @example Bypass Security Check
56
- # module Web::Controllers::Books
57
- # class Create
58
- # include Web::Action
59
- #
60
- # def call(params)
61
- # # ...
62
- # end
63
- #
64
- # private
65
- #
66
- # def verify_csrf_token?
67
- # false
68
- # end
69
- # end
70
- # end
71
- module CSRFProtection
72
- # Session and params key for CSRF token.
73
- #
74
- # This key is shared with <tt>hanami-controller</tt> and <tt>hanami-helpers</tt>
75
- #
76
- # @since 0.4.0
77
- # @api private
78
- CSRF_TOKEN = :_csrf_token
79
-
80
- # Idempotent HTTP methods
81
- #
82
- # By default, the check isn't performed if the request method is included
83
- # in this list.
84
- #
85
- # @since 0.4.0
86
- # @api private
87
- IDEMPOTENT_HTTP_METHODS = Hash[
88
- 'GET' => true,
89
- 'HEAD' => true,
90
- 'TRACE' => true,
91
- 'OPTIONS' => true
92
- ].freeze
93
-
94
- # @since 0.4.0
95
- # @api private
96
- def self.included(action)
97
- action.class_eval do
98
- before :set_csrf_token, :verify_csrf_token
99
- end unless Hanami.env?(:test)
100
- end
101
-
102
- private
103
- # Set CSRF Token in session
104
- #
105
- # @since 0.4.0
106
- # @api private
107
- def set_csrf_token
108
- session[CSRF_TOKEN] ||= generate_csrf_token
109
- end
110
-
111
- # Verify if CSRF token from params, matches the one stored in session.
112
- # If not, it raises an error.
113
- #
114
- # Don't override this method.
115
- #
116
- # To bypass the security check, please override <tt>#verify_csrf_token?</tt>.
117
- # For custom handling of an attack, please override <tt>#handle_invalid_csrf_token</tt>.
118
- #
119
- # @since 0.4.0
120
- # @api private
121
- def verify_csrf_token
122
- handle_invalid_csrf_token if invalid_csrf_token?
123
- end
124
-
125
- # Verify if CSRF token from params, matches the one stored in session.
126
- #
127
- # Don't override this method.
128
- #
129
- # @since 0.4.0
130
- # @api private
131
- def invalid_csrf_token?
132
- return false unless verify_csrf_token?
133
-
134
- missing_csrf_token? ||
135
- !::Rack::Utils.secure_compare(session[CSRF_TOKEN], params[CSRF_TOKEN])
136
- end
137
-
138
- # Verify the CSRF token was passed in params.
139
- #
140
- # @api private
141
- def missing_csrf_token?
142
- Hanami::Utils::Blank.blank?(params[CSRF_TOKEN])
143
- end
144
-
145
- # Generates a random CSRF Token
146
- #
147
- # @since 0.4.0
148
- # @api private
149
- def generate_csrf_token
150
- SecureRandom.hex(32)
151
- end
152
-
153
- # Decide if perform the check or not.
154
- #
155
- # Override and return <tt>false</tt> if you want to bypass security check.
156
- #
157
- # @since 0.4.0
158
- #
159
- # @example
160
- # module Web::Controllers::Books
161
- # class Create
162
- # include Web::Action
163
- #
164
- # def call(params)
165
- # # ...
166
- # end
167
- #
168
- # private
169
- #
170
- # def verify_csrf_token?
171
- # false
172
- # end
173
- # end
174
- # end
175
- def verify_csrf_token?
176
- !IDEMPOTENT_HTTP_METHODS[request_method]
177
- end
178
-
179
- # Handle CSRF attack.
180
- #
181
- # The default policy resets the session and raises an exception.
182
- #
183
- # Override this method, for custom handling.
184
- #
185
- # @raise [Hanami::Action::InvalidCSRFTokenError]
186
- #
187
- # @since 0.4.0
188
- #
189
- # @example
190
- # module Web::Controllers::Books
191
- # class Create
192
- # include Web::Action
193
- #
194
- # def call(params)
195
- # # ...
196
- # end
197
- #
198
- # private
199
- #
200
- # def handle_invalid_csrf_token
201
- # # custom invalid CSRF management goes here
202
- # end
203
- # end
204
- # end
205
- def handle_invalid_csrf_token
206
- session.clear
207
- raise InvalidCSRFTokenError.new
208
- end
209
- end
210
- end
211
- end
@@ -1,40 +0,0 @@
1
- require 'hanami/utils/string'
2
-
3
- module Hanami
4
- module Action
5
- # Routing helper for full stack Hanami web applications.
6
- #
7
- # For a given application called <tt>Web::Application</tt>, at runtime
8
- # Hanami creates a routes factory called <tt>Web::Routes</tt>.
9
- #
10
- # Included by default in every controller.
11
- #
12
- # @since 0.3.2
13
- #
14
- # @example Usage in controller
15
- # require 'hanami'
16
- #
17
- # module Web::Controllers::Protected
18
- # class Index
19
- # include Web::Action
20
- #
21
- # def call(params)
22
- # redirect_to routes.root_path
23
- # end
24
- # end
25
- # end
26
- module RoutingHelpers
27
- def self.included(base)
28
- factory = "#{Utils::String.namespace(base)}.routes"
29
-
30
- base.class_eval <<-END_EVAL, __FILE__, __LINE__
31
- private
32
-
33
- def routes
34
- #{factory}
35
- end
36
- END_EVAL
37
- end
38
- end
39
- end
40
- end
data/lib/hanami/app.rb DELETED
@@ -1,96 +0,0 @@
1
- require 'rack'
2
- require 'rack/builder'
3
- require 'hanami/router'
4
- require 'hanami/components'
5
- require 'hanami/common_logger'
6
-
7
- module Hanami
8
- # Main application that mounts many Rack and/or Hanami applications.
9
- #
10
- # @see Hanami.app
11
- #
12
- # @since 0.9.0
13
- # @api private
14
- class App
15
- # Initialize a new instance
16
- #
17
- # @param configuration [Hanami::Configuration] general configuration
18
- # @param environment [Hanami::Environment] current environment
19
- #
20
- # @since 0.9.0
21
- # @api private
22
- def initialize(configuration, environment)
23
- Components.resolve('apps')
24
-
25
- @builder = Rack::Builder.new
26
- @routes = Hanami::Router.new
27
-
28
- mount(configuration)
29
- middleware(configuration, environment)
30
- builder.run(routes)
31
-
32
- @app = builder.to_app
33
- end
34
-
35
- # Implements Rack SPEC
36
- #
37
- # @param env [Hash] a Rack env
38
- #
39
- # @return [Array] a serialized Rack response
40
- #
41
- # @since 0.9.0
42
- # @api private
43
- def call(env)
44
- app.call(env)
45
- end
46
-
47
- private
48
-
49
- # @since 1.2.0
50
- # @api private
51
- attr_reader :app
52
-
53
- # @since 0.9.0
54
- # @api private
55
- attr_reader :builder
56
-
57
- # @since 0.9.0
58
- # @api private
59
- attr_reader :routes
60
-
61
- # @since 0.9.0
62
- # @api private
63
- def mount(configuration)
64
- configuration.mounted.each do |klass, app|
65
- routes.mount(klass, at: app.path_prefix, host: app.host)
66
- end
67
- end
68
-
69
- # @since 0.9.0
70
- # @api private
71
- #
72
- # rubocop:disable Metrics/AbcSize
73
- # rubocop:disable Metrics/MethodLength
74
- def middleware(configuration, environment)
75
- builder.use Hanami::CommonLogger, Hanami.logger unless Hanami.logger.nil?
76
- builder.use Rack::ContentLength
77
-
78
- configuration.middleware.each do |m, args, blk|
79
- builder.use(m, *args, &blk)
80
- end
81
-
82
- if configuration.early_hints
83
- require 'hanami/early_hints'
84
- builder.use Hanami::EarlyHints
85
- end
86
-
87
- if middleware = environment.static_assets_middleware # rubocop:disable Lint/AssignmentInCondition
88
- builder.use middleware
89
- end
90
-
91
- builder.use Rack::MethodOverride
92
- end
93
- # rubocop:enable Metrics/MethodLength
94
- # rubocop:enable Metrics/AbcSize
95
- end
96
- end