@webiny/api-elasticsearch 0.0.0-mt-2 → 0.0.0-unstable.06b2ede40f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/client.d.ts +1 -0
- package/client.js +79 -36
- package/client.js.map +1 -0
- package/compression.d.ts +1 -1
- package/compression.js +13 -49
- package/compression.js.map +1 -0
- package/cursors.d.ts +3 -2
- package/cursors.js +10 -14
- package/cursors.js.map +1 -0
- package/index.d.ts +19 -4
- package/index.js +187 -13
- package/index.js.map +1 -0
- package/indexConfiguration/base.d.ts +6 -0
- package/indexConfiguration/base.js +42 -0
- package/indexConfiguration/base.js.map +1 -0
- package/indexConfiguration/common.d.ts +9 -0
- package/indexConfiguration/common.js +54 -0
- package/indexConfiguration/common.js.map +1 -0
- package/indexConfiguration/index.d.ts +3 -0
- package/indexConfiguration/index.js +40 -0
- package/indexConfiguration/index.js.map +1 -0
- package/indexConfiguration/japanese.d.ts +6 -0
- package/indexConfiguration/japanese.js +121 -0
- package/indexConfiguration/japanese.js.map +1 -0
- package/indexPrefix.d.ts +1 -0
- package/indexPrefix.js +12 -0
- package/indexPrefix.js.map +1 -0
- package/indices.d.ts +9 -0
- package/indices.js +30 -0
- package/indices.js.map +1 -0
- package/limit.js +2 -8
- package/limit.js.map +1 -0
- package/normalize.d.ts +1 -0
- package/normalize.js +47 -12
- package/normalize.js.map +1 -0
- package/operations/ElasticsearchCatHealth.d.ts +7 -0
- package/operations/ElasticsearchCatHealth.js +38 -0
- package/operations/ElasticsearchCatHealth.js.map +1 -0
- package/operations/ElasticsearchCatNodes.d.ts +7 -0
- package/operations/ElasticsearchCatNodes.js +36 -0
- package/operations/ElasticsearchCatNodes.js.map +1 -0
- package/operations/index.d.ts +3 -0
- package/operations/index.js +40 -0
- package/operations/index.js.map +1 -0
- package/operations/stripConnectionFromException.d.ts +1 -0
- package/operations/stripConnectionFromException.js +24 -0
- package/operations/stripConnectionFromException.js.map +1 -0
- package/operations/types.d.ts +35 -0
- package/operations/types.js +14 -0
- package/operations/types.js.map +1 -0
- package/operators.d.ts +5 -14
- package/operators.js +37 -32
- package/operators.js.map +1 -0
- package/package.json +12 -25
- package/plugins/definition/ElasticsearchBodyModifierPlugin.d.ts +1 -1
- package/plugins/definition/ElasticsearchBodyModifierPlugin.js +3 -12
- package/plugins/definition/ElasticsearchBodyModifierPlugin.js.map +1 -0
- package/plugins/definition/ElasticsearchFieldPlugin.d.ts +11 -17
- package/plugins/definition/ElasticsearchFieldPlugin.js +22 -75
- package/plugins/definition/ElasticsearchFieldPlugin.js.map +1 -0
- package/plugins/definition/ElasticsearchIndexPlugin.d.ts +18 -0
- package/plugins/definition/ElasticsearchIndexPlugin.js +36 -0
- package/plugins/definition/ElasticsearchIndexPlugin.js.map +1 -0
- package/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin.d.ts +6 -2
- package/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin.js +12 -8
- package/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin.js.map +1 -0
- package/plugins/definition/ElasticsearchQueryModifierPlugin.d.ts +1 -1
- package/plugins/definition/ElasticsearchQueryModifierPlugin.js +3 -12
- package/plugins/definition/ElasticsearchQueryModifierPlugin.js.map +1 -0
- package/plugins/definition/ElasticsearchSortModifierPlugin.d.ts +1 -1
- package/plugins/definition/ElasticsearchSortModifierPlugin.js +3 -12
- package/plugins/definition/ElasticsearchSortModifierPlugin.js.map +1 -0
- package/plugins/definition/index.d.ts +6 -0
- package/plugins/definition/index.js +73 -0
- package/plugins/definition/index.js.map +1 -0
- package/plugins/index.d.ts +2 -0
- package/plugins/index.js +29 -0
- package/plugins/index.js.map +1 -0
- package/plugins/operator/andIn.d.ts +1 -1
- package/plugins/operator/andIn.js +6 -20
- package/plugins/operator/andIn.js.map +1 -0
- package/plugins/operator/between.d.ts +1 -1
- package/plugins/operator/between.js +10 -22
- package/plugins/operator/between.js.map +1 -0
- package/plugins/operator/contains.d.ts +1 -1
- package/plugins/operator/contains.js +4 -16
- package/plugins/operator/contains.js.map +1 -0
- package/plugins/operator/equal.d.ts +1 -1
- package/plugins/operator/equal.js +31 -19
- package/plugins/operator/equal.js.map +1 -0
- package/plugins/operator/gt.d.ts +1 -1
- package/plugins/operator/gt.js +4 -15
- package/plugins/operator/gt.js.map +1 -0
- package/plugins/operator/gte.d.ts +1 -1
- package/plugins/operator/gte.js +4 -15
- package/plugins/operator/gte.js.map +1 -0
- package/plugins/operator/in.d.ts +1 -1
- package/plugins/operator/in.js +9 -27
- package/plugins/operator/in.js.map +1 -0
- package/plugins/operator/index.d.ts +3 -0
- package/plugins/operator/index.js +36 -27
- package/plugins/operator/index.js.map +1 -0
- package/plugins/operator/japanese/contains.d.ts +8 -0
- package/plugins/operator/japanese/contains.js +44 -0
- package/plugins/operator/japanese/contains.js.map +1 -0
- package/plugins/operator/lt.d.ts +1 -1
- package/plugins/operator/lt.js +4 -15
- package/plugins/operator/lt.js.map +1 -0
- package/plugins/operator/lte.d.ts +1 -1
- package/plugins/operator/lte.js +4 -15
- package/plugins/operator/lte.js.map +1 -0
- package/plugins/operator/not.d.ts +1 -1
- package/plugins/operator/not.js +27 -16
- package/plugins/operator/not.js.map +1 -0
- package/plugins/operator/notBetween.d.ts +1 -1
- package/plugins/operator/notBetween.js +9 -21
- package/plugins/operator/notBetween.js.map +1 -0
- package/plugins/operator/notContains.d.ts +1 -1
- package/plugins/operator/notContains.js +4 -16
- package/plugins/operator/notContains.js.map +1 -0
- package/plugins/operator/notIn.d.ts +1 -1
- package/plugins/operator/notIn.js +6 -18
- package/plugins/operator/notIn.js.map +1 -0
- package/plugins/operator/notStartsWith.d.ts +7 -0
- package/plugins/operator/notStartsWith.js +30 -0
- package/plugins/operator/notStartsWith.js.map +1 -0
- package/plugins/operator/startsWith.d.ts +7 -0
- package/plugins/operator/startsWith.js +30 -0
- package/plugins/operator/startsWith.js.map +1 -0
- package/sharedIndex.d.ts +1 -0
- package/sharedIndex.js +12 -0
- package/sharedIndex.js.map +1 -0
- package/sort.d.ts +5 -4
- package/sort.js +22 -17
- package/sort.js.map +1 -0
- package/types.d.ts +178 -6
- package/types.js +14 -3
- package/types.js.map +1 -0
- package/utils/createIndex.d.ts +20 -0
- package/utils/createIndex.js +100 -0
- package/utils/createIndex.js.map +1 -0
- package/utils/index.d.ts +3 -0
- package/utils/index.js +29 -0
- package/utils/index.js.map +1 -0
- package/utils/waitUntilHealthy/UnhealthyClusterError.d.ts +4 -0
- package/utils/waitUntilHealthy/UnhealthyClusterError.js +18 -0
- package/utils/waitUntilHealthy/UnhealthyClusterError.js.map +1 -0
- package/utils/waitUntilHealthy/WaitUntilHealthy.d.ts +71 -0
- package/utils/waitUntilHealthy/WaitUntilHealthy.js +157 -0
- package/utils/waitUntilHealthy/WaitUntilHealthy.js.map +1 -0
- package/utils/waitUntilHealthy/WaitingHealthyClusterAbortedError.d.ts +4 -0
- package/utils/waitUntilHealthy/WaitingHealthyClusterAbortedError.js +18 -0
- package/utils/waitUntilHealthy/WaitingHealthyClusterAbortedError.js.map +1 -0
- package/utils/waitUntilHealthy/index.d.ts +6 -0
- package/utils/waitUntilHealthy/index.js +51 -0
- package/utils/waitUntilHealthy/index.js.map +1 -0
- package/utils/waitUntilHealthy/reason/ClusterHealthReason.d.ts +15 -0
- package/utils/waitUntilHealthy/reason/ClusterHealthReason.js +21 -0
- package/utils/waitUntilHealthy/reason/ClusterHealthReason.js.map +1 -0
- package/utils/waitUntilHealthy/reason/IReason.d.ts +4 -0
- package/utils/waitUntilHealthy/reason/IReason.js +7 -0
- package/utils/waitUntilHealthy/reason/IReason.js.map +1 -0
- package/utils/waitUntilHealthy/reason/MemoryReason.d.ts +14 -0
- package/utils/waitUntilHealthy/reason/MemoryReason.js +21 -0
- package/utils/waitUntilHealthy/reason/MemoryReason.js.map +1 -0
- package/utils/waitUntilHealthy/reason/ProcessorReason.d.ts +14 -0
- package/utils/waitUntilHealthy/reason/ProcessorReason.js +21 -0
- package/utils/waitUntilHealthy/reason/ProcessorReason.js.map +1 -0
- package/utils/waitUntilHealthy/reason/index.d.ts +3 -0
- package/utils/waitUntilHealthy/reason/index.js +40 -0
- package/utils/waitUntilHealthy/reason/index.js.map +1 -0
- package/where.d.ts +5 -5
- package/where.js +11 -26
- package/where.js.map +1 -0
- package/plugins/GzipCompression.d.ts +0 -19
- package/plugins/GzipCompression.js +0 -75
- package/plugins/definition/CompressionPlugin.d.ts +0 -20
- package/plugins/definition/CompressionPlugin.js +0 -17
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.stripConnectionFromException = void 0;
|
|
7
|
+
const stripConnectionFromException = ex => {
|
|
8
|
+
if (typeof ex !== "object") {
|
|
9
|
+
return ex;
|
|
10
|
+
}
|
|
11
|
+
if (!ex?.meta?.meta?.connection) {
|
|
12
|
+
return ex;
|
|
13
|
+
}
|
|
14
|
+
return {
|
|
15
|
+
...ex.meta,
|
|
16
|
+
meta: {
|
|
17
|
+
...ex.meta.meta,
|
|
18
|
+
connection: null
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
exports.stripConnectionFromException = stripConnectionFromException;
|
|
23
|
+
|
|
24
|
+
//# sourceMappingURL=stripConnectionFromException.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["stripConnectionFromException","ex","meta","connection","exports"],"sources":["stripConnectionFromException.ts"],"sourcesContent":["export const stripConnectionFromException = (ex: any): any => {\n if (typeof ex !== \"object\") {\n return ex;\n }\n if (!ex?.meta?.meta?.connection) {\n return ex;\n }\n return {\n ...ex.meta,\n meta: {\n ...ex.meta.meta,\n connection: null\n }\n };\n};\n"],"mappings":";;;;;;AAAO,MAAMA,4BAA4B,GAAIC,EAAO,IAAU;EAC1D,IAAI,OAAOA,EAAE,KAAK,QAAQ,EAAE;IACxB,OAAOA,EAAE;EACb;EACA,IAAI,CAACA,EAAE,EAAEC,IAAI,EAAEA,IAAI,EAAEC,UAAU,EAAE;IAC7B,OAAOF,EAAE;EACb;EACA,OAAO;IACH,GAAGA,EAAE,CAACC,IAAI;IACVA,IAAI,EAAE;MACF,GAAGD,EAAE,CAACC,IAAI,CAACA,IAAI;MACfC,UAAU,EAAE;IAChB;EACJ,CAAC;AACL,CAAC;AAACC,OAAA,CAAAJ,4BAAA,GAAAA,4BAAA","ignoreList":[]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export declare enum ElasticsearchCatClusterHealthStatus {
|
|
2
|
+
Green = "green",
|
|
3
|
+
Yellow = "yellow",
|
|
4
|
+
Red = "red"
|
|
5
|
+
}
|
|
6
|
+
export interface IElasticsearchCatHealthResponse {
|
|
7
|
+
epoch: number;
|
|
8
|
+
timestamp: `${number}:${number}:${number}`;
|
|
9
|
+
cluster: string;
|
|
10
|
+
status: ElasticsearchCatClusterHealthStatus;
|
|
11
|
+
"node.total": `${number}`;
|
|
12
|
+
"node.data": `${number}`;
|
|
13
|
+
shards: `${number}`;
|
|
14
|
+
pri: `${number}`;
|
|
15
|
+
relo: `${number}`;
|
|
16
|
+
init: `${number}`;
|
|
17
|
+
unassign: `${number}`;
|
|
18
|
+
pending_tasks: `${number}`;
|
|
19
|
+
max_task_wait_time: string;
|
|
20
|
+
active_shards_percent: `${number}%`;
|
|
21
|
+
discovered_cluster_manager?: `${boolean}`;
|
|
22
|
+
}
|
|
23
|
+
export interface IElasticsearchCatNodeResponse {
|
|
24
|
+
ip: string;
|
|
25
|
+
"heap.percent": `${number}`;
|
|
26
|
+
"ram.percent": `${number}`;
|
|
27
|
+
cpu: `${number}`;
|
|
28
|
+
load_1m: `${number}` | null;
|
|
29
|
+
load_5m: `${number}` | null;
|
|
30
|
+
load_15m: `${number}` | null;
|
|
31
|
+
"node.role": string;
|
|
32
|
+
master?: string;
|
|
33
|
+
name: string;
|
|
34
|
+
}
|
|
35
|
+
export type IElasticsearchCatNodesResponse = IElasticsearchCatNodeResponse[];
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ElasticsearchCatClusterHealthStatus = void 0;
|
|
7
|
+
let ElasticsearchCatClusterHealthStatus = exports.ElasticsearchCatClusterHealthStatus = /*#__PURE__*/function (ElasticsearchCatClusterHealthStatus) {
|
|
8
|
+
ElasticsearchCatClusterHealthStatus["Green"] = "green";
|
|
9
|
+
ElasticsearchCatClusterHealthStatus["Yellow"] = "yellow";
|
|
10
|
+
ElasticsearchCatClusterHealthStatus["Red"] = "red";
|
|
11
|
+
return ElasticsearchCatClusterHealthStatus;
|
|
12
|
+
}({});
|
|
13
|
+
|
|
14
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["ElasticsearchCatClusterHealthStatus","exports"],"sources":["types.ts"],"sourcesContent":["export enum ElasticsearchCatClusterHealthStatus {\n Green = \"green\",\n Yellow = \"yellow\",\n Red = \"red\"\n}\n\nexport interface IElasticsearchCatHealthResponse {\n epoch: number;\n timestamp: `${number}:${number}:${number}`;\n cluster: string;\n status: ElasticsearchCatClusterHealthStatus;\n \"node.total\": `${number}`;\n \"node.data\": `${number}`;\n shards: `${number}`;\n pri: `${number}`;\n relo: `${number}`;\n init: `${number}`;\n unassign: `${number}`;\n pending_tasks: `${number}`;\n max_task_wait_time: string;\n active_shards_percent: `${number}%`;\n discovered_cluster_manager?: `${boolean}`;\n}\n\nexport interface IElasticsearchCatNodeResponse {\n ip: string;\n \"heap.percent\": `${number}`;\n \"ram.percent\": `${number}`;\n cpu: `${number}`;\n load_1m: `${number}` | null;\n load_5m: `${number}` | null;\n load_15m: `${number}` | null;\n \"node.role\": string;\n master?: string;\n name: string;\n}\n\nexport type IElasticsearchCatNodesResponse = IElasticsearchCatNodeResponse[];\n"],"mappings":";;;;;;IAAYA,mCAAmC,GAAAC,OAAA,CAAAD,mCAAA,0BAAnCA,mCAAmC;EAAnCA,mCAAmC;EAAnCA,mCAAmC;EAAnCA,mCAAmC;EAAA,OAAnCA,mCAAmC;AAAA","ignoreList":[]}
|
package/operators.d.ts
CHANGED
|
@@ -1,18 +1,9 @@
|
|
|
1
|
-
import { ElasticsearchQueryBuilderOperatorBetweenPlugin } from "./plugins/operator
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { ElasticsearchQueryBuilderOperatorNotContainsPlugin } from "./plugins/operator/notContains";
|
|
5
|
-
import { ElasticsearchQueryBuilderOperatorEqualPlugin } from "./plugins/operator/equal";
|
|
6
|
-
import { ElasticsearchQueryBuilderOperatorNotPlugin } from "./plugins/operator/not";
|
|
7
|
-
import { ElasticsearchQueryBuilderOperatorGreaterThanPlugin } from "./plugins/operator/gt";
|
|
8
|
-
import { ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin } from "./plugins/operator/gte";
|
|
9
|
-
import { ElasticsearchQueryBuilderOperatorLesserThanPlugin } from "./plugins/operator/lt";
|
|
10
|
-
import { ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin } from "./plugins/operator/lte";
|
|
11
|
-
import { ElasticsearchQueryBuilderOperatorInPlugin } from "./plugins/operator/in";
|
|
12
|
-
import { ElasticsearchQueryBuilderOperatorAndInPlugin } from "./plugins/operator/andIn";
|
|
13
|
-
import { ElasticsearchQueryBuilderOperatorNotInPlugin } from "./plugins/operator/notIn";
|
|
1
|
+
import { ElasticsearchQueryBuilderOperatorBetweenPlugin, ElasticsearchQueryBuilderJapaneseOperatorContainsPlugin, ElasticsearchQueryBuilderOperatorAndInPlugin, ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin, ElasticsearchQueryBuilderOperatorGreaterThanPlugin, ElasticsearchQueryBuilderOperatorContainsPlugin, ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin, ElasticsearchQueryBuilderOperatorInPlugin, ElasticsearchQueryBuilderOperatorLesserThanPlugin, ElasticsearchQueryBuilderOperatorNotBetweenPlugin, ElasticsearchQueryBuilderOperatorNotContainsPlugin, ElasticsearchQueryBuilderOperatorNotPlugin, ElasticsearchQueryBuilderOperatorNotInPlugin, ElasticsearchQueryBuilderOperatorEqualPlugin, ElasticsearchQueryBuilderOperatorStartsWithPlugin, ElasticsearchQueryBuilderOperatorNotStartsWithPlugin } from "./plugins/operator";
|
|
2
|
+
import type { PluginsContainer } from "@webiny/plugins";
|
|
3
|
+
import { ElasticsearchQueryBuilderOperatorPlugin } from "./plugins/definition/ElasticsearchQueryBuilderOperatorPlugin";
|
|
14
4
|
/**
|
|
15
5
|
* We export as a function because there might be something to be sent to the operators at some point.
|
|
16
6
|
* This way, we make it easier to upgrade.
|
|
17
7
|
*/
|
|
18
|
-
export declare const getElasticsearchOperators: () => (ElasticsearchQueryBuilderOperatorBetweenPlugin |
|
|
8
|
+
export declare const getElasticsearchOperators: () => (ElasticsearchQueryBuilderOperatorBetweenPlugin | ElasticsearchQueryBuilderOperatorContainsPlugin | ElasticsearchQueryBuilderOperatorEqualPlugin | ElasticsearchQueryBuilderOperatorGreaterThanPlugin | ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin | ElasticsearchQueryBuilderOperatorAndInPlugin | ElasticsearchQueryBuilderOperatorInPlugin | ElasticsearchQueryBuilderOperatorLesserThanPlugin | ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin | ElasticsearchQueryBuilderOperatorNotPlugin | ElasticsearchQueryBuilderOperatorNotBetweenPlugin | ElasticsearchQueryBuilderOperatorNotContainsPlugin | ElasticsearchQueryBuilderOperatorNotInPlugin | ElasticsearchQueryBuilderOperatorStartsWithPlugin | ElasticsearchQueryBuilderOperatorNotStartsWithPlugin | ElasticsearchQueryBuilderJapaneseOperatorContainsPlugin)[];
|
|
9
|
+
export declare const getElasticsearchOperatorPluginsByLocale: (plugins: PluginsContainer, locale: string) => Record<string, ElasticsearchQueryBuilderOperatorPlugin>;
|
package/operators.js
CHANGED
|
@@ -3,40 +3,45 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.getElasticsearchOperators = void 0;
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
var _notContains = require("./plugins/operator/notContains");
|
|
15
|
-
|
|
16
|
-
var _equal = require("./plugins/operator/equal");
|
|
17
|
-
|
|
18
|
-
var _not = require("./plugins/operator/not");
|
|
19
|
-
|
|
20
|
-
var _gt = require("./plugins/operator/gt");
|
|
21
|
-
|
|
22
|
-
var _gte = require("./plugins/operator/gte");
|
|
23
|
-
|
|
24
|
-
var _lt = require("./plugins/operator/lt");
|
|
25
|
-
|
|
26
|
-
var _lte = require("./plugins/operator/lte");
|
|
27
|
-
|
|
28
|
-
var _in = require("./plugins/operator/in");
|
|
29
|
-
|
|
30
|
-
var _andIn = require("./plugins/operator/andIn");
|
|
31
|
-
|
|
32
|
-
var _notIn = require("./plugins/operator/notIn");
|
|
33
|
-
|
|
34
|
-
const operators = [new _between.ElasticsearchQueryBuilderOperatorBetweenPlugin(), new _notBetween.ElasticsearchQueryBuilderOperatorNotBetweenPlugin(), new _contains.ElasticsearchQueryBuilderOperatorContainsPlugin(), new _notContains.ElasticsearchQueryBuilderOperatorNotContainsPlugin(), new _equal.ElasticsearchQueryBuilderOperatorEqualPlugin(), new _not.ElasticsearchQueryBuilderOperatorNotPlugin(), new _gt.ElasticsearchQueryBuilderOperatorGreaterThanPlugin(), new _gte.ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin(), new _lt.ElasticsearchQueryBuilderOperatorLesserThanPlugin(), new _lte.ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin(), new _in.ElasticsearchQueryBuilderOperatorInPlugin(), new _andIn.ElasticsearchQueryBuilderOperatorAndInPlugin(), new _notIn.ElasticsearchQueryBuilderOperatorNotInPlugin()];
|
|
6
|
+
exports.getElasticsearchOperators = exports.getElasticsearchOperatorPluginsByLocale = void 0;
|
|
7
|
+
var _operator = require("./plugins/operator");
|
|
8
|
+
var _ElasticsearchQueryBuilderOperatorPlugin = require("./plugins/definition/ElasticsearchQueryBuilderOperatorPlugin");
|
|
9
|
+
const operators = [new _operator.ElasticsearchQueryBuilderOperatorBetweenPlugin(), new _operator.ElasticsearchQueryBuilderOperatorNotBetweenPlugin(), new _operator.ElasticsearchQueryBuilderOperatorContainsPlugin(), new _operator.ElasticsearchQueryBuilderOperatorNotContainsPlugin(), new _operator.ElasticsearchQueryBuilderOperatorEqualPlugin(), new _operator.ElasticsearchQueryBuilderOperatorNotPlugin(), new _operator.ElasticsearchQueryBuilderOperatorGreaterThanPlugin(), new _operator.ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin(), new _operator.ElasticsearchQueryBuilderOperatorLesserThanPlugin(), new _operator.ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin(), new _operator.ElasticsearchQueryBuilderOperatorInPlugin(), new _operator.ElasticsearchQueryBuilderOperatorAndInPlugin(), new _operator.ElasticsearchQueryBuilderOperatorNotInPlugin(), new _operator.ElasticsearchQueryBuilderOperatorStartsWithPlugin(), new _operator.ElasticsearchQueryBuilderOperatorNotStartsWithPlugin(),
|
|
10
|
+
/**
|
|
11
|
+
* Japanese
|
|
12
|
+
*/
|
|
13
|
+
new _operator.ElasticsearchQueryBuilderJapaneseOperatorContainsPlugin()];
|
|
35
14
|
/**
|
|
36
15
|
* We export as a function because there might be something to be sent to the operators at some point.
|
|
37
16
|
* This way, we make it easier to upgrade.
|
|
38
17
|
*/
|
|
39
|
-
|
|
40
18
|
const getElasticsearchOperators = () => operators;
|
|
41
|
-
|
|
42
|
-
|
|
19
|
+
exports.getElasticsearchOperators = getElasticsearchOperators;
|
|
20
|
+
const getElasticsearchOperatorPluginsByLocale = (plugins, locale) => {
|
|
21
|
+
/**
|
|
22
|
+
* We always set the last one operator plugin added.
|
|
23
|
+
* This way user can override the plugins.
|
|
24
|
+
*/
|
|
25
|
+
return plugins.byType(_ElasticsearchQueryBuilderOperatorPlugin.ElasticsearchQueryBuilderOperatorPlugin.type).reduce((acc, plugin) => {
|
|
26
|
+
const op = plugin.getOperator();
|
|
27
|
+
/**
|
|
28
|
+
* We only allow the plugins which can pass the locale test.
|
|
29
|
+
* The default plugins always return true.
|
|
30
|
+
*/
|
|
31
|
+
if (plugin.isLocaleSupported(locale) === false) {
|
|
32
|
+
return acc;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* We also only allow the override of the plugins if the new plugin is NOT a default one.
|
|
36
|
+
* If a user names the plugin with .default, we cannot do anything about it.
|
|
37
|
+
*/
|
|
38
|
+
if (!!acc[op] && (plugin.name || "").match(/\.default$/)) {
|
|
39
|
+
return acc;
|
|
40
|
+
}
|
|
41
|
+
acc[op] = plugin;
|
|
42
|
+
return acc;
|
|
43
|
+
}, {});
|
|
44
|
+
};
|
|
45
|
+
exports.getElasticsearchOperatorPluginsByLocale = getElasticsearchOperatorPluginsByLocale;
|
|
46
|
+
|
|
47
|
+
//# sourceMappingURL=operators.js.map
|
package/operators.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_operator","require","_ElasticsearchQueryBuilderOperatorPlugin","operators","ElasticsearchQueryBuilderOperatorBetweenPlugin","ElasticsearchQueryBuilderOperatorNotBetweenPlugin","ElasticsearchQueryBuilderOperatorContainsPlugin","ElasticsearchQueryBuilderOperatorNotContainsPlugin","ElasticsearchQueryBuilderOperatorEqualPlugin","ElasticsearchQueryBuilderOperatorNotPlugin","ElasticsearchQueryBuilderOperatorGreaterThanPlugin","ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin","ElasticsearchQueryBuilderOperatorLesserThanPlugin","ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin","ElasticsearchQueryBuilderOperatorInPlugin","ElasticsearchQueryBuilderOperatorAndInPlugin","ElasticsearchQueryBuilderOperatorNotInPlugin","ElasticsearchQueryBuilderOperatorStartsWithPlugin","ElasticsearchQueryBuilderOperatorNotStartsWithPlugin","ElasticsearchQueryBuilderJapaneseOperatorContainsPlugin","getElasticsearchOperators","exports","getElasticsearchOperatorPluginsByLocale","plugins","locale","byType","ElasticsearchQueryBuilderOperatorPlugin","type","reduce","acc","plugin","op","getOperator","isLocaleSupported","name","match"],"sources":["operators.ts"],"sourcesContent":["import {\n ElasticsearchQueryBuilderOperatorBetweenPlugin,\n ElasticsearchQueryBuilderJapaneseOperatorContainsPlugin,\n ElasticsearchQueryBuilderOperatorAndInPlugin,\n ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin,\n ElasticsearchQueryBuilderOperatorGreaterThanPlugin,\n ElasticsearchQueryBuilderOperatorContainsPlugin,\n ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin,\n ElasticsearchQueryBuilderOperatorInPlugin,\n ElasticsearchQueryBuilderOperatorLesserThanPlugin,\n ElasticsearchQueryBuilderOperatorNotBetweenPlugin,\n ElasticsearchQueryBuilderOperatorNotContainsPlugin,\n ElasticsearchQueryBuilderOperatorNotPlugin,\n ElasticsearchQueryBuilderOperatorNotInPlugin,\n ElasticsearchQueryBuilderOperatorEqualPlugin,\n ElasticsearchQueryBuilderOperatorStartsWithPlugin,\n ElasticsearchQueryBuilderOperatorNotStartsWithPlugin\n} from \"~/plugins/operator\";\nimport type { PluginsContainer } from \"@webiny/plugins\";\nimport { ElasticsearchQueryBuilderOperatorPlugin } from \"~/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin\";\n\nconst operators = [\n new ElasticsearchQueryBuilderOperatorBetweenPlugin(),\n new ElasticsearchQueryBuilderOperatorNotBetweenPlugin(),\n new ElasticsearchQueryBuilderOperatorContainsPlugin(),\n new ElasticsearchQueryBuilderOperatorNotContainsPlugin(),\n new ElasticsearchQueryBuilderOperatorEqualPlugin(),\n new ElasticsearchQueryBuilderOperatorNotPlugin(),\n new ElasticsearchQueryBuilderOperatorGreaterThanPlugin(),\n new ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin(),\n new ElasticsearchQueryBuilderOperatorLesserThanPlugin(),\n new ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin(),\n new ElasticsearchQueryBuilderOperatorInPlugin(),\n new ElasticsearchQueryBuilderOperatorAndInPlugin(),\n new ElasticsearchQueryBuilderOperatorNotInPlugin(),\n new ElasticsearchQueryBuilderOperatorStartsWithPlugin(),\n new ElasticsearchQueryBuilderOperatorNotStartsWithPlugin(),\n /**\n * Japanese\n */\n new ElasticsearchQueryBuilderJapaneseOperatorContainsPlugin()\n];\n/**\n * We export as a function because there might be something to be sent to the operators at some point.\n * This way, we make it easier to upgrade.\n */\nexport const getElasticsearchOperators = () => operators;\n\nexport const getElasticsearchOperatorPluginsByLocale = (\n plugins: PluginsContainer,\n locale: string\n): Record<string, ElasticsearchQueryBuilderOperatorPlugin> => {\n /**\n * We always set the last one operator plugin added.\n * This way user can override the plugins.\n */\n return plugins\n .byType<ElasticsearchQueryBuilderOperatorPlugin>(\n ElasticsearchQueryBuilderOperatorPlugin.type\n )\n .reduce((acc, plugin) => {\n const op = plugin.getOperator();\n /**\n * We only allow the plugins which can pass the locale test.\n * The default plugins always return true.\n */\n if (plugin.isLocaleSupported(locale) === false) {\n return acc;\n }\n /**\n * We also only allow the override of the plugins if the new plugin is NOT a default one.\n * If a user names the plugin with .default, we cannot do anything about it.\n */\n if (!!acc[op] && (plugin.name || \"\").match(/\\.default$/)) {\n return acc;\n }\n acc[op] = plugin;\n return acc;\n }, {} as Record<string, ElasticsearchQueryBuilderOperatorPlugin>);\n};\n"],"mappings":";;;;;;AAAA,IAAAA,SAAA,GAAAC,OAAA;AAmBA,IAAAC,wCAAA,GAAAD,OAAA;AAEA,MAAME,SAAS,GAAG,CACd,IAAIC,wDAA8C,CAAC,CAAC,EACpD,IAAIC,2DAAiD,CAAC,CAAC,EACvD,IAAIC,yDAA+C,CAAC,CAAC,EACrD,IAAIC,4DAAkD,CAAC,CAAC,EACxD,IAAIC,sDAA4C,CAAC,CAAC,EAClD,IAAIC,oDAA0C,CAAC,CAAC,EAChD,IAAIC,4DAAkD,CAAC,CAAC,EACxD,IAAIC,qEAA2D,CAAC,CAAC,EACjE,IAAIC,2DAAiD,CAAC,CAAC,EACvD,IAAIC,oEAA0D,CAAC,CAAC,EAChE,IAAIC,mDAAyC,CAAC,CAAC,EAC/C,IAAIC,sDAA4C,CAAC,CAAC,EAClD,IAAIC,sDAA4C,CAAC,CAAC,EAClD,IAAIC,2DAAiD,CAAC,CAAC,EACvD,IAAIC,8DAAoD,CAAC,CAAC;AAC1D;AACJ;AACA;AACI,IAAIC,iEAAuD,CAAC,CAAC,CAChE;AACD;AACA;AACA;AACA;AACO,MAAMC,yBAAyB,GAAGA,CAAA,KAAMjB,SAAS;AAACkB,OAAA,CAAAD,yBAAA,GAAAA,yBAAA;AAElD,MAAME,uCAAuC,GAAGA,CACnDC,OAAyB,EACzBC,MAAc,KAC4C;EAC1D;AACJ;AACA;AACA;EACI,OAAOD,OAAO,CACTE,MAAM,CACHC,gFAAuC,CAACC,IAC5C,CAAC,CACAC,MAAM,CAAC,CAACC,GAAG,EAAEC,MAAM,KAAK;IACrB,MAAMC,EAAE,GAAGD,MAAM,CAACE,WAAW,CAAC,CAAC;IAC/B;AACZ;AACA;AACA;IACY,IAAIF,MAAM,CAACG,iBAAiB,CAACT,MAAM,CAAC,KAAK,KAAK,EAAE;MAC5C,OAAOK,GAAG;IACd;IACA;AACZ;AACA;AACA;IACY,IAAI,CAAC,CAACA,GAAG,CAACE,EAAE,CAAC,IAAI,CAACD,MAAM,CAACI,IAAI,IAAI,EAAE,EAAEC,KAAK,CAAC,YAAY,CAAC,EAAE;MACtD,OAAON,GAAG;IACd;IACAA,GAAG,CAACE,EAAE,CAAC,GAAGD,MAAM;IAChB,OAAOD,GAAG;EACd,CAAC,EAAE,CAAC,CAA4D,CAAC;AACzE,CAAC;AAACR,OAAA,CAAAC,uCAAA,GAAAA,uCAAA","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/api-elasticsearch",
|
|
3
|
-
"version": "0.0.0-
|
|
3
|
+
"version": "0.0.0-unstable.06b2ede40f",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/webiny/webiny-js.git",
|
|
@@ -13,37 +13,24 @@
|
|
|
13
13
|
"license": "MIT",
|
|
14
14
|
"dependencies": {
|
|
15
15
|
"@elastic/elasticsearch": "7.12.0",
|
|
16
|
-
"@webiny/
|
|
17
|
-
"@webiny/
|
|
18
|
-
"@webiny/plugins": "0.0.0-
|
|
19
|
-
"
|
|
20
|
-
"
|
|
21
|
-
"aws-sdk": "2.1026.0",
|
|
22
|
-
"elastic-ts": "0.7.0"
|
|
16
|
+
"@webiny/api": "0.0.0-unstable.06b2ede40f",
|
|
17
|
+
"@webiny/error": "0.0.0-unstable.06b2ede40f",
|
|
18
|
+
"@webiny/plugins": "0.0.0-unstable.06b2ede40f",
|
|
19
|
+
"aws-elasticsearch-connector": "9.2.0",
|
|
20
|
+
"elastic-ts": "0.12.0"
|
|
23
21
|
},
|
|
24
22
|
"devDependencies": {
|
|
25
|
-
"@
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
"@webiny/project-utils": "^0.0.0-mt-2",
|
|
29
|
-
"rimraf": "^3.0.2",
|
|
30
|
-
"ttypescript": "^1.5.12",
|
|
31
|
-
"typescript": "^4.1.3"
|
|
23
|
+
"@webiny/project-utils": "0.0.0-unstable.06b2ede40f",
|
|
24
|
+
"rimraf": "6.0.1",
|
|
25
|
+
"typescript": "5.3.3"
|
|
32
26
|
},
|
|
33
27
|
"publishConfig": {
|
|
34
28
|
"access": "public",
|
|
35
29
|
"directory": "dist"
|
|
36
30
|
},
|
|
37
31
|
"scripts": {
|
|
38
|
-
"build": "
|
|
39
|
-
"watch": "
|
|
32
|
+
"build": "node ../cli/bin.js run build",
|
|
33
|
+
"watch": "node ../cli/bin.js run watch"
|
|
40
34
|
},
|
|
41
|
-
"
|
|
42
|
-
"ignore": {
|
|
43
|
-
"src": [
|
|
44
|
-
"aws-sdk"
|
|
45
|
-
]
|
|
46
|
-
}
|
|
47
|
-
},
|
|
48
|
-
"gitHead": "3c0dcfb3c22c9f83107fdb97b25014cd03d9db7d"
|
|
35
|
+
"gitHead": "06b2ede40fc2212a70eeafd74afd50b56fb0ce82"
|
|
49
36
|
}
|
|
@@ -1,35 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.ElasticsearchBodyModifierPlugin = void 0;
|
|
9
|
-
|
|
10
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
|
-
|
|
12
8
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
13
|
-
|
|
14
9
|
var _plugins = require("@webiny/plugins");
|
|
15
|
-
|
|
16
10
|
class ElasticsearchBodyModifierPlugin extends _plugins.Plugin {
|
|
17
11
|
constructor(callable) {
|
|
18
12
|
super();
|
|
19
|
-
(0, _defineProperty2.default)(this, "callable", void 0);
|
|
20
13
|
this.callable = callable;
|
|
21
14
|
}
|
|
22
|
-
|
|
23
15
|
modifyBody(params) {
|
|
24
16
|
if (typeof this.callable !== "function") {
|
|
25
17
|
throw new _error.default(`Missing modification for the body.`, "BODY_MODIFICATION_MISSING", {
|
|
26
18
|
params
|
|
27
19
|
});
|
|
28
20
|
}
|
|
29
|
-
|
|
30
21
|
this.callable(params);
|
|
31
22
|
}
|
|
32
|
-
|
|
33
23
|
}
|
|
24
|
+
exports.ElasticsearchBodyModifierPlugin = ElasticsearchBodyModifierPlugin;
|
|
34
25
|
|
|
35
|
-
|
|
26
|
+
//# sourceMappingURL=ElasticsearchBodyModifierPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_error","_interopRequireDefault","require","_plugins","ElasticsearchBodyModifierPlugin","Plugin","constructor","callable","modifyBody","params","WebinyError","exports"],"sources":["ElasticsearchBodyModifierPlugin.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { Plugin } from \"@webiny/plugins\";\nimport type { SearchBody } from \"elastic-ts\";\n\nexport interface ModifyBodyParams {\n body: SearchBody;\n}\n\nexport interface ModifyBodyCallable<T extends ModifyBodyParams> {\n (params: T): void;\n}\n\nexport abstract class ElasticsearchBodyModifierPlugin<\n T extends ModifyBodyParams = ModifyBodyParams\n> extends Plugin {\n private readonly callable?: ModifyBodyCallable<T>;\n\n public constructor(callable?: ModifyBodyCallable<T>) {\n super();\n this.callable = callable;\n }\n\n public modifyBody(params: T): void {\n if (typeof this.callable !== \"function\") {\n throw new WebinyError(\n `Missing modification for the body.`,\n \"BODY_MODIFICATION_MISSING\",\n {\n params\n }\n );\n }\n this.callable(params);\n }\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AAWO,MAAeE,+BAA+B,SAE3CC,eAAM,CAAC;EAGNC,WAAWA,CAACC,QAAgC,EAAE;IACjD,KAAK,CAAC,CAAC;IACP,IAAI,CAACA,QAAQ,GAAGA,QAAQ;EAC5B;EAEOC,UAAUA,CAACC,MAAS,EAAQ;IAC/B,IAAI,OAAO,IAAI,CAACF,QAAQ,KAAK,UAAU,EAAE;MACrC,MAAM,IAAIG,cAAW,CACjB,oCAAoC,EACpC,2BAA2B,EAC3B;QACID;MACJ,CACJ,CAAC;IACL;IACA,IAAI,CAACF,QAAQ,CAACE,MAAM,CAAC;EACzB;AACJ;AAACE,OAAA,CAAAP,+BAAA,GAAAA,+BAAA","ignoreList":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Plugin } from "@webiny/plugins";
|
|
2
|
-
import { FieldSortOptions, SortOrder } from "elastic-ts";
|
|
3
|
-
export
|
|
2
|
+
import type { FieldSortOptions, SortOrder } from "elastic-ts";
|
|
3
|
+
export type UnmappedTypes = "date" | "long" | string;
|
|
4
4
|
export interface ToSearchValueParams {
|
|
5
5
|
/**
|
|
6
6
|
* The value to transform.
|
|
@@ -15,7 +15,7 @@ export interface ToSearchValueParams {
|
|
|
15
15
|
*/
|
|
16
16
|
basePath: string;
|
|
17
17
|
}
|
|
18
|
-
export interface
|
|
18
|
+
export interface ElasticsearchFieldPluginParams {
|
|
19
19
|
/**
|
|
20
20
|
* Which field is this plugin for.
|
|
21
21
|
*/
|
|
@@ -48,22 +48,16 @@ export interface Params {
|
|
|
48
48
|
*/
|
|
49
49
|
toSearchValue?: (params: ToSearchValueParams) => any;
|
|
50
50
|
}
|
|
51
|
-
export declare
|
|
51
|
+
export declare class ElasticsearchFieldPlugin extends Plugin {
|
|
52
52
|
static readonly type: string;
|
|
53
53
|
static readonly ALL: string;
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
get path(): string;
|
|
62
|
-
get keyword(): boolean;
|
|
63
|
-
get unmappedType(): string | undefined;
|
|
64
|
-
get sortable(): boolean;
|
|
65
|
-
get searchable(): boolean;
|
|
66
|
-
constructor(params: Params);
|
|
54
|
+
readonly field: string;
|
|
55
|
+
readonly path: string;
|
|
56
|
+
readonly keyword: boolean;
|
|
57
|
+
readonly unmappedType?: string;
|
|
58
|
+
readonly sortable: boolean;
|
|
59
|
+
readonly searchable: boolean;
|
|
60
|
+
constructor(params: ElasticsearchFieldPluginParams);
|
|
67
61
|
/**
|
|
68
62
|
* The default sort options. Extend in your own plugin if you want to add more options.
|
|
69
63
|
*/
|
|
@@ -1,128 +1,75 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
3
|
Object.defineProperty(exports, "__esModule", {
|
|
6
4
|
value: true
|
|
7
5
|
});
|
|
8
6
|
exports.ElasticsearchFieldPlugin = void 0;
|
|
9
|
-
|
|
10
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
|
-
|
|
12
7
|
var _plugins = require("@webiny/plugins");
|
|
13
|
-
|
|
14
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
15
|
-
|
|
16
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
17
|
-
|
|
18
8
|
const keywordLessUnmappedType = ["date", "long"];
|
|
19
|
-
|
|
20
9
|
const unmappedTypeHasKeyword = type => {
|
|
21
|
-
if (
|
|
10
|
+
if (!type) {
|
|
11
|
+
return true;
|
|
12
|
+
} else if (keywordLessUnmappedType.includes(type)) {
|
|
22
13
|
return false;
|
|
23
14
|
}
|
|
24
|
-
|
|
25
15
|
return true;
|
|
26
16
|
};
|
|
27
|
-
|
|
28
17
|
class ElasticsearchFieldPlugin extends _plugins.Plugin {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
get path() {
|
|
34
|
-
return this._path;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
get keyword() {
|
|
38
|
-
return this._keyword;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
get unmappedType() {
|
|
42
|
-
return this._unmappedType;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
get sortable() {
|
|
46
|
-
return this._sortable;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
get searchable() {
|
|
50
|
-
return this._searchable;
|
|
51
|
-
}
|
|
52
|
-
|
|
18
|
+
static type = "elasticsearch.fieldDefinition";
|
|
19
|
+
static ALL = "*";
|
|
53
20
|
constructor(params) {
|
|
54
21
|
super();
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
(0, _defineProperty2.default)(this, "_sortable", void 0);
|
|
60
|
-
(0, _defineProperty2.default)(this, "_searchable", void 0);
|
|
61
|
-
this._field = params.field;
|
|
62
|
-
this._path = params.path || params.field;
|
|
63
|
-
this._keyword = params.keyword === undefined ? true : params.keyword;
|
|
64
|
-
this._unmappedType = params.unmappedType;
|
|
65
|
-
|
|
22
|
+
this.field = params.field;
|
|
23
|
+
this.path = params.path || params.field;
|
|
24
|
+
this.keyword = params.keyword === undefined ? true : params.keyword;
|
|
25
|
+
this.unmappedType = params.unmappedType;
|
|
66
26
|
if (unmappedTypeHasKeyword(params.unmappedType) === false) {
|
|
67
|
-
this.
|
|
27
|
+
this.keyword = false;
|
|
68
28
|
}
|
|
69
|
-
|
|
70
|
-
this.
|
|
71
|
-
this._searchable = params.searchable === undefined ? true : params.searchable;
|
|
29
|
+
this.sortable = params.sortable === undefined ? true : params.sortable;
|
|
30
|
+
this.searchable = params.searchable === undefined ? true : params.searchable;
|
|
72
31
|
}
|
|
73
32
|
/**
|
|
74
33
|
* The default sort options. Extend in your own plugin if you want to add more options.
|
|
75
34
|
*/
|
|
76
|
-
|
|
77
|
-
|
|
78
35
|
getSortOptions(order) {
|
|
79
36
|
const options = {
|
|
80
37
|
order
|
|
81
38
|
};
|
|
82
|
-
|
|
83
|
-
if (!this._unmappedType) {
|
|
39
|
+
if (!this.unmappedType) {
|
|
84
40
|
return options;
|
|
85
41
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
unmapped_type: this.
|
|
89
|
-
}
|
|
42
|
+
return {
|
|
43
|
+
...options,
|
|
44
|
+
unmapped_type: this.unmappedType
|
|
45
|
+
};
|
|
90
46
|
}
|
|
91
47
|
/**
|
|
92
48
|
* The default path generator. Extend in your own plugin if you want to add more options.
|
|
93
49
|
* Field parameter is here because there is a possibility that this is the ALL field plugin, so we need to know which field are we working on.
|
|
94
50
|
*/
|
|
95
|
-
|
|
96
|
-
|
|
97
51
|
getPath(field) {
|
|
98
|
-
return `${this.getBasePath(field)}${this.
|
|
52
|
+
return `${this.getBasePath(field)}${this.keyword ? ".keyword" : ""}`;
|
|
99
53
|
}
|
|
100
54
|
/**
|
|
101
55
|
* @see getPath
|
|
102
56
|
*
|
|
103
57
|
* This is the default base path generator. Basically it replaces ALL with given field name.
|
|
104
58
|
*/
|
|
105
|
-
|
|
106
|
-
|
|
107
59
|
getBasePath(field) {
|
|
108
|
-
if (this.
|
|
60
|
+
if (this.path === ElasticsearchFieldPlugin.ALL) {
|
|
109
61
|
return field;
|
|
110
62
|
}
|
|
111
|
-
|
|
112
|
-
return this._path;
|
|
63
|
+
return this.path;
|
|
113
64
|
}
|
|
114
65
|
/**
|
|
115
66
|
* The default transformer. Just returns the value by default.
|
|
116
67
|
* Override to implement what ever is required.
|
|
117
68
|
*/
|
|
118
|
-
|
|
119
|
-
|
|
120
69
|
toSearchValue(params) {
|
|
121
70
|
return params.value;
|
|
122
71
|
}
|
|
123
|
-
|
|
124
72
|
}
|
|
125
|
-
|
|
126
73
|
exports.ElasticsearchFieldPlugin = ElasticsearchFieldPlugin;
|
|
127
|
-
|
|
128
|
-
|
|
74
|
+
|
|
75
|
+
//# sourceMappingURL=ElasticsearchFieldPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_plugins","require","keywordLessUnmappedType","unmappedTypeHasKeyword","type","includes","ElasticsearchFieldPlugin","Plugin","ALL","constructor","params","field","path","keyword","undefined","unmappedType","sortable","searchable","getSortOptions","order","options","unmapped_type","getPath","getBasePath","toSearchValue","value","exports"],"sources":["ElasticsearchFieldPlugin.ts"],"sourcesContent":["import { Plugin } from \"@webiny/plugins\";\nimport type { FieldSortOptions, SortOrder } from \"elastic-ts\";\n\nexport type UnmappedTypes = \"date\" | \"long\" | string;\n\nconst keywordLessUnmappedType = [\"date\", \"long\"];\n\nconst unmappedTypeHasKeyword = (type?: string): boolean => {\n if (!type) {\n return true;\n } else if (keywordLessUnmappedType.includes(type)) {\n return false;\n }\n return true;\n};\n\nexport interface ToSearchValueParams {\n /**\n * The value to transform.\n */\n value: any;\n /**\n * When using toSearchValue() in our code we send a field.getPath() value here.\n */\n path: string;\n /**\n * When using toSearchValue() in our code we send a field.getBasePath() value here.\n */\n basePath: string;\n}\nexport interface ElasticsearchFieldPluginParams {\n /**\n * Which field is this plugin for.\n */\n field: string;\n /**\n * Some specific path of a field?\n * Example: createdBy is createdBy.id\n */\n path?: string;\n /**\n * Add a .keyword at the end of the field path?\n */\n keyword?: boolean;\n /**\n * Is the field of a specific type, but possibly not mapped?\n * Happens when inserting a date in string format.\n * You need to cast it as date when running the search/sort to work correctly.\n */\n unmappedType?: UnmappedTypes;\n /**\n * Is the field sortable?\n */\n sortable?: boolean;\n /**\n * Is the field searchable?\n */\n searchable?: boolean;\n /**\n * Used to transform the input value for the search.\n */\n toSearchValue?: (params: ToSearchValueParams) => any;\n}\n\nexport class ElasticsearchFieldPlugin extends Plugin {\n public static override readonly type: string = \"elasticsearch.fieldDefinition\";\n public static readonly ALL: string = \"*\";\n\n public readonly field: string;\n public readonly path: string;\n public readonly keyword: boolean;\n public readonly unmappedType?: string;\n public readonly sortable: boolean;\n public readonly searchable: boolean;\n\n constructor(params: ElasticsearchFieldPluginParams) {\n super();\n this.field = params.field;\n this.path = params.path || params.field;\n this.keyword = params.keyword === undefined ? true : params.keyword;\n this.unmappedType = params.unmappedType;\n if (unmappedTypeHasKeyword(params.unmappedType) === false) {\n this.keyword = false;\n }\n this.sortable = params.sortable === undefined ? true : params.sortable;\n this.searchable = params.searchable === undefined ? true : params.searchable;\n }\n /**\n * The default sort options. Extend in your own plugin if you want to add more options.\n */\n public getSortOptions(order: SortOrder): FieldSortOptions {\n const options = {\n order\n };\n if (!this.unmappedType) {\n return options;\n }\n return {\n ...options,\n unmapped_type: this.unmappedType\n };\n }\n /**\n * The default path generator. Extend in your own plugin if you want to add more options.\n * Field parameter is here because there is a possibility that this is the ALL field plugin, so we need to know which field are we working on.\n */\n public getPath(field: string): string {\n return `${this.getBasePath(field)}${this.keyword ? \".keyword\" : \"\"}`;\n }\n /**\n * @see getPath\n *\n * This is the default base path generator. Basically it replaces ALL with given field name.\n */\n public getBasePath(field: string): string {\n if (this.path === ElasticsearchFieldPlugin.ALL) {\n return field;\n }\n return this.path;\n }\n /**\n * The default transformer. Just returns the value by default.\n * Override to implement what ever is required.\n */\n public toSearchValue(params: ToSearchValueParams): any {\n return params.value;\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,QAAA,GAAAC,OAAA;AAKA,MAAMC,uBAAuB,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;AAEhD,MAAMC,sBAAsB,GAAIC,IAAa,IAAc;EACvD,IAAI,CAACA,IAAI,EAAE;IACP,OAAO,IAAI;EACf,CAAC,MAAM,IAAIF,uBAAuB,CAACG,QAAQ,CAACD,IAAI,CAAC,EAAE;IAC/C,OAAO,KAAK;EAChB;EACA,OAAO,IAAI;AACf,CAAC;AAkDM,MAAME,wBAAwB,SAASC,eAAM,CAAC;EACjD,OAAgCH,IAAI,GAAW,+BAA+B;EAC9E,OAAuBI,GAAG,GAAW,GAAG;EASxCC,WAAWA,CAACC,MAAsC,EAAE;IAChD,KAAK,CAAC,CAAC;IACP,IAAI,CAACC,KAAK,GAAGD,MAAM,CAACC,KAAK;IACzB,IAAI,CAACC,IAAI,GAAGF,MAAM,CAACE,IAAI,IAAIF,MAAM,CAACC,KAAK;IACvC,IAAI,CAACE,OAAO,GAAGH,MAAM,CAACG,OAAO,KAAKC,SAAS,GAAG,IAAI,GAAGJ,MAAM,CAACG,OAAO;IACnE,IAAI,CAACE,YAAY,GAAGL,MAAM,CAACK,YAAY;IACvC,IAAIZ,sBAAsB,CAACO,MAAM,CAACK,YAAY,CAAC,KAAK,KAAK,EAAE;MACvD,IAAI,CAACF,OAAO,GAAG,KAAK;IACxB;IACA,IAAI,CAACG,QAAQ,GAAGN,MAAM,CAACM,QAAQ,KAAKF,SAAS,GAAG,IAAI,GAAGJ,MAAM,CAACM,QAAQ;IACtE,IAAI,CAACC,UAAU,GAAGP,MAAM,CAACO,UAAU,KAAKH,SAAS,GAAG,IAAI,GAAGJ,MAAM,CAACO,UAAU;EAChF;EACA;AACJ;AACA;EACWC,cAAcA,CAACC,KAAgB,EAAoB;IACtD,MAAMC,OAAO,GAAG;MACZD;IACJ,CAAC;IACD,IAAI,CAAC,IAAI,CAACJ,YAAY,EAAE;MACpB,OAAOK,OAAO;IAClB;IACA,OAAO;MACH,GAAGA,OAAO;MACVC,aAAa,EAAE,IAAI,CAACN;IACxB,CAAC;EACL;EACA;AACJ;AACA;AACA;EACWO,OAAOA,CAACX,KAAa,EAAU;IAClC,OAAO,GAAG,IAAI,CAACY,WAAW,CAACZ,KAAK,CAAC,GAAG,IAAI,CAACE,OAAO,GAAG,UAAU,GAAG,EAAE,EAAE;EACxE;EACA;AACJ;AACA;AACA;AACA;EACWU,WAAWA,CAACZ,KAAa,EAAU;IACtC,IAAI,IAAI,CAACC,IAAI,KAAKN,wBAAwB,CAACE,GAAG,EAAE;MAC5C,OAAOG,KAAK;IAChB;IACA,OAAO,IAAI,CAACC,IAAI;EACpB;EACA;AACJ;AACA;AACA;EACWY,aAAaA,CAACd,MAA2B,EAAO;IACnD,OAAOA,MAAM,CAACe,KAAK;EACvB;AACJ;AAACC,OAAA,CAAApB,wBAAA,GAAAA,wBAAA","ignoreList":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Plugin } from "@webiny/plugins";
|
|
2
|
+
import type { ElasticsearchIndexRequestBody } from "../../types";
|
|
3
|
+
export interface ElasticsearchIndexPluginParams {
|
|
4
|
+
/**
|
|
5
|
+
* For which locales are we applying this plugin.
|
|
6
|
+
* Options:
|
|
7
|
+
* - locale codes to target specific locale
|
|
8
|
+
* - null for all
|
|
9
|
+
*/
|
|
10
|
+
locales?: string[];
|
|
11
|
+
body: ElasticsearchIndexRequestBody;
|
|
12
|
+
}
|
|
13
|
+
export declare abstract class ElasticsearchIndexPlugin extends Plugin {
|
|
14
|
+
readonly body: ElasticsearchIndexRequestBody;
|
|
15
|
+
private readonly locales;
|
|
16
|
+
constructor(params: ElasticsearchIndexPluginParams);
|
|
17
|
+
canUse(locale: string): boolean;
|
|
18
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.ElasticsearchIndexPlugin = void 0;
|
|
8
|
+
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
9
|
+
var _plugins = require("@webiny/plugins");
|
|
10
|
+
class ElasticsearchIndexPlugin extends _plugins.Plugin {
|
|
11
|
+
constructor(params) {
|
|
12
|
+
super();
|
|
13
|
+
const {
|
|
14
|
+
locales,
|
|
15
|
+
body
|
|
16
|
+
} = params;
|
|
17
|
+
this.body = {
|
|
18
|
+
...body
|
|
19
|
+
};
|
|
20
|
+
this.locales = locales ? locales.map(locale => locale.toLowerCase()) : undefined;
|
|
21
|
+
}
|
|
22
|
+
canUse(locale) {
|
|
23
|
+
if (!this.locales) {
|
|
24
|
+
return true;
|
|
25
|
+
} else if (this.locales.length === 0) {
|
|
26
|
+
throw new _error.default("Cannot have Elasticsearch Index Template plugin with no locales defined.", "LOCALES_ERROR", {
|
|
27
|
+
body: this.body,
|
|
28
|
+
locales: this.locales
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
return this.locales.includes(locale.toLowerCase());
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.ElasticsearchIndexPlugin = ElasticsearchIndexPlugin;
|
|
35
|
+
|
|
36
|
+
//# sourceMappingURL=ElasticsearchIndexPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_error","_interopRequireDefault","require","_plugins","ElasticsearchIndexPlugin","Plugin","constructor","params","locales","body","map","locale","toLowerCase","undefined","canUse","length","WebinyError","includes","exports"],"sources":["ElasticsearchIndexPlugin.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { Plugin } from \"@webiny/plugins\";\nimport type { ElasticsearchIndexRequestBody } from \"~/types\";\n\nexport interface ElasticsearchIndexPluginParams {\n /**\n * For which locales are we applying this plugin.\n * Options:\n * - locale codes to target specific locale\n * - null for all\n */\n locales?: string[];\n body: ElasticsearchIndexRequestBody;\n}\n\nexport abstract class ElasticsearchIndexPlugin extends Plugin {\n public readonly body: ElasticsearchIndexRequestBody;\n private readonly locales: string[] | undefined;\n\n public constructor(params: ElasticsearchIndexPluginParams) {\n super();\n const { locales, body } = params;\n this.body = {\n ...body\n };\n this.locales = locales ? locales.map(locale => locale.toLowerCase()) : undefined;\n }\n\n public canUse(locale: string): boolean {\n if (!this.locales) {\n return true;\n } else if (this.locales.length === 0) {\n throw new WebinyError(\n \"Cannot have Elasticsearch Index Template plugin with no locales defined.\",\n \"LOCALES_ERROR\",\n {\n body: this.body,\n locales: this.locales\n }\n );\n }\n return this.locales.includes(locale.toLowerCase());\n }\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AAcO,MAAeE,wBAAwB,SAASC,eAAM,CAAC;EAInDC,WAAWA,CAACC,MAAsC,EAAE;IACvD,KAAK,CAAC,CAAC;IACP,MAAM;MAAEC,OAAO;MAAEC;IAAK,CAAC,GAAGF,MAAM;IAChC,IAAI,CAACE,IAAI,GAAG;MACR,GAAGA;IACP,CAAC;IACD,IAAI,CAACD,OAAO,GAAGA,OAAO,GAAGA,OAAO,CAACE,GAAG,CAACC,MAAM,IAAIA,MAAM,CAACC,WAAW,CAAC,CAAC,CAAC,GAAGC,SAAS;EACpF;EAEOC,MAAMA,CAACH,MAAc,EAAW;IACnC,IAAI,CAAC,IAAI,CAACH,OAAO,EAAE;MACf,OAAO,IAAI;IACf,CAAC,MAAM,IAAI,IAAI,CAACA,OAAO,CAACO,MAAM,KAAK,CAAC,EAAE;MAClC,MAAM,IAAIC,cAAW,CACjB,0EAA0E,EAC1E,eAAe,EACf;QACIP,IAAI,EAAE,IAAI,CAACA,IAAI;QACfD,OAAO,EAAE,IAAI,CAACA;MAClB,CACJ,CAAC;IACL;IACA,OAAO,IAAI,CAACA,OAAO,CAACS,QAAQ,CAACN,MAAM,CAACC,WAAW,CAAC,CAAC,CAAC;EACtD;AACJ;AAACM,OAAA,CAAAd,wBAAA,GAAAA,wBAAA","ignoreList":[]}
|
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import { Plugin } from "@webiny/plugins";
|
|
2
|
-
import { ElasticsearchBoolQueryConfig, ElasticsearchQueryBuilderArgsPlugin } from "../../types";
|
|
2
|
+
import type { ElasticsearchBoolQueryConfig, ElasticsearchQueryBuilderArgsPlugin } from "../../types";
|
|
3
3
|
/**
|
|
4
4
|
* Built-in operators name ends with .default because user can override the operator, just write a name without the .default keyword.
|
|
5
5
|
*/
|
|
6
6
|
export declare abstract class ElasticsearchQueryBuilderOperatorPlugin extends Plugin {
|
|
7
|
-
static readonly type
|
|
7
|
+
static readonly type: string;
|
|
8
|
+
/**
|
|
9
|
+
* Check if current locale is supported by this plugin.
|
|
10
|
+
*/
|
|
11
|
+
isLocaleSupported(_: string): boolean;
|
|
8
12
|
abstract getOperator(): string;
|
|
9
13
|
abstract apply(query: ElasticsearchBoolQueryConfig, params: ElasticsearchQueryBuilderArgsPlugin): void;
|
|
10
14
|
}
|