Class: Workarea::Elasticsearch::Index

Inherits:
Object
  • Object
show all
Defined in:
lib/workarea/elasticsearch/index.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name, mappings, aliases = {}) ⇒ Index

Returns a new instance of Index.



6
7
8
9
10
# File 'lib/workarea/elasticsearch/index.rb', line 6

def initialize(name, mappings, aliases = {})
  @name = name
  @mappings = mappings
  @aliases = aliases
end

Instance Attribute Details

#aliasesObject (readonly)

Returns the value of attribute aliases.



4
5
6
# File 'lib/workarea/elasticsearch/index.rb', line 4

def aliases
  @aliases
end

#mappingsObject (readonly)

Returns the value of attribute mappings.



4
5
6
# File 'lib/workarea/elasticsearch/index.rb', line 4

def mappings
  @mappings
end

#nameObject (readonly)

Returns the value of attribute name.



4
5
6
# File 'lib/workarea/elasticsearch/index.rb', line 4

def name
  @name
end

Instance Method Details

#bulk(documents, options = {}) ⇒ Object



76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
# File 'lib/workarea/elasticsearch/index.rb', line 76

def bulk(documents, options = {})
  return if documents.blank?

  params = {
    index: name,
    refresh: Workarea.config.auto_refresh_search,
    body: documents.map do |document|
            action = document.delete(:bulk_action).try(:to_sym) || :index

            if action == :delete
              { action => { _id: find_id_from(document) } }
            else
              { action => { _id: find_id_from(document), data: document } }
            end
          end
  }

  Workarea.elasticsearch.bulk(params.merge(options))
end

#clear_scroll(*scroll_ids) ⇒ Object



131
132
133
134
# File 'lib/workarea/elasticsearch/index.rb', line 131

def clear_scroll(*scroll_ids)
  scroll_id = scroll_ids.present? ? scroll_ids.join(',') : '_all'
  Workarea.elasticsearch.clear_scroll(scroll_id: scroll_id)
end

#count(query = nil, options = {}) ⇒ Object



117
118
119
120
# File 'lib/workarea/elasticsearch/index.rb', line 117

def count(query = nil, options = {})
  query ||= { query: { match_all: {} } }
  search(query, options.merge(size: 0))['hits']['total']
end

#create!(force: false) ⇒ Object



21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/workarea/elasticsearch/index.rb', line 21

def create!(force: false)
  delete! if force

  unless exists?
    Workarea.elasticsearch.indices.create(
      index: name,
      body: {
        settings: Search::Settings.current.elasticsearch_settings,
        mappings: mappings,
        aliases: aliases
      }
    )
  end
end

#delete(id, options = {}) ⇒ Object



96
97
98
99
100
101
102
103
104
105
# File 'lib/workarea/elasticsearch/index.rb', line 96

def delete(id, options = {})
  params = {
    index: name,
    id: id,
    refresh: Workarea.config.auto_refresh_search,
    ignore: [404]
  }

  Workarea.elasticsearch.delete(params.merge(options))
end

#delete!Object



36
37
38
# File 'lib/workarea/elasticsearch/index.rb', line 36

def delete!
  Workarea.elasticsearch.indices.delete(index: name, ignore: 404)
end

#exists?Boolean

Returns:

  • (Boolean)


17
18
19
# File 'lib/workarea/elasticsearch/index.rb', line 17

def exists?
  Workarea.elasticsearch.indices.exists?(index: name)
end

#save(document, options = {}) ⇒ Object



54
55
56
57
58
59
60
61
62
63
# File 'lib/workarea/elasticsearch/index.rb', line 54

def save(document, options = {})
  params = {
    index: name,
    id: find_id_from(document),
    body: document,
    refresh: Workarea.config.auto_refresh_search
  }

  Workarea.elasticsearch.index(params.merge(options))
end

#scroll(scroll_id, options = {}) ⇒ Object



122
123
124
125
126
127
128
129
# File 'lib/workarea/elasticsearch/index.rb', line 122

def scroll(scroll_id, options = {})
  Workarea.elasticsearch.scroll(
    {
      body: { scroll_id: scroll_id },
      scroll: Workarea.config.elasticsearch_default_scroll
    }.merge(options)
  )
end

#search(query, options = {}) ⇒ Object



107
108
109
110
111
112
113
114
115
# File 'lib/workarea/elasticsearch/index.rb', line 107

def search(query, options = {})
  query = if query.respond_to?(:to_h)
            { index: name, body: query.to_h }
          else
            { index: name, q: query.to_s }
          end

  Workarea.elasticsearch.search(query.merge(options))
end

#update(document, options = {}) ⇒ Object



65
66
67
68
69
70
71
72
73
74
# File 'lib/workarea/elasticsearch/index.rb', line 65

def update(document, options = {})
  params = {
    index: name,
    id: find_id_from(document),
    body: { doc: document },
    refresh: Workarea.config.auto_refresh_search
  }

  Workarea.elasticsearch.update(params.merge(options))
end

#urlObject



12
13
14
15
# File 'lib/workarea/elasticsearch/index.rb', line 12

def url
  host = Workarea.elasticsearch.transport.hosts.first
  "#{Workarea.elasticsearch.transport.__full_url(host)}/#{name}"
end

#wait_for_healthObject



47
48
49
50
51
52
# File 'lib/workarea/elasticsearch/index.rb', line 47

def wait_for_health
  Workarea.elasticsearch.cluster.health(
    index: name,
    wait_for_status: 'yellow'
  )
end

#while_closedObject



40
41
42
43
44
45
# File 'lib/workarea/elasticsearch/index.rb', line 40

def while_closed
  Workarea.elasticsearch.indices.close(index: name)
  result = yield
  Workarea.elasticsearch.indices.open(index: name)
  result
end