passive_columns 0.3.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: baf809905aa69dc2f9ee36bcb51c2c2187790c2d2455fdb0ba828546c260625f
4
- data.tar.gz: 005e105b072004ef89f410d4470a760be689b589a9f767c6a907e31e7ffd9644
3
+ metadata.gz: 3c37d7d720dab3e13b2084d7f6277a35b1d99de88b75eae8ef67b89d67472172
4
+ data.tar.gz: 5ada8404f4509e694764d732892c2833d71c94c959c7ae45c080266781473e7e
5
5
  SHA512:
6
- metadata.gz: 02f54e4528a456f37d07e6340bbc0aeb01c672db28002ad681d5394c8d4617f3bf50ae97b1eaaa13c1d4561712554e95d5612ec239fe0bf2f246db2316f2cf6c
7
- data.tar.gz: 72b5738f265fdc05deb98defee7853fc37427ed8922e19f0e1911bffd9cbe20e48a5a62b49afc188096e6cb9a01c958b1b851f7a1fca709d2332ea10ad4c585f
6
+ metadata.gz: b0ed4cbe6220e1752cb6f98e7b555f31bd178db3941f4a8c2e2d5fb022b3e00eb9abffc71a90cdb29f23fad14cc004e573850d51f9b18b1df3e0e05f4747d32e
7
+ data.tar.gz: c73cf064d995e5c9705f609319e4f0609616d346cc17d1a41a8f4efe98cd5cbd934008ca6c0b7a3226d9a9967323038b0bf0fcf9e33f9c5b6ac3d199f86635f2
@@ -6,16 +6,12 @@ module PassiveColumns
6
6
  module ActiveRecordRelationExtension
7
7
  if ActiveRecord::VERSION::MAJOR >= 7
8
8
  def exec_main_query(...)
9
- if klass.try(:_passive_columns).present? && select_values.blank?
10
- self.select_values = klass.column_names - klass._passive_columns
11
- end
9
+ PassiveColumns.apply_select_scope_to(self)
12
10
  super
13
11
  end
14
12
  else
15
13
  def exec_queries(...)
16
- if klass.try(:_passive_columns).present? && select_values.blank?
17
- self.select_values = klass.column_names - klass._passive_columns
18
- end
14
+ PassiveColumns.apply_select_scope_to(self)
19
15
  super
20
16
  end
21
17
  end
@@ -26,10 +22,7 @@ module PassiveColumns
26
22
  # @see ActiveRecord::QueryMethods::assert_mutability!
27
23
  return super if @loaded || (defined?(@arel) && @arel)
28
24
 
29
- if klass.try(:_passive_columns).present? && select_values.blank?
30
- self.select_values = klass.column_names - klass._passive_columns
31
- end
32
-
25
+ PassiveColumns.apply_select_scope_to(self)
33
26
  super
34
27
  end
35
28
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module PassiveColumns
4
- VERSION = '0.3.0'
4
+ VERSION = '0.3.1'
5
5
  end
@@ -93,6 +93,28 @@ module PassiveColumns
93
93
  end
94
94
  super(name, *filter_list, opts, &block)
95
95
  end
96
+
97
+ def cached_find_by_statement(key, &block)
98
+ cache = @find_by_statement_cache[connection.prepared_statements]
99
+ cache.compute_if_absent(key) do
100
+ ActiveRecord::StatementCache.create(connection) do |params|
101
+ relation = block.call params
102
+ PassiveColumns.apply_select_scope_to(relation)
103
+ relation
104
+ end
105
+ end
106
+ end
107
+ end
108
+
109
+ # This method is used to apply the select scope to the relation.
110
+ # It is used to automatically select all columns except passive columns if no columns are selected.
111
+ # @param [ActiveRecord::Relation] relation
112
+ # @return [void]
113
+ def self.apply_select_scope_to(relation)
114
+ return if relation.klass.try(:_passive_columns).blank?
115
+ return if relation.select_values.present?
116
+
117
+ relation.select_values = relation.klass.column_names - relation.klass._passive_columns
96
118
  end
97
119
 
98
120
  # This method loads a column value, if not already loaded, from the database
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: passive_columns
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.0
4
+ version: 0.3.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Dmitry Golovin
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-07-16 00:00:00.000000000 Z
11
+ date: 2024-11-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord
@@ -115,7 +115,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
115
115
  - !ruby/object:Gem::Version
116
116
  version: '0'
117
117
  requirements: []
118
- rubygems_version: 3.3.26
118
+ rubygems_version: 3.1.6
119
119
  signing_key:
120
120
  specification_version: 4
121
121
  summary: A gem that extends Active Record to retrieve columns from a db on demand