thinking-sphinx 4.3.0 → 5.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +16 -21
- data/Appraisals +2 -17
- data/CHANGELOG.markdown +62 -1
- data/README.textile +14 -16
- data/bin/loadsphinx +20 -5
- data/lib/thinking_sphinx/active_record/association_proxy.rb +1 -2
- data/lib/thinking_sphinx/active_record/association_proxy/attribute_finder.rb +1 -1
- data/lib/thinking_sphinx/active_record/base.rb +17 -6
- data/lib/thinking_sphinx/active_record/callbacks/delete_callbacks.rb +1 -1
- data/lib/thinking_sphinx/active_record/callbacks/delta_callbacks.rb +3 -2
- data/lib/thinking_sphinx/active_record/callbacks/update_callbacks.rb +1 -1
- data/lib/thinking_sphinx/active_record/interpreter.rb +4 -4
- data/lib/thinking_sphinx/active_record/sql_source.rb +12 -0
- data/lib/thinking_sphinx/active_record/sql_source/template.rb +2 -2
- data/lib/thinking_sphinx/callbacks.rb +9 -0
- data/lib/thinking_sphinx/callbacks/appender.rb +47 -0
- data/lib/thinking_sphinx/commands/index_real_time.rb +1 -3
- data/lib/thinking_sphinx/configuration.rb +9 -3
- data/lib/thinking_sphinx/core/index.rb +5 -2
- data/lib/thinking_sphinx/deletion.rb +18 -17
- data/lib/thinking_sphinx/index_set.rb +7 -3
- data/lib/thinking_sphinx/middlewares/sphinxql.rb +1 -1
- data/lib/thinking_sphinx/railtie.rb +9 -1
- data/lib/thinking_sphinx/real_time.rb +17 -0
- data/lib/thinking_sphinx/real_time/index.rb +4 -0
- data/lib/thinking_sphinx/real_time/interpreter.rb +8 -6
- data/lib/thinking_sphinx/real_time/populator.rb +1 -1
- data/lib/thinking_sphinx/real_time/processor.rb +36 -0
- data/lib/thinking_sphinx/real_time/transcriber.rb +35 -19
- data/lib/thinking_sphinx/subscribers/populator_subscriber.rb +0 -4
- data/spec/acceptance/big_integers_spec.rb +1 -1
- data/spec/acceptance/merging_spec.rb +1 -1
- data/spec/acceptance/real_time_updates_spec.rb +2 -2
- data/spec/acceptance/sql_deltas_spec.rb +3 -3
- data/spec/acceptance/suspended_deltas_spec.rb +3 -3
- data/spec/internal/app/models/admin/person.rb +3 -1
- data/spec/internal/app/models/album.rb +3 -1
- data/spec/internal/app/models/animal.rb +1 -0
- data/spec/internal/app/models/article.rb +2 -0
- data/spec/internal/app/models/bird.rb +1 -0
- data/spec/internal/app/models/book.rb +2 -0
- data/spec/internal/app/models/car.rb +1 -1
- data/spec/internal/app/models/city.rb +2 -0
- data/spec/internal/app/models/product.rb +1 -1
- data/spec/internal/app/models/tee.rb +2 -0
- data/spec/internal/app/models/user.rb +2 -0
- data/spec/thinking_sphinx/active_record/callbacks/update_callbacks_spec.rb +2 -1
- data/spec/thinking_sphinx/active_record/index_spec.rb +0 -12
- data/spec/thinking_sphinx/active_record/interpreter_spec.rb +15 -14
- data/spec/thinking_sphinx/active_record/sql_source_spec.rb +38 -0
- data/spec/thinking_sphinx/configuration_spec.rb +17 -16
- data/spec/thinking_sphinx/deletion_spec.rb +5 -4
- data/spec/thinking_sphinx/index_set_spec.rb +28 -12
- data/spec/thinking_sphinx/middlewares/sphinxql_spec.rb +2 -1
- data/spec/thinking_sphinx/real_time/index_spec.rb +38 -12
- data/spec/thinking_sphinx/real_time/interpreter_spec.rb +14 -14
- data/spec/thinking_sphinx/real_time/transcriber_spec.rb +9 -1
- data/thinking-sphinx.gemspec +3 -5
- metadata +9 -8
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7f0e9705ca201e4e4aad6aee89116b150a6dbef077ae949eeddc594d8b3c2c50
|
4
|
+
data.tar.gz: 336af45f825119fde255c8bb373094e4d63f2ae6a98d01495410e68165534555
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b8d6ec2efdace6c3b214ca488f0b1befdceb61de3b2287d8eb0ce6d6eeb489619bdda92402448b51e7655936b959bfc33d94bc173b171ad542bf02133b6fe394
|
7
|
+
data.tar.gz: ca5e3308d74888ec60cbc0144f7972dfc5602552f6e03396f29f2ab010e7bbfebc0a2f8781d2345eeddc97a3cafcaaba24221e3c560e231a5fb51cd4180f6f57
|
data/.travis.yml
CHANGED
@@ -1,41 +1,36 @@
|
|
1
1
|
language: ruby
|
2
|
+
dist: xenial
|
2
3
|
rvm:
|
3
|
-
- 2.
|
4
|
-
- 2.
|
5
|
-
- 2.
|
6
|
-
- 2.
|
4
|
+
- 2.4.10
|
5
|
+
- 2.5.8
|
6
|
+
- 2.6.6
|
7
|
+
- 2.7.1
|
7
8
|
before_install:
|
8
|
-
- pip install --upgrade --user awscli
|
9
9
|
- gem update --system
|
10
|
-
- gem
|
11
|
-
|
10
|
+
- gem install bundler -v '1.17.3'
|
11
|
+
install: bundle _1.17.3_ install --jobs=3 --retry=3
|
12
12
|
before_script:
|
13
13
|
- mysql -e 'create database thinking_sphinx;' > /dev/null
|
14
14
|
- psql -c 'create database thinking_sphinx;' -U postgres >/dev/null
|
15
15
|
- "./bin/loadsphinx $SPHINX_VERSION $SPHINX_ENGINE"
|
16
|
-
- bundle exec appraisal install
|
17
|
-
script: bundle exec appraisal rspec
|
16
|
+
- bundle _1.17.3_ exec appraisal install
|
17
|
+
script: bundle _1.17.3_ exec appraisal rspec
|
18
18
|
env:
|
19
|
-
global:
|
20
|
-
- secure: cUPinkilBafqDSPsTkl/PXYc2aXNKUQKXGK8poBBMqKN9/wjfJx1DWgtowDKalekdZELxDhc85Ye3bL1xlW4nLjOu+U6Tkt8eNw2Nhs1flodHzA/RyENdBLr/tBHt43EjkrDehZx5sBHmWQY4miHs8AJz0oKO9Ae2inTOHx9Iuc=
|
21
19
|
matrix:
|
22
|
-
- DATABASE=mysql2 SPHINX_VERSION=2.1.9 SPHINX_ENGINE=sphinx
|
23
|
-
- DATABASE=postgresql SPHINX_VERSION=2.1.9 SPHINX_ENGINE=sphinx
|
24
20
|
- DATABASE=mysql2 SPHINX_VERSION=2.2.11 SPHINX_ENGINE=sphinx
|
25
21
|
- DATABASE=postgresql SPHINX_VERSION=2.2.11 SPHINX_ENGINE=sphinx
|
26
|
-
- DATABASE=mysql2 SPHINX_VERSION=3.
|
27
|
-
- DATABASE=postgresql SPHINX_VERSION=3.0.3 SPHINX_ENGINE=sphinx
|
28
|
-
- DATABASE=mysql2 SPHINX_VERSION=3.1.1 SPHINX_ENGINE=sphinx
|
29
|
-
- DATABASE=mysql2 SPHINX_VERSION=2.6.4 SPHINX_ENGINE=manticore
|
30
|
-
- DATABASE=postgresql SPHINX_VERSION=2.6.4 SPHINX_ENGINE=manticore
|
31
|
-
- DATABASE=mysql2 SPHINX_VERSION=2.7.5 SPHINX_ENGINE=manticore
|
32
|
-
- DATABASE=postgresql SPHINX_VERSION=2.7.5 SPHINX_ENGINE=manticore
|
22
|
+
- DATABASE=mysql2 SPHINX_VERSION=3.2.1 SPHINX_ENGINE=sphinx
|
33
23
|
- DATABASE=mysql2 SPHINX_VERSION=2.8.2 SPHINX_ENGINE=manticore
|
34
24
|
- DATABASE=postgresql SPHINX_VERSION=2.8.2 SPHINX_ENGINE=manticore
|
35
|
-
|
25
|
+
- DATABASE=mysql2 SPHINX_VERSION=3.4.2 SPHINX_ENGINE=manticore
|
26
|
+
- DATABASE=postgresql SPHINX_VERSION=3.4.2 SPHINX_ENGINE=manticore
|
27
|
+
# - DATABASE=postgresql SPHINX_VERSION=3.2.1 SPHINX_ENGINE=sphinx
|
36
28
|
sudo: false
|
37
29
|
addons:
|
38
30
|
postgresql: '9.4'
|
31
|
+
apt:
|
32
|
+
packages:
|
33
|
+
- libodbc1
|
39
34
|
services:
|
40
35
|
- mysql
|
41
36
|
- postgresql
|
data/Appraisals
CHANGED
@@ -1,22 +1,7 @@
|
|
1
|
-
appraise 'rails_3_2' do
|
2
|
-
gem 'rails', '~> 3.2.22.2'
|
3
|
-
gem 'mysql2', '~> 0.3.10', :platform => :ruby
|
4
|
-
end if RUBY_VERSION.to_f <= 2.3
|
5
|
-
|
6
|
-
appraise 'rails_4_0' do
|
7
|
-
gem 'rails', '~> 4.0.13'
|
8
|
-
gem 'mysql2', '~> 0.3.10', :platform => :ruby
|
9
|
-
end if RUBY_VERSION.to_f <= 2.3
|
10
|
-
|
11
|
-
appraise 'rails_4_1' do
|
12
|
-
gem 'rails', '~> 4.1.15'
|
13
|
-
gem 'mysql2', '~> 0.3.13', :platform => :ruby
|
14
|
-
end if RUBY_VERSION.to_f <= 2.3
|
15
|
-
|
16
1
|
appraise 'rails_4_2' do
|
17
2
|
gem 'rails', '~> 4.2.6'
|
18
3
|
gem 'mysql2', '~> 0.4.0', :platform => :ruby
|
19
|
-
end if RUBY_VERSION.to_f <= 2.
|
4
|
+
end if RUBY_VERSION.to_f <= 2.4
|
20
5
|
|
21
6
|
appraise 'rails_5_0' do
|
22
7
|
if RUBY_PLATFORM == "java"
|
@@ -44,7 +29,7 @@ appraise 'rails_5_2' do
|
|
44
29
|
end if RUBY_PLATFORM != 'java'
|
45
30
|
|
46
31
|
appraise 'rails_6_0' do
|
47
|
-
gem 'rails', '~> 6.0.0
|
32
|
+
gem 'rails', '~> 6.0.0'
|
48
33
|
gem 'mysql2', '~> 0.5.0', :platform => :ruby
|
49
34
|
gem 'pg', '~> 1.0', :platform => :ruby
|
50
35
|
end if RUBY_PLATFORM != 'java' && RUBY_VERSION.to_f >= 2.5
|
data/CHANGELOG.markdown
CHANGED
@@ -2,13 +2,74 @@
|
|
2
2
|
|
3
3
|
All notable changes to this project (at least, from v3.0.0 onwards) are documented in this file.
|
4
4
|
|
5
|
+
## 5.0.0 - 2020-07-20
|
6
|
+
|
7
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v5.0.0)
|
8
|
+
|
9
|
+
### Added
|
10
|
+
|
11
|
+
* New interface for adding callbacks to indexed models (which is no longer done automatically). Discussed in [#1173](https://github.com/pat/thinking-sphinx/issues/1173) and committed via [#1175](https://github.com/pat/thinking-sphinx/pull/1175). **This is a breaking change - you will need to add these callbacks. See [the full release notes](https://github.com/pat/thinking-sphinx/releases/tag/v5.0.0) for examples.**
|
12
|
+
* Fields and attributes can be overriden - whichever's defined last with a given name is the definition that's used. This is an edge case, but useful if you want to override any of the default fields/indices. (Requested by @kalsan in [#1172](https://github.com/pat/thinking-sphinx/issues/1172).)
|
13
|
+
* Custom index_set_class implementations can now expect the `:instances` option to be set alongside `:classes`, which is useful in cases to limit the indices returned if you're splitting index data for given classes/models into shards. (Introduced in PR [#1171](https://github.com/pat/thinking-sphinx/pull/1171) after discussions with @lunaru in [#1166](https://github.com/pat/thinking-sphinx/issues/1166).)
|
14
|
+
|
15
|
+
### Changed
|
16
|
+
|
17
|
+
* Sphinx 2.2.11 or newer is required, or Manticore 2.8.2 or newer.
|
18
|
+
* Ruby 2.4 or newer is required.
|
19
|
+
* Rails 4.2 or newer is required.
|
20
|
+
* Remove internal uses of `send`, replaced with `public_send` as that's available in all supported Ruby versions.
|
21
|
+
* Deletion statements are simplified by avoiding the need to calculate document keys/offsets (@njakobsen via [#1134](https://github.com/pat/thinking-sphinx/issues/1134)).
|
22
|
+
* Real-time data is deleted before replacing it, to avoid duplicate data when offsets change (@njakobsen via [#1134](https://github.com/pat/thinking-sphinx/issues/1134)).
|
23
|
+
* Use `reference_name` as per custom `index_set_class` definitions. Previously, the class method was called on `ThinkingSphinx::IndexSet` even if a custom subclass was configured. (As per discussinos with @kalsan in [#1172](https://github.com/pat/thinking-sphinx/issues/1172).)
|
24
|
+
|
25
|
+
## 4.4.1 - 2019-08-23
|
26
|
+
|
27
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.4.1)
|
28
|
+
|
29
|
+
### Changed
|
30
|
+
|
31
|
+
* Automatically remove `app/indices` from Zeitwerk's autoload paths in Rails 6.0 onwards (if using Zeitwerk as the autoloader).
|
32
|
+
|
33
|
+
## 4.4.0 - 2019-08-21
|
34
|
+
|
35
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.4.0)
|
36
|
+
|
37
|
+
### Added
|
38
|
+
|
39
|
+
* Confirmed Rails 6.0 support.
|
40
|
+
* Added ability to have custom real-time index processors (which handles all indices) and populators (which handles a particular index). These are available to get/set via `ThinkingSphinx::RealTime.processor` and `ThinkingSphinx::RealTime.populator` (and discussed in more detail in the [release notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.4.0)).
|
41
|
+
|
42
|
+
### Changed
|
43
|
+
|
44
|
+
* Improve failure message when tables don't exist for models associated with Sphinx indices ([Kiril Mitov](https://github.com/thebravoman) in [#1139](https://github.com/pat/thinking-sphinx/pull/1139)).
|
45
|
+
|
46
|
+
### Fixed
|
47
|
+
|
48
|
+
* Injected has-many/habtm collection search calls as default extensions to associations in Rails 5+, as it's a more reliable approach in Rails 6.0.0.
|
49
|
+
|
50
|
+
## 4.3.2 - 2019-07-10
|
51
|
+
|
52
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.3.2)
|
53
|
+
|
54
|
+
### Fixed
|
55
|
+
|
56
|
+
* Reverted loading change behaviour from v4.3.1 for Rails v5 ([Eduardo J.](https://github.com/eduardoj) in [#1138](https://github.com/pat/thinking-sphinx/pull/1138)).
|
57
|
+
|
58
|
+
## 4.3.1 - 2019-06-27
|
59
|
+
|
60
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.3.1)
|
61
|
+
|
62
|
+
### Fixed
|
63
|
+
|
64
|
+
* Fixed loading of index files to work with Rails 6 and Zeitwerk ([#1137](https://github.com/pat/thinking-sphinx/issues/1137)).
|
65
|
+
|
5
66
|
## 4.3.0 - 2019-05-18
|
6
67
|
|
7
68
|
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.3.0)
|
8
69
|
|
9
70
|
### Added
|
10
71
|
|
11
|
-
* Allow overriding of Sphinx's running state, which is useful when Sphinx commands are interacting with a remote Sphinx daemon. As per discussions in [#1131](https://github.com/pat/thinking-sphinx/pull/
|
72
|
+
* Allow overriding of Sphinx's running state, which is useful when Sphinx commands are interacting with a remote Sphinx daemon. As per discussions in [#1131](https://github.com/pat/thinking-sphinx/pull/1131).
|
12
73
|
* Allow skipping of directory creation, as per discussions in [#1131](https://github.com/pat/thinking-sphinx/pull/1131).
|
13
74
|
|
14
75
|
### Fixed
|
data/README.textile
CHANGED
@@ -1,22 +1,22 @@
|
|
1
1
|
h1. Thinking Sphinx
|
2
2
|
|
3
|
-
Thinking Sphinx is a library for connecting ActiveRecord to the Sphinx full-text search tool, and integrates closely with Rails (but also works with other Ruby web frameworks). The current release is
|
3
|
+
Thinking Sphinx is a library for connecting ActiveRecord to the Sphinx full-text search tool, and integrates closely with Rails (but also works with other Ruby web frameworks). The current release is v5.0.0.
|
4
4
|
|
5
5
|
h2. Upgrading
|
6
6
|
|
7
7
|
Please refer to "the changelog":https://github.com/pat/thinking-sphinx/blob/develop/CHANGELOG.markdown and "release notes":https://github.com/pat/thinking-sphinx/releases for any changes you need to make when upgrading. The release notes in particular are quite good at covering breaking changes and more details for new features.
|
8
8
|
|
9
|
-
The documentation also has more details on what's involved for upgrading from "v3 to v4":https://freelancing-gods.com/thinking-sphinx/v4/upgrading.html, and "v1/v2 to v3":https://freelancing-gods.com/thinking-sphinx/v3/upgrading.html.
|
9
|
+
The documentation also has more details on what's involved for upgrading from "v4 to v5":https://freelancing-gods.com/thinking-sphinx/v5/upgrading.html, "v3 to v4":https://freelancing-gods.com/thinking-sphinx/v4/upgrading.html, and "v1/v2 to v3":https://freelancing-gods.com/thinking-sphinx/v3/upgrading.html.
|
10
10
|
|
11
11
|
h2. Installation
|
12
12
|
|
13
13
|
It's a gem, so install it like you would any other gem. You will also need to specify the mysql2 gem if you're using MRI, or jdbc-mysql if you're using JRuby:
|
14
14
|
|
15
|
-
<pre><code>gem 'mysql2', '~> 0.
|
15
|
+
<pre><code>gem 'mysql2', '~> 0.4', :platform => :ruby
|
16
16
|
gem 'jdbc-mysql', '~> 5.1.35', :platform => :jruby
|
17
|
-
gem 'thinking-sphinx', '~>
|
17
|
+
gem 'thinking-sphinx', '~> 5.0'</code></pre>
|
18
18
|
|
19
|
-
The MySQL gems mentioned are required for connecting to Sphinx, so please include it even when you're using PostgreSQL for your database.
|
19
|
+
The MySQL gems mentioned are required for connecting to Sphinx, so please include it even when you're using PostgreSQL for your database.
|
20
20
|
|
21
21
|
You'll also need to install Sphinx - this is covered in "the extended documentation":https://freelancing-gods.com/thinking-sphinx/installing_sphinx.html.
|
22
22
|
|
@@ -29,10 +29,10 @@ h2. Requirements
|
|
29
29
|
The current release of Thinking Sphinx works with the following versions of its dependencies:
|
30
30
|
|
31
31
|
|_. Library |_. Minimum |_. Tested Against |
|
32
|
-
| Ruby | v2.
|
33
|
-
| Sphinx | v2.
|
34
|
-
| Manticore | v2.
|
35
|
-
| ActiveRecord |
|
32
|
+
| Ruby | v2.4 | v2.4, v2.5, v2.6, v2.7 |
|
33
|
+
| Sphinx | v2.2.11 | v2.2.11, v3.2.1 |
|
34
|
+
| Manticore | v2.8 | v2.8, v3.4 |
|
35
|
+
| ActiveRecord | v4.2 | v4.2..v6.0 |
|
36
36
|
|
37
37
|
It _might_ work with older versions of Ruby, but it's highly recommended to update to a supported release.
|
38
38
|
|
@@ -40,19 +40,17 @@ It should also work with JRuby, but the test environment on Travis CI has been t
|
|
40
40
|
|
41
41
|
h3. Sphinx or Manticore
|
42
42
|
|
43
|
-
Thinking Sphinx
|
43
|
+
Thinking Sphinx is currently built for Sphinx 2.2.11 or newer (though it'll likely work with 2.1.x releases), or Manticore v2.8+.
|
44
44
|
|
45
45
|
h3. Rails and ActiveRecord
|
46
46
|
|
47
|
-
Currently Thinking Sphinx
|
47
|
+
Currently Thinking Sphinx is built to support Rails/ActiveRecord 4.2 or newer. If you're using Sinatra and ActiveRecord instead of Rails, that's fine - just make sure you add the @:require => 'thinking_sphinx/sinatra'@ option when listing @thinking-sphinx@ in your Gemfile.
|
48
48
|
|
49
|
-
|
50
|
-
|
51
|
-
If you want ActiveRecord 3.1 support, then refer to the 3.0.x releases of Thinking Sphinx. Anything older than that, then you're stuck with Thinking Sphinx v2.x (for Rails/ActiveRecord 3.0) or v1.x (Rails 2.3). Please note that these older versions are no longer actively supported.
|
49
|
+
If you want ActiveRecord 3.2-4.1 support, then refer to the 4.x releases of Thinking Sphinx. Or, for ActiveRecord 3.1 support, then refer to the 3.0.x releases. Anything older than that, then you're stuck with Thinking Sphinx v2.x (for Rails/ActiveRecord 3.0) or v1.x (Rails 2.3). Please note that these older versions are no longer actively supported.
|
52
50
|
|
53
51
|
h3. Ruby
|
54
52
|
|
55
|
-
You'll need either the standard Ruby (v2.
|
53
|
+
You'll need either the standard Ruby (v2.4 or newer) or JRuby (9.1 or newer).
|
56
54
|
|
57
55
|
h3. Database Versions
|
58
56
|
|
@@ -81,4 +79,4 @@ You can then run the unit tests with @rake spec:unit@, the acceptance tests with
|
|
81
79
|
|
82
80
|
h2. Licence
|
83
81
|
|
84
|
-
Copyright (c) 2007-
|
82
|
+
Copyright (c) 2007-2020, Thinking Sphinx is developed and maintained by Pat Allan, and is released under the open MIT Licence. Many thanks to "all who have contributed patches":https://github.com/pat/thinking-sphinx/contributors.
|
data/bin/loadsphinx
CHANGED
@@ -3,13 +3,18 @@
|
|
3
3
|
version=$1
|
4
4
|
engine=$2
|
5
5
|
|
6
|
+
set -e
|
7
|
+
|
6
8
|
load_sphinx () {
|
9
|
+
distro="xenial"
|
10
|
+
|
7
11
|
case $version in
|
8
12
|
2.1.9)
|
9
13
|
url="http://sphinxsearch.com/files/sphinxsearch_2.1.9-release-0ubuntu11~trusty_amd64.deb"
|
10
|
-
format="deb"
|
14
|
+
format="deb"
|
15
|
+
distro="trusty";;
|
11
16
|
2.2.11)
|
12
|
-
url="http://sphinxsearch.com/files/sphinxsearch_2.2.11-release-1~
|
17
|
+
url="http://sphinxsearch.com/files/sphinxsearch_2.2.11-release-1~xenial_amd64.deb"
|
13
18
|
format="deb";;
|
14
19
|
3.0.3)
|
15
20
|
url="http://sphinxsearch.com/files/sphinx-3.0.3-facc3fb-linux-amd64.tar.gz"
|
@@ -17,11 +22,19 @@ load_sphinx () {
|
|
17
22
|
3.1.1)
|
18
23
|
url="http://sphinxsearch.com/files/sphinx-3.1.1-612d99f-linux-amd64.tar.gz"
|
19
24
|
format="gz";;
|
25
|
+
3.2.1)
|
26
|
+
url="http://www.sphinxsearch.com/files/sphinx-3.2.1-f152e0b-linux-amd64.tar.gz"
|
27
|
+
format="gz";;
|
20
28
|
*)
|
21
29
|
echo "No Sphinx version $version available"
|
22
30
|
exit 1;;
|
23
31
|
esac
|
24
32
|
|
33
|
+
if [ "$distro" == "trusty" ]; then
|
34
|
+
curl --location http://launchpadlibrarian.net/247512886/libmysqlclient18_5.6.28-1ubuntu3_amd64.deb -o libmysql.deb
|
35
|
+
sudo apt-get install ./libmysql.deb
|
36
|
+
fi
|
37
|
+
|
25
38
|
if [ "$format" == "deb" ]; then
|
26
39
|
curl --location $url -o sphinx.deb
|
27
40
|
sudo apt-get install ./sphinx.deb
|
@@ -37,11 +50,13 @@ load_manticore () {
|
|
37
50
|
|
38
51
|
case $version in
|
39
52
|
2.6.4)
|
40
|
-
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.6.4/manticore_2.6.4-180503-37308c3-release-stemmer.
|
53
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.6.4/manticore_2.6.4-180503-37308c3-release-stemmer.xenial_amd64-bin.deb";;
|
41
54
|
2.7.5)
|
42
|
-
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.7.5/manticore_2.7.5-181204-
|
55
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.7.5/manticore_2.7.5-181204-4a31c54-release-stemmer.xenial_amd64-bin.deb";;
|
43
56
|
2.8.2)
|
44
|
-
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.8.2/manticore_2.8.2-190402-4e81114-release-stemmer.
|
57
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.8.2/manticore_2.8.2-190402-4e81114-release-stemmer.xenial_amd64-bin.deb";;
|
58
|
+
3.4.2)
|
59
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/3.4.2/manticore_3.4.2-200410-6903305-release.xenial_amd64-bin.deb";;
|
45
60
|
*)
|
46
61
|
echo "No Manticore version $version available"
|
47
62
|
exit 1;;
|
@@ -1,8 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module ThinkingSphinx::ActiveRecord::AssociationProxy
|
4
|
-
extend ActiveSupport::Concern
|
5
|
-
|
6
4
|
def search(query = nil, options = {})
|
7
5
|
perform_search super(*normalise_search_arguments(query, options))
|
8
6
|
end
|
@@ -12,6 +10,7 @@ module ThinkingSphinx::ActiveRecord::AssociationProxy
|
|
12
10
|
end
|
13
11
|
|
14
12
|
private
|
13
|
+
|
15
14
|
def normalise_search_arguments(query, options)
|
16
15
|
query, options = nil, query if query.is_a?(Hash)
|
17
16
|
options[:ignore_scopes] = true
|
@@ -31,7 +31,7 @@ class ThinkingSphinx::ActiveRecord::AssociationProxy::AttributeFinder
|
|
31
31
|
@indices ||= begin
|
32
32
|
configuration.preload_indices
|
33
33
|
configuration.indices_for_references(
|
34
|
-
*
|
34
|
+
*configuration.index_set_class.reference_name(@association.klass)
|
35
35
|
).reject &:distributed?
|
36
36
|
end
|
37
37
|
end
|
@@ -4,13 +4,24 @@ module ThinkingSphinx::ActiveRecord::Base
|
|
4
4
|
extend ActiveSupport::Concern
|
5
5
|
|
6
6
|
included do
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
7
|
+
if ActiveRecord::VERSION::STRING.to_i >= 5
|
8
|
+
[
|
9
|
+
::ActiveRecord::Reflection::HasManyReflection,
|
10
|
+
::ActiveRecord::Reflection::HasAndBelongsToManyReflection
|
11
|
+
].each do |reflection_class|
|
12
|
+
reflection_class.include DefaultReflectionAssociations
|
13
|
+
end
|
14
|
+
else
|
15
|
+
::ActiveRecord::Associations::CollectionProxy.include(
|
16
|
+
ThinkingSphinx::ActiveRecord::AssociationProxy
|
17
|
+
)
|
18
|
+
end
|
19
|
+
end
|
11
20
|
|
12
|
-
|
13
|
-
|
21
|
+
module DefaultReflectionAssociations
|
22
|
+
def extensions
|
23
|
+
super + [ThinkingSphinx::ActiveRecord::AssociationProxy]
|
24
|
+
end
|
14
25
|
end
|
15
26
|
|
16
27
|
module ClassMethods
|
@@ -43,8 +43,9 @@ class ThinkingSphinx::ActiveRecord::Callbacks::DeltaCallbacks <
|
|
43
43
|
end
|
44
44
|
|
45
45
|
def indices
|
46
|
-
@indices ||= config.index_set_class.new(
|
47
|
-
|
46
|
+
@indices ||= config.index_set_class.new(
|
47
|
+
:instances => [instance], :classes => [instance.class]
|
48
|
+
).select { |index| index.type == "plain" }
|
48
49
|
end
|
49
50
|
|
50
51
|
def new_or_changed?
|
@@ -13,15 +13,15 @@ class ThinkingSphinx::ActiveRecord::Interpreter <
|
|
13
13
|
end
|
14
14
|
|
15
15
|
def has(*columns)
|
16
|
-
|
16
|
+
build_properties(
|
17
17
|
::ThinkingSphinx::ActiveRecord::Attribute, columns
|
18
|
-
)
|
18
|
+
).each { |attribute| __source.add_attribute attribute }
|
19
19
|
end
|
20
20
|
|
21
21
|
def indexes(*columns)
|
22
|
-
|
22
|
+
build_properties(
|
23
23
|
::ThinkingSphinx::ActiveRecord::Field, columns
|
24
|
-
)
|
24
|
+
).each { |field| __source.add_field field }
|
25
25
|
end
|
26
26
|
|
27
27
|
def join(*columns)
|
@@ -39,6 +39,18 @@ module ThinkingSphinx
|
|
39
39
|
@adapter ||= DatabaseAdapters.adapter_for(@model)
|
40
40
|
end
|
41
41
|
|
42
|
+
def add_attribute(attribute)
|
43
|
+
attributes.delete_if { |existing| existing.name == attribute.name }
|
44
|
+
|
45
|
+
attributes << attribute
|
46
|
+
end
|
47
|
+
|
48
|
+
def add_field(field)
|
49
|
+
fields.delete_if { |existing| existing.name == field.name }
|
50
|
+
|
51
|
+
fields << field
|
52
|
+
end
|
53
|
+
|
42
54
|
def delta_processor
|
43
55
|
options[:delta_processor].try(:new, adapter, @options[:delta_options] || {})
|
44
56
|
end
|
@@ -18,14 +18,14 @@ class ThinkingSphinx::ActiveRecord::SQLSource::Template
|
|
18
18
|
private
|
19
19
|
|
20
20
|
def add_attribute(column, name, type, options = {})
|
21
|
-
source.
|
21
|
+
source.add_attribute ThinkingSphinx::ActiveRecord::Attribute.new(
|
22
22
|
source.model, ThinkingSphinx::ActiveRecord::Column.new(column),
|
23
23
|
options.merge(:as => name, :type => type)
|
24
24
|
)
|
25
25
|
end
|
26
26
|
|
27
27
|
def add_field(column, name, options = {})
|
28
|
-
source.
|
28
|
+
source.add_field ThinkingSphinx::ActiveRecord::Field.new(
|
29
29
|
source.model, ThinkingSphinx::ActiveRecord::Column.new(column),
|
30
30
|
options.merge(:as => name)
|
31
31
|
)
|