-
Notifications
You must be signed in to change notification settings - Fork 307
Expand file tree
/
Copy pathquery_builder.rb
More file actions
35 lines (29 loc) · 901 Bytes
/
query_builder.rb
File metadata and controls
35 lines (29 loc) · 901 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
require 'uri'
module Quickbooks
module Util
class QueryBuilder
VALUE_QUOTE = "'"
def initialize
end
def clause(field, operator, value)
value = case value
when DateTime, Time
value.iso8601
when Date
value.strftime('%Y-%m-%d')
when Array
value = value.map{|v| v.to_s.gsub("'", "\\\\'") }
else
# escape single quotes with an escaped backslash
value = value.to_s.gsub("'", "\\\\'")
end
if operator.downcase == 'in' && value.is_a?(Array)
value = value.map{|v| "#{VALUE_QUOTE}#{v}#{VALUE_QUOTE}"}
"#{field} #{operator} (#{value.join(', ')})"
else
"#{field} #{operator} #{VALUE_QUOTE}#{value}#{VALUE_QUOTE}"
end
end
end
end
end