aboutsummaryrefslogtreecommitdiff
path: root/lib/some/messages.rb
diff options
context:
space:
mode:
authormms <git@sapka.me>2024-11-07 22:31:31 +0100
committermms <git@sapka.me>2024-11-07 22:31:31 +0100
commiteb327b3b8ccde4f0a682a0167af8fc4ab89d3958 (patch)
treef044a1093ad9528bb27f6aa2297db6e3cd0fa603 /lib/some/messages.rb
parenta8d3a3d70e6e69ae5c98b7066c62d9dc9625907c (diff)
feat: basic filters
Diffstat (limited to 'lib/some/messages.rb')
-rw-r--r--lib/some/messages.rb46
1 files changed, 37 insertions, 9 deletions
diff --git a/lib/some/messages.rb b/lib/some/messages.rb
index 2f89d2b..78c36a3 100644
--- a/lib/some/messages.rb
+++ b/lib/some/messages.rb
@@ -6,11 +6,21 @@ module Some
OR_CONJUCTION = :or
DEFAULT_CONJUCTION = AND_CONJUCTION
- attr_reader :query, :current_conjuction
+ Token = Struct.new(:id, :conjuction, :field, :value) do
+ def to_query
+ conjuction_to_use = id > 1 ? conjuction : ''
+ return unless field == :direct
+
+ "#{conjuction_to_use} (#{value})"
+ end
+ end
+
+ attr_accessor :query, :current_conjuction, :token_count
def initialize
@query = []
@current_conjuction = AND_CONJUCTION
+ @token_count = 0
end
def or
@@ -18,22 +28,40 @@ module Some
self
end
+ def and
+ @current_conjuction = AND_CONJUCTION
+ self
+ end
+
def filter(params)
- query << params.map do |key, value|
- unless value.is_a? Array
- [current_conjuction, key, value.to_sym]
- else
-
- [current_conjuction,
- value.map { |subarg| [OR_CONJUCTION, key, subarg] }]
- end
+ case params
+ when String
+ add_filter_from_string(params)
end
+ # query << params.map do |key, value|
+ # unless value.is_a? Array
+ # [current_conjuction, key, value.to_sym]
+ # else
+ #
+ # [current_conjuction,
+ # value.map { |subarg| [OR_CONJUCTION, key, subarg] }]
+ # end
+ # end
+ #
self
end
+ def add_filter_from_string(string)
+ @query << Token.new(next_token_id, current_conjuction, :direct, string)
+ end
+
def query_string
+ query.map(&:to_query).join(' ')
+ end
+ def next_token_id
+ @token_count += 1
end
end
end