diff options
author | Lin Jen-Shin <godfat@godfat.org> | 2017-07-06 15:45:38 +0800 |
---|---|---|
committer | Lin Jen-Shin <godfat@godfat.org> | 2017-07-06 16:25:03 +0800 |
commit | d9435d61218f677395f3b53976a41ac5f361f24b (patch) | |
tree | daeffa17eef21005694cea90eb300b359d433b66 /lib/gitlab/sql | |
parent | 2520edefb9a7481f575ac7bcdbcf89cb1432f27d (diff) | |
download | gitlab-ce-d9435d61218f677395f3b53976a41ac5f361f24b.tar.gz |
Backports for ee-2112
https://gitlab.com/gitlab-org/gitlab-ee/merge_requests/2112
Diffstat (limited to 'lib/gitlab/sql')
-rw-r--r-- | lib/gitlab/sql/glob.rb | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/lib/gitlab/sql/glob.rb b/lib/gitlab/sql/glob.rb new file mode 100644 index 00000000000..5e89e12b2b1 --- /dev/null +++ b/lib/gitlab/sql/glob.rb @@ -0,0 +1,22 @@ +module Gitlab + module SQL + module Glob + extend self + + # Convert a simple glob pattern with wildcard (*) to SQL LIKE pattern + # with SQL expression + def to_like(pattern) + <<~SQL + REPLACE(REPLACE(REPLACE(#{pattern}, + #{q('%')}, #{q('\\%')}), + #{q('_')}, #{q('\\_')}), + #{q('*')}, #{q('%')}) + SQL + end + + def q(string) + ActiveRecord::Base.connection.quote(string) + end + end + end +end |