2017-02-13 13:58:58 -05:00
|
|
|
# frozen_string_literal: true
|
2018-02-24 01:45:50 -05:00
|
|
|
|
|
|
|
require "arel/errors"
|
|
|
|
|
|
|
|
require "arel/crud"
|
|
|
|
require "arel/factory_methods"
|
|
|
|
|
|
|
|
require "arel/expressions"
|
|
|
|
require "arel/predications"
|
|
|
|
require "arel/window_predications"
|
|
|
|
require "arel/math"
|
|
|
|
require "arel/alias_predication"
|
|
|
|
require "arel/order_predications"
|
|
|
|
require "arel/table"
|
2019-06-15 10:50:45 -04:00
|
|
|
require "arel/attributes/attribute"
|
2018-02-24 01:45:50 -05:00
|
|
|
|
|
|
|
require "arel/visitors"
|
|
|
|
require "arel/collectors/sql_string"
|
|
|
|
|
|
|
|
require "arel/tree_manager"
|
|
|
|
require "arel/insert_manager"
|
|
|
|
require "arel/select_manager"
|
|
|
|
require "arel/update_manager"
|
|
|
|
require "arel/delete_manager"
|
|
|
|
require "arel/nodes"
|
2010-08-12 17:55:31 -04:00
|
|
|
|
2019-09-26 19:37:42 -04:00
|
|
|
module Arel
|
2018-02-24 01:45:50 -05:00
|
|
|
VERSION = "10.0.0"
|
2010-09-26 19:06:37 -04:00
|
|
|
|
2019-09-26 19:37:42 -04:00
|
|
|
# Wrap a known-safe SQL string for passing to query methods, e.g.
|
|
|
|
#
|
|
|
|
# Post.order(Arel.sql("length(title)")).last
|
|
|
|
#
|
|
|
|
# Great caution should be taken to avoid SQL injection vulnerabilities.
|
|
|
|
# This method should not be used with unsafe values such as request
|
|
|
|
# parameters or model attributes.
|
2018-02-24 01:45:50 -05:00
|
|
|
def self.sql(raw_sql)
|
2010-09-28 20:08:28 -04:00
|
|
|
Arel::Nodes::SqlLiteral.new raw_sql
|
|
|
|
end
|
2010-12-22 21:02:56 -05:00
|
|
|
|
2019-09-26 19:37:42 -04:00
|
|
|
def self.star # :nodoc:
|
2018-02-24 01:45:50 -05:00
|
|
|
sql "*"
|
2010-12-22 21:02:56 -05:00
|
|
|
end
|
2018-09-27 15:53:43 -04:00
|
|
|
|
2019-09-26 19:37:42 -04:00
|
|
|
def self.arel_node?(value) # :nodoc:
|
2018-09-27 15:53:43 -04:00
|
|
|
value.is_a?(Arel::Node) || value.is_a?(Arel::Attribute) || value.is_a?(Arel::Nodes::SqlLiteral)
|
|
|
|
end
|
|
|
|
|
2019-11-13 17:35:28 -05:00
|
|
|
def self.fetch_attribute(value, &block) # :nodoc:
|
2018-05-06 13:26:31 -04:00
|
|
|
case value
|
2019-11-13 17:35:28 -05:00
|
|
|
when Arel::Nodes::Between, Arel::Nodes::In, Arel::Nodes::NotIn, Arel::Nodes::Equality,
|
|
|
|
Arel::Nodes::NotEqual, Arel::Nodes::LessThan, Arel::Nodes::LessThanOrEqual,
|
|
|
|
Arel::Nodes::GreaterThan, Arel::Nodes::GreaterThanOrEqual
|
|
|
|
if value.left.is_a?(Arel::Attributes::Attribute)
|
|
|
|
yield value.left
|
2020-02-27 04:43:56 -05:00
|
|
|
elsif value.right.is_a?(Arel::Attributes::Attribute)
|
2019-11-13 17:35:28 -05:00
|
|
|
yield value.right
|
|
|
|
end
|
|
|
|
when Arel::Nodes::Or
|
|
|
|
fetch_attribute(value.left, &block) && fetch_attribute(value.right, &block)
|
|
|
|
when Arel::Nodes::Grouping
|
|
|
|
fetch_attribute(value.expr, &block)
|
2018-05-06 13:26:31 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-11-29 18:44:02 -05:00
|
|
|
## Convenience Alias
|
2019-09-26 19:37:42 -04:00
|
|
|
Node = Arel::Nodes::Node # :nodoc:
|
2010-09-26 19:06:37 -04:00
|
|
|
end
|