brick 1.0.114 → 1.0.116

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 5006a6dabf5c9e86965e57a40ae344f9d67c2fc5e76caec8a00e978117089062
4
- data.tar.gz: 5bd0fef75e305514b4ef22e4930660cdbf9385c22b07ee92d6eb77a626a13943
3
+ metadata.gz: b515113ca31f4e0ad1a13e90df981c411e96c4a93507012876c9b2f10e76e68b
4
+ data.tar.gz: e23d63fe9fbbaaacd20d9646c382e914dfa46cfa61a8a504aaee9f3f6352d849
5
5
  SHA512:
6
- metadata.gz: b0621761d15baec575a9cd16fdb1b22e9a1d4784308c071d9878121ac841f6cf7419cb6fbcc210afad2ce98a69814c27279dc951a5d84750e7573e203d2f806a
7
- data.tar.gz: ed4b5c992076b4f28c85ab8af48bab847ab80105f2999371475529219cc6b0053444dc722a700d686fc7ed7ea39d3d939cb448c43d798bde18a0b5cfd80be23e
6
+ metadata.gz: 78fcea6b98fae7cbb0496a55a824021f4accf8c75eaf3680696333000a90854dda52783cd14a67ee7dcb91f3a48cef871ba4e3ea037f3dbec42f31c1bb485a25
7
+ data.tar.gz: a1191c8adfd3d6dbd8393e85c4bb7857a030db449891e744ac6bc3ea7f9f9cae5303987143f02892374fd088528463aacc1b06c9c4541560a0df0ded1dafe1e5
@@ -972,7 +972,10 @@ Module.class_exec do
972
972
  end
973
973
  # puts "#{self.name} - #{args.first}"
974
974
  desired_classname = (self == Object || !name) ? requested : "#{name}::#{requested}"
975
- if ((is_defined = self.const_defined?(args.first)) && (possible = self.const_get(args.first)) && possible.name == desired_classname) ||
975
+ if ((is_defined = self.const_defined?(args.first)) && (possible = self.const_get(args.first)) &&
976
+ # Reset `possible` if it's a controller request that's not a perfect match
977
+ # Was: (possible = nil) but changed to #local_variable_set in order to suppress the "= should be ==" warning
978
+ (possible.name == desired_classname || (is_controller && binding.local_variable_set(:possible, nil)))) ||
976
979
  # Try to require the respective Ruby file
977
980
  ((filename = ActiveSupport::Dependencies.search_for_file(desired_classname.underscore) ||
978
981
  (self != Object && ActiveSupport::Dependencies.search_for_file((desired_classname = requested).underscore))
@@ -983,7 +986,7 @@ Module.class_exec do
983
986
  # then return what we've found.
984
987
  (is_defined && !::Brick.is_eager_loading) # Used to also have: && possible != self
985
988
  if (!brick_root && (filename || possible.instance_of?(Class))) ||
986
- (possible.instance_of?(Module) && possible.module_parent == self) ||
989
+ (possible.instance_of?(Module) && possible&.module_parent == self) ||
987
990
  (possible.instance_of?(Class) && possible == self) # Are we simply searching for ourselves?
988
991
  return possible
989
992
  end
@@ -82,6 +82,15 @@ function linkSchemas() {
82
82
  }
83
83
  };
84
84
  "
85
+ BRICK_SVG = "<svg version=\"1.1\" style=\"display: inline; padding-left: 0.5em;\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"
86
+ viewBox=\"0 0 58 58\" height=\"1.4em\" xml:space=\"preserve\">
87
+ <g>
88
+ <polygon style=\"fill:#C2615F;\" points=\"58,15.831 19.106,35.492 0,26.644 40,6\"/>
89
+ <polygon style=\"fill:#6D4646;\" points=\"19,52 0,43.356 0,26.644 19,35\"/>
90
+ <polygon style=\"fill:#894747;\" points=\"58,31.559 19,52 19,35 58,15.831\"/>
91
+ </g>
92
+ </svg>
93
+ ".html_safe
85
94
 
86
95
  # paths['app/models'] << 'lib/brick/frameworks/active_record/models'
87
96
  config.brick = ActiveSupport::OrderedOptions.new
@@ -246,15 +255,7 @@ window.addEventListener(\"popstate\", linkSchemas);
246
255
  end
247
256
  def to_s
248
257
  @_name.to_s.html_safe + @vc.instance_variable_get(:@__vc_helpers)&.link_to_brick(nil,
249
- "<svg version=\"1.1\" style=\"display: inline; padding-left: 0.5em;\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"
250
- viewBox=\"0 0 58 58\" height=\"1.4em\" xml:space=\"preserve\">
251
- <g>
252
- <polygon style=\"fill:#C2615F;\" points=\"58,15.831 19.106,35.492 0,26.644 40,6\"/>
253
- <polygon style=\"fill:#6D4646;\" points=\"19,52 0,43.356 0,26.644 19,35\"/>
254
- <polygon style=\"fill:#894747;\" points=\"58,31.559 19,52 19,35 58,15.831\"/>
255
- </g>
256
- </svg>
257
- ".html_safe,
258
+ BRICK_SVG,
258
259
  { title: "#{@_name} in Brick" }
259
260
  )
260
261
  end
@@ -298,7 +299,14 @@ window.addEventListener(\"popstate\", linkSchemas);
298
299
  )
299
300
  nil
300
301
  else # This is either a non-Avo request or a proper Avo request, so carry on
301
- _brick_url_for(options, *args)
302
+ begin
303
+ _brick_url_for(options, *args)
304
+ rescue
305
+ # Last-ditch effort in case we were in yet a different RouteSet
306
+ unless (rar = ::Rails.application.routes) == self
307
+ rar.url_for(options, *args)
308
+ end
309
+ end
302
310
  end
303
311
  end
304
312
  end
@@ -314,14 +322,87 @@ window.addEventListener(\"popstate\", linkSchemas);
314
322
  ::Brick.relations.each do |k, v|
315
323
  next if k == 'active_admin_comments'
316
324
 
317
- if (class_name = Object.const_get(v.fetch(:class_name, nil)))
318
- ::ActiveAdmin.register(class_name) { config.clear_batch_actions! }
325
+ begin
326
+ if (class_name = Object.const_get(v.fetch(:class_name, nil)))
327
+ ::ActiveAdmin.register(class_name) { config.clear_batch_actions! }
328
+ end
329
+ rescue
319
330
  end
320
331
  end
321
332
  _brick_routes(*args)
322
333
  end
323
334
  end
324
335
  end
336
+ ::ActiveAdmin::Views::TitleBar.class_exec do
337
+ alias _brick_build_title_tag build_title_tag
338
+ def build_title_tag
339
+ if klass = begin
340
+ aa_id = helpers.instance_variable_get(:@current_tab)&.id
341
+ ::Brick.relations.fetch(aa_id, nil)&.fetch(:class_name, nil)&.constantize
342
+ rescue
343
+ end
344
+ h2((@title + link_to_brick(nil,
345
+ BRICK_SVG, # This would do well to be sized a bit smaller
346
+ { title: "#{@_name} in Brick" }
347
+ )).html_safe)
348
+ else
349
+ _brick_build_title_tag # Revert to the original
350
+ end
351
+ end
352
+ end
353
+ end
354
+
355
+ # Forest Admin compatibility
356
+ if Object.const_defined?('ForestLiana')
357
+ ForestLiana::Bootstrapper.class_exec do
358
+ alias _brick_fetch_models fetch_models
359
+ def fetch_models
360
+ # Auto-create Brick models
361
+ ::Brick.relations.each do |k, v|
362
+ next if k == 'active_admin_comments'
363
+
364
+ begin
365
+ v[:class_name].constantize
366
+ rescue
367
+ end
368
+ end
369
+ _brick_fetch_models
370
+ end
371
+ end
372
+ end
373
+
374
+ # MotorAdmin compatibility
375
+ if Object.const_defined?('Motor') && ::Motor.const_defined?('BuildSchema')
376
+ ::Motor::BuildSchema::LoadFromRails.class_exec do
377
+ class << self
378
+ alias _brick_models models
379
+ def models
380
+ # If RailsAdmin is also present and had already cached its list of models, this builds out the MotorAdmin
381
+ # models differently, so invalidate RailsAdmin's cached list.
382
+ if Object.const_defined?('RailsAdmin') && ::RailsAdmin::Config.class_variable_defined?(:@@system_models)
383
+ ::RailsAdmin::Config.remove_class_variable(:@@system_models)
384
+ ::RailsAdmin::AbstractModel.reset
385
+ end
386
+
387
+ eager_load_models!
388
+ # Auto-create Brick models (except for those related to Motor::ApplicationRecord)
389
+ mar_tables = Motor::ApplicationRecord.descendants.map(&:table_name)
390
+ # Add JSON fields
391
+ if mar_tables.include?('motor_api_configs')
392
+ mac = (::Brick.config.json_columns['motor_api_configs'] ||= [])
393
+ mac += ['preferences', 'credentials']
394
+ end
395
+ (::Brick.config.json_columns['motor_audits'] ||= []) << 'audited_changes' if mar_tables.include?('motor_audits')
396
+ (::Brick.config.json_columns['motor_configs'] ||= []) << 'value' if mar_tables.include?('motor_configs')
397
+ ::Brick.relations.each do |k, v|
398
+ next if mar_tables.include?(k) || k == 'motor_audits'
399
+
400
+ v[:class_name].constantize
401
+ end
402
+ _brick_models.reject { |m| mar_tables.include?(m.table_name) || m.table_name == 'motor_audits' }
403
+ end
404
+ end
405
+ end
325
406
  end
326
407
 
327
408
  # ====================================
@@ -846,7 +927,9 @@ callbacks = {} %>
846
927
  <path opacity=\"0.25\" d=\"M41.9129 30.649L35.3301 45.0422C35.2023 45.3204 35.0074 45.563 34.7627 45.7484C34.518 45.9337 34.2311 46.0562 33.9274 46.1048C27.3926 47.1897 21.1567 49.6166 15.617 53.2308C15.279 53.4505 14.8783 53.555 14.4753 53.5286C14.0723 53.5022 13.6889 53.3463 13.3827 53.0844C13.0765 52.8225 12.8642 52.4688 12.7777 52.0765C12.6911 51.6842 12.7351 51.2745 12.9029 50.9092L32.0285 8.99382L33.4869 5.7959C32.6687 7.95084 32.7141 10.336 33.6135 12.4586L33.7958 12.8565L41.9129 30.649Z\" fill=\"currentColor\" fill-opacity=\"0.22\"></path>
847
928
  </svg>
848
929
  ".gsub('"', '\"')
849
- }\".html_safe %>"
930
+ }\".html_safe
931
+ aa_png = \"<img src=\\\"\\\">\".html_safe
932
+ %>"
850
933
 
851
934
  if ['index', 'show', 'new', 'update'].include?(args.first)
852
935
  poly_cols = []
@@ -1194,6 +1277,19 @@ erDiagram
1194
1277
  title: \"#\{model.name} in Avo\" }
1195
1278
  ) %></td>
1196
1279
  <% end %>
1280
+ <% if Object.const_defined?('ActiveAdmin')
1281
+ ActiveAdmin.application.namespaces.names.each do |ns|
1282
+ td_count += 1 %>
1283
+ <td><%= link_to_brick(
1284
+ aa_png,
1285
+ { index_proc: Proc.new do |aa_model, relation|
1286
+ path_helper = \"#\{ns}_#\{relation.fetch(:auto_prefixed_schema, nil)}#\{rk = aa_model.model_name.route_key}_path\".to_sym
1287
+ send(path_helper) if respond_to?(path_helper)
1288
+ end,
1289
+ title: \"#\{model.name} in ActiveAdmin\" }
1290
+ ) %></td>
1291
+ <% end
1292
+ end %>
1197
1293
  </tr><%= if (page_num = @#{table_name}._brick_page_num)
1198
1294
  \"<tr><td colspan=\\\"#\{td_count}\\\">Page #\{page_num}</td></tr>\".html_safe
1199
1295
  end %></table>#{template_link}<%
@@ -1382,7 +1478,20 @@ erDiagram
1382
1478
  end,
1383
1479
  title: \"#\{page_title} in Avo\" }
1384
1480
  ) %></td>
1385
- <% end %>
1481
+ <% end
1482
+
1483
+ if Object.const_defined?('ActiveAdmin')
1484
+ ActiveAdmin.application.namespaces.names.each do |ns| %>
1485
+ <td><%= link_to_brick(
1486
+ aa_png,
1487
+ { show_proc: Proc.new do |aa_model, relation|
1488
+ path_helper = \"#\{ns}_#\{relation.fetch(:auto_prefixed_schema, nil)}#\{rk = aa_model.model_name.singular_route_key}_path\".to_sym
1489
+ send(path_helper, obj) if respond_to?(path_helper)
1490
+ end,
1491
+ title: \"#\{page_title} in ActiveAdmin\" }
1492
+ ) %></td>
1493
+ <% end
1494
+ end %>
1386
1495
  </table>
1387
1496
  <%
1388
1497
  if (description = (relation = Brick.relations[tbl_name = #{model_name}.table_name])&.fetch(:description, nil)) %><%=
@@ -1821,9 +1930,24 @@ document.querySelectorAll(\"input, select\").forEach(function (inp) {
1821
1930
 
1822
1931
  alias _brick_viable_models viable_models
1823
1932
  def viable_models
1824
- return _brick_viable_models if class_variables.include?(:@@system_models)
1933
+ return _brick_viable_models if ::RailsAdmin::Config.class_variables.include?(:@@system_models)
1934
+
1935
+ brick_models = ::Brick.relations.map { |_k, v| v[:class_name] }
1825
1936
 
1826
- @@system_models = (vm = _brick_viable_models) + (::Brick.auto_models - vm)
1937
+ # The original from RailsAdmin (now aliased as _brick_viable_models) loads all classes
1938
+ # in the whole project. This Brick approach is a little more tame.
1939
+ ::Brick.eager_load_classes
1940
+ # All tables used by non-Brick models
1941
+ ar_tables = (arbd = ActiveRecord::Base.descendants).each_with_object([]) do |ar, s|
1942
+ s << ar.table_name unless brick_models.include?(ar.name)
1943
+ end
1944
+ viable = arbd.each_with_object([]) do |ar, s|
1945
+ # Include all the app's models, plus any Brick models which describe tables not covered by the app's models
1946
+ unless ar.abstract_class? || (brick_models.include?(ar.name) && ar_tables.include?(ar.table_name))
1947
+ s << ar.name
1948
+ end
1949
+ end
1950
+ RailsAdmin::Config.class_variable_set(:@@system_models, viable)
1827
1951
  end
1828
1952
  end
1829
1953
  end
@@ -5,7 +5,7 @@ module Brick
5
5
  module VERSION
6
6
  MAJOR = 1
7
7
  MINOR = 0
8
- TINY = 114
8
+ TINY = 116
9
9
 
10
10
  # PRE is nil unless it's a pre-release (beta, RC, etc.)
11
11
  PRE = nil
data/lib/brick.rb CHANGED
@@ -137,6 +137,7 @@ module Brick
137
137
 
138
138
  attr_accessor :default_schema, :db_schemas, :test_schema,
139
139
  :routes_done, :is_oracle, :is_eager_loading, :auto_models, :initializer_loaded
140
+ ::Brick.auto_models = []
140
141
 
141
142
  def set_db_schema(params = nil)
142
143
  # If Apartment::Tenant.current is not still the default (usually 'public') then an elevator has brought us into
@@ -610,7 +611,7 @@ In config/initializers/brick.rb appropriate entries would look something like:
610
611
 
611
612
  def display_classes(prefix, rels, max_length)
612
613
  rels.sort.each do |rel|
613
- (::Brick.auto_models ||= []) << rel.first
614
+ ::Brick.auto_models << rel.first
614
615
  puts "#{rel.first}#{' ' * (max_length - rel.first.length)} /#{prefix}#{"#{rel[1]}/" if rel[1]}#{rel.last}"
615
616
  end
616
617
  puts "\n"
@@ -660,7 +661,7 @@ In config/initializers/brick.rb appropriate entries would look something like:
660
661
  module RouteSet
661
662
  def finalize!
662
663
  routeset_to_use = ::Rails.application.routes
663
- return super unless self == routeset_to_use
664
+ return super if self != routeset_to_use || ::Brick.routes_done
664
665
 
665
666
  path_prefix = ::Brick.config.path_prefix
666
667
  existing_controllers = routes.each_with_object({}) do |r, s|
@@ -867,9 +868,12 @@ In config/initializers/brick.rb appropriate entries would look something like:
867
868
 
868
869
  # Trestle compatibility
869
870
  if Object.const_defined?('Trestle') && ::Trestle.config.options&.key?(:site_title) &&
870
- !Object.const_defined?("#{resource_name.camelize}Admin")
871
- ::Trestle.resource(res_sym = k.to_sym) do
872
- menu { item res_sym, icon: "fa fa-star" }
871
+ !Object.const_defined?("#{(res_name = resource_name.tr('/', '_')).camelize}Admin")
872
+ begin
873
+ ::Trestle.resource(res_sym = res_name.to_sym, model: class_name&.constantize) do
874
+ menu { item res_sym, icon: "fa fa-star" }
875
+ end
876
+ rescue
873
877
  end
874
878
  end
875
879
  end
@@ -887,54 +891,56 @@ In config/initializers/brick.rb appropriate entries would look something like:
887
891
  get("/#{controller_prefix}brick_crosstab/data", to: 'brick_gem#crosstab_data')
888
892
  end
889
893
 
890
- unless ::Brick.routes_done
891
- if Object.const_defined?('Rswag::Ui')
892
- rswag_path = routeset_to_use.routes.find { |r| r.app.app == Rswag::Ui::Engine }&.instance_variable_get(:@path_formatter)&.instance_variable_get(:@parts)&.join
893
- first_endpoint_parts = nil
894
- (doc_endpoints = Rswag::Ui.config.config_object[:urls])&.each do |doc_endpoint|
895
- puts "Mounting OpenApi 3.0 documentation endpoint for \"#{doc_endpoint[:name]}\" on #{doc_endpoint[:url]}"
896
- send(:get, doc_endpoint[:url], { to: 'brick_openapi#index' })
897
- endpoint_parts = doc_endpoint[:url]&.split('/')
898
- first_endpoint_parts ||= endpoint_parts
899
- end
900
- if doc_endpoints.present?
901
- if rswag_path && first_endpoint_parts
902
- puts "API documentation now available when navigating to: /#{first_endpoint_parts&.find(&:present?)}/index.html"
903
- else
904
- puts "In order to make documentation available you can put this into your routes.rb:"
905
- puts " mount Rswag::Ui::Engine => '/#{first_endpoint_parts&.find(&:present?) || 'api-docs'}'"
906
- end
894
+ if Object.const_defined?('Rswag::Ui')
895
+ rswag_path = routeset_to_use.routes.find { |r| r.app.app == Rswag::Ui::Engine }&.instance_variable_get(:@path_formatter)&.instance_variable_get(:@parts)&.join
896
+ first_endpoint_parts = nil
897
+ (doc_endpoints = Rswag::Ui.config.config_object[:urls])&.each do |doc_endpoint|
898
+ puts "Mounting OpenApi 3.0 documentation endpoint for \"#{doc_endpoint[:name]}\" on #{doc_endpoint[:url]}" unless ::Brick.routes_done
899
+ send(:get, doc_endpoint[:url], { to: 'brick_openapi#index' })
900
+ endpoint_parts = doc_endpoint[:url]&.split('/')
901
+ first_endpoint_parts ||= endpoint_parts
902
+ end
903
+ end
904
+ next if ::Brick.routes_done
905
+
906
+ if Object.const_defined?('Rswag::Ui')
907
+ if doc_endpoints.present?
908
+ if rswag_path && first_endpoint_parts
909
+ puts "API documentation now available when navigating to: /#{first_endpoint_parts&.find(&:present?)}/index.html"
907
910
  else
908
- sample_path = rswag_path || '/api-docs'
911
+ puts "In order to make documentation available you can put this into your routes.rb:"
912
+ puts " mount Rswag::Ui::Engine => '/#{first_endpoint_parts&.find(&:present?) || 'api-docs'}'"
913
+ end
914
+ else
915
+ sample_path = rswag_path || '/api-docs'
916
+ puts
917
+ puts "Brick: rswag-ui gem detected -- to make OpenAPI 3.0 documentation available from a path such as '#{sample_path}/v1/swagger.json',"
918
+ puts ' put code such as this in an initializer:'
919
+ puts ' Rswag::Ui.configure do |config|'
920
+ puts " config.swagger_endpoint '#{sample_path}/v1/swagger.json', 'API V1 Docs'"
921
+ puts ' end'
922
+ unless rswag_path
909
923
  puts
910
- puts "Brick: rswag-ui gem detected -- to make OpenAPI 3.0 documentation available from a path such as '#{sample_path}/v1/swagger.json',"
911
- puts ' put code such as this in an initializer:'
912
- puts ' Rswag::Ui.configure do |config|'
913
- puts " config.swagger_endpoint '#{sample_path}/v1/swagger.json', 'API V1 Docs'"
914
- puts ' end'
915
- unless rswag_path
916
- puts
917
- puts ' and put this into your routes.rb:'
918
- puts " mount Rswag::Ui::Engine => '/api-docs'"
919
- end
924
+ puts ' and put this into your routes.rb:'
925
+ puts " mount Rswag::Ui::Engine => '/api-docs'"
920
926
  end
921
927
  end
928
+ end
922
929
 
923
- ::Brick.routes_done = true
924
- puts "\n" if tables.present? || views.present?
925
- if tables.present?
926
- puts "Classes that can be built from tables:#{' ' * (table_class_length - 38)} Path:"
927
- puts "======================================#{' ' * (table_class_length - 38)} ====="
928
- ::Brick.display_classes(controller_prefix, tables, table_class_length)
929
- end
930
- if views.present?
931
- puts "Classes that can be built from views:#{' ' * (view_class_length - 37)} Path:"
932
- puts "=====================================#{' ' * (view_class_length - 37)} ====="
933
- ::Brick.display_classes(controller_prefix, views, view_class_length)
934
- end
930
+ puts "\n" if tables.present? || views.present?
931
+ if tables.present?
932
+ puts "Classes that can be built from tables:#{' ' * (table_class_length - 38)} Path:"
933
+ puts "======================================#{' ' * (table_class_length - 38)} ====="
934
+ ::Brick.display_classes(controller_prefix, tables, table_class_length)
935
+ end
936
+ if views.present?
937
+ puts "Classes that can be built from views:#{' ' * (view_class_length - 37)} Path:"
938
+ puts "=====================================#{' ' * (view_class_length - 37)} ====="
939
+ ::Brick.display_classes(controller_prefix, views, view_class_length)
935
940
  end
936
941
  end
937
942
  super
943
+ ::Brick.routes_done = true
938
944
  end
939
945
  end
940
946
 
@@ -976,6 +982,21 @@ module ::Rails
976
982
  end
977
983
  end
978
984
 
985
+ # # Support for when a table or view is named just 's'
986
+ # ActiveSupport::Inflector.class_eval do
987
+ # class << self
988
+ # alias _brick_singularize singularize
989
+ # def singularize(word, locale = :en)
990
+ # if word.present? && ((ret = _brick_singularize(word, locale)).empty? || ret[-1] == '/')
991
+ # # puts word
992
+ # # binding.pry if ret.empty? || ret[-1] == '/'
993
+ # ret << 's'
994
+ # end
995
+ # ret
996
+ # end
997
+ # end
998
+ # end
999
+
979
1000
  # Major compatibility fixes for ActiveRecord < 4.2
980
1001
  # ================================================
981
1002
  ActiveSupport.on_load(:active_record) do
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: brick
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.114
4
+ version: 1.0.116
5
5
  platform: ruby
6
6
  authors:
7
7
  - Lorin Thwaits
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-02-19 00:00:00.000000000 Z
11
+ date: 2023-02-25 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord