railties 6.1.7.8 → 7.0.8.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (164) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +219 -320
  3. data/RDOC_MAIN.rdoc +16 -16
  4. data/README.rdoc +1 -2
  5. data/lib/minitest/rails_plugin.rb +1 -1
  6. data/lib/rails/all.rb +0 -1
  7. data/lib/rails/app_updater.rb +9 -6
  8. data/lib/rails/application/bootstrap.rb +24 -5
  9. data/lib/rails/application/configuration.rb +95 -33
  10. data/lib/rails/application/default_middleware_stack.rb +22 -3
  11. data/lib/rails/application/finisher.rb +53 -95
  12. data/lib/rails/application/routes_reloader.rb +8 -0
  13. data/lib/rails/application.rb +74 -101
  14. data/lib/rails/application_controller.rb +3 -3
  15. data/lib/rails/autoloaders/inflector.rb +21 -0
  16. data/lib/rails/autoloaders.rb +42 -42
  17. data/lib/rails/code_statistics.rb +2 -2
  18. data/lib/rails/code_statistics_calculator.rb +10 -1
  19. data/lib/rails/command/base.rb +26 -12
  20. data/lib/rails/command/behavior.rb +1 -1
  21. data/lib/rails/command/environment_argument.rb +1 -1
  22. data/lib/rails/command.rb +9 -6
  23. data/lib/rails/commands/console/console_command.rb +4 -0
  24. data/lib/rails/commands/credentials/USAGE +4 -2
  25. data/lib/rails/commands/credentials/credentials_command/diffing.rb +26 -16
  26. data/lib/rails/commands/credentials/credentials_command.rb +7 -3
  27. data/lib/rails/commands/dbconsole/dbconsole_command.rb +10 -11
  28. data/lib/rails/commands/help/USAGE +3 -2
  29. data/lib/rails/commands/runner/runner_command.rb +3 -2
  30. data/lib/rails/commands/server/server_command.rb +7 -5
  31. data/lib/rails/configuration.rb +18 -23
  32. data/lib/rails/console/helpers.rb +2 -2
  33. data/lib/rails/engine/configuration.rb +3 -3
  34. data/lib/rails/engine.rb +31 -37
  35. data/lib/rails/gem_version.rb +5 -5
  36. data/lib/rails/generators/actions/create_migration.rb +2 -4
  37. data/lib/rails/generators/actions.rb +229 -62
  38. data/lib/rails/generators/app_base.rb +155 -130
  39. data/lib/rails/generators/app_name.rb +1 -1
  40. data/lib/rails/generators/base.rb +12 -16
  41. data/lib/rails/generators/erb/scaffold/scaffold_generator.rb +2 -0
  42. data/lib/rails/generators/erb/scaffold/templates/_form.html.erb.tt +8 -8
  43. data/lib/rails/generators/erb/scaffold/templates/edit.html.erb.tt +8 -4
  44. data/lib/rails/generators/erb/scaffold/templates/index.html.erb.tt +11 -28
  45. data/lib/rails/generators/erb/scaffold/templates/new.html.erb.tt +7 -3
  46. data/lib/rails/generators/erb/scaffold/templates/partial.html.erb.tt +17 -0
  47. data/lib/rails/generators/erb/scaffold/templates/show.html.erb.tt +8 -17
  48. data/lib/rails/generators/erb.rb +1 -1
  49. data/lib/rails/generators/generated_attribute.rb +45 -9
  50. data/lib/rails/generators/migration.rb +2 -6
  51. data/lib/rails/generators/model_helpers.rb +1 -1
  52. data/lib/rails/generators/named_base.rb +13 -13
  53. data/lib/rails/generators/rails/app/app_generator.rb +70 -91
  54. data/lib/rails/generators/rails/app/templates/Gemfile.tt +44 -52
  55. data/lib/rails/generators/rails/app/templates/app/assets/stylesheets/application.css.tt +2 -2
  56. data/lib/rails/generators/rails/app/templates/app/mailers/application_mailer.rb.tt +2 -2
  57. data/lib/rails/generators/rails/app/templates/app/models/application_record.rb.tt +1 -1
  58. data/lib/rails/generators/rails/app/templates/app/views/layouts/application.html.erb.tt +3 -9
  59. data/lib/rails/generators/rails/app/templates/bin/rails.tt +1 -4
  60. data/lib/rails/generators/rails/app/templates/bin/rake.tt +0 -3
  61. data/lib/rails/generators/rails/app/templates/bin/setup.tt +9 -14
  62. data/lib/rails/generators/rails/app/templates/config/application.rb.tt +0 -1
  63. data/lib/rails/generators/rails/app/templates/config/boot.rb.tt +1 -1
  64. data/lib/rails/generators/rails/app/templates/config/databases/jdbc.yml.tt +2 -2
  65. data/lib/rails/generators/rails/app/templates/config/databases/jdbcmysql.yml.tt +3 -3
  66. data/lib/rails/generators/rails/app/templates/config/databases/jdbcpostgresql.yml.tt +3 -3
  67. data/lib/rails/generators/rails/app/templates/config/databases/jdbcsqlite3.yml.tt +2 -2
  68. data/lib/rails/generators/rails/app/templates/config/databases/mysql.yml.tt +3 -3
  69. data/lib/rails/generators/rails/app/templates/config/databases/oracle.yml.tt +2 -2
  70. data/lib/rails/generators/rails/app/templates/config/databases/postgresql.yml.tt +3 -3
  71. data/lib/rails/generators/rails/app/templates/config/databases/sqlite3.yml.tt +1 -1
  72. data/lib/rails/generators/rails/app/templates/config/databases/sqlserver.yml.tt +5 -5
  73. data/lib/rails/generators/rails/app/templates/config/environments/development.rb.tt +7 -13
  74. data/lib/rails/generators/rails/app/templates/config/environments/production.rb.tt +12 -39
  75. data/lib/rails/generators/rails/app/templates/config/environments/test.rb.tt +7 -12
  76. data/lib/rails/generators/rails/app/templates/config/initializers/assets.rb.tt +1 -5
  77. data/lib/rails/generators/rails/app/templates/config/initializers/content_security_policy.rb.tt +21 -28
  78. data/lib/rails/generators/rails/app/templates/config/initializers/cors.rb.tt +2 -2
  79. data/lib/rails/generators/rails/app/templates/config/initializers/filter_parameter_logging.rb.tt +3 -1
  80. data/lib/rails/generators/rails/app/templates/config/initializers/inflections.rb.tt +4 -4
  81. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_0.rb.tt +143 -0
  82. data/lib/rails/generators/rails/app/templates/config/locales/en.yml +3 -3
  83. data/lib/rails/generators/rails/app/templates/config/puma.rb.tt +1 -1
  84. data/lib/rails/generators/rails/app/templates/config/routes.rb.tt +4 -1
  85. data/lib/rails/generators/rails/app/templates/config/storage.yml.tt +5 -5
  86. data/lib/rails/generators/rails/app/templates/db/seeds.rb.tt +2 -2
  87. data/lib/rails/generators/rails/app/templates/gitattributes.tt +0 -5
  88. data/lib/rails/generators/rails/app/templates/gitignore.tt +3 -1
  89. data/lib/rails/generators/rails/app/templates/test/test_helper.rb.tt +1 -1
  90. data/lib/rails/generators/rails/controller/controller_generator.rb +1 -2
  91. data/lib/rails/generators/rails/controller/templates/controller.rb.tt +0 -4
  92. data/lib/rails/generators/rails/db/system/change/change_generator.rb +1 -1
  93. data/lib/rails/generators/rails/generator/templates/%file_name%_generator.rb.tt +1 -1
  94. data/lib/rails/generators/rails/plugin/plugin_generator.rb +76 -27
  95. data/lib/rails/generators/rails/plugin/templates/%name%.gemspec.tt +7 -3
  96. data/lib/rails/generators/rails/plugin/templates/Gemfile.tt +9 -31
  97. data/lib/rails/generators/rails/plugin/templates/README.md.tt +1 -1
  98. data/lib/rails/generators/rails/plugin/templates/app/mailers/%namespaced_name%/application_mailer.rb.tt +2 -2
  99. data/lib/rails/generators/rails/plugin/templates/app/views/layouts/%namespaced_name%/application.html.erb.tt +0 -3
  100. data/lib/rails/generators/rails/plugin/templates/bin/rails.tt +7 -6
  101. data/lib/rails/generators/rails/plugin/templates/gitignore.tt +0 -5
  102. data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%/engine.rb.tt +2 -2
  103. data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%/version.rb.tt +1 -1
  104. data/lib/rails/generators/rails/plugin/templates/rails/boot.rb.tt +2 -2
  105. data/lib/rails/generators/rails/plugin/templates/test/test_helper.rb.tt +2 -7
  106. data/lib/rails/generators/rails/scaffold/scaffold_generator.rb +0 -19
  107. data/lib/rails/generators/rails/scaffold_controller/templates/api_controller.rb.tt +1 -5
  108. data/lib/rails/generators/rails/scaffold_controller/templates/controller.rb.tt +6 -10
  109. data/lib/rails/generators/resource_helpers.rb +2 -2
  110. data/lib/rails/generators/test_unit/generator/templates/generator_test.rb.tt +1 -1
  111. data/lib/rails/generators/test_unit/model/templates/fixtures.yml.tt +2 -2
  112. data/lib/rails/generators/test_unit/scaffold/scaffold_generator.rb +3 -3
  113. data/lib/rails/generators/test_unit/scaffold/templates/api_functional_test.rb.tt +5 -5
  114. data/lib/rails/generators/test_unit/scaffold/templates/functional_test.rb.tt +7 -7
  115. data/lib/rails/generators/test_unit/scaffold/templates/system_test.rb.tt +9 -11
  116. data/lib/rails/generators/testing/behaviour.rb +3 -4
  117. data/lib/rails/generators.rb +17 -24
  118. data/lib/rails/info.rb +1 -1
  119. data/lib/rails/info_controller.rb +1 -3
  120. data/lib/rails/initializable.rb +1 -1
  121. data/lib/rails/mailers_controller.rb +2 -4
  122. data/lib/rails/paths.rb +1 -1
  123. data/lib/rails/rack/logger.rb +7 -9
  124. data/lib/rails/railtie/configuration.rb +1 -2
  125. data/lib/rails/railtie.rb +36 -13
  126. data/lib/rails/ruby_version_check.rb +3 -3
  127. data/lib/rails/source_annotation_extractor.rb +1 -1
  128. data/lib/rails/tasks/framework.rake +7 -9
  129. data/lib/rails/tasks/statistics.rake +3 -1
  130. data/lib/rails/tasks/tmp.rake +8 -1
  131. data/lib/rails/tasks/yarn.rake +8 -9
  132. data/lib/rails/tasks/zeitwerk.rake +2 -10
  133. data/lib/rails/templates/layouts/application.html.erb +15 -0
  134. data/lib/rails/templates/rails/mailers/email.html.erb +13 -11
  135. data/lib/rails/templates/rails/welcome/index.html.erb +64 -48
  136. data/lib/rails/test_help.rb +4 -0
  137. data/lib/rails/test_unit/railtie.rb +0 -4
  138. data/lib/rails/test_unit/runner.rb +16 -9
  139. data/lib/rails/test_unit/testing.rake +4 -9
  140. data/lib/rails/version.rb +1 -1
  141. data/lib/rails/welcome_controller.rb +1 -0
  142. data/lib/rails.rb +13 -2
  143. metadata +33 -37
  144. data/lib/rails/command/spellchecker.rb +0 -57
  145. data/lib/rails/generators/css/assets/assets_generator.rb +0 -15
  146. data/lib/rails/generators/css/assets/templates/stylesheet.css +0 -4
  147. data/lib/rails/generators/css/scaffold/scaffold_generator.rb +0 -18
  148. data/lib/rails/generators/rails/app/templates/app/javascript/channels/consumer.js +0 -6
  149. data/lib/rails/generators/rails/app/templates/app/javascript/channels/index.js +0 -5
  150. data/lib/rails/generators/rails/app/templates/app/javascript/packs/application.js.tt +0 -23
  151. data/lib/rails/generators/rails/app/templates/bin/spring.tt +0 -13
  152. data/lib/rails/generators/rails/app/templates/bin/yarn.tt +0 -16
  153. data/lib/rails/generators/rails/app/templates/config/initializers/application_controller_renderer.rb.tt +0 -8
  154. data/lib/rails/generators/rails/app/templates/config/initializers/backtrace_silencers.rb.tt +0 -8
  155. data/lib/rails/generators/rails/app/templates/config/initializers/cookies_serializer.rb.tt +0 -5
  156. data/lib/rails/generators/rails/app/templates/config/initializers/mime_types.rb.tt +0 -4
  157. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_6_1.rb.tt +0 -67
  158. data/lib/rails/generators/rails/app/templates/config/initializers/wrap_parameters.rb.tt +0 -16
  159. data/lib/rails/generators/rails/app/templates/config/spring.rb.tt +0 -6
  160. data/lib/rails/generators/rails/app/templates/package.json.tt +0 -11
  161. data/lib/rails/generators/rails/assets/USAGE +0 -16
  162. data/lib/rails/generators/rails/assets/assets_generator.rb +0 -26
  163. data/lib/rails/generators/rails/assets/templates/stylesheet.css +0 -4
  164. data/lib/rails/generators/rails/scaffold/templates/scaffold.css +0 -80
@@ -1,5 +1,9 @@
1
- <h1>New <%= singular_table_name.titleize %></h1>
1
+ <h1>New <%= human_name.downcase %></h1>
2
2
 
3
- <%%= render 'form', <%= singular_table_name %>: @<%= singular_table_name %> %>
3
+ <%%= render "form", <%= singular_table_name %>: @<%= singular_table_name %> %>
4
4
 
5
- <%%= link_to 'Back', <%= index_helper %>_path %>
5
+ <br>
6
+
7
+ <div>
8
+ <%%= link_to "Back to <%= human_name.pluralize.downcase %>", <%= index_helper(type: :path) %> %>
9
+ </div>
@@ -0,0 +1,17 @@
1
+ <div id="<%%= dom_id <%= singular_name %> %>">
2
+ <% attributes.reject(&:password_digest?).each do |attribute| -%>
3
+ <p>
4
+ <strong><%= attribute.human_name %>:</strong>
5
+ <% if attribute.attachment? -%>
6
+ <%%= link_to <%= singular_name %>.<%= attribute.column_name %>.filename, <%= singular_name %>.<%= attribute.column_name %> if <%= singular_name %>.<%= attribute.column_name %>.attached? %>
7
+ <% elsif attribute.attachments? -%>
8
+ <%% <%= singular_name %>.<%= attribute.column_name %>.each do |<%= attribute.singular_name %>| %>
9
+ <div><%%= link_to <%= attribute.singular_name %>.filename, <%= attribute.singular_name %> %></div>
10
+ <%% end %>
11
+ <% else -%>
12
+ <%%= <%= singular_name %>.<%= attribute.column_name %> %>
13
+ <% end -%>
14
+ </p>
15
+
16
+ <% end -%>
17
+ </div>
@@ -1,19 +1,10 @@
1
- <p id="notice"><%%= notice %></p>
1
+ <p style="color: green"><%%= notice %></p>
2
2
 
3
- <% attributes.reject(&:password_digest?).each do |attribute| -%>
4
- <p>
5
- <strong><%= attribute.human_name %>:</strong>
6
- <% if attribute.attachment? -%>
7
- <%%= link_to @<%= singular_table_name %>.<%= attribute.column_name %>.filename, @<%= singular_table_name %>.<%= attribute.column_name %> if @<%= singular_table_name %>.<%= attribute.column_name %>.attached? %>
8
- <% elsif attribute.attachments? -%>
9
- <%% @<%= singular_table_name %>.<%= attribute.column_name %>.each do |<%= attribute.singular_name %>| %>
10
- <div><%%= link_to <%= attribute.singular_name %>.filename, <%= attribute.singular_name %> %></div>
11
- <%% end %>
12
- <% else -%>
13
- <%%= @<%= singular_table_name %>.<%= attribute.column_name %> %>
14
- <% end -%>
15
- </p>
3
+ <%%= render @<%= singular_table_name %> %>
16
4
 
17
- <% end -%>
18
- <%%= link_to 'Edit', edit_<%= singular_table_name %>_path(@<%= singular_table_name %>) %> |
19
- <%%= link_to 'Back', <%= index_helper %>_path %>
5
+ <div>
6
+ <%%= link_to "Edit this <%= human_name.downcase %>", <%= edit_helper(type: :path) %> %> |
7
+ <%%= link_to "Back to <%= human_name.pluralize.downcase %>", <%= index_helper(type: :path) %> %>
8
+
9
+ <%%= button_to "Destroy this <%= human_name.downcase %>", <%= model_resource_name(prefix: "@") %>, method: :delete %>
10
+ </div>
@@ -4,7 +4,7 @@ require "rails/generators/named_base"
4
4
 
5
5
  module Erb # :nodoc:
6
6
  module Generators # :nodoc:
7
- class Base < Rails::Generators::NamedBase #:nodoc:
7
+ class Base < Rails::Generators::NamedBase # :nodoc:
8
8
  private
9
9
  def formats
10
10
  [format]
@@ -7,6 +7,25 @@ module Rails
7
7
  class GeneratedAttribute # :nodoc:
8
8
  INDEX_OPTIONS = %w(index uniq)
9
9
  UNIQ_INDEX_OPTIONS = %w(uniq)
10
+ DEFAULT_TYPES = %w(
11
+ attachment
12
+ attachments
13
+ belongs_to
14
+ boolean
15
+ date
16
+ datetime
17
+ decimal
18
+ digest
19
+ float
20
+ integer
21
+ references
22
+ rich_text
23
+ string
24
+ text
25
+ time
26
+ timestamp
27
+ token
28
+ )
10
29
 
11
30
  attr_accessor :name, :type
12
31
  attr_reader :attr_options
@@ -14,23 +33,40 @@ module Rails
14
33
 
15
34
  class << self
16
35
  def parse(column_definition)
17
- name, type, has_index = column_definition.split(":")
36
+ name, type, index_type = column_definition.split(":")
18
37
 
19
38
  # if user provided "name:index" instead of "name:string:index"
20
39
  # type should be set blank so GeneratedAttribute's constructor
21
40
  # could set it to :string
22
- has_index, type = type, nil if INDEX_OPTIONS.include?(type)
41
+ index_type, type = type, nil if valid_index_type?(type)
23
42
 
24
43
  type, attr_options = *parse_type_and_options(type)
25
44
  type = type.to_sym if type
26
45
 
46
+ if type && !valid_type?(type)
47
+ raise Error, "Could not generate field '#{name}' with unknown type '#{type}'."
48
+ end
49
+
50
+ if index_type && !valid_index_type?(index_type)
51
+ raise Error, "Could not generate field '#{name}' with unknown index '#{index_type}'."
52
+ end
53
+
27
54
  if type && reference?(type)
28
- if UNIQ_INDEX_OPTIONS.include?(has_index)
55
+ if UNIQ_INDEX_OPTIONS.include?(index_type)
29
56
  attr_options[:index] = { unique: true }
30
57
  end
31
58
  end
32
59
 
33
- new(name, type, has_index, attr_options)
60
+ new(name, type, index_type, attr_options)
61
+ end
62
+
63
+ def valid_type?(type)
64
+ DEFAULT_TYPES.include?(type.to_s) ||
65
+ ActiveRecord::Base.connection.valid_type?(type)
66
+ end
67
+
68
+ def valid_index_type?(index_type)
69
+ INDEX_OPTIONS.include?(index_type.to_s)
34
70
  end
35
71
 
36
72
  def reference?(type)
@@ -70,9 +106,9 @@ module Rails
70
106
  @field_type ||= case type
71
107
  when :integer then :number_field
72
108
  when :float, :decimal then :text_field
73
- when :time then :time_select
74
- when :datetime, :timestamp then :datetime_select
75
- when :date then :date_select
109
+ when :time then :time_field
110
+ when :datetime, :timestamp then :datetime_field
111
+ when :date then :date_field
76
112
  when :text then :text_area
77
113
  when :rich_text then :rich_text_area
78
114
  when :boolean then :check_box
@@ -87,8 +123,8 @@ module Rails
87
123
  when :integer then 1
88
124
  when :float then 1.5
89
125
  when :decimal then "9.99"
90
- when :datetime, :timestamp, :time then Time.now.to_s(:db)
91
- when :date then Date.today.to_s(:db)
126
+ when :datetime, :timestamp, :time then Time.now.to_fs(:db)
127
+ when :date then Date.today.to_fs(:db)
92
128
  when :string then name == "type" ? "" : "MyString"
93
129
  when :text then "MyText"
94
130
  when :boolean then false
@@ -12,7 +12,7 @@ module Rails
12
12
  extend ActiveSupport::Concern
13
13
  attr_reader :migration_number, :migration_file_name, :migration_class_name
14
14
 
15
- module ClassMethods #:nodoc:
15
+ module ClassMethods # :nodoc:
16
16
  def migration_lookup_at(dirname)
17
17
  Dir.glob("#{dirname}/[0-9]*_*.rb")
18
18
  end
@@ -63,11 +63,7 @@ module Rails
63
63
  numbered_destination = File.join(dir, ["%migration_number%", base].join("_"))
64
64
 
65
65
  file = create_migration numbered_destination, nil, config do
66
- if ERB.instance_method(:initialize).parameters.assoc(:key) # Ruby 2.6+
67
- ERB.new(::File.binread(source), trim_mode: "-", eoutvar: "@output_buffer").result(context)
68
- else
69
- ERB.new(::File.binread(source), nil, "-", "@output_buffer").result(context)
70
- end
66
+ ERB.new(::File.binread(source), trim_mode: "-", eoutvar: "@output_buffer").result(context)
71
67
  end
72
68
  Rails::Generators.add_generated_file(file)
73
69
  end
@@ -18,7 +18,7 @@ module Rails
18
18
  ERROR
19
19
  mattr_accessor :skip_warn
20
20
 
21
- def self.included(base) #:nodoc:
21
+ def self.included(base) # :nodoc:
22
22
  base.class_option :force_plural, type: :boolean, default: false, desc: "Forces the use of the given model name"
23
23
  end
24
24
 
@@ -8,7 +8,7 @@ module Rails
8
8
  class NamedBase < Base
9
9
  argument :name, type: :string
10
10
 
11
- def initialize(args, *options) #:nodoc:
11
+ def initialize(args, *options) # :nodoc:
12
12
  @inside_template = nil
13
13
  # Unfreeze name in case it's given as a frozen string
14
14
  args[0] = args[0].dup if args[0].is_a?(String) && args[0].frozen?
@@ -94,20 +94,20 @@ module Rails
94
94
  singular_name == plural_name
95
95
  end
96
96
 
97
- def index_helper # :doc:
98
- uncountable? ? "#{plural_route_name}_index" : plural_route_name
97
+ def index_helper(type: nil) # :doc:
98
+ [plural_route_name, ("index" if uncountable?), type].compact.join("_")
99
99
  end
100
100
 
101
- def show_helper # :doc:
102
- "#{singular_route_name}_url(@#{singular_table_name})"
101
+ def show_helper(arg = "@#{singular_table_name}", type: :url) # :doc:
102
+ "#{singular_route_name}_#{type}(#{arg})"
103
103
  end
104
104
 
105
- def edit_helper # :doc:
106
- "edit_#{show_helper}"
105
+ def edit_helper(...) # :doc:
106
+ "edit_#{show_helper(...)}"
107
107
  end
108
108
 
109
- def new_helper # :doc:
110
- "new_#{singular_route_name}_url"
109
+ def new_helper(type: :url) # :doc:
110
+ "new_#{singular_route_name}_#{type}"
111
111
  end
112
112
 
113
113
  def singular_table_name # :doc:
@@ -127,7 +127,7 @@ module Rails
127
127
  end
128
128
 
129
129
  def route_url # :doc:
130
- @route_url ||= class_path.collect { |dname| "/" + dname }.join + "/" + plural_file_name
130
+ @route_url ||= controller_class_path.collect { |dname| "/" + dname }.join + "/" + plural_file_name
131
131
  end
132
132
 
133
133
  def url_helper_prefix # :doc:
@@ -147,8 +147,8 @@ module Rails
147
147
  model_resource_name(prefix: "@")
148
148
  end
149
149
 
150
- def model_resource_name(prefix: "") # :doc:
151
- resource_name = "#{prefix}#{singular_table_name}"
150
+ def model_resource_name(base_name = singular_table_name, prefix: "") # :doc:
151
+ resource_name = "#{prefix}#{base_name}"
152
152
  if options[:model_name]
153
153
  "[#{controller_class_path.map { |name| ":" + name }.join(", ")}, #{resource_name}]"
154
154
  else
@@ -202,7 +202,7 @@ module Rails
202
202
  end
203
203
 
204
204
  # Add a class collisions name to be checked on class initialization. You
205
- # can supply a hash with a :prefix or :suffix to be tested.
205
+ # can supply a hash with a +:prefix+ or +:suffix+ to be tested.
206
206
  #
207
207
  # ==== Examples
208
208
  #
@@ -73,13 +73,12 @@ module Rails
73
73
  def version_control
74
74
  if !options[:skip_git] && !options[:pretend]
75
75
  run "git init", capture: options[:quiet], abort_on_failure: false
76
+ if user_default_branch.strip.empty?
77
+ `git symbolic-ref HEAD refs/heads/main`
78
+ end
76
79
  end
77
80
  end
78
81
 
79
- def package_json
80
- template "package.json"
81
- end
82
-
83
82
  def app
84
83
  directory "app"
85
84
 
@@ -94,58 +93,42 @@ module Rails
94
93
  "#{shebang}\n" + content
95
94
  end
96
95
  chmod "bin", 0755 & ~File.umask, verbose: false
97
-
98
- remove_file "bin/spring" unless spring_install?
99
- remove_file "bin/yarn" if options[:skip_javascript]
100
96
  end
101
97
 
102
98
  def bin_when_updating
103
99
  bin
104
100
  end
105
101
 
106
- def yarn_when_updating
107
- template "bin/yarn", force: true do |content|
108
- "#{shebang}\n" + content
109
- end
110
-
111
- chmod "bin", 0755 & ~File.umask, verbose: false
112
- end
113
-
114
102
  def config
115
103
  empty_directory "config"
116
104
 
117
105
  inside "config" do
118
- template "routes.rb"
106
+ template "routes.rb" unless options[:updating]
119
107
  template "application.rb"
120
108
  template "environment.rb"
121
- template "cable.yml" unless options[:skip_action_cable]
122
- template "puma.rb" unless options[:skip_puma]
123
- template "spring.rb" if spring_install?
124
- template "storage.yml" unless skip_active_storage?
109
+ template "cable.yml" unless options[:updating] || options[:skip_action_cable]
110
+ template "puma.rb" unless options[:updating]
111
+ template "storage.yml" unless options[:updating] || skip_active_storage?
125
112
 
126
113
  directory "environments"
127
114
  directory "initializers"
128
- directory "locales"
115
+ directory "locales" unless options[:updating]
129
116
  end
130
117
  end
131
118
 
132
119
  def config_when_updating
133
- cookie_serializer_config_exist = File.exist?("config/initializers/cookies_serializer.rb")
134
- action_cable_config_exist = File.exist?("config/cable.yml")
135
- active_storage_config_exist = File.exist?("config/storage.yml")
136
- rack_cors_config_exist = File.exist?("config/initializers/cors.rb")
137
- assets_config_exist = File.exist?("config/initializers/assets.rb")
138
- csp_config_exist = File.exist?("config/initializers/content_security_policy.rb")
120
+ action_cable_config_exist = File.exist?("config/cable.yml")
121
+ active_storage_config_exist = File.exist?("config/storage.yml")
122
+ rack_cors_config_exist = File.exist?("config/initializers/cors.rb")
123
+ assets_config_exist = File.exist?("config/initializers/assets.rb")
124
+ asset_manifest_exist = File.exist?("app/assets/config/manifest.js")
125
+ asset_app_stylesheet_exist = File.exist?("app/assets/stylesheets/application.css")
126
+ csp_config_exist = File.exist?("config/initializers/content_security_policy.rb")
139
127
  permissions_policy_config_exist = File.exist?("config/initializers/permissions_policy.rb")
140
128
 
141
129
  @config_target_version = Rails.application.config.loaded_config_version || "5.0"
142
130
 
143
131
  config
144
- configru
145
-
146
- unless cookie_serializer_config_exist
147
- gsub_file "config/initializers/cookies_serializer.rb", /json(?!,)/, "marshal"
148
- end
149
132
 
150
133
  if !options[:skip_action_cable] && !action_cable_config_exist
151
134
  template "config/cable.yml"
@@ -155,19 +138,23 @@ module Rails
155
138
  template "config/storage.yml"
156
139
  end
157
140
 
158
- if options[:skip_sprockets] && !assets_config_exist
141
+ if skip_sprockets? && skip_propshaft? && !assets_config_exist
159
142
  remove_file "config/initializers/assets.rb"
160
143
  end
161
144
 
145
+ if skip_sprockets? && !asset_manifest_exist
146
+ remove_file "app/assets/config/manifest.js"
147
+ end
148
+
149
+ if skip_sprockets? && !asset_app_stylesheet_exist
150
+ remove_file "app/assets/stylesheets/application.css"
151
+ end
152
+
162
153
  unless rack_cors_config_exist
163
154
  remove_file "config/initializers/cors.rb"
164
155
  end
165
156
 
166
157
  if options[:api]
167
- unless cookie_serializer_config_exist
168
- remove_file "config/initializers/cookies_serializer.rb"
169
- end
170
-
171
158
  unless csp_config_exist
172
159
  remove_file "config/initializers/content_security_policy.rb"
173
160
  end
@@ -176,6 +163,10 @@ module Rails
176
163
  remove_file "config/initializers/permissions_policy.rb"
177
164
  end
178
165
  end
166
+
167
+ if !skip_sprockets?
168
+ insert_into_file "config/application.rb", %(require "sprockets/railtie"), after: /require\(["']rails\/all["']\)\n/
169
+ end
179
170
  end
180
171
 
181
172
  def master_key
@@ -202,6 +193,14 @@ module Rails
202
193
  directory "db"
203
194
  end
204
195
 
196
+ def db_when_updating
197
+ path = File.expand_path("db/schema.rb", destination_root)
198
+
199
+ if File.exist?(path)
200
+ gsub_file("db/schema.rb", /ActiveRecord::Schema\.define/, "ActiveRecord::Schema[6.1].define")
201
+ end
202
+ end
203
+
205
204
  def lib
206
205
  empty_directory "lib"
207
206
  empty_directory_with_keep_file "lib/tasks"
@@ -253,6 +252,11 @@ module Rails
253
252
  def config_target_version
254
253
  defined?(@config_target_version) ? @config_target_version : Rails::VERSION::STRING.to_f
255
254
  end
255
+
256
+ private
257
+ def user_default_branch
258
+ @user_default_branch ||= `git config init.defaultbranch`
259
+ end
256
260
  end
257
261
 
258
262
  module Generators
@@ -263,28 +267,15 @@ module Rails
263
267
  class AppGenerator < AppBase
264
268
  # :stopdoc:
265
269
 
266
- WEBPACKS = %w( react vue angular elm stimulus )
267
-
268
270
  add_shared_options_for "application"
269
271
 
270
272
  # Add rails command options
271
- class_option :version, type: :boolean, aliases: "-v", group: :rails,
272
- desc: "Show Rails version number and quit"
273
-
274
- class_option :api, type: :boolean,
275
- desc: "Preconfigure smaller stack for API only apps"
276
-
277
- class_option :minimal, type: :boolean,
278
- desc: "Preconfigure a minimal rails app"
279
-
280
- class_option :skip_bundle, type: :boolean, aliases: "-B", default: false,
281
- desc: "Don't run bundle install"
282
-
283
- class_option :webpack, type: :string, aliases: "--webpacker", default: nil,
284
- desc: "Preconfigure Webpack with a particular framework (options: #{WEBPACKS.join(", ")})"
285
-
286
- class_option :skip_webpack_install, type: :boolean, default: false,
287
- desc: "Don't run Webpack install"
273
+ class_option :version, type: :boolean, aliases: "-v", group: :rails, desc: "Show Rails version number and quit"
274
+ class_option :api, type: :boolean, desc: "Preconfigure smaller stack for API only apps"
275
+ class_option :minimal, type: :boolean, desc: "Preconfigure a minimal rails app"
276
+ class_option :javascript, type: :string, aliases: "-j", default: "importmap", desc: "Choose JavaScript approach [options: importmap (default), webpack, esbuild, rollup]"
277
+ class_option :css, type: :string, aliases: "-c", desc: "Choose CSS processor [options: tailwind, bootstrap, bulma, postcss, sass] check https://github.com/rails/cssbundling-rails"
278
+ class_option :skip_bundle, type: :boolean, aliases: "-B", default: false, desc: "Don't run bundle install"
288
279
 
289
280
  def initialize(*args)
290
281
  super
@@ -293,10 +284,10 @@ module Rails
293
284
  raise Error, "Invalid value for --database option. Supported preconfigurations are: #{DATABASES.join(", ")}."
294
285
  end
295
286
 
296
- # Force sprockets and yarn to be skipped when generating API only apps.
287
+ # Force sprockets and JavaScript to be skipped when generating API only apps.
297
288
  # Can't modify options hash as it's frozen by default.
298
289
  if options[:api]
299
- self.options = options.merge(skip_sprockets: true, skip_javascript: true).freeze
290
+ self.options = options.merge(skip_asset_pipeline: true, skip_javascript: true).freeze
300
291
  end
301
292
 
302
293
  if options[:minimal]
@@ -311,15 +302,8 @@ module Rails
311
302
  skip_dev_gems: true,
312
303
  skip_javascript: true,
313
304
  skip_jbuilder: true,
314
- skip_spring: true,
315
305
  skip_system_test: true,
316
- skip_webpack_install: true,
317
- skip_turbolinks: true).tap do |option|
318
- if option[:webpack]
319
- option[:skip_webpack_install] = false
320
- option[:skip_javascript] = false
321
- end
322
- end.freeze
306
+ skip_hotwire: true).freeze
323
307
  end
324
308
 
325
309
  @after_bundle_callbacks = []
@@ -327,6 +311,7 @@ module Rails
327
311
 
328
312
  public_task :set_default_accessors!
329
313
  public_task :create_root
314
+ public_task :target_rails_prerelease
330
315
 
331
316
  def create_root_files
332
317
  build(:readme)
@@ -339,9 +324,8 @@ module Rails
339
324
  build(:gitattributes)
340
325
  end
341
326
 
342
- build(:gemfile) unless options[:skip_gemfile]
327
+ build(:gemfile)
343
328
  build(:version_control)
344
- build(:package_json) unless options[:skip_javascript]
345
329
  end
346
330
 
347
331
  def create_app_files
@@ -357,10 +341,10 @@ module Rails
357
341
  end
358
342
  remove_task :update_bin_files
359
343
 
360
- def update_bin_yarn
361
- build(:yarn_when_updating)
344
+ def update_db_schema
345
+ build(:db_when_updating)
362
346
  end
363
- remove_task :update_bin_yarn
347
+ remove_task :update_db_schema
364
348
 
365
349
  def update_active_storage
366
350
  unless skip_active_storage?
@@ -454,7 +438,7 @@ module Rails
454
438
 
455
439
  def delete_app_views_if_api_option
456
440
  if options[:api]
457
- if options[:skip_action_mailer]
441
+ if skip_action_mailer?
458
442
  remove_dir "app/views"
459
443
  else
460
444
  remove_file "app/views/layouts/application.html.erb"
@@ -473,22 +457,16 @@ module Rails
473
457
  end
474
458
  end
475
459
 
476
- def delete_js_folder_skipping_javascript
477
- if options[:skip_javascript] && !options[:minimal]
478
- remove_dir "app/javascript"
479
- end
480
- end
481
-
482
- def delete_js_packs_when_minimal_skipping_webpack
483
- if options[:minimal] && options[:skip_webpack_install]
484
- remove_dir "app/javascript/packs"
485
- keep_file "app/javascript"
460
+ def delete_assets_initializer_skipping_sprockets_and_propshaft
461
+ if skip_sprockets? && skip_propshaft?
462
+ remove_file "config/initializers/assets.rb"
486
463
  end
487
- end
488
464
 
489
- def delete_assets_initializer_skipping_sprockets
490
- if options[:skip_sprockets]
491
- remove_file "config/initializers/assets.rb"
465
+ if skip_sprockets?
466
+ remove_file "app/assets/config/manifest.js"
467
+ remove_dir "app/assets/config"
468
+ remove_file "app/assets/stylesheets/application.css"
469
+ create_file "app/assets/stylesheets/application.css", "/* Application styles */\n" unless options[:api]
492
470
  end
493
471
  end
494
472
 
@@ -505,7 +483,7 @@ module Rails
505
483
  end
506
484
 
507
485
  def delete_action_mailer_files_skipping_action_mailer
508
- if options[:skip_action_mailer]
486
+ if skip_action_mailer?
509
487
  remove_file "app/views/layouts/mailer.html.erb"
510
488
  remove_file "app/views/layouts/mailer.text.erb"
511
489
  remove_dir "app/mailers"
@@ -523,7 +501,6 @@ module Rails
523
501
 
524
502
  def delete_non_api_initializers_if_api_option
525
503
  if options[:api]
526
- remove_file "config/initializers/cookies_serializer.rb"
527
504
  remove_file "config/initializers/content_security_policy.rb"
528
505
  remove_file "config/initializers/permissions_policy.rb"
529
506
  end
@@ -537,7 +514,7 @@ module Rails
537
514
 
538
515
  def delete_new_framework_defaults
539
516
  unless options[:update]
540
- remove_file "config/initializers/new_framework_defaults_6_1.rb"
517
+ remove_file "config/initializers/new_framework_defaults_7_0.rb"
541
518
  end
542
519
  end
543
520
 
@@ -547,7 +524,9 @@ module Rails
547
524
 
548
525
  public_task :apply_rails_template, :run_bundle
549
526
  public_task :generate_bundler_binstub
550
- public_task :run_webpack
527
+ public_task :run_javascript
528
+ public_task :run_hotwire
529
+ public_task :run_css
551
530
 
552
531
  def run_after_bundle_callbacks
553
532
  @after_bundle_callbacks.each(&:call)
@@ -565,7 +544,7 @@ module Rails
565
544
  create_file(*args, &block)
566
545
  end
567
546
 
568
- # Registers a callback to be executed after bundle and spring binstubs
547
+ # Registers a callback to be executed after bundle binstubs
569
548
  # have run.
570
549
  #
571
550
  # after_bundle do