indexers 4.1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +313 -0
- data/Rakefile +19 -0
- data/lib/generators/indexers/indexer/indexer_generator.rb +23 -0
- data/lib/generators/indexers/indexer/templates/indexer.rb +12 -0
- data/lib/generators/indexers/install/install_generator.rb +19 -0
- data/lib/generators/indexers/install/templates/configuration.yml +15 -0
- data/lib/generators/indexers/install/templates/initializer.rb +6 -0
- data/lib/indexers/collection.rb +181 -0
- data/lib/indexers/computed_sorts.rb +19 -0
- data/lib/indexers/concern.rb +30 -0
- data/lib/indexers/configuration.rb +35 -0
- data/lib/indexers/definitions.rb +24 -0
- data/lib/indexers/dsl/api.rb +94 -0
- data/lib/indexers/dsl/mappings.rb +14 -0
- data/lib/indexers/dsl/search.rb +29 -0
- data/lib/indexers/dsl/serialization.rb +17 -0
- data/lib/indexers/dsl/traitable.rb +38 -0
- data/lib/indexers/extensions/active_record/base.rb +20 -0
- data/lib/indexers/indexer.rb +132 -0
- data/lib/indexers/pagination.rb +33 -0
- data/lib/indexers/proxy.rb +22 -0
- data/lib/indexers/railtie.rb +23 -0
- data/lib/indexers/version.rb +5 -0
- data/lib/indexers.rb +82 -0
- data/lib/tasks/indexers.rake +16 -0
- data/test/dsl_test.rb +127 -0
- data/test/dummy/Rakefile +5 -0
- data/test/dummy/app/assets/javascripts/application.js +13 -0
- data/test/dummy/app/assets/stylesheets/application.css +15 -0
- data/test/dummy/app/controllers/application_controller.rb +5 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/indexers/product_indexer.rb +55 -0
- data/test/dummy/app/indexers/shop_indexer.rb +28 -0
- data/test/dummy/app/models/product.rb +5 -0
- data/test/dummy/app/models/shop.rb +5 -0
- data/test/dummy/app/views/layouts/application.html.erb +12 -0
- data/test/dummy/bin/bundle +4 -0
- data/test/dummy/bin/rails +5 -0
- data/test/dummy/bin/rake +5 -0
- data/test/dummy/bin/setup +30 -0
- data/test/dummy/config/application.rb +25 -0
- data/test/dummy/config/boot.rb +5 -0
- data/test/dummy/config/database.yml +10 -0
- data/test/dummy/config/database.yml.travis +3 -0
- data/test/dummy/config/elasticsearch.yml +15 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +41 -0
- data/test/dummy/config/environments/production.rb +79 -0
- data/test/dummy/config/environments/test.rb +42 -0
- data/test/dummy/config/initializers/assets.rb +11 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/cookies_serializer.rb +3 -0
- data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/test/dummy/config/initializers/indexers.rb +65 -0
- data/test/dummy/config/initializers/inflections.rb +16 -0
- data/test/dummy/config/initializers/mime_types.rb +4 -0
- data/test/dummy/config/initializers/session_store.rb +3 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/test/dummy/config/locales/en.yml +23 -0
- data/test/dummy/config/routes.rb +56 -0
- data/test/dummy/config/secrets.yml +22 -0
- data/test/dummy/config.ru +4 -0
- data/test/dummy/db/migrate/20161104164148_create_products.rb +14 -0
- data/test/dummy/db/migrate/20161104182219_create_shops.rb +9 -0
- data/test/dummy/db/schema.rb +36 -0
- data/test/dummy/log/development.log +114 -0
- data/test/dummy/log/test.log +20986 -0
- data/test/dummy/public/404.html +61 -0
- data/test/dummy/public/422.html +61 -0
- data/test/dummy/public/500.html +60 -0
- data/test/dummy/public/favicon.ico +0 -0
- data/test/generator_test.rb +26 -0
- data/test/index_test.rb +42 -0
- data/test/record_test.rb +25 -0
- data/test/search_test.rb +164 -0
- data/test/task_test.rb +31 -0
- data/test/test_helper.rb +14 -0
- metadata +237 -0
@@ -0,0 +1,22 @@
|
|
1
|
+
# Be sure to restart your server when you modify this file.
|
2
|
+
|
3
|
+
# Your secret key is used for verifying the integrity of signed cookies.
|
4
|
+
# If you change this key, all old signed cookies will become invalid!
|
5
|
+
|
6
|
+
# Make sure the secret is at least 30 characters and all random,
|
7
|
+
# no regular words or you'll be exposed to dictionary attacks.
|
8
|
+
# You can use `rake secret` to generate a secure secret key.
|
9
|
+
|
10
|
+
# Make sure the secrets in this file are kept private
|
11
|
+
# if you're sharing your code publicly.
|
12
|
+
|
13
|
+
development:
|
14
|
+
secret_key_base: 2c1c8d4cbaa726b21aa6483b7d556125f4897508e2b94f8b3ddaec675168382c9b3b6eb5a9359d2fade03f539c16ac1ef905891c2410f2fd00b83b76c1666feb
|
15
|
+
|
16
|
+
test:
|
17
|
+
secret_key_base: 9dd531171128e7c3d11dd2c5c18c84ba43d29b677043002634a6f4d58bf2687a283b7b6dc6af741d63c3824f11fa1f858010d7c2509a932023f2ece0d3bfe6cf
|
18
|
+
|
19
|
+
# Do not keep production secrets in the repository,
|
20
|
+
# instead read values from the environment.
|
21
|
+
production:
|
22
|
+
secret_key_base: <%= ENV['SECRET_KEY_BASE'] %>
|
@@ -0,0 +1,14 @@
|
|
1
|
+
class CreateProducts < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
create_table :products do |t|
|
4
|
+
t.string :name
|
5
|
+
t.string :category
|
6
|
+
t.integer :shop_id
|
7
|
+
t.integer :price
|
8
|
+
t.integer :position
|
9
|
+
t.string :currency
|
10
|
+
|
11
|
+
t.timestamps null: false
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
# This file is auto-generated from the current state of the database. Instead
|
3
|
+
# of editing this file, please use the migrations feature of Active Record to
|
4
|
+
# incrementally modify your database, and then regenerate this schema definition.
|
5
|
+
#
|
6
|
+
# Note that this schema.rb definition is the authoritative source for your
|
7
|
+
# database schema. If you need to create the application database on another
|
8
|
+
# system, you should be using db:schema:load, not running all the migrations
|
9
|
+
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
10
|
+
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
11
|
+
#
|
12
|
+
# It's strongly recommended that you check this file into your version control system.
|
13
|
+
|
14
|
+
ActiveRecord::Schema.define(version: 20161104182219) do
|
15
|
+
|
16
|
+
# These are extensions that must be enabled in order to support this database
|
17
|
+
enable_extension "plpgsql"
|
18
|
+
|
19
|
+
create_table "products", force: :cascade do |t|
|
20
|
+
t.string "name"
|
21
|
+
t.string "category"
|
22
|
+
t.integer "shop_id"
|
23
|
+
t.integer "price"
|
24
|
+
t.integer "position"
|
25
|
+
t.string "currency"
|
26
|
+
t.datetime "created_at", null: false
|
27
|
+
t.datetime "updated_at", null: false
|
28
|
+
end
|
29
|
+
|
30
|
+
create_table "shops", force: :cascade do |t|
|
31
|
+
t.string "name"
|
32
|
+
t.datetime "created_at", null: false
|
33
|
+
t.datetime "updated_at", null: false
|
34
|
+
end
|
35
|
+
|
36
|
+
end
|
@@ -0,0 +1,114 @@
|
|
1
|
+
[1m[36m (27.8ms)[0m [1mCREATE TABLE "schema_migrations" ("version" character varying NOT NULL) [0m
|
2
|
+
[1m[35m (1.2ms)[0m CREATE UNIQUE INDEX "unique_schema_migrations" ON "schema_migrations" ("version")
|
3
|
+
[1m[36mActiveRecord::SchemaMigration Load (0.3ms)[0m [1mSELECT "schema_migrations".* FROM "schema_migrations"[0m
|
4
|
+
Migrating to CreateProducts (20161104164148)
|
5
|
+
[1m[35m (0.2ms)[0m BEGIN
|
6
|
+
[1m[36m (23.9ms)[0m [1mCREATE TABLE "products" ("id" serial primary key, "name" character varying, "category" character varying, "shop_id" integer, "price" integer, "position" integer, "currency" character varying, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL) [0m
|
7
|
+
[1m[35mSQL (9.0ms)[0m INSERT INTO "schema_migrations" ("version") VALUES ($1) [["version", "20161104164148"]]
|
8
|
+
[1m[36m (5.9ms)[0m [1mCOMMIT[0m
|
9
|
+
Migrating to CreateShops (20161104182219)
|
10
|
+
[1m[35m (6.8ms)[0m BEGIN
|
11
|
+
[1m[36m (3.1ms)[0m [1mCREATE TABLE "shops" ("id" serial primary key, "name" character varying, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL) [0m
|
12
|
+
[1m[35mSQL (0.2ms)[0m INSERT INTO "schema_migrations" ("version") VALUES ($1) [["version", "20161104182219"]]
|
13
|
+
[1m[36m (0.5ms)[0m [1mCOMMIT[0m
|
14
|
+
[1m[35mActiveRecord::SchemaMigration Load (0.2ms)[0m SELECT "schema_migrations".* FROM "schema_migrations"
|
15
|
+
[1m[36m (2.2ms)[0m [1mSELECT t2.oid::regclass::text AS to_table, a1.attname AS column, a2.attname AS primary_key, c.conname AS name, c.confupdtype AS on_update, c.confdeltype AS on_delete
|
16
|
+
FROM pg_constraint c
|
17
|
+
JOIN pg_class t1 ON c.conrelid = t1.oid
|
18
|
+
JOIN pg_class t2 ON c.confrelid = t2.oid
|
19
|
+
JOIN pg_attribute a1 ON a1.attnum = c.conkey[1] AND a1.attrelid = t1.oid
|
20
|
+
JOIN pg_attribute a2 ON a2.attnum = c.confkey[1] AND a2.attrelid = t2.oid
|
21
|
+
JOIN pg_namespace t3 ON c.connamespace = t3.oid
|
22
|
+
WHERE c.contype = 'f'
|
23
|
+
AND t1.relname = 'products'
|
24
|
+
AND t3.nspname = ANY (current_schemas(false))
|
25
|
+
ORDER BY c.conname
|
26
|
+
[0m
|
27
|
+
[1m[35m (1.6ms)[0m SELECT t2.oid::regclass::text AS to_table, a1.attname AS column, a2.attname AS primary_key, c.conname AS name, c.confupdtype AS on_update, c.confdeltype AS on_delete
|
28
|
+
FROM pg_constraint c
|
29
|
+
JOIN pg_class t1 ON c.conrelid = t1.oid
|
30
|
+
JOIN pg_class t2 ON c.confrelid = t2.oid
|
31
|
+
JOIN pg_attribute a1 ON a1.attnum = c.conkey[1] AND a1.attrelid = t1.oid
|
32
|
+
JOIN pg_attribute a2 ON a2.attnum = c.confkey[1] AND a2.attrelid = t2.oid
|
33
|
+
JOIN pg_namespace t3 ON c.connamespace = t3.oid
|
34
|
+
WHERE c.contype = 'f'
|
35
|
+
AND t1.relname = 'shops'
|
36
|
+
AND t3.nspname = ANY (current_schemas(false))
|
37
|
+
ORDER BY c.conname
|
38
|
+
|
39
|
+
[1m[36m (34.7ms)[0m [1mCREATE TABLE "schema_migrations" ("version" character varying NOT NULL) [0m
|
40
|
+
[1m[35m (10.8ms)[0m CREATE UNIQUE INDEX "unique_schema_migrations" ON "schema_migrations" ("version")
|
41
|
+
[1m[36mActiveRecord::SchemaMigration Load (0.2ms)[0m [1mSELECT "schema_migrations".* FROM "schema_migrations"[0m
|
42
|
+
Migrating to CreateProducts (20161104164148)
|
43
|
+
[1m[35m (0.1ms)[0m BEGIN
|
44
|
+
[1m[36m (26.2ms)[0m [1mCREATE TABLE "products" ("id" serial primary key, "name" character varying, "category" character varying, "shop_id" integer, "price" integer, "position" integer, "currency" character varying, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL) [0m
|
45
|
+
[1m[35mSQL (0.6ms)[0m INSERT INTO "schema_migrations" ("version") VALUES ($1) [["version", "20161104164148"]]
|
46
|
+
[1m[36m (6.2ms)[0m [1mCOMMIT[0m
|
47
|
+
Migrating to CreateShops (20161104182219)
|
48
|
+
[1m[35m (6.1ms)[0m BEGIN
|
49
|
+
[1m[36m (12.5ms)[0m [1mCREATE TABLE "shops" ("id" serial primary key, "name" character varying, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL) [0m
|
50
|
+
[1m[35mSQL (0.2ms)[0m INSERT INTO "schema_migrations" ("version") VALUES ($1) [["version", "20161104182219"]]
|
51
|
+
[1m[36m (0.5ms)[0m [1mCOMMIT[0m
|
52
|
+
[1m[35mActiveRecord::SchemaMigration Load (0.2ms)[0m SELECT "schema_migrations".* FROM "schema_migrations"
|
53
|
+
[1m[36m (1.8ms)[0m [1mSELECT t2.oid::regclass::text AS to_table, a1.attname AS column, a2.attname AS primary_key, c.conname AS name, c.confupdtype AS on_update, c.confdeltype AS on_delete
|
54
|
+
FROM pg_constraint c
|
55
|
+
JOIN pg_class t1 ON c.conrelid = t1.oid
|
56
|
+
JOIN pg_class t2 ON c.confrelid = t2.oid
|
57
|
+
JOIN pg_attribute a1 ON a1.attnum = c.conkey[1] AND a1.attrelid = t1.oid
|
58
|
+
JOIN pg_attribute a2 ON a2.attnum = c.confkey[1] AND a2.attrelid = t2.oid
|
59
|
+
JOIN pg_namespace t3 ON c.connamespace = t3.oid
|
60
|
+
WHERE c.contype = 'f'
|
61
|
+
AND t1.relname = 'products'
|
62
|
+
AND t3.nspname = ANY (current_schemas(false))
|
63
|
+
ORDER BY c.conname
|
64
|
+
[0m
|
65
|
+
[1m[35m (1.3ms)[0m SELECT t2.oid::regclass::text AS to_table, a1.attname AS column, a2.attname AS primary_key, c.conname AS name, c.confupdtype AS on_update, c.confdeltype AS on_delete
|
66
|
+
FROM pg_constraint c
|
67
|
+
JOIN pg_class t1 ON c.conrelid = t1.oid
|
68
|
+
JOIN pg_class t2 ON c.confrelid = t2.oid
|
69
|
+
JOIN pg_attribute a1 ON a1.attnum = c.conkey[1] AND a1.attrelid = t1.oid
|
70
|
+
JOIN pg_attribute a2 ON a2.attnum = c.confkey[1] AND a2.attrelid = t2.oid
|
71
|
+
JOIN pg_namespace t3 ON c.connamespace = t3.oid
|
72
|
+
WHERE c.contype = 'f'
|
73
|
+
AND t1.relname = 'shops'
|
74
|
+
AND t3.nspname = ANY (current_schemas(false))
|
75
|
+
ORDER BY c.conname
|
76
|
+
|
77
|
+
[1m[36m (2.5ms)[0m [1mCREATE TABLE "schema_migrations" ("version" character varying NOT NULL) [0m
|
78
|
+
[1m[35m (12.3ms)[0m CREATE UNIQUE INDEX "unique_schema_migrations" ON "schema_migrations" ("version")
|
79
|
+
[1m[36mActiveRecord::SchemaMigration Load (0.3ms)[0m [1mSELECT "schema_migrations".* FROM "schema_migrations"[0m
|
80
|
+
Migrating to CreateProducts (20161104164148)
|
81
|
+
[1m[35m (0.1ms)[0m BEGIN
|
82
|
+
[1m[36m (7.7ms)[0m [1mCREATE TABLE "products" ("id" serial primary key, "name" character varying, "category" character varying, "shop_id" integer, "price" integer, "position" integer, "currency" character varying, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL) [0m
|
83
|
+
[1m[35mSQL (0.3ms)[0m INSERT INTO "schema_migrations" ("version") VALUES ($1) [["version", "20161104164148"]]
|
84
|
+
[1m[36m (0.4ms)[0m [1mCOMMIT[0m
|
85
|
+
Migrating to CreateShops (20161104182219)
|
86
|
+
[1m[35m (0.2ms)[0m BEGIN
|
87
|
+
[1m[36m (2.1ms)[0m [1mCREATE TABLE "shops" ("id" serial primary key, "name" character varying, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL) [0m
|
88
|
+
[1m[35mSQL (0.2ms)[0m INSERT INTO "schema_migrations" ("version") VALUES ($1) [["version", "20161104182219"]]
|
89
|
+
[1m[36m (0.6ms)[0m [1mCOMMIT[0m
|
90
|
+
[1m[35mActiveRecord::SchemaMigration Load (0.3ms)[0m SELECT "schema_migrations".* FROM "schema_migrations"
|
91
|
+
[1m[36m (1.8ms)[0m [1mSELECT t2.oid::regclass::text AS to_table, a1.attname AS column, a2.attname AS primary_key, c.conname AS name, c.confupdtype AS on_update, c.confdeltype AS on_delete
|
92
|
+
FROM pg_constraint c
|
93
|
+
JOIN pg_class t1 ON c.conrelid = t1.oid
|
94
|
+
JOIN pg_class t2 ON c.confrelid = t2.oid
|
95
|
+
JOIN pg_attribute a1 ON a1.attnum = c.conkey[1] AND a1.attrelid = t1.oid
|
96
|
+
JOIN pg_attribute a2 ON a2.attnum = c.confkey[1] AND a2.attrelid = t2.oid
|
97
|
+
JOIN pg_namespace t3 ON c.connamespace = t3.oid
|
98
|
+
WHERE c.contype = 'f'
|
99
|
+
AND t1.relname = 'products'
|
100
|
+
AND t3.nspname = ANY (current_schemas(false))
|
101
|
+
ORDER BY c.conname
|
102
|
+
[0m
|
103
|
+
[1m[35m (1.3ms)[0m SELECT t2.oid::regclass::text AS to_table, a1.attname AS column, a2.attname AS primary_key, c.conname AS name, c.confupdtype AS on_update, c.confdeltype AS on_delete
|
104
|
+
FROM pg_constraint c
|
105
|
+
JOIN pg_class t1 ON c.conrelid = t1.oid
|
106
|
+
JOIN pg_class t2 ON c.confrelid = t2.oid
|
107
|
+
JOIN pg_attribute a1 ON a1.attnum = c.conkey[1] AND a1.attrelid = t1.oid
|
108
|
+
JOIN pg_attribute a2 ON a2.attnum = c.confkey[1] AND a2.attrelid = t2.oid
|
109
|
+
JOIN pg_namespace t3 ON c.connamespace = t3.oid
|
110
|
+
WHERE c.contype = 'f'
|
111
|
+
AND t1.relname = 'shops'
|
112
|
+
AND t3.nspname = ANY (current_schemas(false))
|
113
|
+
ORDER BY c.conname
|
114
|
+
|